@import url("https://fonts.googleapis.com/css2?family=Geist+Mono:wght@100..900&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Playfair+Display:ital,wght@0,400..900;1,400..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@200..700&display=swap");
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  line-height: 1.5;
}

html {
  scroll-behavior: smooth;
}

body {
  max-width: 100%;
}

body,
p {
  font-size: 16px;
  font-weight: 400;
  color: #b1b1b1;
  line-height: 1.75rem;
}

.header_text {
  font-weight: 400;
  margin-bottom: 20px;
  font-size: 1.125rem;
}

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

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

ul,
ol,
li {
  list-style: none;
  padding: 0;
  margin: 0;
}

@font-face {
  font-family: "Outward Block";
  src: url("../../../public/fonts/outward-block.ttf") format("truetype");
}
@font-face {
  font-family: "PP Neue Montreal";
  src: url("../../../public/fonts/ppneuemontreal-book.otf") format("opentype");
}
body {
  font-family: "Inter", sans-serif;
  font-family: "PP Neue Montreal";
  font-family: "Google Sans", sans-serif;
  font-style: normal;
}

.sans {
  font-family: "Inter", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}

.serif {
  font-family: "Playfair Display", serif;
  font-optical-sizing: auto;
  font-style: normal;
}

.mono, .mono_highlighted {
  font-family: "Geist Mono", monospace;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: 0.9125rem;
  font-weight: 300;
}

.mono_highlighted {
  background-color: rgba(72, 0, 140, 0.25);
  color: #f5f3ee;
  padding: 2px 5px;
  font-size: 12px;
  width: fit-content;
}
.mono_highlighted_clickable {
  transition: background-color 0.3s ease-out;
  margin-bottom: 1rem;
}
.mono_highlighted_clickable:hover {
  background-color: rgba(72, 0, 140, 0.5);
}

h1 {
  font-size: 2.625rem;
  font-size: clamp(3rem, 1.848vw + 1.522rem, 5rem) !important;
  font-weight: 500;
  line-height: clamp(3rem, 2.771vw + 2.283rem, 4.5rem);
  line-height: 1.25;
  margin-bottom: 20px;
  color: #fff;
}

h2 {
  font-size: clamp(2rem, 0.924vw + 1.761rem, 2.25rem) !important;
  font-weight: 500 !important;
  max-width: 50vw;
  line-height: 1.3;
  margin-bottom: 1.5rem;
}

p {
  font-size: 1.125rem;
  font-size: clamp(1rem, 0.231vw + 0.815rem, 1.25rem) !important;
  line-height: clamp(1.5rem, 0.67vw + 0.964rem, 1.7rem);
  margin-bottom: 32px;
  color: #f5f5f5;
}

a {
  font-size: clamp(1rem, 0.231vw + 0.815rem, 1.25rem) !important;
  line-height: clamp(1.138rem, 0.67vw + 0.964rem, 1.5rem);
}

.current_section_name,
.progress-percentage {
  font-size: clamp(1rem, 0.231vw + 0.815rem, 1.25rem) !important;
  line-height: clamp(1.5rem, 0.67vw + 0.964rem, 1.7rem);
}

.col_1_span_1 {
  grid-column: 1/span 1;
}

.col_1_span_2 {
  grid-column: 1/span 2;
}

.col_1_span_3 {
  grid-column: 1/span 3;
}

.col_1_span_4 {
  grid-column: 1/span 4;
}

.col_1_span_5 {
  grid-column: 1/span 5;
}

.col_1_span_6 {
  grid-column: 1/span 6;
}

.col_1_span_7 {
  grid-column: 1/span 7;
}

.col_1_span_8 {
  grid-column: 1/span 8;
}

.col_1_span_9 {
  grid-column: 1/span 9;
}

.col_1_span_10 {
  grid-column: 1/span 10;
}

.col_1_span_11 {
  grid-column: 1/span 11;
}

.col_1_span_12 {
  grid-column: 1/span 12;
}

.col_2_span_1 {
  grid-column: 2/span 1;
}

.col_2_span_2 {
  grid-column: 2/span 2;
}

.col_2_span_3 {
  grid-column: 2/span 3;
}

.col_2_span_4 {
  grid-column: 2/span 4;
}

.col_2_span_5 {
  grid-column: 2/span 5;
}

.col_2_span_6 {
  grid-column: 2/span 6;
}

.col_2_span_7 {
  grid-column: 2/span 7;
}

.col_2_span_8 {
  grid-column: 2/span 8;
}

.col_2_span_9 {
  grid-column: 2/span 9;
}

.col_2_span_10 {
  grid-column: 2/span 10;
}

.col_2_span_11 {
  grid-column: 2/span 11;
}

.col_2_span_12 {
  grid-column: 2/span 12;
}

.col_3_span_1 {
  grid-column: 3/span 1;
}

.col_3_span_2 {
  grid-column: 3/span 2;
}

.col_3_span_3 {
  grid-column: 3/span 3;
}

.col_3_span_4 {
  grid-column: 3/span 4;
}

.col_3_span_5 {
  grid-column: 3/span 5;
}

.col_3_span_6 {
  grid-column: 3/span 6;
}

.col_3_span_7 {
  grid-column: 3/span 7;
}

.col_3_span_8 {
  grid-column: 3/span 8;
}

.col_3_span_9 {
  grid-column: 3/span 9;
}

.col_3_span_10 {
  grid-column: 3/span 10;
}

.col_3_span_11 {
  grid-column: 3/span 11;
}

.col_3_span_12 {
  grid-column: 3/span 12;
}

.col_4_span_1 {
  grid-column: 4/span 1;
}

.col_4_span_2 {
  grid-column: 4/span 2;
}

.col_4_span_3 {
  grid-column: 4/span 3;
}

.col_4_span_4 {
  grid-column: 4/span 4;
}

.col_4_span_5 {
  grid-column: 4/span 5;
}

.col_4_span_6 {
  grid-column: 4/span 6;
}

.col_4_span_7 {
  grid-column: 4/span 7;
}

.col_4_span_8 {
  grid-column: 4/span 8;
}

.col_4_span_9 {
  grid-column: 4/span 9;
}

