html {
  scroll-behavior: smooth;
  max-width: 100%;
  overflow-x: hidden;
  -ms-overflow-style: none;
  scrollbar-width: none;
  -webkit-tap-highlight-color: transparent;
}

html::-webkit-scrollbar { display: none; }

.no_scroll { overflow: hidden; height: 100%; }

body { margin: 0; }

body, button, input, textarea {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}

body.dark { background-color: #070c16; color: #ffffff; }
body.light { background-color: #e9eaed; color: #070c16; }

.logo { width: 126px; height: 20px; }

.logo svg, .logo svg * { fill: currentColor !important; }

.top_bar .logo, .menu_top_bar .logo, .footer_content_container .logo { color: inherit; }

.top_bar a, .menu_top_bar a, .footer_content_container a[href="about.html"] {
  text-decoration: none; color: inherit;
}

.dark .logo svg, .dark .logo svg * { fill: #ffffff !important; }
.light .logo svg, .light .logo svg * { fill: #070c16 !important; }

#fullscreen_intro { width: 100vw; height: 100vh; }

.fullscreen_intro_container { width: 100%; height: 100%; display: flex; flex-direction: column; }

.card_background {
  padding: 16px; box-sizing: border-box;
  background-size: cover; background-repeat: no-repeat; background-position: center center;
}
.card_background.stroke-bottom { border-radius: 0 0 24px 24px; }
.light .card_background { background-image: url("../images/bg_light_396.png"); }
.dark  .card_background { background-image: url("../images/bg_dark_396.png"); }
.light .card_background.stroke-bottom { border-bottom: 1px solid #d5d6d9; }
.dark  .card_background.stroke-bottom { border-bottom: 1px solid #353c43; }
.light .card_background.stroke-top { border-top: 1px solid #d5d6d9; }
.dark  .card_background.stroke-top { border-top: 1px solid #353c43; }

.fullscreen_intro_content_wrapper { display: flex; flex: 1; justify-content: center; flex-direction: column; gap: 36px; }

.huge_title { margin: 0; font-weight: 600; font-size: 36px; }

.fullscreen_intro_actions {
  display: flex; flex-direction: column-reverse; gap: 8px; justify-content: center; align-items: center;
}

.button {
  margin: 0; height: 56px; width: 100%;
  font-size: 16px; font-weight: 500; border-radius: 28px; cursor: pointer;
  display: inline-flex; flex-direction: row; text-decoration: none;
  justify-content: center; align-items: center; text-align: center; border: none;
}

.light .button.primary { background-color: #070c16; color: #ffffff; }
.dark  .button.primary { background-color: #ffffff; color: #080d17; }
.light .button.secondary { border: 1px solid #070c16; color: #080d17; }
.dark  .button.secondary { border: 1px solid #ffffff; color: #ffffff; }

.about_us_title { margin: 0; font-weight: 600; font-size: 24px; grid-column: span 2; }

.section_title, .about_us_slogan {
  margin: 0; font-weight: 500; font-size: 36px; line-height: 36px; padding-bottom: 8px; letter-spacing: -0.48px;
}

p { margin: 0; font-weight: 500; font-size: 16px; }

#about_us { scroll-margin-top: 110px; }

.about_us_container {
  display: flex; flex-direction: column; gap: 16px; padding: 36px 16px; box-sizing: border-box;
}

.dark #about_us { color: #d7dfe5; border-bottom: 1px solid #353c43; }
.light #about_us { color: #121721; border-bottom: 1px solid #d5d6d9; }

.skills_container {
  margin-left: auto; margin-right: auto; padding: 36px 16px;
  display: flex; flex-direction: column; gap: 16px; box-sizing: border-box;
}

.skills_grid { display: grid; grid-template-columns: repeat(2, 50%); gap: 4px; }

.skills_grid_card { border-radius: 24px; padding: 16px; display: flex; flex-direction: column; gap: 4px; }

.skills_grid_card.wide { grid-column: span 2; }

.light .skills_grid_card { background-color: #ffffff; }
.dark  .skills_grid_card { background-color: #121721; }

.skill_item_title { margin: 0; font-size: 24px; font-weight: 700; }

.skill_item_description { margin: 0; font-size: 16px; font-weight: 500; }
.light .skill_item_description { color: #575b63; }
.dark  .skill_item_description { color: #d0d1d3; }

.skill_item_icon { width: 24px; height: 24px; margin-bottom: 12px; }

.footer_container { width: 100%; padding: 12px 16px; }
.footer_submit_description { margin-bottom: 24px; }

.footer_submit_container {
  margin-top: 36px; margin-bottom: 64px; display: flex; flex-direction: column;
}

.footer_content_container {
  display: grid; grid-template-columns: repeat(2, 50%); column-gap: 16px; row-gap: 24px;
}

.footer_section { display: flex; flex-direction: column; gap: 12px; }

.footer_section_title { margin: 0; font-size: 15px; font-weight: 500; }

.footer_link { text-decoration: none; display: block; font-size: 15px; font-weight: 500; cursor: pointer; }

.dark .footer_link { color: #d1e0eb; opacity: 0.62; }
.light .footer_link { color: #070c16; opacity: 0.4; }

.footer_social_media {
  display: flex; flex-direction: row; gap: 16px; align-items: center; justify-content: center;
}

.footer_social_icon { width: 24px; height: 24px; }

@media (max-width: 833px) {
  #footer .footer_content_container > a:first-child { grid-column: span 2; margin-bottom: 12px; }
  #footer .footer_social_media {
    grid-column: span 2; margin-top: 12px; justify-content: flex-start; align-self: flex-start;
  }
}

@media (min-width: 834px) and (max-width: 1439px) {
  .footer_content_container {
  }
  #footer .footer_content_container {
    margin-left: auto; margin-right: auto; max-width: 802px;
    display: grid; grid-template-columns: repeat(4, 174px); column-gap: 16px; box-sizing: border-box;
  }
  #footer .footer_content_container > a:first-child { grid-column: span 4; margin-bottom: 12px; }
  #footer .footer_social_media {
    grid-column: span 4; margin-top: 12px; justify-content: flex-start; align-self: flex-start;
  }
}

@media (min-width: 1440px) {
  .footer_container { padding: 48px; }

  .footer_submit_container { margin-top: 200px; margin-bottom: 132px; gap: 12px; }

  #footer .footer_content_container {
    margin-left: auto; margin-right: auto;
    display: grid; grid-template-columns: 288px repeat(4, 200px); column-gap: 56px; max-width: min-content;
  }

  #footer .footer_section { grid-row: span 2; }

  #footer .footer_content_container > a:first-child { grid-column: 1; margin-bottom: 0; }

  #footer .footer_social_media {
    grid-column: 1; grid-row: 2; margin-top: 24px; justify-content: flex-start; align-self: flex-start;
  }
}

.overlay {
  position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; z-index: 9999;
  backdrop-filter: blur(80px); -webkit-backdrop-filter: blur(80px);
}

.dialog-overlay { background: #00000080; }

.overlay_window_container {
  width: 100%; margin: 16px; padding: 16px; border-radius: 24px; align-self: center;
  max-height: min-content; pointer-events: auto; display: flex; flex-flow: column; gap: 32px;
}

.light .overlay_window_container { background-color: #e9eaed; border: 1px solid #d5d6d9; }
.dark  .overlay_window_container { background-color: #070c16; border: 1px solid #191e28; }

.overlay_header { display: flex; flex-direction: column; gap: 4px; text-align: center; }
.overlay_header_title { margin: 0; font-size: 24px; font-weight: 700; }
.overlay_header_description { margin: 0; font-size: 16px; font-weight: 500; }
.light .overlay_header_description { color: #575b63; }
.dark  .overlay_header_description { color: #d0d1d3; }

.form_inputs_container { display: flex; flex-direction: column; gap: 4px; }

.text_field { border-radius: 24px; padding: 12px 16px; display: flex; flex-flow: column; gap: 10px; }
.light .text_field { background-color: #ffffff; }
.dark  .text_field { background-color: #121721; }

.text_field_title { font-size: 14px; font-weight: 600; }

.text_field_input {
  width: 100%; border: none; outline: none; background: none; font-size: 16px; font-weight: 600; color: inherit;
}
.light .text_field_input::placeholder { color: #c3c3c3; }
.dark  .text_field_input::placeholder { color: #444953; }

.text_area_input { resize: none; min-height: 94px; line-height: 1.3; }
.text_area_input.big { min-height: 134px; }

.submit_form_social_block { display: flex; flex-direction: column; gap: 10px; text-align: center; }
.submit_form_social_block_text { margin: 0; font-size: 14px; font-weight: 600; }
.social_media_links_container { display: flex; flex-direction: row; gap: 4px; margin: 0 auto; }

.submit_form_social_media_icon { width: 24px; height: 24px; }

.submit_form_social_media_link {
  margin: 0; height: 36px; font-size: 14px; font-weight: 600; border-radius: 18px; cursor: pointer;
  display: inline-flex; flex-direction: row; gap: 10px; text-decoration: none; justify-content: center;
  align-items: center; text-align: center; padding: 0 8px;
}

.submit_form_buttons_container, .careers_form_buttons_container {
  display: flex; flex-direction: column-reverse; gap: 8px;
}

.light .submit_form_social_media_link { border: 1px solid #070c16; color: #080d17; }
.dark  .submit_form_social_media_link { border: 1px solid #353c43; color: #ffffff; }

.button.submit_form_action_cancel,
button.language_selection_action_cancel,
button.careers_form_action_cancel { background: none; }

.submit_form_buttons_container button,
.careers_form_buttons_container button,
.language_selection_buttons_container button {
  letter-spacing: -0.64px; height: 48px; width: 100%;
}

.menu_content_container {
  padding: 16px; box-sizing: border-box; display: flex; flex-direction: column; justify-content: space-between;
}

.menu_content_top { display: flex; flex-direction: column; gap: 32px; }

.menu_content_bottom { display: flex; flex-direction: column; gap: 24px; }

.menu_navigation { display: flex; flex-direction: column; gap: 36px; }

.menu_nav_item {
  text-decoration: none; color: inherit; font-size: 36px; line-height: 36px; font-weight: 600; opacity: 0.4;
}
.menu_nav_item.active { opacity: 1; }

.menu_content_container .language_selector { height: 46px; width: min-content; min-width: 0; }

.menu_content_bottom .theme_button { width: 100%; }

.menu_content_bottom .theme_switcher {
  width: 100%; max-width: 460px; margin: 0 auto;
}

.languages_list { display: flex; flex-direction: column; gap: 4px; }

.language_selection_buttons_container { display: flex; flex-direction: column; gap: 4px; }

.careers_contact_mode_selector { display: flex; flex-flow: row wrap; gap: 4px; }

.chip { display: flex; flex-direction: row; border-radius: 50px; box-sizing: border-box; align-items: center; padding: 4px 8px; }
.dark .chip { background: #1c212b; }
.light .chip { background: #e9eaed; }
.dark .chip.active { background: #ffffff; color: #070c16; }
.light .chip.active { background: #070c16; color: #ffffff; }
.chip .checkmark { width: 24px; height: 24px; display: none; }
.chip.active .checkmark { display: inline; }
.chip span { margin: 0 4px; font-size: 14px; font-weight: 600; }

.careers_specification_selector { position: relative; }

.careers_specification_current_value {
  position: relative; display: flex; width: 100%; justify-content: space-between; align-items: center;
}

.careers_specification_current_value span { font-size: 16px; font-weight: 600; }

.careers_specification_dropdown_container { width: 100%; position: relative; }

.specification_dropdown {
  top: 34px; border-radius: 28px; width: 100%; max-height: 236px; padding: 4px; box-sizing: border-box;
  overflow: auto; -ms-overflow-style: none; scrollbar-width: none;
}

.dark .specification_dropdown { background: #070c16; }
.light .specification_dropdown { background: #e9eaed; }

.main_content { display: flex; flex-direction: column; gap: 36px; margin: 106px 16px 16px; }

.main_content .contact_form, .contact_ways { width: 100%; }

.main_content .form_inputs_container { margin-top: 24px; margin-bottom: 32px; }

.contact_us_title { margin: 0; font-size: 48px; font-weight: 600; }

.contact_us_form_buttons_container { display: flex; flex-direction: row; gap: 8px; }

.contact_us_form_buttons_container button { height: 48px; }

.contact_way_card {
  width: 100%; border-radius: 24px; display: flex; flex-direction: column; gap: 24px;
  text-decoration: none; color: inherit; padding: 16px; box-sizing: border-box;
}

.dark .contact_way_card { background-color: #121721; }
.light .contact_way_card { background-color: #ffffff; }

.contact_way_icons { display: flex; justify-content: space-between; }

.contact_way_icon { width: 40px; height: 40px; }

.contact_way_link_arrow { width: 24px; height: 24px; }

.contact_way_text { display: flex; flex-direction: column; gap: 4px; }

.contact_way_title { margin: 0; font-size: 16px; font-weight: 600; }

.contact_way_info { margin: 0; font-size: 14px; font-weight: 600; opacity: 0.7; }

.contact_ways { display: grid; grid-template-columns: repeat(2, 50%); gap: 4px; }
.contact_way_card:last-child { grid-column: span 2; }

#made_by_us {
  padding: 64px 0; display: flex; flex-direction: row; width: 100%;
  overflow-x: hidden; justify-content: space-between;
}

.made_by_us_wrap { display: flex; justify-content: center; flex-direction: column; width: 100%; }

.made_by_us_wrap h2 {
  font-weight: 500; font-size: 36px; line-height: 36px; padding-bottom: 8px; letter-spacing: -0.48px;
  margin-bottom: 16px; margin-top: 0;
}

.dark #made_by_us { color: #d7dfe5; border-bottom: 1px solid #353c43; }
.light #made_by_us { color: #121721; border-bottom: 1px solid #d5d6d9; }

.platform { display: flex; align-items: center; gap: 10px; }

.filter_button {
  display: flex; align-items: center; border-radius: 80px; width: max-content; height: 46px; border: none;
  padding: 10px 20px; font-weight: 500; font-size: 16px; line-height: 100%; letter-spacing: -0.64px;
  white-space: nowrap; gap: 10px; cursor: pointer;
}
.light .filter_button { background-color: #ffffff; color: #070c16; }
.dark  .filter_button { background-color: #1c212b; color: white; }
.light .filter_button.active { background-color: #070c16; color: white; }
.dark  .filter_button.active  { background-color: #ffffff; color: #070c16; }

.check-icon { display: none; width: 24px; height: 24px; }
.filter_button.active .check-icon { display: block; opacity: 1; }
.check-icon svg { width: 100%; height: 100%; }
.light .filter_button .check-icon svg path { fill: white !important; }
.dark  .filter_button .check-icon svg path  { fill: #070c16 !important; }

.container { padding: 0 16px; width: 100%; }

.categories {
  display: flex; flex-wrap: wrap; gap: 4px; width: 100%; height: max-content; max-width: 380px; margin-top: 36px;
}

.slider_wrap { display: flex; box-sizing: border-box; }

.slides::-webkit-scrollbar { display: none; }

.project-slide-wrapper {
  position: relative; scroll-snap-align: center; flex: 0 0 auto; cursor: pointer; transition: transform 0.3s ease; display: inline-block;
}

.slide.center-active { opacity: 1; width: 230px; height: 510px; }

.slide { width: 204px; height: 450px; transform: scale(1); transition: transform 0.3s ease, opacity 0.3s ease; }

.slide:not(.active):not(.center-active)::before {
  content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  background: linear-gradient(270deg, rgba(233, 234, 237, 0.7) 0%, #e9eaed 100%);
  z-index: 2; border-radius: 15px;
}

.slider-nav {
  position: absolute; top: 50%; width: 100%; display: flex; justify-content: space-between;
  transform: translateY(-50%); pointer-events: none; z-index: 3;
}
.slider-nav button {
  pointer-events: all; background: rgba(255, 255, 255, 0.9); border: none; width: 50px; height: 50px;
  border-radius: 50%; cursor: pointer; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); transition: all 0.3s ease;
}
.slider-nav button:hover { background: white; box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2); }

.slider { display: flex; flex-direction: column; justify-content: center; align-items: center; position: relative; }
.slider .category { font-weight: 700; font-style: Bold; font-size: 24px; line-height: 100%; letter-spacing: -0.5%; margin-bottom: 16px; }
.light .slider .category { color: #070c16; }
.dark  .slider .category { color: #ffffff; }

.slider .buttons { position: absolute; width: 100%; top: 45%; z-index: 100; display: none; }
.slider .buttons .prev  { display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 8px; position: absolute; left: 0; top: 50%; cursor: pointer; }
.slider .buttons .nav   { display: flex; justify-content: center; align-items: center; width: 44px; height: 44px; border-radius: 80px; gap: 10px; }
.dark .slider .buttons .nav { background-color: #ffffff; }
.light .slider .buttons .nav { background-color: #070c16; }
.slider .buttons .next { display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 8px; position: absolute; right: 0; top: 50%; cursor: pointer; }

.slider .buttons span {
  border-radius: 80px; padding: 8px 12px; gap: 10px; font-weight: 500; font-style: Medium; font-size: 14px; line-height: 100%;
  letter-spacing: -4%; user-select: none;
}

.categories_wrap { display: flex; flex-direction: column; }

.btn_andmore { display: none; justify-content: center; align-items: center; width: 106px; height: 46px; border-radius: 80px; gap: 10px; opacity: 1; border-width: 1px; margin-top: 4px; }
.light .btn_andmore { border: 1px solid #d5d6d9; }
.dark  .btn_andmore { border: 1px solid #d5d6d9; }
.light .btn_andmore span { font-weight: 500; font-size: 16px; line-height: 100%; letter-spacing: -4%; color: #070c16; }
.dark  .btn_andmore span { font-weight: 500; font-size: 16px; line-height: 100%; letter-spacing: -4%; color: #ffffff; }

.slider .slides {
  width: 100%; overflow: hidden; gap: 15px; display: flex; position: relative; align-items: center; transition: all 0.3s ease; overflow-x: auto;
}

.slide img { width: 100%; height: 100%; object-fit: cover; border-radius: 20px; }

.light .slider .buttons span { background-color: #ffffff; color: #070c16; }
.dark  .slider .buttons span { background-color: #121721; color: #ffffff; }

.slider .nav img svg { width: 24px; height: 24px; }
.light .slider svg path { fill: white !important; }
.dark  .slider svg path { fill: #070c16 !important; }

.slider_wrap { display: flex; flex-direction: column; gap: 24px; }

.mobile_categories { display: flex; align-items: center; width: 100%; overflow: auto; gap: 4px; padding-left: 16px; padding-right: 16px; box-sizing: border-box; }
.mobile_categories::-webkit-scrollbar { display: none; }

.menu_footer_sections {
  display: grid; grid-template-columns: 1fr; grid-auto-flow: row; gap: 24px 16px; width: 100%;
}

@media (min-width: 768px) {
  .menu_footer_sections { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (min-width: 1024px) {
  .menu_footer_sections { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

@media (min-width: 460px) {
  .menu_content_top { text-align: center; }
  .menu_content_top .language_selector { margin: 0 auto; }
}

@media (min-width: 834px) {
  .button { width: 364px; }
  .huge_title { text-align: center; }
  .light .card_background { background-image: url("../images/bg_light_834.png"); }
  .dark  .card_background { background-image: url("../images/bg_dark_834.png"); }
  .about_us_container { max-width: 834px; margin-left: auto; margin-right: auto; }
  .skills_grid { display: grid; grid-template-columns: repeat(4, 25%); gap: 4px; }
  .skills_container { max-width: 834px; }
  .footer_submit_container { text-align: center; align-items: center; }

  .overlay_window_container { width: 432px; margin: 0 auto; }
  .submit_form_buttons_container, .careers_form_buttons_container { flex-direction: row; }
  .main_content { align-items: center; }
  .main_content .contact_form, .contact_ways { width: 468px; }

  .slider .slides { overflow-x: hidden; }
  .project-slide-wrapper { cursor: default; border-radius: 24px; overflow: hidden; }
  .slider .buttons { display: block; }
}

@media (max-width: 1439px) {
  #about_us { scroll-margin-top: 74px; }
}

@media (min-width: 1280px) {
  .made_by_us_wrap { flex-direction: row; justify-content: space-between; }
  .slider { max-width: 880px; padding-right: 46px; }
  .btn_andmore { display: flex; }
}

@media (min-width: 1440px) {
  .container { padding: 0 79px; }
  .made_by_us_wrap h2 { font-size: 48px; line-height: 52px; }
  .section_title { text-align: center; }

  #fullscreen_intro, #footer { padding: 16px; box-sizing: border-box; }
  .card_background { border-radius: 24px !important; }
  .light .card_background { border: 1px solid #d5d6d9; background-image: url("../images/bg_light_1440.png"); }
  .dark  .card_background { border: 1px solid #353c43; background-image: url("../images/bg_dark_1440.png"); }

  .fullscreen_intro_content_wrapper { gap: 50px; }
  .huge_title { font-size: 80px; line-height: 85px; }
  .button { height: 48px; }
  .fullscreen_intro_actions { flex-direction: row; }

  .about_us_container {
    max-width: 1440px; display: grid; grid-template-columns: 50% 50%;
    grid-row-gap: 16px; padding: 64px; box-sizing: border-box;
  }

  p { font-size: 24px; line-height: 32px; }
  .section_title, .about_us_slogan { font-size: 48px; line-height: 52px; }
  .about_us_slogan { padding-right: 44px; padding-bottom: 0; }

  .skills_container { max-width: 972px; gap: 24px; padding: 164px 0; }

  .footer_content_container {}

  .footer_section { grid-row: span 2; }
  .footer_container { padding: 48px; }

  .main_content {
    margin-top: 178px; flex-direction: row; gap: 8px; justify-content: center; align-items: start;
  }
  .main_content .contact_form, .contact_ways { width: 432px; }

  .contact_ways { margin-top: 84px; grid-template-columns: repeat(6, 16.666%); }
  .contact_way_card:nth-child(1), .contact_way_card:nth-child(2), .contact_way_card:nth-child(3) { grid-column: span 2; }
  .contact_way_card:nth-child(4), .contact_way_card:nth-child(5) { grid-column: span 3; }
}

.menu_content_container .footer_content_container > * {
  grid-column: auto !important; grid-row: auto !important;
}

.menu_content_container .footer_content_container {
  display: grid;
  grid-template-columns: repeat(2, 50%);
  column-gap: 16px; row-gap: 24px;
  grid-auto-flow: row;
}

@media (min-width: 834px) {
  .menu_content_container .footer_content_container {
    margin-left: auto; margin-right: auto;
    max-width: 802px;
    grid-template-columns: repeat(4, 174px);
    column-gap: 16px;
  }
}

@media (min-width: 1440px) {
  .menu_content_container .footer_content_container {
    grid-template-columns: 288px repeat(4, 200px);
    column-gap: 56px;
    max-width: min-content;
  }
}