@font-face {
  font-family: Hkgroteskwide;
  src: url('../fonts/HKGroteskWide-SemiBold.otf') format("opentype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Hkgroteskwide;
  src: url('../fonts/HKGroteskWide-Light.otf') format("opentype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Hkgroteskwide;
  src: url('../fonts/HKGroteskWide-Bold.otf') format("opentype"), url('../fonts/HKGroteskWide-ExtraBold.otf') format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Hkgroteskwide;
  src: url('../fonts/HKGroteskWide-Medium.otf') format("opentype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Hkgroteskwide;
  src: url('../fonts/HKGroteskWide-Black.otf') format("opentype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Hkgroteskwide;
  src: url('../fonts/HKGroteskWide-Regular.otf') format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --black: black;
  --gray: #ddd;
  --white: white;
  --black-2: black;
}

.w-layout-hflex {
  flex-direction: row;
  align-items: flex-start;
  display: flex;
}

body {
  color: #000;
  font-family: Hkgroteskwide, sans-serif;
  font-size: 14px;
  line-height: 20px;
}

li {
  margin-bottom: 8px;
}

.nav-wrapper {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  background-color: #0000;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  padding: 20px 48px;
  font-size: 18px;
  font-weight: 500;
  display: flex;
  position: absolute;
  inset: 0% 0% auto;
}

.nav-wrapper:where(.w-variant-02634eb2-240b-7ce4-a727-fe511c7bd59b) {
  background-color: #0000004d;
}

.nav-wrapper:hover {
  font-size: 22px;
}

.nav-links {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  justify-content: space-between;
  margin-top: 0;
  padding: 0;
  font-size: 18px;
  font-weight: 500;
  display: flex;
    z-index: 960 !important;
}

.nav-links:hover {
  font-size: 22px;
}

.home-title {
  color: #000;
  -webkit-text-stroke-color: #000;
  font-family: Hkgroteskwide, sans-serif;
  font-size: 18px;
  font-weight: 400;
  text-decoration: none;
}

.home-title:where(.w-variant-02634eb2-240b-7ce4-a727-fe511c7bd59b) {
  color: #fff;
}

.nav-link {
  color: #000;
  padding-top: 10px;
  font-family: Hkgroteskwide, sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  text-decoration: none;
  transition: all .2s ease-in-out;
}

.nav-link:where(.w-variant-02634eb2-240b-7ce4-a727-fe511c7bd59b) {
  color: #fff;
  transition: all .2s ease-in-out;
}

.nav-link:hover, .nav-link:hover:where(.w-variant-02634eb2-240b-7ce4-a727-fe511c7bd59b), .bold-text {
  font-size: 22px;
}

.nav-name {
  font-family: Hkgroteskwide, sans-serif;
  font-size: 22px;
}

.nav-name:where(.w-variant-02634eb2-240b-7ce4-a727-fe511c7bd59b) {
  color: #fff;
  -webkit-text-stroke-color: #fff;
}

.hero-text-wrapper {
  z-index: 10;
  flex-flow: row;
  justify-content: space-between;
  align-self: flex-start;
  width: 100%;
  padding: 200px 0px 20px;
  display: block;
  position: relative;
}

.hero-quote {
  color: #000;
  flex-flow: row;
  align-self: flex-end;
  max-width: 100%;
  margin-bottom: 0;
  padding-bottom: 0;
  font-size: 32px;
  font-weight: 700;
  line-height: 112%;
  display: block;
  position: static;
}

.selected-work {
  color: var(--black);
  align-self: flex-end;
  font-size: 24px;
  font-weight: 600;
}

.projects-flex-wrapper {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  object-fit: contain;
  border-radius: 0;
  flex: 0 auto;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  align-self: auto;
  max-width: 100%;
  padding-bottom: 240px;
  padding-left: 0;
  padding-right: 0;
  transition: all .2s ease-in-out;
  display: flex;
  position: relative;
  overflow: hidden;
}

.projects-column-wrapper {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  justify-content: space-between;
  padding-bottom: 160px;
  display: flex;
}

.project-kcpt {
  object-fit: contain;
  border-radius: 10px;
  transition: all .2s ease-in-out;
  display: block;
  position: absolute;
}

.project-kcpt:hover {
  border-radius: 20px;
}

.qonnect-23 {
  max-width: 100%;
}

.project-small {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  object-fit: fill;
  border-radius: 10px;
  flex-flow: column;
  align-items: stretch;
  width: auto;
  max-width: 37%;
  height: auto;
  max-height: none;
  display: flex;
  position: relative;
  top: 0;
  left: 0;
  overflow: hidden;
}

.div-block-2 {
  justify-content: space-between;
  display: flex;
}

.project-big {
  border-radius: 0;
  max-width: 63%;
}

.project-big:hover {
  width: auto;
  max-width: 63%;
}

.project-text {
  z-index: 15;
  color: #000;
  justify-content: space-between;
  padding-top: 4px;
  font-size: 16px;
  font-weight: 400;
  display: flex;
  position: relative;
  overflow: visible;
}

.project-title {
  font-family: Hkgroteskwide, sans-serif;
  font-size: 16px;
  font-weight: 600;
}

.project-type {
  font-family: Hkgroteskwide, sans-serif;
  font-size: 14px;
  font-weight: 500;
}

.project-title-2 {
  direction: ltr;
  color: #000;
  padding-bottom: 10px;
  font-size: 44px;
  font-style: normal;
  font-weight: 500;
  line-height: 100%;
}

.project-type-2 {
  color: #000;
  padding-top: 10px;
  padding-left: 1px;
  font-size: 28px;
  font-weight: 400;
  line-height: 100%;
}

.project-text-alt {
  align-self: center;
  padding-left: 60px;
}

.project-half {
  max-width: 50%;
}

.projects-additional-wrapper {
  flex-flow: column;
  align-self: flex-start;
  width: 100%;
  padding-bottom: 120px;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  position: relative;
}

.project-list-top {
  border-bottom: 1px solid var(--gray);
  color: #000;
  border-radius: 0;
  justify-content: space-between;
  padding-top: 10px;
  padding-bottom: 10px;
  display: flex;
  position: relative;
}

.text-block {
  color: #000;
  padding-bottom: 50px;
  font-size: 24px;
  font-weight: 600;
}

.project-list-bottom {
  justify-content: space-between;
  padding-top: 10px;
  padding-bottom: 10px;
  display: flex;
  position: relative;
}

.footer-wrapper {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  justify-content: space-between;
  padding: 20px 48px;
  display: flex;
}

.footer-social {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  color: var(--black);
  justify-content: space-between;
  align-self: center;
  width: auto;
  max-width: 50%;
  display: flex;
}

.connect {
  align-self: center;
  font-size: 12px;
  font-weight: 500;
}

.linkedin {
  align-self: center;
  max-width: 22px;
  max-height: 22px;
  transition: all .2s ease-in-out;
}

.linkedin:hover {
  max-width: 28px;
  max-height: 28px;
}

.dribbble {
  align-self: center;
  max-width: 22px;
  max-height: 22px;
  transition: all .2s ease-in-out;
}

.dribbble:hover {
  max-width: 28px;
  max-height: 28px;
}

.text-block-2 {
  color: var(--black);
  align-self: center;
  font-size: 12px;
  font-weight: 500;
}

.body {
  font-family: Hkgroteskwide, sans-serif;
}

.italic-text, .italic-text-2 {
  font-style: normal;
}

.author {
  font-size: 24px;
  font-style: normal;
  font-weight: 500;
}

.hero-quote-wrapper {
  max-width: 60%;
}

.hero-author {
  color: #000;
  -webkit-text-stroke-color: black;
  font-size: 24px;
}

.header-nav-wrapper {
  flex-flow: column;
  width: auto;
  height: auto;
  display: flex;
  position: relative;
  overflow: visible;
}

.header-full-width-image {
  height: 70vh;
  overflow: clip;
  align-items: center;
}

._2-block {
  grid-column-gap: 24px;
  grid-row-gap: 24px;
  flex-flow: row;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  align-items: center;
  margin-left: 0;
  margin-right: 0;
  padding-left: 48px;
  padding-right: 48px;
  display: grid;
}

.image, .image-2 {
  width: auto;
  max-width: 50vw;
  display: block;
}

.section {
  flex-flow: column;
  align-items: center;
  margin-left: 48px;
  margin-right: 48px;
  padding-top: 160px;
  padding-bottom: 80px;
  display: flex;
}

.section-image-row {
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  padding: 0 0 24px;
}

.image-row-wrapper {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  justify-content: center;
  align-items: center;
}

.square-img {
  width: 50%;
}

.image-3 {
  width: auto;
}

.section-nav {
  position: relative;
}

.section-image-full {
  padding-bottom: 24px;
}

.section-project-row {
  padding: 48px 120px;
}

.project-details-wrapper {
  grid-column-gap: 13px;
  grid-row-gap: 13px;
  flex-flow: column;
  display: flex;
  position: static;
}

.project-name {
  font-family: Hkgroteskwide, sans-serif;
  font-size: 18px;
  font-weight: 600;
}

.project-details {
  font-family: Hkgroteskwide, sans-serif;
  font-weight: 400;
  line-height: 20px;
}

.body-2, .body-3 {
  font-family: Hkgroteskwide, sans-serif;
}

.project-role {
  line-height: 18px;
}

.project-name-wrapper {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  flex-flow: column;
  display: flex;
}

.section-image-last {
  padding-bottom: 24px;
}

.project-nav {
  padding-top: 48px;
  padding-bottom: 48px;
}

.project-nav-wrapper {
  grid-column-gap: 44px;
  grid-row-gap: 44px;
  justify-content: center;
  align-items: center;
  font-size: 24px;
  font-weight: 500;
}

.project-nav-right a {
  all: unset;                /* Reset all browser styles */
  cursor: pointer;           /* Keep pointer behavior */
  font-size: 24px;
  font-weight: 500;
  transition: all 0.2s ease-in-out;
  text-align: right;
  color: inherit;
  display: inline-block;
}

.project-nav-right a:hover {
  font-size: 28px;
  text-decoration: underline;
}

.project-nav-left a {
  all: unset;                /* Reset all browser styles */
  cursor: pointer;           /* Keep pointer behavior */
  font-size: 24px;
  font-weight: 500;
  transition: all 0.2s ease-in-out;
  text-align: right;
  color: inherit;
  display: inline-block;
}

.project-nav-left a:hover {
  font-size: 28px;
  text-decoration: underline;
}

.section-image-row-last {
  padding-bottom: 24px;
}

.project-otp {
  border-radius: 10px;
  transition: all .2s ease-in-out;
}

.project-otp:hover {
  border-radius: 20px;
  max-width: 100%;
}

.project-list-qonnect-22 {
  border-bottom: 1px solid var(--gray);
  justify-content: space-between;
  padding-top: 10px;
  padding-bottom: 10px;
  display: flex;
  position: relative;
  left: auto;
}

.project-list-building-buddy {
  border-bottom: 1px solid var(--gray);
  justify-content: space-between;
  padding-top: 10px;
  padding-bottom: 10px;
  display: flex;
  position: relative;
}

.hero-brands, .hero-their-campaigns {
  font-weight: 700;
}

.hero-leader {
  position: relative;
}

.image-4 {
  width: 300px;
}

.hero-leader-gif-wrapper {
  border-radius: 10px;
  transition: all .2s ease-in-out;
  display: block;
  position: absolute;
  inset: 28% auto auto 54%;
}

.hero-leader-gif {
  border-radius: 10px;
  width: 310px;
}

.project-list-49ers-wrapper {
  border: 1px #000;
  border-radius: 0;
  position: absolute;
  inset: -16% auto auto 44%;
}

.project-list-thumb {
  border-radius: 10px;
  width: 280px;
}

.project-list-qonnect-22-wrapper {
  position: absolute;
  top: -4%;
  left: 40%;
}

.project-list-building-buddy-wrapper {
  position: absolute;
  top: 8%;
  left: 48%;
}

.project-list-nextpage-wrapper {
  position: absolute;
  top: 20%;
  left: 42%;
}

.hero-brands-gif-wrapper {
  width: 360px;
  transition: all .2s ease-in-out;
  position: absolute;
  top: 16%;
  left: 48%;
}

.hero-campaigns-gif-wrapper {
  width: 360px;
  transition: all .2s ease-in-out;
  position: absolute;
  top: 38%;
  left: 50%;
}

.home-nav {
  position: relative;
}

.home-nav:hover {
  font-size: 22px;
}

.section-about {
  position: static;
}

.about-me {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.about-me-header {
  color: #000;
  text-align: center;
}

.about-paragraph {
  text-align: left;
  justify-content: center;
  align-items: stretch;
  max-width: 800px;
  padding: 36px 120px;
  display: block;
}

.image-5 {
  height: auto;
  overflow: clip;
}

.text-block-3 {
  padding-left: 120px;
  padding-right: 120px;
}

.paragraph {
  justify-content: center;
  align-items: flex-start;
  max-width: 820px;
  padding-top: 40px;
  padding-bottom: 40px;
  display: flex;
}

.experience-section {
  box-sizing: border-box;
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  color: #000;
  flex-flow: column;
  justify-content: flex-start;
  align-self: flex-start;
  align-items: flex-start;
  width: auto;
  max-width: 820px;
  margin-bottom: 20px;
  display: flex;
  position: static;
  overflow: visible;
}

.heading {
  color: #000;
  text-align: left;
  margin-top: 0;
  margin-bottom: 0;
}

.experience-heading {
  color: #000;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  max-width: 820px;
  margin-top: 0;
  margin-bottom: 0;
  display: block;
  position: static;
}

.about-intro {
  flex-flow: column;
  justify-content: flex-start;
  align-self: flex-start;
  align-items: center;
  display: flex;
}

.heading-2 {
  color: #000;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 22px;
}

.resume-company {
  margin-bottom: 8px;
}

.resume-description {
  justify-content: center;
  padding-bottom: 0;
  display: flex;
}

.heading-3 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 16px;
}

.paragraph-2 {
  margin-bottom: 0;
}

.paragraph-3 {
  margin-top: 10px;
}

.list {
  margin-bottom: 0;
  padding-bottom: 0;
  padding-left: 14px;
  line-height: 20px;
}

.experience {
  max-width: 820px;
  margin-top: 0;
  margin-bottom: 0;
}

.rich-text-block {
  -webkit-text-stroke-color: var(--black);
  padding-bottom: 0;
}

.rich-text-block-2 {
  display: block;
}

.education-section {
  box-sizing: border-box;
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  aspect-ratio: auto;
  flex-flow: column;
  flex: 0 auto;
  justify-content: flex-start;
  align-self: flex-start;
  align-items: flex-start;
  width: auto;
  max-width: 820px;
  margin-top: 20px;
  margin-bottom: 20px;
  display: flex;
  position: static;
}

.skills-section {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  align-self: flex-start;
  margin-top: 20px;
  margin-bottom: 20px;
  display: flex;
}

.skills-wrapper {
  grid-column-gap: 48px;
  grid-row-gap: 48px;
  flex-flow: row;
  justify-content: flex-start;
}

.list-2 {
  width: auto;
}

.project-video-hover {
  z-index: 10;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 20px;
  justify-content: flex-start;
  align-items: flex-start;
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: none;
  padding-bottom: 0;
  display: block;
  position: absolute;
  inset: 0 auto 0%;
  overflow: hidden;
}

.kcpt-video {
  box-sizing: border-box;
  aspect-ratio: 1800 / 1013;
  object-fit: fill;
  object-position: 50% 50%;
  border: 1px #000;
  border-radius: 20px;
  width: 100%;
  min-width: auto;
  max-width: 100%;
  min-height: auto;
  max-height: 100%;
  display: flex;
  position: static;
  overflow: hidden;
}

.kcpt-video-hover {
  aspect-ratio: 16 / 9;
  object-fit: contain;
  border-radius: 20px;
  width: auto;
  max-width: 100%;
  display: block;
  position: relative;
}

.play-state, .pause-state {
  display: block;
}

.video {
  object-fit: cover;
  border-radius: 20px;
  overflow: hidden;
}

.kcpt-hover {
  z-index: 10;
  object-fit: contain;
  border-radius: 20px;
  width: 100%;
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  overflow: visible;
}

.project-images {
  position: relative;
}

.kcpt {
  z-index: 5;
  object-fit: cover;
  border-radius: 10px;
  width: auto;
  height: auto;
  min-height: 0;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  overflow: visible;
}

.image-wrapper {
  object-fit: cover;
  border-radius: 10px;
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: 100%;
  position: relative;
  overflow: hidden;
}

.image-6 {
  border-radius: 0;
  overflow: visible;
}

.image-7 {
  border-radius: 10px;
}

.img-home {
  z-index: 8;
  border-radius: 10px;
  transition: all .2s ease-in-out;
  display: block;
  position: relative;
}

.img-home:hover {
  z-index: 2;
  border-radius: 20px;
  display: block;
}

.img-home-hover {
  z-index: 5;
  border-radius: 20px;
  display: block;
  position: absolute;
}

.img-home-hover:hover {
  border-radius: 20px;
  overflow: clip;
}

.img-home-scale {
  z-index: 10;
  border-radius: 10px;
  transition: all .2s ease-in-out;
  display: block;
  position: relative;
}

.img-home-scale:hover {
  z-index: 2;
  border-radius: 20px;
  display: block;
}

.scale-video {
  aspect-ratio: 1920 / 1080;
  object-fit: fill;
  border-radius: 10px;
  max-width: 100%;
  overflow: clip;
}

.scale-video:hover {
  border-radius: 20px;
}

.project-video-bg {
  aspect-ratio: auto;
  object-fit: cover;
  border-radius: 10px;
  flex-flow: row;
  width: 100%;
  max-width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
}

.homepage-video-wrapper {
  aspect-ratio: 16 / 9;
  object-fit: contain;
  width: 100%;
  max-width: 100%;
  height: auto;
}

.project-row-wrapper {
  display: flex;
  justify-content: flex-start;
  gap:20px
  padding-bottom: 240px;
  width: 100%; /* 48px gap on left/right */
  display: flex;
  position: static;
}

.project-big-wrapper {
  flex-flow: column;
  max-width: 63%;
  display: flex;
}

.project-small-wrapper {
  flex-flow: column;
  max-width: 37%;
  display: flex;
}

.project-image-wrapper {
  border-radius: 10px;
  max-width: 100%;
  transition: all .2s ease-in-out;
  overflow: visible;
}

.project-img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 10px;
  transition: all 0.2s ease-in-out;
}

.project-img:hover {
  border-radius: 20px;
}


@media screen and (max-width: 991px) {
  .hero-text-wrapper {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    padding-top: 200px;
    padding-left: 20px;
    padding-right: 20px;
    display: none;
  }

  .hero-quote {
    flex-flow: row;
    padding-right: 0;
    display: none;
  }

  .selected-work {
    margin-left: 100px;
    padding-left: 0;
  }

  .projects-flex-wrapper {
    max-width: 100%;
    padding-bottom: 120px;
  }

  .project-big {
    flex-flow: column;
    width: 100%;
    display: flex;
    overflow: hidden;
  }

  .project-big:hover {
    width: 100%;
  }

  .project-list-bottom {
    flex-flow: row;
  }

  .header-full-width-image {
    justify-content: center;
    align-items: flex-start;
    width: auto;
    height: auto;
    display: flex;
  }

  ._2-block {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
  }

  .section-image-row {
    padding-left: 0;
    padding-right: 0;
  }

  .scale-video {
    aspect-ratio: 1800 / 1018;
    object-fit: cover;
    width: 100%;
    max-width: 100%;
    height: 100%;
    display: block;
    overflow: clip;
  }
}
/* === Fix flicker on hover-reveal project thumbnails === */
.project-list-49ers-wrapper,
.project-list-qonnect-22-wrapper,
.project-list-building-buddy-wrapper,
.project-list-nextpage-wrapper {
  pointer-events: none !important;
}

.projects-additional-wrapper {
  position: relative;
}

.project-item {
  display: block;
  text-decoration: none;
  color: inherit;
  position: relative;
  padding: 1rem 0;
}

.project-hover-image {
  display: none;
  position: absolute;
  top: 0;
  right: -420px; /* adjust as needed */
  width: 400px;
  z-index: 80;
}

.project-hover-image img {
  width: 100%;
  height: auto;
}

.project-link {
  text-decoration: none;
  color: inherit;
  display: block; /* ensures link fills the area */
}


@media screen and (max-width: 767px) {
  .home-title:where(.w-variant-02634eb2-240b-7ce4-a727-fe511c7bd59b) {
    font-size: 14px;
  }

  .home-title.w--current {
    font-size: 16px;
  }

  .nav-name {
    font-size: 18px;
  }

  .projects-flex-wrapper {
    padding-bottom: 100px;
  }

  .project-text {
    flex-flow: row;
    justify-content: space-between;
    max-width: 100%;
  }

  .project-type {
    text-align: right;
    font-size: 12px;
  }

  .section-project-row {
    padding-left: 60px;
    padding-right: 60px;
  }

  .project-nav-right, .project-nav-left {
    font-size: 18px;
  }

  .scale-video {
    height: 100%;
  }
}

@media screen and (max-width: 479px) {
  .nav-wrapper {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    flex-flow: row;
    justify-content: space-between;
    align-items: center;
    padding-left: 20px;
    padding-right: 40px;
    display: flex;
  }

  .nav-wrapper:where(.w-variant-02634eb2-240b-7ce4-a727-fe511c7bd59b) {
    grid-column-gap: 29px;
    grid-row-gap: 29px;
    flex-flow: row;
    justify-content: space-between;
    align-items: center;
    padding-left: 20px;
    padding-right: 20px;
    display: flex;
  }

  .nav-links {
    grid-column-gap: 4px;
    grid-row-gap: 4px;
    flex-flow: column;
    justify-content: space-between;
  }

  .nav-links:where(.w-variant-02634eb2-240b-7ce4-a727-fe511c7bd59b) {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    flex-flow: column;
    font-size: 12px;
  }

  .home-title {
    font-size: 9px;
    line-height: 12px;
  }

  .home-title:where(.w-variant-02634eb2-240b-7ce4-a727-fe511c7bd59b) {
    text-align: left;
    font-size: 12px;
    line-height: 14px;
  }

  .home-title.w--current {
    width: Infinity% ;
    font-size: 9px;
    line-height: 12px;
  }

  .nav-link {
    text-align: right;
    font-size: 14px;
    line-height: 12px;
  }

  .nav-link:where(.w-variant-02634eb2-240b-7ce4-a727-fe511c7bd59b) {
    padding-top: 0;
    font-size: 12px;
  }

  .nav-name {
    font-size: 12px;
  }

  .nav-name:where(.w-variant-02634eb2-240b-7ce4-a727-fe511c7bd59b) {
    text-align: center;
    font-size: 14px;
    line-height: 14px;
  }

  .hero-text-wrapper {
    width: 80%;
  }

  .projects-flex-wrapper {
    flex-flow: column;
    padding-bottom: 20px;
  }

  .project-small {
    max-width: 100%;
  }

  .project-big {
    max-width: 100%;
    position: relative;
    overflow: visible;
  }

  .project-big:hover {
    max-width: 100%;
  }

  .project-title {
    font-size: 14px;
  }

  .project-type {
    text-align: right;
    align-self: flex-start;
  }

  .projects-additional-wrapper {
    padding-top: 60px;
    padding-bottom: 60px;
  }

  .header-nav-wrapper {
    grid-column-gap: 7px;
    grid-row-gap: 7px;
    flex-flow: row;
    grid-template-rows: auto auto;
    grid-template-columns: 1fr 1fr;
    grid-auto-columns: 1fr;
    justify-content: space-between;
    display: flex;
  }

  .section {
    margin-left: 20px;
    margin-right: 20px;
    padding-top: 140px;
    padding-bottom: 40px;
  }

  .section-image-row {
    padding-left: 0;
    padding-right: 0;
  }

  .image-row-wrapper {
    flex-flow: column;
  }

  .square-img {
    width: 100%;
  }

  .section-nav {
    flex-flow: row;
    justify-content: space-between;
    display: flex;
    z-index: 110;
  }

  .section-project-row {
    flex-flow: column;
    padding: 20px;
    display: flex;
  }

  .project-role {
    align-self: flex-start;
  }

  .project-nav-wrapper {
    grid-column-gap: 30px;
    grid-row-gap: 30px;
    padding-left: 40px;
    padding-right: 40px;
  }

  .project-nav-right {
    font-size: 12px;
    line-height: 16px;
    display: block;
  }

  .project-nav-left {
    font-size: 12px;
    line-height: 16px;
  }

  .project-list-49ers-wrapper, .project-list-qonnect-22-wrapper, .project-list-building-buddy-wrapper, .project-list-nextpage-wrapper {
    display: none;
  }

  .img-home {
    width: 100%;
  }

  .img-home:hover {
    width: 100%;
    height: auto;
    overflow: clip;
  }

  .scale-video {
    width: 100%;
    height: 100%;
  }
}
.project-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.project-list-49ers-wrapper img {
  position: relative;
  top: -30px;
  left: -15px;
}

.project-img {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}

.additional-projects{
  flex-flow: column;
  align-items: center;
  margin-left: 48px;
  margin-right: 48px;
  padding-top: 120px;
  padding-bottom: 80px;
  display: flex;
}

.project-row-wrapper {
  display: flex;
  gap: 20px;
}




@font-face {
  font-family: 'Hkgroteskwide';
  src: url('../fonts/HKGroteskWide-SemiBold.otf') format('opentype');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Hkgroteskwide';
  src: url('../fonts/HKGroteskWide-Light.otf') format('opentype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Hkgroteskwide';
  src: url('../fonts/HKGroteskWide-Bold.otf') format('opentype'), url('../fonts/HKGroteskWide-ExtraBold.otf') format('opentype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Hkgroteskwide';
  src: url('../fonts/HKGroteskWide-Medium.otf') format('opentype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Hkgroteskwide';
  src: url('../fonts/HKGroteskWide-Black.otf') format('opentype');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Hkgroteskwide';
  src: url('../fonts/HKGroteskWide-Regular.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

.project-image-wrapper {
  width: 100%;
  aspect-ratio: 16 / 9; /* or whatever your ratio is */
  overflow: hidden;
  position: relative;
}

.project-image-wrapper img,
.project-image-wrapper video {
  width: 100%;
  height: 100%;
  object-fit: cover; /* ensures the media covers the container without stretching */
  display: block;
}
.project-image-wrapper {
  width: 100%;
  aspect-ratio: 16 / 9; /* or your actual aspect ratio */
  overflow: hidden;
  position: relative;
}

.project-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  display: block; /* critical for images */
}
.project-big-wrapper, {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  max-width: 63%; /* or 37% for small */
}
.project-small-wrapper, {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  max-width: 37%; /* or 37% for small */
}
.project-row-wrapper.reverse {
  flex-direction: row-reverse;
}

.project-row-wrapper,
.project-row-wrapper.reverse {
  display: flex;
  gap: 20px; /* spacing between big and small wrappers */
  padding-bottom: 240px;
}

.projects {
  padding: 0 48px;
     z-index: 2;
}

.w-nav-menu {
  display: block !important;
  opacity: 1 !important;
  z-index: 999 !important;
}
.hero-brands,
.hero-their-campaigns {
  position: relative;
  display: inline-block;
}


.hero-gradient {
  background: repeating-linear-gradient(
    90deg,
    #0059ff 0%,
    #000000 20%,
    #0059ff 40%,
    #000000 60%,
    #0059ff 80%
  );
  background-size: 300% 100%;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  white-space: nowrap;
  animation-fill-mode: forwards;
}

.hero-their-campaigns {
  animation: seamlessGradient 10s linear forwards, fadeToBlack 3s linear 2s forwards;
}

.hero-brands {
  animation: seamlessGradient 10s linear forwards, fadeToBlack 3s linear 2s forwards;
  animation-delay: 1s;
}

@keyframes seamlessGradient {
  0% {
    background-position: 0% 0%;
    color: transparent;
  }
  100% {
    background-position: 400% 0%;
    color: transparent;
  }
}

@keyframes fadeToBlack {
  0% {
    color: transparent;
    -webkit-text-fill-color: transparent; /* for Safari */
  }
  100% {
    color: black;
    -webkit-text-fill-color: black; /* for Safari */
  }
}


.hero-and {
  color: #000;
}

.video-wrapper {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; /* 16:9 ratio */
  height: 0;
  overflow: hidden;
}

.video-wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}


.section-image-full {
  width: 100%;
}

.image-full-wrapper {
  width: 100%;
}

.full-img {
  width: 100%;
}

.full-img img {
  width: 100%;
  height: auto;
  display: block; /* prevents inline spacing */
}
.square-img {
  width: 100%;
}

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