.col_4_span_10 {
  grid-column: 4/span 10;
}

.col_4_span_11 {
  grid-column: 4/span 11;
}

.col_4_span_12 {
  grid-column: 4/span 12;
}

.col_5_span_1 {
  grid-column: 5/span 1;
}

.col_5_span_2 {
  grid-column: 5/span 2;
}

.col_5_span_3 {
  grid-column: 5/span 3;
}

.col_5_span_4 {
  grid-column: 5/span 4;
}

.col_5_span_5 {
  grid-column: 5/span 5;
}

.col_5_span_6 {
  grid-column: 5/span 6;
}

.col_5_span_7 {
  grid-column: 5/span 7;
}

.col_5_span_8 {
  grid-column: 5/span 8;
}

.col_5_span_9 {
  grid-column: 5/span 9;
}

.col_5_span_10 {
  grid-column: 5/span 10;
}

.col_5_span_11 {
  grid-column: 5/span 11;
}

.col_5_span_12 {
  grid-column: 5/span 12;
}

.col_6_span_1 {
  grid-column: 6/span 1;
}

.col_6_span_2 {
  grid-column: 6/span 2;
}

.col_6_span_3 {
  grid-column: 6/span 3;
}

.col_6_span_4 {
  grid-column: 6/span 4;
}

.col_6_span_5 {
  grid-column: 6/span 5;
}

.col_6_span_6 {
  grid-column: 6/span 6;
}

.col_6_span_7 {
  grid-column: 6/span 7;
}

.col_6_span_8 {
  grid-column: 6/span 8;
}

.col_6_span_9 {
  grid-column: 6/span 9;
}

.col_6_span_10 {
  grid-column: 6/span 10;
}

.col_6_span_11 {
  grid-column: 6/span 11;
}

.col_6_span_12 {
  grid-column: 6/span 12;
}

.col_7_span_1 {
  grid-column: 7/span 1;
}

.col_7_span_2 {
  grid-column: 7/span 2;
}

.col_7_span_3 {
  grid-column: 7/span 3;
}

.col_7_span_4 {
  grid-column: 7/span 4;
}

.col_7_span_5 {
  grid-column: 7/span 5;
}

.col_7_span_6 {
  grid-column: 7/span 6;
}

.col_7_span_7 {
  grid-column: 7/span 7;
}

.col_7_span_8 {
  grid-column: 7/span 8;
}

.col_7_span_9 {
  grid-column: 7/span 9;
}

.col_7_span_10 {
  grid-column: 7/span 10;
}

.col_7_span_11 {
  grid-column: 7/span 11;
}

.col_7_span_12 {
  grid-column: 7/span 12;
}

.col_8_span_1 {
  grid-column: 8/span 1;
}

.col_8_span_2 {
  grid-column: 8/span 2;
}

.col_8_span_3 {
  grid-column: 8/span 3;
}

.col_8_span_4 {
  grid-column: 8/span 4;
}

.col_8_span_5 {
  grid-column: 8/span 5;
}

.col_8_span_6 {
  grid-column: 8/span 6;
}

.col_8_span_7 {
  grid-column: 8/span 7;
}

.col_8_span_8 {
  grid-column: 8/span 8;
}

.col_8_span_9 {
  grid-column: 8/span 9;
}

.col_8_span_10 {
  grid-column: 8/span 10;
}

.col_8_span_11 {
  grid-column: 8/span 11;
}

.col_8_span_12 {
  grid-column: 8/span 12;
}

.col_9_span_1 {
  grid-column: 9/span 1;
}

.col_9_span_2 {
  grid-column: 9/span 2;
}

.col_9_span_3 {
  grid-column: 9/span 3;
}

.col_9_span_4 {
  grid-column: 9/span 4;
}

.col_9_span_5 {
  grid-column: 9/span 5;
}

.col_9_span_6 {
  grid-column: 9/span 6;
}

.col_9_span_7 {
  grid-column: 9/span 7;
}

.col_9_span_8 {
  grid-column: 9/span 8;
}

.col_9_span_9 {
  grid-column: 9/span 9;
}

.col_9_span_10 {
  grid-column: 9/span 10;
}

.col_9_span_11 {
  grid-column: 9/span 11;
}

.col_9_span_12 {
  grid-column: 9/span 12;
}

.col_10_span_1 {
  grid-column: 10/span 1;
}

.col_10_span_2 {
  grid-column: 10/span 2;
}

.col_10_span_3 {
  grid-column: 10/span 3;
}

.col_10_span_4 {
  grid-column: 10/span 4;
}

.col_10_span_5 {
  grid-column: 10/span 5;
}

.col_10_span_6 {
  grid-column: 10/span 6;
}

.col_10_span_7 {
  grid-column: 10/span 7;
}

.col_10_span_8 {
  grid-column: 10/span 8;
}

.col_10_span_9 {
  grid-column: 10/span 9;
}

.col_10_span_10 {
  grid-column: 10/span 10;
}

.col_10_span_11 {
  grid-column: 10/span 11;
}

.col_10_span_12 {
  grid-column: 10/span 12;
}

.col_11_span_1 {
  grid-column: 11/span 1;
}

.col_11_span_2 {
  grid-column: 11/span 2;
}

.col_11_span_3 {
  grid-column: 11/span 3;
}

.col_11_span_4 {
  grid-column: 11/span 4;
}

.col_11_span_5 {
  grid-column: 11/span 5;
}

.col_11_span_6 {
  grid-column: 11/span 6;
}

.col_11_span_7 {
  grid-column: 11/span 7;
}

.col_11_span_8 {
  grid-column: 11/span 8;
}

.col_11_span_9 {
  grid-column: 11/span 9;
}

.col_11_span_10 {
  grid-column: 11/span 10;
}

.col_11_span_11 {
  grid-column: 11/span 11;
}

.col_11_span_12 {
  grid-column: 11/span 12;
}

.col_12_span_1 {
  grid-column: 12/span 1;
}

.col_12_span_2 {
  grid-column: 12/span 2;
}

.col_12_span_3 {
  grid-column: 12/span 3;
}

.col_12_span_4 {
  grid-column: 12/span 4;
}

