/* v3 experiments — loaded on top of v2 */

.services {
  position: relative;
  top: 0;
  z-index: 1;
  min-height: 879px;
  --svc-card-scale: 0.8;
  --svc-inactive-card-lift: 50px;
  --svc-active-build-lift: 20px;
  --svc-active-ux-lift: 20px;
  --svc-active-revamp-lift: 85px;
  --svc-active-design-system-lift: 85px;
  --svc-active-strategic-lift: 85px;
  --svc-active-build-shift-x: 35px;
  --svc-active-ux-shift-x: 61px;
  --svc-inactive-build-shift-x: 24px;
  --svc-inactive-ux-shift-x: 44px;
  --svc-inactive-strategic-lift-extra: 30px;
  --svc-inactive-strategic-shift-x: 35px;
}

.svc-card {
  transform-origin: top left;
}

.services__inner {
  top: 30px;
}

.engagement {
  position: relative;
  z-index: 2;
}

.engagement__card--cobuild .engagement__bullet,
.engagement__card--fixed .engagement__bullet {
  font-size: 20px;
}

.engagement__card--cobuild .engagement__tick,
.engagement__card--fixed .engagement__tick {
  width: 20px;
  height: 20px;
  display: block;
}

.engagement__card--cobuild {
  background: #fafafa;
  border: 1px solid var(--orange);
  gap: 68px;
  padding: 72px 48px;
}

.engagement__card--cobuild .engagement__card-name {
  color: var(--dark);
}

.engagement__card--cobuild .engagement__card-desc,
.engagement__card--cobuild .engagement__bullet {
  color: var(--grey);
}

.engagement__card-panel--cobuild {
  width: 425px;
  min-width: 425px;
  min-height: 274px;
  padding: 0;
  background: transparent;
}

.engagement__card-panel--cobuild .engagement__card-illus {
  width: 100%;
  max-width: 100%;
}

.engagement__card--fixed {
  background: #fafafa;
  border: 1px solid var(--accent-yellow);
  gap: 68px;
  padding: 72px 48px;
}

.engagement__card--fixed .engagement__card-name {
  color: var(--dark);
}

.engagement__card--fixed .engagement__card-desc,
.engagement__card--fixed .engagement__bullet {
  color: var(--grey);
}

.engagement__card-panel--fixed {
  width: 425px;
  min-width: 425px;
  min-height: 274px;
  padding: 0;
  background: transparent;
}

.engagement__card-panel--fixed .engagement__card-illus {
  width: 100%;
  max-width: 100%;
}

.services__stage:not(.services__stage--active) {
  border-left: none;
  border-right: none;
}

.services__stage:not(:first-child):not(.services__stage--active) {
  border-left: 0.5px solid #4c4c4c;
}

/* ============================================================
   CTA hover states from Figma
   ============================================================ */
.cta__btn,
.cta__dot,
.cta__btn--secondary-inner,
.transform-cta__submit-label,
.transform-cta__submit-dots span {
  transition:
    background-color 180ms ease,
    color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.cta:hover .cta__btn {
  transform: none;
  box-shadow: none;
}

.cta:hover .cta__dot {
  background: #171717;
}

.cta:hover .cta__btn--primary {
  background: #171717;
  color: #ffffff;
}

.cta--sm:hover .cta__btn {
  background: #000000;
  color: #ffffff;
}

.cta:hover .cta__btn--secondary {
  background: #fafafa;
  color: #ffffff;
}

.cta:hover .cta__btn--secondary-inner {
  background: #000000;
  color: #ffffff;
}

.transform-cta__submit:hover .transform-cta__submit-label,
.transform-cta__submit:focus-visible .transform-cta__submit-label {
  background: #000000;
  color: #ffffff;
}

.transform-cta__submit:hover .transform-cta__submit-dots span,
.transform-cta__submit:focus-visible .transform-cta__submit-dots span {
  background: #171717;
}

/* ============================================================
   Section 7 - Transform CTA
   ============================================================ */
.transform-cta {
  position: relative;
  z-index: 3;
  background: transparent;
  padding: 50px 0 0;
  margin-bottom: -200px;
}

.transform-cta::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: calc(100% - 200px);
  background: #ffffff;
  z-index: -1;
}

.transform-cta__card {
  width: 1240px;
  min-height: 525px;
  margin: 0 auto;
  display: flex;
  align-items: stretch;
  overflow: hidden;
  background: #ffffff;
  border-radius: 10px;
  box-shadow:
    -2px -2px 24px rgba(0, 0, 0, 0.1),
    2px 2px 4px rgba(0, 0, 0, 0.1);
}

.transform-cta__content {
  width: 588px;
  padding: 104px 44px 64px 48px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 40px;
  flex-shrink: 0;
}

.transform-cta__heading {
  margin: 0;
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 48px;
  line-height: 1.24;
  color: #1d1d1d;
}

.transform-cta__heading span,
.transform-cta__heading em {
  display: block;
}

.transform-cta__heading em {
  color: var(--orange);
  font-style: italic;
}

.transform-cta__form {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.transform-cta__label {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 18px;
  line-height: 1.4;
  color: var(--grey);
}

.transform-cta__field {
  width: 100%;
  height: 66px;
  padding: 9px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border: 0.9px solid #fdcbbc;
  border-radius: 10px;
  background: #ffffff;
}

.transform-cta__input {
  min-width: 0;
  flex: 1;
  border: 0;
  outline: 0;
  background: transparent;
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 18px;
  color: #1d1d1d;
}

.transform-cta__input::placeholder {
  color: #1d1d1d;
  opacity: 1;
}

.transform-cta__submit {
  width: 161px;
  height: 41.4px;
  padding: 0;
  border: 0;
  display: flex;
  align-items: center;
  gap: 2.3px;
  background: transparent;
  cursor: pointer;
  flex-shrink: 0;
}

.transform-cta__submit-label {
  width: 147.2px;
  height: 41.4px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--orange);
  font-family: var(--font-sans);
  font-size: 20.7px;
  line-height: 1;
  color: #ffffff;
}