.col_12_span_5 {
  grid-column: 12/span 5;
}

.col_12_span_6 {
  grid-column: 12/span 6;
}

.col_12_span_7 {
  grid-column: 12/span 7;
}

.col_12_span_8 {
  grid-column: 12/span 8;
}

.col_12_span_9 {
  grid-column: 12/span 9;
}

.col_12_span_10 {
  grid-column: 12/span 10;
}

.col_12_span_11 {
  grid-column: 12/span 11;
}

.col_12_span_12 {
  grid-column: 12/span 12;
}

.section_full_dark,
.section_full_light {
  min-height: 100vh;
  width: 100%;
}

.section_full_dark {
  background-color: #232325;
  color: #232325;
}

.section_full_light {
  background-color: #0e0e0e;
  color: #f5f3ee;
}

.visually-hidden {
  position: absolute !important;
  overflow: hidden;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  clip: rect(0 0 0 0);
  word-wrap: normal !important;
}

nav.navbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: fit-content;
  padding-inline: 1.5rem 0;
  border-bottom: 1px solid #272727;
  font-size: 0.9rem;
  position: fixed;
  inset: 0;
  gap: 0;
  z-index: 20000;
  background-color: rgba(14, 14, 14, 0.65);
  backdrop-filter: blur(50px);
  transition: top 0.5s;
  overflow: hidden;
}
nav.navbar ul {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  width: fit-content;
  width: calc(50% + 1px + 0.75rem);
}
nav.navbar .logo {
  font-size: 1.125rem;
  font-weight: 500;
  text-transform: capitalize;
}
nav.navbar a.link {
  padding-block: 0.75rem;
  padding-inline: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-weight: 400;
  font-size: clamp(0.875rem, 0.231vw + 0.815rem, 1rem);
  line-height: clamp(1.138rem, 0.67vw + 0.964rem, 1.5rem);
  font-size: 0.9125rem !important;
  border-left: 1px solid #272727;
}
nav.navbar .contact {
  border-inline: 1px solid #272727;
}
nav.navbar .contact_btn {
  display: flex;
  padding: 0.75rem 1rem;
  min-height: 100%;
  border-radius: 0rem !important;
}
nav.navbar .active {
  background-color: #272727;
}

.side-menu {
  position: fixed;
  right: 0;
  top: 0;
  width: 0%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  z-index: 1000;
}
.side-menu .side-menu-content {
  background-color: #48008c;
  background-color: #0e0e0e;
  width: 100%;
  height: 100%;
  margin-left: auto;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding-inline: 1.5rem;
}
.side-menu .side-menu-content ul {
  margin-bottom: auto;
}
.side-menu .side-menu-content ul li.side-menu-link {
  padding: 0.375rem;
  border-bottom: 1px solid #272727;
}
.side-menu .side-menu-content ul li.side-menu-link a {
  background: #0e0e0e;
  padding: 0.75rem calc(0.75rem + 0.5vw);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  clip-path: polygon(3% 0%, 100% 0%, 100% 70%, 97% 100%, 0% 100%, 0% 30%);
  border-radius: 0 10px 0 10px;
}
.side-menu .side-menu-content ul li.side-menu-link a:hover {
  background-color: rgba(40, 40, 40, 0.75);
}
.side-menu .side-menu-content .side-menu-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #272727;
  margin-bottom: 4rem;
  padding-block: 0.75rem;
}
.side-menu .side-menu-content .side-menu-header .close {
  cursor: pointer;
  border-radius: 100rem;
  padding: 0.25rem;
  transition: background-color 0.3s;
}
.side-menu .side-menu-content .side-menu-header .close:hover {
  background-color: #282828;
}
.side-menu .side-menu-content .side-menu-socials {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.9rem;
  gap: 1rem;
}
.side-menu .side-menu-content .side-menu-socials .links {
  display: flex;
  align-items: center;
  padding-block: 0.75rem;
  gap: 0.75rem;
  text-wrap: nowrap;
}
.side-menu .side-menu-content .side-menu-socials .separator {
  width: 100%;
  height: 100%;
  position: relative;
}
.side-menu .side-menu-content .side-menu-socials .separator::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  top: 50%;
  left: 0%;
  background-color: #f5f3ee;
}

.btn {
  background-color: #171717;
  color: #f5f3ee;
  display: flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  padding: 0.65rem 1rem;
  border: none;
  font-size: 1rem !important;
  white-space: nowrap;
  border-radius: 0;
  min-width: 150px;
  transition: background-color 0.2s linear, color 0.2s linear;
}
.btn .icon {
  display: none;
}
.btn:hover {
  background-color: #fff;
  color: #232325;
}

.cta {
  background-color: #fff;
  color: #232325;
  transition: background-color 0.2s linear, color 0.2s linear, box-shadow 0.2s linear;
  border: none;
}
.cta:hover {
  box-shadow: 0 0 1rem rgba(255, 255, 255, 0.5);
}

.marque {
  overflow: hidden;
  width: 100%;
  mask: linear-gradient(90deg, transparent, white 20%, white 80%, transparent);
}
.marque .marque_inner {
  display: flex;
  width: fit-content;
  flex-wrap: nowrap;
  gap: 3rem;
  animation: infinite_scroll 20s infinite linear;
}

@keyframes infinite_scroll {
  to {
    transform: translate(calc(-50% - 1.5rem));
  }
}
.ring-container {
  position: relative;
  width: 50px;
  height: 50px;
  transform: translateX(-15px);
}

.circle_dot {
  width: 10px;
  height: 10px;
  background-color: #fff;
  position: absolute;
  top: 20px;
  left: 20px;
}

.ringring {
  border: 3px solid #fff;
  height: 20px;
  width: 20px;
  position: absolute;
  top: 15px;
  left: 15px;
  opacity: 0;
  -webkit-animation: pulsate 1s ease-out infinite;
  animation: pulsate 1s ease-out infinite;
}

@keyframes pulsate {
  0% {
    transform: scale(0.1, 0.1);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: scale(1.2, 1.2);
    opacity: 0;
  }
}
@-webkit-keyframes pulsate {
  0% {
    -webkit-transform: scale(0.1, 0.1);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(1.2, 1.2);
    opacity: 0;
  }
}
.hero {
  min-height: calc(100vh + 1px);
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
  gap: 0;
  border-bottom: 1px solid #272727;
  position: relative;
}
.hero .background--custom {
  width: 100vw;
  height: 100vh;
  position: absolute;
  overflow: hidden;
  z-index: 1;
  top: 0;
  left: 0;
}
.hero .background--custom::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.2);
  z-index: 2;
  backdrop-filter: blur(5px);
  width: 100vw;
  height: 100%;
}
.hero canvas#canvas {
  z-index: 2;
  position: absolute;
  width: 100%;
  height: 100%;
  opacity: 90%;
  transform: rotate(0deg) scale(2) translateY(0%);
  --gradient-color-1: #47008a;
  --gradient-color-2: #05152e;
  --gradient-color-3: #21053b;
  --gradient-color-4: #0d0d0d;
  --gradient-speed: 0.000009;
}
.hero .availability {
  display: flex;
  align-items: center;
}
.hero .availability .availability_text {
  transform: translateX(-22px);
  font-weight: inherit;
}
.hero .hero_content {
  padding-inline: 1.5rem;
  align-content: center;
  z-index: 3;
  position: relative;
}
.hero .hero_content h1.hero_title {
  font-weight: 400;
  line-height: 130%;
  font-size: 2.125rem !important;
  letter-spacing: -0.012em;
  margin-bottom: 2rem;
  color: #5a5757;
}
.hero .hero_content h1.hero_title .light_text {
  line-height: inherit; /* make sure it matches surrounding text */
  font-family: inherit; /* ensure same font */
  color: #fff;
}
.hero .hero_content .call_to_actions {
  display: flex;
  gap: 1rem;
  margin-bottom: 1rem;
  z-index: 30000;
}
.hero .contact_links {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-inline: 1.5rem;
  width: 100vw;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  font-weight: 400 !important;
  border-top: 1px solid #272727;
}
.hero .contact_links .socials {
  display: flex;
  gap: 0.75rem;
}
.hero .contact_links .socials a {
  color: inherit;
  transition: color ease 0.5s;
}
.hero .contact_links .socials a:hover {
  color: #575454;
}
.hero .hero_visuals {
  display: none;
  height: 100%;
  width: calc(100% + 1px);
  transform: translateX(-1px);
  border-left: 1px solid #272727;
  position: relative;
  z-index: 3;
}
.hero .hero_visuals .socials {
  display: flex;
  align-items: center;
  position: absolute;
  bottom: 0;
  right: 0;
  padding: 0.75rem;
  gap: 0.75rem;
}
.hero .hero_visuals .circle {
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid #272727;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.hero .hero_visuals .circle1 {
  height: 45vh;
}
.hero .hero_visuals .circle2 {
  height: 36vh;
}
.hero .hero_visuals .circle3 {
  height: 27vh;
}
.hero .hero_visuals .circle4 {
  height: 18vh;
}
.hero .hero_visuals .circle5 {
  height: 9vh;
}
.hero .hero_visuals .v_line {
  border-bottom: 1px solid #272727;
  position: absolute;
  height: 1px;
  width: 100%;
  top: 50%;
  transform: translateY(-50%);
}