.transform-cta__submit-dots {
  width: 4.6px;
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.transform-cta__submit-dots span {
  width: 4.6px;
  height: 4.6px;
  background: var(--orange);
}

.transform-cta__visual {
  width: 652px;
  min-height: 525px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0 10px 10px 0;
  overflow: hidden;
}

.transform-cta__image {
  width: 652px;
  height: 525px;
  object-fit: cover;
  display: block;
}

/* ============================================================
   Footer
   ============================================================ */
.site-footer {
  position: relative;
  z-index: 2;
  background: #080200;
  padding: 280px 100px 18px;
  color: #ffffff;
}

.site-footer__inner {
  width: 1240px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 29px;
}

.site-footer__top {
  width: 1194px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

.site-footer__brand {
  width: 265px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.site-footer__logo {
  width: 133px;
  height: 41px;
  display: block;
  margin-bottom: 20px;
}

.site-footer__tagline {
  margin: 0 0 17px;
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.25;
  color: #ffffff;
}

.site-footer__email {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.25;
  color: #ffffff;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.site-footer__links {
  width: 287px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

.site-footer__nav {
  width: 72px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.site-footer__nav a {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 18px;
  line-height: 1.2;
  color: #ffffff;
}

.site-footer__socials {
  display: flex;
  flex-direction: column;
  gap: 17px;
}

.site-footer__social {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.25;
  color: #ffffff;
  white-space: nowrap;
}

.site-footer__social-icon {
  width: 34.25px;
  height: 34.25px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 0.43px solid rgba(189, 189, 189, 0.5);
  border-radius: 2px;
  flex-shrink: 0;
}

.site-footer__social-icon img {
  width: 34.25px;
  height: 34.25px;
  display: block;
}

.site-footer__wordmark {
  width: 1240px;
  height: 147px;
  display: block;
  margin-top: 36px;
}

.site-footer__copyright {
  margin: 0;
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 20px;
  line-height: 1.25;
  color: var(--grey);
  text-align: center;
}

.roles-mobile {
  display: none;
}

.hero__mobile-break {
  display: none;
}

.portfolio__mobile-cta {
  display: none;
}

.values__heading-line,
.values__heading-accent {
  display: block;
}

.values__heading-line {
  white-space: nowrap;
}

.portfolio__heading-primary {
  color: var(--orange);
}

/* ============================================================
   Fluid desktop layout
   Keeps the 1440px design proportions while allowing every
   desktop width to scale inside the viewport instead of clipping.
   ============================================================ */
@media (min-width: 768px) {
  :root {
    --page-gutter: clamp(40px, 7.25vw, 104px);
    --content-max: 1240px;
    --content-width: min(var(--content-max), calc(100vw - (var(--page-gutter) * 2)));
  }

  .header__inner,
  .hero__content,
  .roles__inner,
  .values__inner,
  .portfolio__inner,
  .engagement__inner,
  .site-footer__inner {
    width: var(--content-width);
    max-width: var(--content-max);
  }

  .header__inner {
    padding: 0;
  }

  .header__right {
    gap: clamp(36px, 8.68vw, 125px);
  }

  .header__nav {
    gap: clamp(24px, 4.17vw, 60px);
  }

  .header__nav-link {
    font-size: clamp(17px, 1.39vw, 20px);
  }

  .hero {
    height: clamp(620px, 52vw, 797px);
  }

  .hero__content {
    max-width: none;
    margin-top: clamp(140px, 13.6vw, 215px);
  }

  .hero__headline-line {
    font-size: clamp(58px, 6.18vw, 94.472px);
  }

  .hero__tagline {
    font-size: clamp(19px, 1.67vw, 24px);
  }

  .roles__inner,
  .values__inner,
  .portfolio__inner,
  .engagement__inner {
    padding-left: 0;
    padding-right: 0;
  }

  .roles__layout {
    gap: clamp(32px, 4.4vw, 63.36px);
  }

  .roles__anim {
    width: min(51.52vw, 638.88px);
    height: auto;
    aspect-ratio: 638.88 / 460.24;
  }

  .roles__accordion {
    min-width: min(320px, 44vw);
  }

  .values__grid,
  .portfolio__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .values__icon-wrap {
    width: min(100%, 343px);
  }

  .values__card--founding {
    flex-basis: clamp(300px, 29.03vw, 360px);
  }

  .values__card--orange {
    min-height: clamp(520px, 50.48vw, 626px);
  }

  .values__card-badge {
    width: clamp(190px, 19.84vw, 246px);
    height: clamp(190px, 19.84vw, 246px);
  }

  .values__card-badge img {
    width: 68%;
    height: 68%;
  }

  .values__card--motion {
    flex-basis: clamp(236px, 22.74vw, 282px);
  }

  .portfolio__card {
    height: clamp(410px, 38vw, 523px);
  }

  .portfolio__card-image {
    top: clamp(150px, 13.9vw, 192px);
    width: min(514px, calc(100% + clamp(80px, 9vw, 112px)));
    height: clamp(260px, 26.5vw, 367px);
  }

  .services {
    min-height: clamp(680px, 56vw, 879px);
    --services-content-left: max(var(--page-gutter), calc((100vw - var(--content-max)) / 2));
    --services-card-shift-x: clamp(0px, 4.38vw, 63px);
    --svc-card-scale: clamp(0.62, 5.25vw, 0.8);
  }

  .services__inner {
    left: var(--services-content-left);
    width: var(--content-width);
    max-width: var(--content-max);
  }

  .services__selector-wrap,
  .services__stages {
    width: 100%;
  }

  .services__stage {
    padding-left: clamp(12px, 1.39vw, 20px);
    padding-right: clamp(12px, 1.39vw, 20px);
  }

  .services__stage-sub {
    font-size: clamp(14px, 1.25vw, 18px);
  }

  .transform-cta__card {
    width: var(--content-width);
    max-width: var(--content-max);
  }

  .transform-cta__content {
    width: 47.42%;
    padding:
      clamp(72px, 8.39vw, 104px)
      clamp(28px, 3.55vw, 44px)
      clamp(48px, 5.16vw, 64px)
      clamp(32px, 3.87vw, 48px);
  }

  .transform-cta__heading {
    font-size: clamp(36px, 3.87vw, 48px);
  }

  .transform-cta__visual {
    flex: 1;
    width: auto;
  }

  .transform-cta__image {
    width: 100%;
    height: 100%;
  }

  .site-footer {
    padding-left: var(--page-gutter);
    padding-right: var(--page-gutter);
  }

  .site-footer__top,
  .site-footer__wordmark {
    width: 100%;
  }
}

/* ============================================================
   Mobile - Hero section
   Breakpoint: 430px and below
   ============================================================ */
@media (min-width: 431px) and (max-width: 767px) {
  html,
  body {
    width: 100%;
    overflow-x: hidden;
  }

  .header {
    height: 88px;
    align-items: center;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(25px);
    -webkit-backdrop-filter: blur(25px);
  }

  .header::before {
    display: none;
  }

  .header__inner {
    width: 100%;
    max-width: none;
    padding: 0 clamp(20px, 6vw, 48px);
    margin-top: 0;
  }

  .header__logo img {
    width: 130px;
    height: auto;
  }

  .header__nav,
  .header .cta {
    display: none;
  }

  .header__right {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
  }

  .header__right::before {
    content: '';
    width: 28px;
    height: 20px;
    display: block;
    background:
      linear-gradient(var(--orange), var(--orange)) 0 0 / 28px 2px no-repeat,
      linear-gradient(var(--orange), var(--orange)) 0 9px / 28px 2px no-repeat,
      linear-gradient(var(--orange), var(--orange)) 0 18px / 28px 2px no-repeat;
  }

  .hero {
    min-height: clamp(746px, 110vw, 860px);
    height: auto;
    padding: clamp(130px, 21vw, 168px) clamp(28px, 8vw, 64px) 56px;
    align-items: flex-start;
    background: #ffffff;
  }

  .hero__bg {
    background-image: url('Mobile Hero Background.png');
    background-size: 100% 116.2%;
    background-position: center -12.68%;
    opacity: 0.3;
  }

  .hero__bg svg {
    display: none;
  }

  .hero__content {
    width: 100%;
    max-width: 520px;
    margin-top: 0;
    gap: 25px;
  }

  .hero__headline,
  .hero__tagline {
    width: min(100%, 520px);
  }

  .hero__headline h1 {
    display: flex;
    flex-direction: column;
    gap: 7px;
    margin: 0;
    width: min(100%, 520px);
  }

  .hero__headline-line {
    font-size: clamp(60px, 13.5vw, 84px);
    line-height: 1;
    letter-spacing: 0;
  }

  .hero__headline-line:last-child {
    line-height: normal;
    margin-top: -1px;
  }

  .hero__mobile-break {
    display: block;
  }

  .hero__tagline {
    font-size: 20px;
    line-height: 1.28;
    color: var(--grey);
  }

  .hero__ctas {
    width: min(100%, 520px);
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 20px;
  }

  .hero__ctas .cta--conversation {
    order: 1;
  }

  .hero__ctas .cta--portfolio {
    order: 2;
  }

  .hero__ctas .cta {
    width: 100%;
    height: 70px;
    align-items: center;
  }

  .hero__ctas .cta__dots {
    width: 5px;
    height: 70px;
    gap: 60px;
  }

  .hero__ctas .cta__dot {
    width: 5px;
    height: 5px;
  }

  .hero__ctas .cta__btn {
    width: calc(100% - 14px);
    height: 60px;
    font-size: 20px;
    transform: none;
    box-shadow: none;
  }

  .hero__ctas .cta__btn--primary {
    padding: 0;
  }

  .hero__ctas .cta__btn--secondary {
    background: #ffffff;
  }

  .hero__ctas .cta__btn--secondary-inner {
    width: calc(100% - 10px);
    height: 51px;
    margin: 4px 5px;
    padding: 0;
  }

  .hero__bottom-fade {
    display: none;
  }

  .values {
    background: #fafafa;
  }

  .values__inner {
    width: 100%;
    max-width: none;
    padding: 56px clamp(28px, 8vw, 64px);
  }

  .values__heading {
    width: min(100%, 420px);
    font-size: clamp(28px, 6.2vw, 40px);
    line-height: 1.25;
    letter-spacing: 0;
    margin: 0 0 32px;
  }

  .values__heading-line,
  .values__heading-accent {
    display: block;
  }

  .values__heading-line {
    white-space: nowrap;
  }

  .values__grid {
    display: flex;
    flex-direction: column;
    gap: 24px;
    width: min(100%, 520px);
  }

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

  .values__card {
    width: 100%;
    flex: none;
    min-height: auto;
    border-radius: 8px;
    padding: 24px 20px;
    align-items: flex-start;
    overflow: hidden;
  }

  .values__card-body {
    max-width: 320px;
    gap: 8px;
    margin: 0;
    position: relative;
    z-index: 2;
  }

  .values__card-title {
    font-size: 20px;
    line-height: 1;
  }

  .values__card-desc {
    font-size: 16px;
    line-height: 1.32;
  }

  .values__icon-wrap {
    width: 100%;
    flex: none;
    margin: 20px 0 0;
  }

  .values__icon {
    max-height: none;
  }

  .values__card--founding {
    height: clamp(328px, 62vw, 390px);
  }

  .values__card--founding .values__card-desc {
    max-width: 266px;
  }

  .values__card--founding .values__icon-wrap {
    align-items: flex-end;
    justify-content: center;
  }

  .values__card--founding .values__icon {
    width: min(100%, 317px);
  }

  .values__card--prompt {
    height: clamp(244px, 45vw, 292px);
    position: relative;
  }

  .values__card--prompt .values__card-body {
    max-width: 266px;
    margin-left: 0;
  }

  .values__card--prompt .values__card-desc {
    max-width: 172px;
  }

  .values__card--prompt .values__icon-wrap {
    position: absolute;
    right: 20px;
    bottom: 24px;
    width: min(48%, 174px);
    margin: 0;
  }

  .values__card--prompt .values__icon {
    width: 100%;
  }

  .values__card--orange {
    height: clamp(432px, 76vw, 500px);
    padding: 24px 20px;
  }

  .values__card--orange .values__card-body {
    max-width: 266px;
  }

  .values__card-badge {
    width: clamp(228px, 46vw, 280px);
    height: clamp(228px, 46vw, 280px);
  }

  .values__card-badge img {
    width: 74%;
    height: 74%;
  }

  .values__card--motion {
    height: clamp(271px, 48vw, 330px);
  }

  .values__card--motion .values__card-body {
    max-width: 319px;
  }

  .values__card--motion .values__icon-wrap {
    justify-content: center;
    align-items: flex-end;
  }

  .values__card--motion .values__icon {
    width: 100%;
  }

  .values__card--business {
    height: clamp(319px, 56vw, 380px);
    position: relative;
  }

  .values__card--business .values__card-body {
    max-width: 266px;
  }

  .values__card--business .values__icon-wrap {
    justify-content: flex-end;
    align-items: flex-end;
    margin-top: 14px;
  }

  .values__card--business .values__icon {
    width: min(98.4%, 319px);
  }

  .portfolio {
    background: #fafafa;
  }

  .portfolio__inner {
    width: 100%;
    max-width: none;
    padding: 56px clamp(28px, 8vw, 64px);
    gap: 44px;
  }

  .portfolio__header {
    display: block;
  }

  .portfolio__heading {
    width: min(100%, 420px);
    font-size: clamp(28px, 6.2vw, 40px);
    line-height: 1.18;
    letter-spacing: 0;
  }

  .portfolio__heading-primary {
    color: var(--orange);
  }

  .portfolio__heading br {
    display: none;
  }

  .portfolio__header .cta {
    display: none;
  }

  .portfolio__grid {
    display: flex;
    flex-direction: column;
    gap: 20px;
    width: min(100%, 520px);
  }

  .portfolio__card {
    width: 100%;
    height: clamp(440px, 78vw, 520px);
    padding: 20px;
    border-radius: 10px;
  }

  .portfolio__card-body {
    gap: 8px;
    width: 100%;
  }

  .portfolio__card-title {
    font-size: 20px;
    line-height: normal;
  }

  .portfolio__card-desc {
    width: min(100%, 330px);
    font-size: 16px;
    line-height: 1.375;
  }

  .portfolio__card-tags {
    gap: 8px;
  }

  .portfolio__tag {
    font-size: 16px;
    padding: 3px 12px;
  }

  .portfolio__card-image {
    left: 20px;
    top: 164px;
    width: 141.1%;
    height: calc(100% - 164px);
  }

  .portfolio__card-image img {
    border-radius: 0;
    object-fit: cover;
    object-position: left top;
  }

  .portfolio__card-image picture {
    width: 100%;
    height: 100%;
    display: block;
  }

  .portfolio__card--questo .portfolio__card-image {
    left: clamp(28px, 6.26vw, 48px);
    top: 185px;
    width: 141.1%;
    height: calc(100% - 185px);
  }

  .portfolio__card--aerobuzz .portfolio__card-image {
    top: 184px;
    height: calc(100% - 204px);
  }

  .portfolio__mobile-cta {
    display: block;
    width: min(100%, 520px);
    margin-top: 0;
  }

  .portfolio__mobile-cta .cta {
    width: 100%;
    height: 70px;
    align-items: center;
  }

  .portfolio__mobile-cta .cta__dots {
    width: 5px;
    height: 70px;
    gap: 60px;
  }

  .portfolio__mobile-cta .cta__dot {
    width: 5px;
    height: 5px;
  }

  .portfolio__mobile-cta .cta__btn {
    width: calc(100% - 14px);
    height: 60px;
    padding: 0;
    font-size: 20px;
    transform: none;
    box-shadow: none;
  }
}
/* Portfolio Tag Colors */

/* Blue */
.portfolio__tag--blue{
    color: rgb(69, 88, 237);
    background: rgba(54, 75, 236, 0.12);
}

/* Orange */
.portfolio__tag--orange{
    color: rgb(255, 94, 45);
    background: rgba(255, 94, 45, 0.12);
}

.portfolio__tag--black{
    color: #1D1D1D;
    background: #E9E9E9;
}
@media (max-width: 767px) {
  :root {
    --mobile-page-pad: clamp(16px, 5.83vw, 24px);
    --mobile-content-max: 520px;
    --mobile-narrow-max: 364px;
  }

  .engagement {
    background: #F8F4EC;
  }

  .engagement__inner {
    width: min(100%, calc(var(--mobile-narrow-max) + (var(--mobile-page-pad) * 2)));
    max-width: none;
    margin: 0 auto;
    padding: 44px 0;
    gap: 33px;
  }

  .engagement__heading {
    width: min(var(--mobile-narrow-max), calc(100% - (var(--mobile-page-pad) * 2)));
    max-width: none;
    margin: 0 auto;
    font-size: 28px;
    line-height: normal;
    letter-spacing: 0;
  }

  .engagement__heading-accent {
    display: inline;
  }

  .engagement__cards {
    width: min(366px, calc(100% - 20px));
    margin: 0 auto;
    gap: 24px;
  }

  .engagement__card {
    width: 100%;
    border: 0;
    border-radius: 5px;
    padding: 44px 24px;
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
  }

  .engagement__card--cobuild {
    min-height: auto;
    background: #fafafa;
    border: 0.8px solid var(--orange);
    border-radius: 10px;
    padding: 24px 20px;
    gap: 20px;
  }

  .engagement__card--fixed {
    min-height: auto;
    background: #fafafa;
    border: 0.8px solid var(--accent-yellow);
    border-radius: 10px;
    padding: 24px 12px 24px 20px;
    gap: 20px;
  }

  .engagement__card--fixed .engagement__card-content {
    width: min(332px, 100%);
  }

  .engagement__card-content {
    width: 100%;
    flex: none;
    gap: 20px;
    justify-content: flex-start;
  }

  .engagement__card--cobuild .engagement__card-content {
    width: min(297px, 100%);
  }

  .engagement__card-label {
    gap: 8px;
  }

  .engagement__card-name {
    font-family: var(--font-sans);
    font-weight: 700;
    font-size: 20px;
    line-height: normal;
    letter-spacing: 0;
  }

  .engagement__card-desc {
    width: 100%;
    font-size: 16px;
    line-height: normal;
  }

  .engagement__bullets {
    width: 226px;
    flex-direction: column;
    gap: 16px;
  }

  .engagement__bullet-col {
    gap: 16px;
  }

  .engagement__card--cobuild .engagement__bullet,
  .engagement__card--fixed .engagement__bullet {
    gap: 8px;
    font-size: 16px;
    line-height: normal;
    white-space: nowrap;
  }

  .engagement__card--cobuild .engagement__tick,
  .engagement__card--fixed .engagement__tick {
    width: 20px;
    height: 20px;
  }

  .engagement__card-panel {
    width: 340px;
    max-width: 100%;
    min-width: 0;
    height: 197px;
    min-height: 197px;
    border-radius: 10px;
    flex: none;
  }

  .engagement__card-panel--cobuild {
    width: min(324px, 100%);
    max-width: 100%;
    align-self: flex-start;
    padding: 0;
    height: auto;
    min-height: 0;
    aspect-ratio: 324 / 185;
    overflow: hidden;
  }

  .engagement__card-panel--cobuild picture {
    width: 100%;
    height: 100%;
    display: block;
  }

  .engagement__card-panel--fixed {
    width: min(325px, 100%);
    max-width: 100%;
    align-self: flex-start;
    padding: 0;
    height: auto;
    min-height: 0;
    aspect-ratio: 325 / 185;
    overflow: hidden;
  }

  .engagement__card-panel--fixed picture {
    width: 100%;
    height: 100%;
    display: block;
  }

  .engagement__card-illus {
    width: auto;
    max-width: 100%;
    max-height: 100%;
  }

  .engagement__card-panel--cobuild .engagement__card-illus {
    width: 100%;
    max-width: 100%;
    height: 100%;
    display: block;
    object-fit: fill;
    transform: none;
    content: url('Co build mobile artifact.svg');
  }

  .engagement__card-panel--fixed .engagement__card-illus {
    width: 100%;
    max-width: 100%;
    height: 100%;
    display: block;
    object-fit: fill;
    transform: none;
    content: url('Fixed Cost Model Mobile artifact.svg');
  }

  .transform-cta {
    z-index: 4;
    margin-bottom: 0;
    padding: 44px var(--mobile-page-pad);
    background: #ffffff;
  }

  .transform-cta::before {
    display: none;
  }

  .transform-cta__card {
    width: min(var(--mobile-narrow-max), 100%);
    max-width: 100%;
    min-height: 0;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 20px;
    overflow: visible;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
  }

  .transform-cta__content {
    width: 100%;
    padding: 0;
    gap: 20px;
  }

  .transform-cta__heading {
    font-size: clamp(25px, 6.8vw, 28px);
    line-height: normal;
    letter-spacing: 0;
    white-space: nowrap;
  }

  .transform-cta__heading span,
  .transform-cta__heading em {
    display: block;
  }

  .transform-cta__form {
    gap: 8px;
  }

  .transform-cta__label {
    font-size: 16px;
    line-height: normal;
  }

  .transform-cta__field {
    height: 48.5px;
    padding: 6.6px 10.3px;
    gap: 10px;
    border-width: 0.667px;
    border-radius: 5px;
  }

  .transform-cta__input {
    font-size: 14px;
    text-align: left;
  }

  .transform-cta__submit {
    width: 118.22px;
    height: 41.4px;
    gap: 1.725px;
    flex: 0 0 auto;
  }

  .transform-cta__submit-label {
    width: 108.1px;
    height: 30.475px;
    font-size: 11.845px;
  }

  .transform-cta__submit-dots {
    width: 3.45px;
    height: 41.4px;
  }

  .transform-cta__submit-dots span {
    width: 3.45px;
    height: 3.45px;
  }

  .transform-cta__visual {
    width: 100%;
    min-height: 0;
    height: clamp(238px, 71vw, 293px);
    border: 0.5px solid var(--orange);
    border-radius: 10px;
    background: #fde5dd;
  }

  .transform-cta__image {
    width: 100%;
    height: 118px;
    object-fit: cover;
    opacity: 0.6;
  }

  .site-footer {
    z-index: 4;
    padding: 44px var(--mobile-page-pad);
  }

  .site-footer__inner {
    width: 100%;
    max-width: var(--mobile-narrow-max);
    align-items: flex-start;
    gap: 44px;
  }

  .site-footer__top {
    width: 265px;
    flex-direction: column;
    gap: 32px;
  }

  .site-footer__brand {
    width: 265px;
  }

  .site-footer__logo {
    width: 133px;
    height: 41px;
    margin-bottom: 20px;
  }

  .site-footer__tagline {
    margin-bottom: 17px;
    font-size: 16px;
    line-height: normal;
  }

  .site-footer__email {
    font-size: 16px;
    line-height: normal;
  }

  .site-footer__links {
    width: 287px;
    justify-content: space-between;
  }

  .site-footer__nav {
    width: 72px;
    gap: 20px;
  }

  .site-footer__nav a {
    font-size: 16px;
    line-height: normal;
  }

  .site-footer__socials {
    gap: 17px;
  }

  .site-footer__social {
    gap: 8px;
    font-size: 16px;
    line-height: 1.25;
  }

  .site-footer__social-icon {
    width: 34.25px;
    height: 34.25px;
    padding: 0;
  }

  .site-footer__social-icon img {
    width: 34.25px;
    height: 34.25px;
  }

  .site-footer__wordmark {
    width: min(363.35px, 100%);
    max-width: 100%;
    height: auto;
    margin: 0;
  }

  .site-footer__copyright {
    width: 100%;
    font-size: 16px;
    line-height: 1.25;
    text-align: center;
  }
.services {
    --services-mobile-width: min(100vw, 412px);
    --services-mobile-offset: max(0px, calc((100vw - var(--services-mobile-width)) / 2));
    --svc-card-scale: 1;
    --svc-inactive-card-lift: 0px;
    --svc-active-build-lift: 0px;
    --svc-active-ux-lift: 0px;
    --svc-active-revamp-lift: 0px;
    --svc-active-design-system-lift: 0px;
    --svc-active-strategic-lift: 0px;
    --svc-active-build-shift-x: 0px;
    --svc-active-ux-shift-x: 0px;
    --svc-inactive-build-shift-x: 0px;
    --svc-inactive-ux-shift-x: 0px;
    --svc-inactive-strategic-lift-extra: 0px;
    --svc-inactive-strategic-shift-x: 0px;

    position: relative;
    top: 0;
    width: 100%;
    height: auto;
    min-height: 760px;
    overflow: visible;
    align-items: flex-start;
    background: #ffffff;
}

  .services__bg-deco {
    left: var(--services-mobile-offset);
    width: var(--services-mobile-width);
    height: 847px;
    object-fit: cover;
    opacity: 0.48;
  }

  .services__inner {
    position: absolute;
    left: calc(var(--services-mobile-offset) + var(--mobile-page-pad));
    top: 0;
    width: calc(var(--services-mobile-width) - (var(--mobile-page-pad) * 2));
    max-width: none;
    padding: 0;
    gap: 30px;
  }

  .services__heading {
    width: 100%;
    max-width: none;
    font-size: 28px;
    line-height: normal;
    letter-spacing: 0;
  }

  .services__selector-wrap {
    width: 100%;
    margin-left: 0;
    align-items: flex-start;
    gap: 30px;
  }

  .services__label {
    width: 100%;
    font-size: 16px;
    line-height: normal;
    text-align: left;
  }

  .services__stages {
    width: 100%;
    min-height: 176px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(12px, 3.88vw, 16px);
    border: 0;
    border-radius: 0;
    overflow: visible;
  }

  .services__stage {
    width: 100%;
    min-height: 80px;
    height: 80px;
    flex: none;
    padding: 20px 12px;
    border: 0.5px solid #4c4c4c;
    background: #ffffff;
    box-shadow: none;
  }

  .services__stage[data-stage="pmf-reinvention"] {
    order: 4;
  }

  .services__stage[data-stage="scaling"] {
    order: 3;
    padding-left: 10.8px;
    padding-right: 10.8px;
  }

  .services__stage:not(.services__stage--active),
  .services__stage:not(:first-child):not(.services__stage--active) {
    border: 0.5px solid #4c4c4c;
  }

  .services__stage--active {
    border: 1.5px solid var(--orange);
    background: rgba(255, 200, 183, 0.5);
    box-shadow: none;
  }
  .services__stage--active:hover {
  background: rgba(255, 200, 183, 0.5);
  color: var(--orange);
  box-shadow: none;
}

  .services__stage-name {
    width: 100%;
    font-size: 16px;
    line-height: normal;
    color: var(--dark);
  }

  .services__stage-sub {
    width: 100%;
    font-size: 14px;
    line-height: normal;
    color: var(--grey);
  }

  .services__stage--active .services__stage-name {
    color: var(--orange);
    font-weight: 600;
  }

  .svc-card {
    margin-left: var(--services-mobile-offset);
    border-radius: 10px;
    overflow: hidden;
  }

  .svc-card--build,
  .svc-card--strategic {
    width: 248px;
    height: 336px;
  }

  .svc-card--ux,
  .svc-card--revamp,
  .svc-card--design-system {
    width: 180px;
    height: 240px;
  }

  .svc-card__label {
    top: 16px;
    left: 12px;
    gap: 4px;
  }

  .svc-card--build .svc-card__label,
  .svc-card--strategic .svc-card__label {
    left: 12px;
  }

  .svc-card__name {
    font-size: 14px;
    line-height: normal;
    white-space: nowrap;
  }

  .svc-card--build .svc-card__name,
  .svc-card--strategic .svc-card__name {
    font-size: 20px;
  }

  .svc-card__icon {
    width: 20px;
    height: 20px;
  }

  .svc-card--build .svc-card__icon,
  .svc-card--strategic .svc-card__icon {
    width: 24px;
    height: 24px;
  }

  .svc-card--build .svc-card__artifact {
    top: 94px;
    left: 30px;
    width: 189px;
  }

  .svc-card--ux .svc-card__artifact {
    top: 71px;
    left: 21px;
    width: 138px;
  }

  .svc-card--revamp .svc-card__artifact {
    top: 71px;
    left: 21px;
    width: 137px;
  }

  .svc-card--design-system .svc-card__artifact {
    top: 56px;
    left: 18px;
    width: 144px;
  }

  .svc-card--strategic .svc-card__artifact {
    top: 94px;
    left: 41px;
    width: 166px;
  }
}

@media (max-width: 430px) {
  html,
  body {
    width: 100%;
    overflow-x: hidden;
  }

  .header {
    height: 83px;
    align-items: center;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(25px);
    -webkit-backdrop-filter: blur(25px);
  }

  .header::before {
    display: none;
  }

  .header__inner {
    width: 100%;
    max-width: none;
    padding: 0 var(--mobile-page-pad);
    margin-top: 0;
  }

  .header__logo img {
    width: 130px;
    height: auto;
  }

  .header__nav,
  .header .cta {
    display: none;
  }

  .header__right {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
  }

  .header__right::before {
    content: '';
    width: 28px;
    height: 20px;
    display: block;
    background:
      linear-gradient(var(--orange), var(--orange)) 0 0 / 28px 2px no-repeat,
      linear-gradient(var(--orange), var(--orange)) 0 9px / 28px 2px no-repeat,
      linear-gradient(var(--orange), var(--orange)) 0 18px / 28px 2px no-repeat;
  }

  .hero {
    min-height: 746px;
    height: auto;
    padding: 130px var(--mobile-page-pad) 44px;
    align-items: flex-start;
    background: #ffffff;
  }

  .hero__bg {
    background-image: url('Mobile Hero Background.png');
    background-size: 100% 116.2%;
    background-position: center -12.68%;
    opacity: 0.3;
  }

  .hero__bg svg {
    display: none;
  }

  .hero__content {
    width: 100%;
    max-width: var(--mobile-narrow-max);
    margin-top: 0;
    gap: 25px;
  }

  .hero__headline {
    width: min(350px, 100%);
    max-width: 100%;
  }

  .hero__headline h1 {
    display: flex;
    flex-direction: column;
    gap: 7px;
    margin: 0;
    width: min(329px, 100%);
    max-width: 100%;
  }

  .hero__headline-line {
    font-size: clamp(50px, 14.56vw, 60px);
    line-height: 1;
    letter-spacing: 0;
  }

  .hero__headline-line:last-child {
    line-height: normal;
    margin-top: -1px;
  }

  .hero__mobile-break {
    display: block;
  }

  .hero__tagline {
    width: min(350px, 100%);
    max-width: 100%;
    font-size: 20px;
    line-height: 1.28;
    color: var(--grey);
  }

  .hero__ctas {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 20px;
  }

  .hero__ctas .cta--conversation {
    order: 1;
  }

  .hero__ctas .cta--portfolio {
    order: 2;
  }

  .hero__ctas .cta {
    width: 100%;
    height: 70px;
    align-items: center;
  }

  .hero__ctas .cta__dots {
    width: 5px;
    height: 70px;
    gap: 60px;
  }

  .hero__ctas .cta__dot {
    width: 5px;
    height: 5px;
  }

  .hero__ctas .cta__btn {
    width: calc(100% - 14px);
    height: 60px;
    font-size: 20px;
    transform: none;
    box-shadow: none;
  }

  .hero__ctas .cta__btn--primary {
    padding: 0;
  }

  .hero__ctas .cta__btn--secondary {
    background: #ffffff;
  }

  .hero__ctas .cta__btn--secondary-inner {
    width: calc(100% - 10px);
    height: 51px;
    margin: 4px 5px;
    padding: 0;
  }

  .hero__bottom-fade {
    display: none;
  }

  .roles {
    height: auto;
    min-height: 0;
    background: #f8f4ec;
  }

  .roles__sticky {
    position: relative;
    top: auto;
    height: auto;
    min-height: 0;
  }

  .roles__inner {
    width: 100%;
    max-width: none;
    padding: 44px var(--mobile-page-pad);
    gap: 32px;
  }

  .roles__heading {
    width: min(310px, 100%);
    max-width: 100%;
    font-size: 28px;
    line-height: 1.2;
    letter-spacing: 0;
  }

  .roles__layout {
    display: none;
  }

  .roles-mobile {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 24px;
  }

  .roles-mobile__item {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }

  .roles-mobile__media {
    width: 100%;
    aspect-ratio: 1452 / 1046;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background:
      radial-gradient(circle at 50% 56%, rgba(255, 255, 255, 0.86) 0 13%, transparent 14%),
      radial-gradient(circle at 50% 56%, transparent 0 20%, rgba(255, 255, 255, 0.85) 21% 28%, transparent 29%),
      radial-gradient(circle at 50% 56%, transparent 0 35%, rgba(255, 255, 255, 0.76) 36% 43%, transparent 44%),
      linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.14));
  }

  .roles-mobile__lottie {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .roles-mobile__lottie svg {
    width: 100%;
    height: 100%;
    display: block;
  }

  .roles-mobile__item--founder .roles-mobile__media {
    background-color: #dce7ff;
  }

  .roles-mobile__item--pm .roles-mobile__media {
    background-color: #ffdd57;
  }

  .roles-mobile__item--cto .roles-mobile__media {
    background-color: #ff7b42;
  }

  .roles-mobile__content {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 14px;
  }

  .roles-mobile__title {
    margin: 0;
    font-family: var(--font-body);
    font-size: 24px;
    line-height: 1.2;
    font-weight: 600;
    letter-spacing: 0;
  }

  .roles-mobile__item--founder .roles-mobile__title {
    color: #4558ed;
  }

  .roles-mobile__item--pm .roles-mobile__title {
    color: #faba0a;
  }

  .roles-mobile__item--cto .roles-mobile__title {
    color: var(--orange);
  }

  .roles-mobile__tagline {
    margin: 0;
    color: var(--grey);
    font-family: var(--font-body);
    font-size: 20px;
    line-height: 1.25;
    letter-spacing: 0;
  }

  .roles-mobile__bullets {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 16px;
  }

  .roles-mobile__bullets li {
    position: relative;
    min-height: 21px;
    padding-left: 32px;
    color: var(--grey);
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.25;
    letter-spacing: 0;
  }

  .roles-mobile__bullets li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 1px;
    width: 16px;
    height: 21px;
    background: currentColor;
    -webkit-mask: url('fi_2767140.svg') center / contain no-repeat;
    mask: url('fi_2767140.svg') center / contain no-repeat;
  }

  .values {
    background: #fafafa;
  }

  .values__inner {
    width: 100%;
    max-width: none;
    padding: 44px var(--mobile-page-pad);
  }

  .values__heading {
    width: min(320px, 100%);
    max-width: 100%;
    font-size: 28px;
    line-height: 1.25;
    letter-spacing: 0;
    margin: 0 0 32px;
  }

  .values__grid {
    display: flex;
    flex-direction: column;
    gap: 24px;
    width: 100%;
  }

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

  .values__card {
    width: 100%;
    flex: none;
    min-height: auto;
    border-radius: 8px;
    padding: 24px 20px;
    align-items: flex-start;
    overflow: hidden;
  }

  .values__card-body {
    max-width: min(320px, 100%);
    gap: 8px;
    margin: 0;
    position: relative;
    z-index: 2;
  }

  .values__card-title {
    font-size: 20px;
    line-height: 1;
  }

  .values__card-desc {
    font-size: 16px;
    line-height: 1.32;
  }

  .values__icon-wrap {
    width: 100%;
    flex: none;
    margin: 20px 0 0;
  }

  .values__icon {
    max-height: none;
  }

  .values__card--founding {
    height: clamp(300px, 79.61vw, 328px);
  }

  .values__card--founding .values__card-desc {
    max-width: 266px;
  }

  .values__card--founding .values__icon-wrap {
    align-items: flex-end;
    justify-content: center;
  }

  .values__card--founding .values__icon {
    width: 317px;
    max-width: 100%;
  }

  .values__card--prompt {
    height: clamp(228px, 59.22vw, 244px);
    position: relative;
  }

  .values__card--prompt .values__card-body {
    max-width: 266px;
    margin-left: 0;
  }

  .values__card--prompt .values__card-desc {
    max-width: 172px;
  }

  .values__card--prompt .values__icon-wrap {
    position: absolute;
    right: 20px;
    bottom: 24px;
    width: min(48%, 174px);
    margin: 0;
  }

  .values__card--prompt .values__icon {
    width: 100%;
  }

  .values__card--orange {
    height: clamp(380px, 104.85vw, 432px);
    padding: 24px var(--mobile-page-pad);
  }

  .values__card--orange .values__card-body {
    max-width: 266px;
  }

  .values__card-badge {
    top: calc(50% + 30px);
    left: 50%;
    right: auto;
    width: min(clamp(190px, 55.34vw, 228px), calc(100% - (var(--mobile-page-pad) * 2)));
    height: auto;
    aspect-ratio: 1;
    transform: translate(-50%, -50%);
  }

  .values__card-badge img {
    width: 74%;
    height: 74%;
  }

  .values__card--motion {
    height: clamp(250px, 65.78vw, 271px);
  }

  .values__card--motion .values__card-body {
    max-width: 319px;
  }

  .values__card--motion .values__icon-wrap {
    justify-content: center;
    align-items: flex-end;
  }

  .values__card--motion .values__icon {
    width: min(319px, 100%);
    max-width: 100%;
  }

  .values__card--business {
    height: clamp(292px, 77.43vw, 319px);
    position: relative;
  }

  .values__card--business .values__card-body {
    max-width: 266px;
  }

  .values__card--business .values__icon-wrap {
    justify-content: flex-end;
    align-items: flex-end;
    margin-top: 14px;
  }

  .values__card--business .values__icon {
    width: 319px;
    max-width: 98.4%;
  }

  .portfolio {
    background: #fafafa;
  }

  .portfolio__inner {
    width: 100%;
    max-width: none;
    padding: 44px var(--mobile-page-pad);
    gap: 44px;
  }

  .portfolio__header {
    display: block;
  }

  .portfolio__heading {
    width: min(297px, 100%);
    max-width: 100%;
    font-size: 28px;
    line-height: 1.18;
    letter-spacing: 0;
  }

  .portfolio__heading br {
    display: none;
  }

  .portfolio__header .cta {
    display: none;
  }

  .portfolio__grid {
    display: flex;
    flex-direction: column;
    gap: 20px;
    width: 100%;
  }

  .portfolio__card {
    width: 100%;
    height: clamp(408px, 106.8vw, 440px);
    padding: 20px;
    border-radius: 10px;
  }

  .portfolio__card-body {
    gap: 8px;
    width: 100%;
  }

  .portfolio__card-title {
    font-size: 20px;
    line-height: normal;
  }

  .portfolio__card-desc {
    width: min(329px, 100%);
    max-width: 100%;
    font-size: 16px;
    line-height: 22px;
  }

  .portfolio__card-tags {
    gap: 8px;
  }

  .portfolio__tag {
    font-size: 16px;
    padding: 3px 12px;
  }

  .portfolio__card-image {
    left: 20px;
    top: 164px;
    width: 141.1%;
    height: calc(100% - 164px);
  }

  .portfolio__card-image img {
    border-radius: 0;
    object-fit: cover;
    object-position: left top;
  }

  .portfolio__card-image picture {
    width: 100%;
    height: 100%;
    display: block;
  }

  .portfolio__card--questo .portfolio__card-image {
    left: clamp(28px, 11.65vw, 48px);
    top: 185px;
    width: 141.1%;
    height: calc(100% - 185px);
  }

  .portfolio__card--aerobuzz .portfolio__card-image {
    top: 184px;
    height: calc(100% - 204px);
  }

  .portfolio__mobile-cta {
    display: block;
    width: 100%;
    margin-top: 0;
  }

  .portfolio__mobile-cta .cta {
    width: 100%;
    height: 70px;
    align-items: center;
  }

  .portfolio__mobile-cta .cta__dots {
    width: 5px;
    height: 70px;
    gap: 60px;
  }

  .portfolio__mobile-cta .cta__dot {
    width: 5px;
    height: 5px;
  }

  .portfolio__mobile-cta .cta__btn {
    width: calc(100% - 14px);
    height: 60px;
    padding: 0;
    font-size: 20px;
    transform: none;
    box-shadow: none;
  }
}

@media (max-width: 380px) {
  .services {
    --svc-card-scale: 0.92;
  }
}

@media (max-width: 360px) {
  .services {
    --svc-card-scale: 0.86;
  }
}

/* ============================================================
   Launch Loader
   ============================================================ */
.launch-loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: #ffffff;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.5s ease-out, visibility 0.5s ease-out;
}
.launch-loader.fade-out {
  opacity: 0;
  visibility: hidden;
}
.launch-loader__animation {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.launch-loader__animation svg {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
}
@media (max-width: 767px) {
  .launch-loader { background-color: #FAFAFA; }
}

/* Mobile Menu */
.mobile-menu {
  position: fixed;
  top: 0; left: 0;
  width: 100vw; height: 100vh;
  z-index: 9998;
  pointer-events: none;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.mobile-menu.is-open {
  pointer-events: auto;
  visibility: visible;
  opacity: 1;
}

/* Panel enters/exits from the LEFT */
.mobile-menu__panel {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: #080200;
  transform: translateX(-100%);
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex;
  flex-direction: column;
}
.mobile-menu.is-open .mobile-menu__panel {
  transform: translateX(0);
}

.mobile-menu__content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  padding: 23px 24px 44px 24px;
}

.mobile-menu__main {
  display: flex;
  flex-direction: column;
  gap: 62px;
}

.mobile-menu__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.mobile-menu__close {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  width: 28px; height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mobile-menu__nav {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.mobile-menu__nav a {
  font-family: 'Switzer', sans-serif;
  font-size: 32px;
  font-weight: 500;
  color: #ffffff;
  text-decoration: none;
  line-height: normal;
}

.mobile-menu__bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}

/* CTA row — orange button with dot columns on each side */
.mobile-menu__cta {
  display: flex;
  align-items: center;
  gap: 2px;
  height: 73px;
  width: 100%;
}
.mobile-menu__dots {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-self: stretch;
  flex-shrink: 0;
  width: 7px;
}
.mobile-menu__dots span {
  display: block;
  width: 7px; height: 7px;
  background-color: #ff5e2d;
}
.mobile-menu__cta-link {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  background-color: #ff5e2d;
  color: #fafafa;
  font-family: 'Switzer', sans-serif;
  font-size: 20px;
  font-weight: 400;
  text-decoration: none;
  white-space: nowrap;
}

/* Socials row */
.mobile-menu__socials {
  display: flex;
  align-items: center;
  gap: 38px;
}
.mobile-menu__socials a {
  font-family: 'Switzer', sans-serif;
  font-size: 18px;
  font-weight: 400;
  color: #ffffff;
  text-decoration: none;
  line-height: normal;
  display: flex;
  align-items: flex-end;
  gap: 2px;
  white-space: nowrap;
}
.mobile-menu__socials a::after {
  content: '↗';
  font-size: 10px;
  line-height: 1;
  padding-bottom: 3px;
}

.mobile-menu__copyright {
  font-family: 'Switzer', sans-serif;
  font-size: 18px;
  font-weight: 400;
  color: #6a6969;
  text-align: center;
  line-height: 1.25;
  width: 100%;
}

/* Hamburger toggle — orange, animates to × when menu is open */
.header__menu-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  flex-direction: column;
  gap: 5px;
  padding: 8px;
}
.header__menu-toggle span {
  display: block;
  width: 24px; height: 2px;
  background-color: #ff5e2d;
  transition: transform 0.3s ease, opacity 0.3s ease;
  transform-origin: center;
}
.header__menu-toggle.is-active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.header__menu-toggle.is-active span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.header__menu-toggle.is-active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
@media (max-width: 767px) { .header__menu-toggle { display: flex; } }