.about {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
  display: none;
  gap: 0;
  width: 100%;
  border-bottom: 1px solid #272727;
  background-color: red;
}
.about .about_visuals {
  display: grid;
  width: 100%;
  grid-template-columns: 1fr 1fr;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid #272727;
}
.about .about_visuals .about-me-text,
.about .about_visuals .my-skills-text {
  position: absolute;
  top: 0;
  padding: 1.5rem;
  width: 50%;
  height: 100%;
  background: rgba(14, 14, 14, 0.85);
  backdrop-filter: blur(10px);
}
.about .about_visuals .about-me-text h3,
.about .about_visuals .my-skills-text h3 {
  margin-bottom: 0.5rem;
}
.about .about_visuals .about-me-text li,
.about .about_visuals .my-skills-text li {
  margin-bottom: 0.5rem;
}
.about .about_visuals .about-me-text {
  right: 0%;
}
.about .about_visuals .my-skills-text {
  left: 0%;
}
.about .about_visuals .my-skills-text p {
  margin-bottom: 1.5rem;
}
.about .about_visuals .my-skills-text .skills-list {
  display: flex;
  flex-wrap: wrap;
  column-gap: 0.5rem;
  margin-bottom: 2rem;
}
.about .about_visuals .my-skills-text .skills-list li {
  border: 1px solid #272727;
  padding: 0.25rem 1rem;
  font-size: 0.875rem;
  margin-bottom: 0.5rem;
}
.about .about_visuals .img_container img {
  -webkit-filter: grayscale(100%);
  filter: grayscale(100%);
  transition: filter 0.5s;
}
.about .about_visuals .img_container img:hover {
  -webkit-filter: grayscale(0%);
  filter: grayscale(0%);
}
.about .about_visuals .img_container {
  height: 120vh;
  width: 100%;
  overflow: hidden !important;
  position: relative;
}
.about .about_visuals .img_container img {
  height: 100%;
  width: 100%;
  object-fit: cover;
  object-position: center;
}
.about .about_visuals .name {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  display: none;
  z-index: 2000;
  background-color: green;
}
.about .about_visuals .name h3 {
  font-size: 20px;
}
.about .about_visuals .name .name_inner p {
  font-size: 0.75rem;
}
.about .about_content {
  width: 100%;
  padding-block: 3rem;
}
.about .about_content h2 {
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.2;
  margin-bottom: 1.5rem;
}
.about .about_content p {
  margin: 0;
}
.about .project-process {
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding: 1.5rem;
  gap: 0;
  width: 100%;
}
.about .project-process .process-visuals {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  background-color: red;
}
.about .project-process .process-image {
  background-color: #72001b;
  margin: 1.5rem;
  padding: 1.5rem;
  height: calc(100% - 3rem);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  display: none;
}
.about .project-process .process-image h2,
.about .project-process .process-image p {
  color: #0e0e0e;
}
.about .project-process .process-image svg {
  height: 15rem;
  color: #0e0e0e;
}
.about .project-process .process-text {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
}
.about .project-process .process-text .process-step {
  border: 1px solid #272727;
  padding: 0.75rem;
  height: fit-content;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 0;
  height: 60vh;
}
.about .project-process .process-text .process-step:last-child {
  margin-bottom: 0;
}
.about .project-process .process-text .process-step .full-description {
  margin-top: auto;
  display: none;
}
.about .project-process .process-text .process-step .intro {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.about .project-process .process-text .process-step h3 {
  font-size: 1.5rem;
  font-weight: 500;
}
.about .project-process .process-text .process-step p {
  font-size: 1rem;
  font-weight: 300;
}

.services {
  border-bottom: 1px solid #272727;
}
.services .skills-text {
  padding: 4rem 1.5rem;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
}
.services .skills-text h2 {
  font-weight: 400 !important;
  line-height: 130%;
  font-size: 2.125rem !important;
  letter-spacing: -0.012em;
  font-size: 2.75rem;
  letter-spacing: -0.5px;
  margin-bottom: 2rem;
}
.services .skills-text p {
  font-size: 1rem;
  line-height: 1.5;
  margin-bottom: 1rem;
}
.services .services_container {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
  gap: 0;
}
.services .services_container .service {
  border-block: 1px solid #272727;
  min-height: 65vh;
  margin-bottom: 2rem;
}
.services .services_container .service:nth-child(2) {
  border-inline: 1px solid #272727;
}
.services .services_container .service li {
  margin-bottom: 0.5rem;
}
.services .services_container .service .service-text {
  padding-bottom: 1.5rem;
}
.services .services_container .service .service-text .technical-skills {
  padding-inline: 1.5rem;
}
.services .services_container .service h3 {
  margin-bottom: 1.5rem;
  border-bottom: 1px solid #272727;
  font-size: 1.5rem;
  line-height: 1.2;
  font-weight: 400;
  font-size: 1.125rem;
  padding: 0.75rem 1.5rem;
}
.services .services_container .service p {
  margin-bottom: 2rem;
  font-weight: 300;
  padding-inline: 1.5rem;
}
.services .services_container .service .deliverables {
  font-weight: 400;
  padding-inline: 1.5rem;
}
.services .services_container .techstack {
  border: 1px dashed #272727;
  margin: 1.5rem;
  padding-bottom: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  overflow: hidden;
  border-radius: 0;
}
.services .services_container .techstack p {
  border-bottom: 1px dashed #272727;
  font-weight: 400;
  font-size: 0.8rem !important;
  text-transform: uppercase;
  line-height: clamp(1.688rem, 1.039vw + 1.419rem, 2.25rem);
  text-wrap: nowrap;
  margin-bottom: 0rem;
  text-align: center;
  width: 100%;
  padding-block: 0.5rem;
}
.services .services_container .techstack .stack-icons {
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: 2rem;
  position: relative;
  overflow: hidden;
}
.services .services_container .techstack .stack-icons::before, .services .services_container .techstack .stack-icons::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 50px;
  pointer-events: none;
  z-index: 1;
}
.services .services_container .techstack .stack-icons .top-tool-row,
.services .services_container .techstack .stack-icons .bottom-tool-row {
  display: flex;
  gap: 2rem;
}
.services .services_container .techstack .stack-icons .tool {
  background-color: #1c0037;
  background-color: #272727;
  width: fit-content;
  padding: calc(0.5rem + 0.25vw);
  border-radius: 0;
}
.services .services_container .techstack .stack-icons .tool:hover {
  background-color: #1c0037;
}
.services .services_container .techstack .stack-icons .tool svg {
  height: 2.25rem;
  width: 2.25rem;
}
.services .my_process {
  height: fit-content;
  border-top: 1px solid #272727;
  display: none;
}
.services .my_process .process-img {
  padding: 4rem 1.5rem;
  border-bottom: 1px solid #272727;
}
.services .my_process .process-img img {
  height: 100%;
}
.services .my_process .process .step {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
  border-bottom: 1px solid #272727;
  overflow: hidden;
}
.services .my_process .process .step .click {
  display: none;
}
.services .my_process .process .step .step_text {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 50px;
}
.services .my_process .process .step .step_container {
  display: flex;
  justify-content: space-between;
  padding: 1.5rem;
  cursor: pointer;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
}
.services .my_process .process .step .step_container .step_icon svg {
  height: 1.5rem;
  width: 1.5rem;
}
.services .my_process .process .step .step_content {
  padding: 1.5rem;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
}

.work {
  border-bottom: 1px solid #272727;
}
.work .work_header {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
  gap: 0;
  border-bottom: 1px solid #272727;
  padding-block: 4rem;
}
.work .work_header .work_title {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
}
.work .work_header .work_title h2 {
  font-weight: 400 !important;
  line-height: 130%;
  font-size: 2.125rem !important;
  letter-spacing: -0.012em;
}
.work .work_header .work_title p {
  margin-bottom: 0;
}
.work .work_header .work_bg {
  background: #1c0037;
}
.work .main-project {
  margin: 3rem 1.5rem;
  padding: 1.5rem;
  display: flex;
  height: 90vh;
  overflow: hidden;
  border-radius: 0;
  position: relative;
  background-color: #272727;
}
.work .main-project .main-project-container {
  border: 1px solid #272727;
  border-radius: 0;
  overflow: hidden;
}
.work .main-project .main-project-container .main-project-image img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
}
.work .main-project .project-details {
  background-color: rgba(39, 39, 39, 0.9);
  position: absolute;
  bottom: 3rem;
  left: 3rem;
  padding: 1rem;
  border-radius: 0;
}
.work .brands_marque {
  overflow: hidden;
  width: calc(100% - 3rem);
  margin-inline: auto;
  margin: 3rem 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid #272727;
  border: 1px dashed #272727;
  position: relative;
  border-radius: 0;
}
.work .brands_marque p {
  border-bottom: 1px dashed #272727;
  font-weight: 400;
  font-size: 0.8rem !important;
  text-transform: uppercase;
  line-height: clamp(1.688rem, 1.039vw + 1.419rem, 2.25rem);
  text-wrap: nowrap;
  margin-bottom: 0rem;
  text-align: center;
  width: 100%;
  padding-block: 0.5rem;
  margin-bottom: 1.5rem;
}
.work .brands_marque .projects_container {
  mask: linear-gradient(90deg, transparent, white 20%, white 80%, transparent);
}
.work .brands_marque .marque_inner {
  display: flex;
  width: fit-content;
  flex-wrap: nowrap;
  gap: 3rem;
  animation: infinite_scroll 20s infinite linear;
}
.work .brands_marque .marque_inner .marque_item {
  -webkit-filter: grayscale(80%);
  filter: grayscale(80%);
  width: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.work .brands_marque .marque_inner .marque_item:hover {
  -webkit-filter: grayscale(0%);
  filter: grayscale(0%);
}
.work .client_testimonials {
  background-color: #272727;
  padding: 1.5rem;
  margin: 1.5rem;
}
.work .project_marque {
  display: flex;
  overflow: hidden;
  display: none;
}
.work .project_marque .logos {
  display: flex;
}
.work .project_marque .logos .logo {
  height: 180px;
  width: 190px;
  border-right: 1px solid #272727;
  position: relative;
}
.work .project_marque .logos .logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}
.work .other_projects {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
  gap: 0;
  height: fit-content;
  display: none;
}
.work .other_projects .project_description {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.work .other_projects .project_description h2 {
  margin-bottom: 1rem;
}
.work .other_projects .project_description p {
  margin-bottom: 2rem;
}
.work .other_projects .project_list,
.work .other_projects .project_description,
.work .other_projects .project_img_container {
  border-left: 1px solid #272727;
  padding: 1.5rem;
}
.work .other_projects .project_list {
  padding: 0;
  border: none;
}
.work .other_projects .project_list ul {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.work .other_projects .project_img_container {
  overflow: hidden;
}
.work .other_projects .project_img_container img {
  width: 100%;
  height: 100%;
  object-position: center;
  max-height: 80vh;
}
.work .other_projects .tag_list {
  display: flex;
  gap: 5px;
}
.work .more_projects {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
  gap: 0;
  margin-bottom: 1.5rem;
  border-block: 1px solid #272727;
}
.work .more_projects .header {
  border-bottom: 1px solid #272727;
  padding: 1.5rem;
}
.work .more_projects .header h3 {
  font-size: 0.9rem !important;
  font-weight: 300 !important;
}
.work .more_projects .project_container {
  border-right: 1px solid #272727;
  padding: 3rem 1.5rem;
}
.work .more_projects .project_one {
  min-height: 60vh;
  border: 1px solid #272727;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  background: transparent;
  padding: 1rem;
  border-radius: 0;
  background-color: #171717;
  transition: background-color 0.5s ease-in-out;
}
.work .more_projects .project_one:hover {
  background-color: #272727;
}
.work .more_projects .project_one .project_name {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-weight: 400;
  font-size: 1rem;
  padding-block: 1rem;
  margin-bottom: 1.5rem;
}
.work .more_projects .project_one .project_name span {
  font-weight: 500;
}
.work .more_projects .project_one .brand_name {
  margin-top: auto;
}
.work .more_projects .project_one .brand_name p {
  margin: 0;
}
.work .more_projects .project_one .project_image {
  overflow: hidden;
  aspect-ratio: 4/3;
  transition: 0.5s ease-in-out;
}
.work .more_projects .project_one .project_image img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}
.work .more_projects .project-ctas {
  display: flex;
  gap: 1.5rem;
  background-color: #272727;
  border: 1px solid #272727;
  border-radius: 0;
  margin: 3rem 1.5rem;
}
.work .more_projects .project-ctas .get-started,
.work .more_projects .project-ctas .view-all {
  padding: 1rem;
  display: flex;
  flex-direction: column;
  font-weight: 400;
  gap: 0.5rem;
}
.work .more_projects .project-ctas .get-started p,
.work .more_projects .project-ctas .view-all p {
  margin-bottom: auto;
}
.work .more_projects .project-ctas .get-started .btn,
.work .more_projects .project-ctas .get-started .cta,
.work .more_projects .project-ctas .view-all .btn,
.work .more_projects .project-ctas .view-all .cta {
  width: 100%;
}

@keyframes infinite_scroll {
  to {
    transform: translate(calc(-50% - 1.5rem));
  }
}
.contact .contact-content {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
  gap: 0;
  min-height: 100vh;
  overflow: hidden;
  border-bottom: 1px solid #272727;
}
.contact .contact_header {
  padding-block: 4rem;
}
.contact .contact_header h2 {
  font-weight: 400 !important;
  line-height: 130%;
  font-size: 2.125rem !important;
  letter-spacing: -0.012em;
}
.contact .contact_header p {
  margin-bottom: 1.5rem;
}
.contact .contact_header .direct_contact {
  width: 100%;
}
.contact .contact_links {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
  gap: 0;
  transform: translate(-1.5rem);
  width: calc(100% + 3rem);
  border-inline: 1px solid #272727;
  position: relative;
  text-align: center;
  border-block: 1px solid #272727;
}
.contact .contact_links a {
  font-size: 0.9rem !important;
  padding: 2px;
}
.contact .contact_links a:hover {
  color: white;
}
.contact .email,
.contact .phone,
.contact .divider {
  display: flex;
  align-items: center;
  border-right: 1px solid #272727;
  padding: 0.9rem 1.5rem;
  font-size: 0.9rem;
  margin: 0;
  gap: 0.5rem;
  border-top: none;
}
.contact .email p,
.contact .phone p,
.contact .divider p {
  font-size: 300;
  margin: 0;
}
.contact .email a,
.contact .phone a,
.contact .divider a {
  line-height: 1;
}
.contact .email .icon,
.contact .phone .icon,
.contact .divider .icon {
  margin-bottom: 1rem;
  display: none;
}
.contact .email:last-child,
.contact .phone:last-child,
.contact .divider:last-child {
  border-right: none;
}
.contact .email {
  width: calc(100% + 1.5rem);
}
.contact .divider {
  background-color: #171717;
  width: 100%;
  height: 100%;
  transform: translateX(-7px);
  border-top: none;
}
.contact .divider:last-child {
  transform: translateX(8px);
  border-left: 1px solid #272727;
}
.contact .middle {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.contact .middle .divide {
  background-color: #171717;
  width: 100%;
  height: 100%;
  transform: translateX(-7px);
  border: 1px solid #272727;
  border-top: none;
  border-bottom: none;
}
.contact .contact-devider {
  height: 20vh;
  background-image: repeating-linear-gradient(90deg, #0e0e0e 0px, #0e0e0e 2px, #323232 2px, #323232 4px);
  background-size: 2.5rem 2.5rem;
  background-position: center center;
  display: none;
}
.contact .contact_form {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
  gap: 0;
  margin-bottom: 0;
  border: none;
  margin-inline: 0;
}
.contact .contact_form .header_text {
  font-size: 0.9rem !important;
  font-weight: 300 !important;
  margin-bottom: 2rem;
}
.contact .contact_form .form_container {
  padding: 1.5rem;
  padding-top: 0;
  border-radius: 0;
  border: 1px #272727 dashed;
  margin: 1.5rem 1.5rem;
  background-color: #171717;
}
.contact .contact_form .form_container h3 {
  border-bottom: 1px dashed #323232;
  font-weight: 400;
  font-size: 0.8rem !important;
  text-transform: uppercase;
  line-height: clamp(1.688rem, 1.039vw + 1.419rem, 2.25rem);
  text-wrap: nowrap;
  margin-bottom: 2.25rem;
  text-align: center;
  width: 100%;
  padding-block: 0.5rem;
}
.contact .contact_form .form_container .form_field {
  display: flex;
  justify-content: space-between;
  gap: 1.5rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-bottom: 1rem;
  height: fit-content;
}
.contact .contact_form .form_container .message_field {
  grid-template-columns: 1fr;
}
.contact .contact_form .form_container .field {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin-bottom: 1rem;
}
.contact .contact_form .form_container .field:last-of-type {
  grid-column: 1/span 2;
}
.contact .contact_form .form_container label {
  font-size: 0.9rem;
  display: flex;
  gap: 2px;
  font-size: 0.75rem;
  line-height: 1;
  color: rgba(255, 255, 255, 0.5019607843);
  text-transform: uppercase;
  pointer-events: none;
  transition: opacity 0.3s linear, color 0.3s linear;
}
.contact .contact_form .form_container input,
.contact .contact_form .form_container select,
.contact .contact_form .form_container textarea {
  outline: none;
  border: none;
  font-weight: 300;
  padding: 1rem 0;
  line-height: 1;
  position: relative;
  width: 100%;
  padding: 10px 0;
  font-size: 1rem;
  line-height: 1.4;
  color: rgb(77, 76, 76);
  background: #171717;
  border-bottom: 1px solid #323232;
  transition: color 0.3s linear, border-color 0.3s linear;
  border-radius: 0 !important;
}
.contact .contact_form .form_container input:focus, .contact .contact_form .form_container input:hover, .contact .contact_form .form_container input:active,
.contact .contact_form .form_container select:focus,
.contact .contact_form .form_container select:hover,
.contact .contact_form .form_container select:active,
.contact .contact_form .form_container textarea:focus,
.contact .contact_form .form_container textarea:hover,
.contact .contact_form .form_container textarea:active {
  color: #ffffff;
  border-color: #ffffff;
}
.contact .contact_form .form_container textarea {
  height: 7rem;
  resize: vertical;
}
.contact .contact_form .form_container .submit_field {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
}
.contact .contact_form .form_container .submit_field label {
  font-size: 0.8rem;
  font-weight: 500;
  text-transform: none;
}

.form-submit-message {
  position: fixed;
  background-color: red;
  z-index: 100000000000000000;
  height: 50vh;
  width: 50vw;
  inset: 0;
}

.main-content {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
  gap: 0;
  border-bottom: 1px solid #272727;
  overflow: hidden;
}
.main-content .blog_header {
  border-right: 1px solid #272727;
  padding: 1.5rem;
}
.main-content .blog_header h2 {
  margin-bottom: 20px;
}
.main-content .blog_header p {
  margin-bottom: 24px;
}
.main-content .blog_posts {
  overflow: scroll;
}
.main-content .blog_posts .blog_posts_inner {
  display: flex;
  column-gap: 1.5rem;
  padding: 1.5rem;
  width: 100vw;
}
.main-content .blog_posts .blog_posts_inner .blog_post {
  border-radius: 0;
  padding-inline: 1rem;
  width: 25vw;
  background-color: #171717;
  height: fit-content;
  overflow: hidden;
  border: 1px solid #272727;
}
.main-content .blog_posts .blog_posts_inner .blog_post a {
  padding: 1rem;
}
.main-content .blog_posts .blog_posts_inner .blog_post a h3 {
  line-height: 1.3;
  font-weight: 500;
  font-size: 1.25rem;
  margin-bottom: 1rem;
}
.main-content .blog_posts .blog_posts_inner .blog_post a p {
  margin: 0;
}
.main-content .blog_posts .blog_posts_inner .blog_post a .image_container {
  height: 30vh;
  width: 100%;
  overflow: hidden;
  margin-bottom: 1rem;
}
.main-content .blog_posts .blog_posts_inner .blog_post a .image_container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.site_name {
  height: 110vh;
  border-bottom: 1px solid #272727;
  overflow: hidden;
  position: relative;
  overflow: hidden !important;
}
.site_name img {
  width: 100%;
  height: auto;
  object-fit: cover;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  backdrop-filter: grayscale(0.9);
}
.site_name .vortex {
  position: absolute;
  inset: 0;
  height: 100%;
  width: 100%;
}
.site_name .vortex .line {
  height: 100%;
  width: 1px;
  background-color: white;
  position: absolute;
  inset: 0;
  right: 50%;
}

.footer {
  height: fit-content;
  position: relative;
  height: 90vh;
  background-image: radial-gradient(140% 107% at 50% 10%, #0e0e0e 37.41%, color_primary_purple 79.27%, #002c6f 100%);
}
.footer .gradient {
  height: 90vh;
  overflow: hidden;
  position: absolute;
  inset: 0;
  z-index: -1;
}
.footer .gradient::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.01);
  backdrop-filter: blur(20px);
  z-index: 1;
}
.footer .gradient .circle_gradient {
  position: absolute;
  left: 0%;
  top: 50%;
  transform: translateX(-50%);
  clip-path: url("#blob1");
  width: 90%;
  height: 90%;
  border-radius: 50%;
  background: radial-gradient(closest-side, #48008c, #0e0e0e);
}
.footer .footer_content {
  margin-top: 1.5rem;
  height: fit-content;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
  gap: 1.5rem;
  z-index: 10;
  border-top: 1px solid #272727;
}
.footer .footer_content p {
  margin-bottom: 0rem;
}
.footer .footer_content .call_to_actions {
  display: none;
  align-items: center;
  gap: 24px;
}
.footer .footer_content .footer_field {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-block: 1px solid #272727;
  padding: 1.5rem;
  margin: 0;
}
.footer .footer_content .footer_field .newsletter-header h2 {
  line-height: 1.3;
  font-weight: 500;
  font-size: 1.25rem !important;
  margin-bottom: 1rem;
}
.footer .footer_content .footer_field .field {
  width: 100%;
  display: flex;
  gap: 0;
}
.footer .footer_content .footer_field .field input {
  padding: 10px;
  width: 100%;
  border: none;
  font-size: 1rem;
  line-height: 1.4;
  color: rgb(77, 76, 76);
  background: transparent;
  border: 1px solid #323232;
  transition: color 0.3s linear, border-color 0.3s linear;
  border-top-left-radius: 0.25rem !important;
  border-bottom-left-radius: 0.25rem !important;
}
.footer .footer_content .footer_field .field input:focus, .footer .footer_content .footer_field .field input:hover, .footer .footer_content .footer_field .field input:active {
  outline: none;
  border-color: #fff;
  color: #fff;
}
.footer .footer_content .footer_field .field .cta, .footer .footer_content .footer_field .field .btn {
  border-top-left-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
  border: none;
}
.footer .footer_content .footer_menu {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #272727;
  margin-bottom: 30vh;
}
.footer .footer_content .footer_menu .first {
  margin-bottom: 1.5rem;
  font-weight: 500;
  opacity: 1;
  font-size: 0.9rem !important;
}
.footer .footer_content .footer_menu ul {
  width: 100%;
  border-right: 1px dashed #272727;
  padding: 1.5rem;
}
.footer .footer_content .footer_menu li,
.footer .footer_content .footer_menu a {
  font-size: 1rem !important;
  margin-bottom: 0.5rem;
}
.footer .copyright {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-inline: 1.5rem;
  z-index: 30;
  background-color: #0e0e0e;
  padding-block: 0.75rem;
  border-top: 1px solid #272727;
  position: absolute;
  bottom: 0;
  left: 0;
}
.footer .copyright p {
  margin: 0;
}

.introduction {
  border-bottom: 1px solid #272727;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 60vh;
}

.image_devider {
  min-height: 120vh;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.5rem;
  gap: 0;
}
.image_devider .devide {
  border-right: 1px solid #272727;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: background-color 0.3s ease-in-out;
}
.image_devider .devide .text {
  font-size: 8rem;
  font-size: 9vw;
  line-height: 0.85;
  height: fit-content;
  text-transform: uppercase;
}
.image_devider .devide .bottom_text_container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: fit-content;
  width: fit-content;
  margin-inline: auto;
}
.image_devider .devide .picture {
  width: 100%;
  aspect-ratio: 8/10;
  margin-bottom: 56px;
  padding-inline: 1rem;
  clip-path: polygon(0 0, 100% 0, 10% 0 100%, 100% 100%);
}
.image_devider .devide .picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.image_devider .devide .number {
  font-size: 0.8rem;
  display: block;
  font-weight: 300;
  margin-bottom: 16px;
}
.image_devider .devide .big_text {
  display: flex;
  justify-self: flex-end;
  width: fit-content;
}
.image_devider .devide .small_text,
.image_devider .devide .text {
  writing-mode: vertical-lr;
  transform: rotate(180deg);
}
.image_devider .devide .small_text {
  margin-right: 10px;
  padding-top: 5px;
}

.main {
  position: relative;
}
.main .progress_bar {
  height: 50px;
  width: 100%;
  z-index: 200000000;
  position: fixed;
  inset: 0;
  transform: translateY(20px);
}
.main .progress_bar .progress {
  height: 100%;
  width: 0;
  background-color: color_primary_purple;
}
.main .section_bar {
  position: fixed;
  top: 100vh;
  transform: translateY(calc(-100vh - 2px));
  width: 100%;
  height: fit-content;
  display: flex;
  justify-content: space-between;
  padding-inline: 1.5rem;
  border-block: 1px solid #272727;
  padding-block: 0.75rem;
  background-color: rgba(14, 14, 14, 0.65);
  backdrop-filter: blur(50px);
  z-index: 2000;
  font-size: 0.9125rem !important;
}
.main .section_bar .current_section {
  display: flex;
  gap: 0.5rem;
}
.main .section_bar .current_section_name,
.main .section_bar .progress-percentage {
  font-size: 0.9125rem !important;
}

.section-header {
  border-bottom: 1px solid #272727;
  padding: 0.5rem 1.5rem;
  display: flex;
  width: 100%;
  background-color: #171717;
  margin-bottom: 0;
  font-size: 0.9125rem !important;
}

svg {
  display: flex;
  align-items: center;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: #fff;
}

p {
  color: #f5f5f5;
  font-size: 0.95rem !important;
}

body .noise-overlay {
  z-index: 10000;
  opacity: 0.05;
  background-image: url(https://cdn.prod.website-files.com/651d15fb8f27f4a03c14ae88/651d15fb8f27f4a03c14afa4_5d8424ac4ffed73f4d72846e_5c06f51d6e75c933fe05c728_giphy.gif);
  background-position: 0 0;
  background-size: 480px;
  background-attachment: fixed;
  position: fixed;
  inset: 0%;
  pointer-events: none;
}
