:root {
  --black: #030303;
  --dark: #151511;
  --yellow: #ffd70f;
  --orange: #ff4b1f;
  --text: #111;
  --muted: #777;
  --light: #f5f5f5;
  --line: #dedede;
  --radius: 12px;
  --container: 1348px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  color: var(--text);
  background: #fff;
  font-family: "Inter", Arial, sans-serif;
  font-size: 16px;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

.container {
  width: min(var(--container), calc(100% - 64px));
  margin: 0 auto;
}

.header {
  position: fixed;
  top: 10px;
  left: 50%;
  z-index: 50;
  width: min(1714px, calc(100% - 96px));
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 38px;
  min-height: 76px;
  padding: 13px 22px 13px 20px;
  border-radius: 999px;
  background: #1b1b1a;
  color: #fff;
}

.logo {
  display: flex;
  align-items: center;
  flex: 0 0 214px;
}

.logo img { width: 177px; height: auto; }

.nav {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 43px;
  font-size: 14px;
  font-weight: 800;
  text-transform: uppercase;
}

.nav > a,
.nav-link {
  color: #fff;
  font: inherit;
  font-weight: 800;
  text-transform: uppercase;
}

.nav-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 22px 0;
  border: 0;
  background: transparent;
  cursor: pointer;
}

.dropdown-arrow {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translateY(-2px) rotate(45deg);
  transition: transform .18s ease;
}

.nav-item:hover .dropdown-arrow,
.nav-item.is-hover .dropdown-arrow,
.nav-item.is-open .dropdown-arrow {
  transform: translateY(2px) rotate(225deg);
}

.nav-item {
  position: static;
}

.nav-item:hover .nav-link,
.nav-item.is-hover .nav-link,
.nav-item.is-open .nav-link {
  color: var(--yellow);
}

.nav-item:hover .mega-menu,
.nav-item:focus-within .mega-menu,
.nav-item.is-hover .mega-menu,
.nav-item.is-open .mega-menu {
  opacity: 1;
  transform: translate(-50%, 0);
  pointer-events: auto;
  visibility: visible;
}

.mega-menu {
  position: fixed;
  top: 80px;
  left: 50%;
  z-index: 45;
  display: grid;
  grid-template-columns: repeat(3, minmax(220px, 1fr)) 280px;
  gap: 58px;
  width: min(1456px, calc(100% - 258px));
  min-height: 390px;
  padding: 34px 32px 30px;
  border-radius: 32px;
  background: #1b1b1a;
  box-shadow: 0 24px 70px rgba(0,0,0,.28);
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, 12px);
  transition: opacity .18s ease, transform .18s ease, visibility .18s ease;
  visibility: hidden;
  text-transform: none;
}

.services-mega {
  grid-template-columns: 180px 170px 170px 170px 170px 220px;
  gap: 34px;
  min-height: 450px;
  padding: 32px 28px 30px;
}

.industries-mega {
  grid-template-columns: 1fr;
  min-height: 382px;
  padding: 34px 36px;
}

.mega-col h3 {
  margin: 0 0 26px;
  color: #f5f5f5;
  font-size: 22px;
  line-height: 1.2;
  text-transform: none;
}

.mega-col a {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 22px;
  color: #f2f2f2;
  font-size: 16px;
  font-weight: 800;
  line-height: 1.15;
  text-transform: none;
}

.mega-col i {
  display: grid;
  flex: 0 0 38px;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 4px;
  background: #2d2a19;
  color: var(--yellow);
  font-style: normal;
  font-size: 18px;
}

.services-mega .mega-col a {
  align-items: center;
  margin-bottom: 14px;
  color: #f0f0f0;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: -0.1px;
}

.services-mega .mega-col h3 {
  margin-bottom: 27px;
  font-size: 20px;
  font-weight: 800;
}

.services-mega .mega-col i {
  flex-basis: 34px;
  width: 34px;
  height: 34px;
  padding: 5px;
  border-radius: 5px;
  background: #f0f0f0;
}

.services-mega .mega-col i img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.service-more {
  padding-top: 39px;
}

.service-more a {
  margin-bottom: 25px !important;
  gap: 0;
  font-size: 14px;
}

.services-menu-img {
  height: 310px;
  border-radius: 22px;
}

.mega-bottom {
  grid-column: 1 / 4;
  display: grid;
  grid-template-columns: repeat(3, minmax(190px, 1fr));
  gap: 34px;
  align-self: end;
  margin-top: 10px;
}

.mega-bottom a {
  display: flex;
  align-items: center;
  min-height: 54px;
  padding: 0 16px;
  border-radius: 14px;
  background: #333;
  color: #fff;
  font-size: 14px;
  font-weight: 900;
  text-transform: none;
}

.mega-col small {
  display: block;
  margin-top: 6px;
  color: #969696;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.25;
}

.mega-img {
  width: 100%;
  height: 330px;
  object-fit: cover;
  filter: grayscale(1);
  border-radius: 22px;
}

.mega-grid-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(230px, 1fr));
  gap: 24px 44px;
}

.mega-grid-list a {
  align-items: flex-start;
  margin-bottom: 0;
  min-width: 0;
}

.industries-mega .mega-col a {
  gap: 14px;
  font-size: 16px;
}

.industries-mega .mega-col i {
  flex-basis: 36px;
  width: 36px;
  height: 36px;
  border-radius: 4px;
  font-size: 13px;
}

.industries-mega .mega-col small {
  margin-top: 4px;
  font-size: 14px;
}

.ai-pill {
  position: relative;
  display: grid;
  place-items: center;
  width: 37px;
  height: 37px;
  margin-right: -4px;
  border-radius: 9px;
  background:
    linear-gradient(#1d1640, #1d1640) padding-box,
    linear-gradient(135deg, #00f0ff, #7d42ff 44%, #ff24de) border-box;
  color: #fff;
  border: 2px solid transparent;
  box-shadow: 0 0 16px rgba(148, 58, 255, .46);
  font-size: 16px;
  line-height: 1;
  animation: aiPulse 1.8s ease-in-out infinite;
}

.ai-pill::before,
.ai-pill::after {
  content: "";
  position: absolute;
  background: #18fff1;
  border-radius: 999px;
}

.ai-pill::before {
  top: -7px;
  left: -6px;
  width: 7px;
  height: 7px;
  box-shadow: 13px -1px 0 -2px #18fff1;
  animation: aiSpark 1.6s ease-in-out infinite;
}

.ai-pill::after {
  top: 7px;
  left: -10px;
  width: 8px;
  height: 2px;
  transform: rotate(45deg);
  animation: aiSpark 1.6s ease-in-out infinite reverse;
}

.nav-btn,
.mini-btn,
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-weight: 900;
  text-transform: uppercase;
  white-space: nowrap;
}

.nav-btn {
  min-height: 42px;
  margin-left: 168px;
  padding: 10px 27px;
  border: 2px solid #fff;
  font-size: 14px;
}

@keyframes aiPulse {
  0%, 100% {
    box-shadow: 0 0 10px rgba(0, 240, 255, .36), 0 0 18px rgba(255, 36, 222, .26);
    transform: translateY(0);
  }
  50% {
    box-shadow: 0 0 18px rgba(0, 240, 255, .7), 0 0 30px rgba(255, 36, 222, .5);
    transform: translateY(-1px);
  }
}

@keyframes aiSpark {
  0%, 100% { opacity: .45; transform: scale(.82) rotate(45deg); }
  50% { opacity: 1; transform: scale(1.15) rotate(45deg); }
}

.menu-toggle {
  display: none;
  width: 42px;
  height: 42px;
  border: 0;
  background: transparent;
}

.menu-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  margin: 6px auto;
  background: #fff;
}

.hero {
  min-height: 945px;
  position: relative;
  overflow: hidden;
  border-bottom-left-radius: 36px;
  border-bottom-right-radius: 36px;
  background: #000;
  color: #fff;
}

.hero-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.98), rgba(0,0,0,.42) 55%, rgba(0,0,0,.94)),
    url("../img/hero-banner-poster.jpg") center / cover no-repeat;
}

.hero-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 54% 47%, transparent 0 26%, rgba(0,0,0,.3) 43%, rgba(0,0,0,.72) 68%),
    linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.08) 52%, rgba(0,0,0,.78));
}

.hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .38;
  mix-blend-mode: screen;
}

.hero-content {
  position: relative;
  z-index: 1;
  padding-top: 272px;
}

.dot-info {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  margin-bottom: 42px;
  border-radius: 999px;
  background: #202020;
  color: var(--yellow);
  font-size: 16px;
  font-weight: 900;
  text-transform: uppercase;
}

.dot-info span {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--yellow);
}

.hero h1 {
  max-width: 910px;
  margin: 0;
  font-size: clamp(56px, 5.35vw, 88px);
  line-height: 1.06;
  letter-spacing: -3px;
  font-weight: 500;
}

.hero h1 strong {
  display: block;
  width: max-content;
  max-width: 100%;
  background: linear-gradient(90deg, #fff200 0%, #ffd500 42%, #ff9b00 72%, #ff401b 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-weight: 900;
}

.hero p {
  position: absolute;
  left: 67.2%;
  top: 535px;
  max-width: 485px;
  margin: 0;
  color: rgba(255,255,255,.92);
  font-size: 25px;
  font-weight: 600;
  line-height: 1.35;
}

.btn {
  min-height: 46px;
  padding: 14px 24px;
  border: 0;
  font-size: 12px;
}

.btn-white { margin-top: 78px; background: #fff; color: #000; }
.btn-yellow { background: var(--yellow); color: #000; }
.btn-dark { background: #000; color: #fff; }

.section { padding: 88px 0; }

.center { text-align: center; }
.narrow { max-width: 920px; }

.section-kicker {
  display: block;
  margin-bottom: 16px;
  color: #e1bc00;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.section h2,
.trusted h2 {
  margin: 0;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.08;
}

.trusted p {
  max-width: 820px;
  margin: 12px auto 38px;
  line-height: 1.6;
}

.trusted-logos {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  align-items: center;
  gap: 28px 54px;
}

.trusted-logos img {
  max-height: 46px;
  margin: auto;
  filter: grayscale(1);
  opacity: .55;
}

.section-row {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 28px;
  margin-bottom: 34px;
}

.section-row h2 { max-width: 760px; }
.section-row p { max-width: 720px; margin: 8px 0 0; line-height: 1.55; }

.actions { display: flex; gap: 10px; }
.mini-btn {
  min-height: 34px;
  padding: 8px 18px;
  border: 1px solid #000;
  font-size: 11px;
}
.mini-btn.dark { background: #000; color: #fff; }

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}

.portfolio-card {
  position: relative;
}

.portfolio-image {
  width: 100%;
  aspect-ratio: 1.28 / 1;
  object-fit: cover;
  border-radius: 8px;
}

.portfolio-logo {
  position: absolute;
  top: 26px;
  left: 28px;
  z-index: 2;
  width: 132px;
  max-height: 54px;
}

.portfolio-meta {
  position: absolute;
  left: 28px;
  bottom: 62px;
  color: #000;
}

.dark-card .portfolio-meta { color: #fff; }
.portfolio-meta span { font-size: 12px; }
.portfolio-meta h3 { margin: 6px 0 0; font-size: 22px; }

.tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding-top: 16px;
}

.tags span {
  padding: 8px 14px;
  border-radius: 999px;
  background: #f2f2f2;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.text-block {
  max-width: 880px;
}

.lead-small {
  margin: 0 0 4px;
  font-size: 20px;
}

.about h2 {
  max-width: 850px;
  font-size: clamp(26px, 3vw, 36px);
}

.lead-large {
  max-width: 900px;
  margin: 36px 0 0;
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1.1;
}

.lead-large span { color: #c7c7c7; }

.services {
  padding: 92px 0 104px;
  background: #100f05;
  color: #fff;
}

.services-top {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 80px;
  margin-bottom: 72px;
}

.services-top h2 {
  margin: 0 0 44px;
  font-size: 24px;
}

.services-top h3 {
  margin: 0 0 18px;
  font-size: clamp(34px, 4vw, 52px);
}

.services-top p {
  max-width: 620px;
  color: #fff;
  line-height: 1.55;
}

.service-list {
  border-top: 1px solid rgba(255,255,255,.16);
}

.service-list a {
  position: relative;
  display: block;
  padding: 42px 0;
  border-bottom: 1px solid rgba(255,255,255,.16);
  color: rgba(255,255,255,.45);
  font-size: clamp(36px, 5vw, 58px);
  font-weight: 900;
}

.service-list img {
  position: absolute;
  top: 16px;
  left: 38%;
  width: 220px;
  opacity: 0;
  transform: rotate(-4deg) scale(.96);
  transition: .2s ease;
}

.service-list a:hover { color: #fff; }
.service-list a:hover img { opacity: 1; transform: rotate(-2deg) scale(1); }

.design-cta {
  position: relative;
  overflow: hidden;
  padding: 0 0 82px;
  background: #fff;
}

.design-wrap { position: relative; min-height: 330px; }
.design-title {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
  border-bottom: 1px solid #ddd;
  font-size: clamp(42px, 6vw, 72px);
  font-weight: 900;
  text-align: center;
}

.design-title span { grid-column: 2; }

.circle-btn {
  display: grid;
  place-items: center;
  width: 78px;
  height: 78px;
  border-radius: 50%;
  background: var(--yellow);
  font-size: 34px;
}

.contact-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  width: min(560px, 100%);
  margin: 58px auto 0;
  padding: 26px 34px;
  border-radius: 16px;
  background: #f3f3f3;
}

.contact-strip p { margin: 0; font-size: 18px; }

.mascot {
  position: absolute;
  right: 20px;
  bottom: -30px;
  width: 255px;
}

.process h2 {
  max-width: 720px;
  margin: 0 0 44px;
  font-size: 28px;
}

.process-grid {
  display: grid;
  grid-template-columns: 1.2fr .86fr .86fr;
  gap: 32px;
}

.process-grid article {
  min-height: 330px;
  padding: 36px;
  border-radius: 8px;
  background: #f3f3f3;
}

.process-grid article:first-child { border: 2px solid #000; background: #fff; }
.process-grid h3 { margin: 0 0 20px; font-size: 28px; font-weight: 500; }
.process-grid p { color: #555; line-height: 1.6; }
.process-grid b { display: block; margin-top: 70px; font-size: 70px; }
.process-grid article span {
  display: grid;
  place-items: center;
  width: 80px;
  height: 80px;
  margin: 28px auto 42px;
  border-radius: 50%;
  background: var(--yellow);
  font-size: 34px;
}

.showreel { padding: 72px 0; }
.showreel-box {
  position: relative;
  display: flex;
  justify-content: space-between;
  min-height: 520px;
  padding: 70px 120px;
  border-radius: 0 0 14px 14px;
  background-color: #eee;
  background-image: radial-gradient(#aaa 1px, transparent 1px);
  background-size: 22px 22px;
}

.showreel-box video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .18;
}

.showreel-box::before {
  content: "";
  position: absolute;
  top: -64px;
  left: 50%;
  width: 390px;
  height: 80px;
  transform: translateX(-50%);
  border-radius: 12px 12px 0 0;
  background: #5a5a5a;
}

.ring {
  position: relative;
  z-index: 1;
  width: 330px;
  height: 330px;
  border-radius: 50%;
}

.ring-dark {
  border: 34px solid #30302f;
  box-shadow: 0 0 14px rgba(0,0,0,.35);
}

.ring-yellow {
  border: 34px solid #e6c800;
  box-shadow: 0 0 14px rgba(199,172,0,.35);
}

.ring button {
  display: grid;
  place-items: center;
  width: 64px;
  height: 64px;
  margin: 100px auto;
  border: 10px solid var(--yellow);
  border-radius: 50%;
  background: #fff;
}

.industry-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}

.industry-grid article {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  background: #000;
}

.industry-grid img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
}

.industry-grid article::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(transparent 45%, rgba(0,0,0,.78));
}

.industry-grid h3 {
  position: absolute;
  left: 20px;
  bottom: 18px;
  z-index: 1;
  margin: 0;
  color: #fff;
  font-size: 22px;
}

.tech-wrap { max-width: 760px; }
.tech-wrap h2 { font-size: 34px; }
.tech-layout {
  display: grid;
  grid-template-columns: 210px 1fr;
  gap: 58px;
  margin-top: 34px;
}

.tech-tabs {
  display: grid;
  gap: 13px;
  align-content: start;
}

.tech-tabs button {
  padding: 0;
  border: 0;
  background: transparent;
  text-align: left;
  color: #555;
  cursor: pointer;
}

.tech-tabs button.active { color: #000; font-weight: 800; }

.tech-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 24px 18px;
}

.tech-item {
  text-align: center;
  font-size: 11px;
}

.tech-item::before {
  content: "";
  display: block;
  height: 62px;
  margin-bottom: 9px;
  border-radius: 8px;
  background: #f2f2f2;
}

.innovation-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  overflow: hidden;
  border-radius: 14px;
  background: #eee;
}

.innovation-art {
  position: relative;
  min-height: 330px;
}

.innovation-art video {
  display: block;
  width: 100%;
  height: 330px;
  object-fit: cover;
}

.innovation-art img:first-child {
  width: 100%;
  height: 330px;
  object-fit: cover;
}

.innovation-art img:last-child {
  position: absolute;
  right: 16px;
  bottom: 0;
  width: 190px;
}

.innovation-card > div:last-child { padding: 50px; }
.innovation-card h2 { margin-bottom: 18px; }
.innovation-card p { color: #555; line-height: 1.55; margin-bottom: 30px; }

.testimonial-grid {
  display: grid;
  grid-template-columns: 1fr 2.2fr 1fr;
  gap: 28px;
  align-items: center;
}

.testimonial-grid article {
  min-height: 230px;
  padding: 36px;
  border-radius: 10px;
  background: #f0f0f0;
}

.testimonial-grid .featured {
  background: #fff;
  border: 2px solid #000;
}

.testimonial-grid p { margin: 0 0 42px; line-height: 1.55; }
.testimonial-grid span { display: block; color: #555; }

.testimonial-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 34px;
}

.testimonial-head h2 {
  margin: 0;
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1;
}

.testimonial-controls {
  display: flex;
  gap: 10px;
}

.testimonial-controls button {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border: 1px solid #111;
  border-radius: 50%;
  background: #fff;
  color: #111;
  cursor: pointer;
  font-size: 18px;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}

.testimonial-controls button:hover {
  background: #111;
  color: #fff;
  transform: translateY(-2px);
}

.testimonial-carousel {
  overflow: hidden;
}

.testimonial-track {
  display: flex;
  transition: transform .48s ease;
}

.testimonial-slide {
  position: relative;
  flex: 0 0 100%;
  min-height: 300px;
  padding: 48px 180px 48px 48px;
  border: 1px solid #e6e6e6;
  border-radius: 8px;
  background: #f4f4f4;
  box-shadow: 0 20px 60px rgba(0,0,0,.07);
}

.testimonial-slide.featured {
  background: #fff;
  border: 2px solid #111;
}

.testimonial-avatar {
  position: absolute;
  top: 44px;
  right: 48px;
  width: 104px;
  height: 104px;
  border: 4px solid #fff;
  border-radius: 50%;
  object-fit: cover;
  box-shadow: 0 16px 38px rgba(0,0,0,.16);
}

.testimonial-slide p {
  max-width: 830px;
  margin: 0 0 42px;
  color: #222;
  font-size: clamp(22px, 2.5vw, 34px);
  line-height: 1.25;
}

.testimonial-slide strong {
  display: block;
  margin-bottom: 6px;
  font-size: 18px;
}

.testimonial-slide span {
  display: block;
  color: #555;
}

.testimonial-dots {
  display: flex;
  justify-content: center;
  gap: 9px;
  margin-top: 22px;
}

.testimonial-dots button {
  width: 9px;
  height: 9px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: #cfcfcf;
  cursor: pointer;
  transition: width .2s ease, background .2s ease;
}

.testimonial-dots button.active {
  width: 28px;
  border-radius: 999px;
  background: var(--yellow);
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 46px;
  margin-top: 80px;
}

.blog-grid article {
  border-bottom: 1px solid #ddd;
  padding-bottom: 22px;
}

.blog-grid img {
  width: 100%;
  aspect-ratio: 2.8 / 1;
  object-fit: cover;
  border-radius: 8px;
  margin-bottom: 22px;
}

.blog-grid h3 { font-size: 19px; line-height: 1.25; }
.blog-grid span { color: #777; font-size: 12px; }

.latest-blog {
  position: relative;
  overflow: hidden;
  padding: 102px 0;
  background:
    linear-gradient(180deg, #fff 0%, #f8f8f8 100%);
}

.latest-blog .section-row {
  align-items: end;
  margin-bottom: 44px;
}

.latest-blog .section-row h2 {
  max-width: 740px;
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1.02;
}

.latest-blog .section-kicker {
  color: #d8b600;
}

.blog-grid {
  gap: 24px;
  margin-top: 0;
}

.blog-grid article {
  overflow: hidden;
  padding-bottom: 0;
  border: 1px solid #e8e8e8;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 52px rgba(0,0,0,.07);
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.blog-grid article:hover {
  border-color: rgba(255, 215, 15, .8);
  box-shadow: 0 28px 68px rgba(0,0,0,.12);
  transform: translateY(-8px);
}

.blog-thumb {
  display: block;
  overflow: hidden;
}

.blog-grid img {
  aspect-ratio: 1.55 / 1;
  margin-bottom: 0;
  border-radius: 0;
  transition: transform .36s ease, filter .36s ease;
}

.blog-grid article:hover img {
  filter: saturate(1.08);
  transform: scale(1.055);
}

.blog-content {
  padding: 26px 26px 28px;
}

.blog-grid span {
  display: inline-flex;
  margin-bottom: 14px;
  color: #777;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.blog-grid h3 {
  min-height: 78px;
  margin: 0 0 24px;
  color: #111;
  font-size: 22px;
  line-height: 1.18;
}

.blog-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #111;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.blog-link::after {
  content: "\2192";
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--yellow);
  transition: transform .2s ease;
}

.blog-grid article:hover .blog-link::after {
  transform: translateX(4px);
}

.service-marquee {
  display: flex;
  gap: 80px;
  overflow: hidden;
  padding: 26px 28px 42px;
  border-bottom-left-radius: 34px;
  border-bottom-right-radius: 34px;
  color: #d6d6d6;
  font-size: clamp(30px, 4vw, 54px);
  font-weight: 900;
  text-transform: uppercase;
  white-space: nowrap;
}

.footer {
  background: #191919;
  color: #fff;
  padding: 72px 0 0;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr 1.02fr;
  gap: 28px;
}

.email-box,
.achievements,
.footer-menus > div,
.clock-row div {
  border: 1px solid #3a3a3a;
  border-radius: 14px;
  background: #202020;
}

.email-box {
  display: flex;
  justify-content: space-between;
  padding: 22px 28px;
  font-weight: 800;
}

.clock-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin: 18px 0;
}

.clock-row div {
  padding: 22px 10px;
  text-align: center;
  text-transform: uppercase;
  font-size: 12px;
}

.clock-row strong {
  display: block;
  margin-top: 12px;
  font-size: 13px;
}

.footer-menus {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.footer-menus > div { padding: 24px; }
.footer-menus h3 { margin: 0 0 16px; }
.footer-menus a {
  display: block;
  margin: 10px 0;
  color: #cfcfcf;
  font-size: 13px;
}

.achievements {
  align-self: start;
  padding: 30px;
  background: #fff;
  color: #000;
  text-align: center;
}

.achievements div {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.achievements span {
  display: grid;
  place-items: center;
  min-height: 58px;
  color: #777;
  border-radius: 8px;
  background: #f3f3f3;
  font-weight: 800;
}

.quote-form {
  display: grid;
  gap: 12px;
  padding: 28px;
  border-radius: 16px;
  background: var(--yellow);
  color: #000;
}

.quote-form h2 { margin: 0; }
.quote-form p { margin: 0 0 8px; }
.quote-form input,
.quote-form select,
.quote-form textarea {
  width: 100%;
  min-height: 48px;
  padding: 0 18px;
  border: 2px solid #000;
  border-radius: 999px;
  background: transparent;
}

.quote-form textarea {
  min-height: 112px;
  padding-top: 16px;
  border-radius: 22px;
  resize: vertical;
}

.quote-form button { justify-self: end; }
.copyright {
  margin-top: 50px;
  padding: 22px max(32px, calc((100vw - var(--container)) / 2));
  background: #242426;
  color: #ccc;
  font-size: 12px;
}

/* Screenshot-matched home sections */
.trusted {
  min-height: 620px;
  display: grid;
  align-items: center;
  padding: 124px 0 108px;
}

.trusted .section-kicker {
  margin-bottom: 24px;
  color: #ffd400;
  font-size: 16px;
}

.trusted h2 {
  max-width: 1060px;
  font-size: clamp(30px, 2.1vw, 42px);
  letter-spacing: -.035em;
}

.trusted p {
  max-width: 1230px;
  margin-top: 12px;
  margin-bottom: 72px;
  color: #202020;
  font-size: 21px;
  line-height: 1.45;
}

.trusted-logos {
  max-width: 1260px;
  margin-inline: auto;
  grid-template-columns: repeat(6, minmax(120px, 1fr));
  gap: 50px 76px;
}

.trusted-logos img {
  width: auto;
  max-width: 190px;
  max-height: 58px;
  opacity: .62;
}

.case-study {
  padding-top: 26px;
  padding-bottom: 86px;
}

.case-study .section-kicker {
  color: #ffd400;
  font-size: 14px;
  margin-bottom: 22px;
}

.case-study .section-row {
  align-items: center;
  margin-bottom: 46px;
}

.case-study .section-row h2 {
  max-width: 780px;
  font-size: clamp(28px, 2vw, 34px);
  line-height: 1.12;
  letter-spacing: -.02em;
}

.actions {
  align-items: center;
}

.mini-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 110px;
  min-height: 44px;
  padding: 10px 22px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
}

.portfolio-grid {
  gap: 24px;
}

.portfolio-card {
  overflow: visible;
  border-radius: 0;
}

.portfolio-card::after {
  display: none;
}

.portfolio-card::before {
  content: "\2197";
  position: absolute;
  right: 8px;
  bottom: -48px;
  color: #111;
  font-size: 20px;
}

.portfolio-card:hover .portfolio-image {
  transform: none;
}

.portfolio-image {
  aspect-ratio: 1.35 / 1;
  border-radius: 8px;
}

.portfolio-logo {
  top: 46px;
  left: 40px;
  width: 150px;
}

.portfolio-meta {
  left: 38px;
  bottom: 44px;
}

.portfolio-meta span {
  font-size: 14px;
}

.portfolio-meta h3 {
  font-size: 22px;
  font-weight: 500;
}

.tags {
  padding-top: 24px;
  padding-bottom: 0;
}

.tags span {
  min-width: 96px;
  text-align: center;
  padding: 8px 16px;
  background: #f5f5f5;
  font-size: 11px;
}

.about {
  padding-top: 112px;
  padding-bottom: 72px;
}

.text-block {
  max-width: 1140px;
}

.about .section-kicker {
  color: #ffd400;
  font-size: 14px;
  margin-bottom: 24px;
}

.lead-small {
  max-width: 1100px;
  color: #1b1b1b;
  font-size: 24px;
  line-height: 1.25;
}

.about h2 {
  max-width: 1120px;
  font-size: 29px;
  line-height: 1.18;
  letter-spacing: -.02em;
}

.lead-large {
  max-width: 1110px;
  margin-top: 42px;
  font-size: clamp(36px, 2.55vw, 44px);
  line-height: 1.18;
  color: #050505;
}

.lead-large span {
  color: inherit;
}

.about-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 42px;
  margin-top: 54px;
}

.about-stats strong {
  display: block;
  margin-bottom: 8px;
  font-size: clamp(44px, 3.2vw, 64px);
  line-height: .95;
  letter-spacing: -.05em;
}

.about-stats span {
  color: #3d3d3d;
  font-size: 21px;
  font-weight: 500;
}

.services {
  padding: 72px 0 0;
  background: #fff;
  color: #050505;
}

.services-top {
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 120px;
  max-width: 1140px;
  margin-bottom: 94px;
}

.services-top h2 {
  margin-bottom: 54px;
  color: #050505;
  font-size: 30px;
}

.services-top h3 {
  color: #050505;
  font-size: clamp(38px, 3vw, 52px);
  line-height: 1.08;
}

.services-top p {
  max-width: 760px;
  color: #111;
  font-size: 21px;
  line-height: 1.38;
}

.services-top .btn-white {
  margin-top: 0;
  background: #111;
  color: #fff;
}

.service-list {
  max-width: 1280px;
  padding-top: 30px;
  padding-bottom: 28px;
  border-top: 1px solid rgba(255,255,255,.22);
  background: #100f05;
  color: #fff;
  box-shadow: 0 0 0 100vmax #100f05;
  clip-path: inset(0 -100vmax);
}

.service-list a {
  min-height: 184px;
  display: flex;
  align-items: center;
  padding: 0 128px 0 210px;
  border-bottom: 1px solid rgba(255,255,255,.22);
  color: rgba(255,255,255,.45);
  font-size: clamp(46px, 4vw, 66px);
  letter-spacing: -.035em;
}

.service-list a:first-child {
  color: #fff;
}

.service-list a::after {
  right: auto;
  left: 240px;
  width: 96px;
  height: 96px;
  opacity: 0;
  transform: translateY(-50%) scale(1);
  content: "\2197";
  display: grid;
  place-items: center;
  color: #050505;
  font-size: 48px;
  font-weight: 700;
}

.service-list a:first-child::after,
.service-list a:hover::after {
  opacity: 1;
}

.service-list img {
  position: static;
  grid-column: 1;
  grid-row: 1;
  width: 410px;
  height: 135px;
  object-fit: cover;
  border-radius: 999px;
  opacity: 0;
  transform: none;
}

.service-list a:first-child img,
.service-list a:hover img {
  opacity: 1;
  transform: none;
}

.design-cta {
  padding-top: 0;
  padding-bottom: 0;
}

.design-wrap {
  max-width: 1120px;
  min-height: 760px;
  padding-top: 0;
}

.design-title {
  display: block;
  min-height: 108px;
  padding: 26px 0 30px;
  border-bottom: 1px solid #ddd;
  text-align: left;
  color: #8a8a8a;
  font-size: 40px;
  line-height: 1;
}

.design-title .circle-btn {
  display: none;
}

.contact-strip {
  width: 430px;
  margin: 60px auto 0;
  padding: 26px 34px;
  border-radius: 14px;
}

.contact-strip p {
  color: #050505;
  font-size: 17px;
  line-height: 1.25;
}

.contact-strip .btn {
  min-height: 40px;
  padding-inline: 26px;
  font-size: 11px;
}

.mascot {
  right: 60px;
  top: -6px;
  bottom: auto;
  width: 260px;
}

.process {
  margin-top: -360px;
  padding-top: 0;
  padding-bottom: 88px;
}

.process .container {
  max-width: 1120px;
}

.process .section-kicker {
  color: #ffd400;
  font-size: 11px;
  margin-bottom: 14px;
}

.process .lead-small {
  font-size: 17px;
}

.process h2 {
  max-width: 760px;
  margin-bottom: 36px;
  font-size: 20px;
  font-weight: 800;
}

.process-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.process-grid article {
  min-height: 320px;
  padding: 28px 28px 32px;
  border: 0;
  background: #f3f3f3;
}

.process-grid article:first-child {
  border: 0;
  background: #f3f3f3;
}

.process-grid article:last-child {
  border: 2px solid #111;
  background: #fff;
}

.process-grid h3 {
  font-size: 22px;
  line-height: 1.05;
}

.process-grid p {
  max-width: 250px;
  font-size: 12px;
}

.process-grid b {
  color: #111;
  font-size: 58px;
}

.process-grid article span {
  width: 74px;
  height: 74px;
  margin: 8px 0 72px;
  background: transparent;
  color: #777;
  font-size: 62px;
  box-shadow: none;
}

/* Below-hero polish */
main {
  background: #fff;
}

.trusted {
  padding: 110px 0 84px;
}

.trusted h2 {
  max-width: 820px;
  margin-inline: auto;
  letter-spacing: -.02em;
}

.trusted p {
  color: #656565;
}

.trusted-logos {
  padding: 12px 0 0;
}

.trusted-logos img {
  max-width: 145px;
  transition: opacity .2s ease, filter .2s ease, transform .2s ease;
}

.trusted-logos img:hover {
  filter: grayscale(0);
  opacity: 1;
  transform: translateY(-2px);
}

.case-study {
  padding-top: 64px;
}

.section-row {
  width: 100%;
}

.section-row .mini-btn,
.actions .mini-btn {
  white-space: nowrap;
}

.portfolio-card {
  overflow: hidden;
  border-radius: 12px;
}

.portfolio-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.28));
  opacity: .25;
  transition: opacity .25s ease;
}

.portfolio-card:hover::after {
  opacity: .55;
}

.portfolio-image {
  display: block;
  border-radius: 12px;
  transition: transform .32s ease;
}

.portfolio-card:hover .portfolio-image {
  transform: scale(1.035);
}

.portfolio-logo,
.portfolio-meta {
  z-index: 2;
}

.tags {
  position: relative;
  z-index: 2;
  background: #fff;
}

.about {
  padding-top: 96px;
  padding-bottom: 104px;
}

.text-block {
  margin-inline: auto;
}

.lead-small {
  color: #606060;
}

.lead-large {
  color: #111;
  letter-spacing: -.025em;
}

.services {
  border-radius: 0;
}

.services-top {
  align-items: start;
}

.services-top h3 {
  letter-spacing: -.03em;
}

.service-list a {
  isolation: isolate;
}

.service-list a::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--yellow);
  opacity: 0;
  transform: translateY(-50%) scale(.85);
  transition: opacity .2s ease, transform .2s ease;
}

.service-list a:hover::after {
  opacity: 1;
  transform: translateY(-50%) scale(1);
}

.design-cta {
  padding-top: 0;
}

.design-wrap {
  padding-top: 12px;
}

.design-title {
  min-height: 118px;
}

.circle-btn,
.process-grid article span,
.ring button {
  transition: transform .2s ease, box-shadow .2s ease;
}

.circle-btn:hover,
.process-grid article span:hover,
.ring button:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(0,0,0,.14);
}

.process {
  padding-top: 82px;
}

.process-grid article {
  display: flex;
  flex-direction: column;
  border: 1px solid transparent;
}

.process-grid article:first-child {
  border-color: #111;
}

.process-grid b {
  margin-top: auto;
  line-height: 1;
}

.showreel {
  padding-top: 52px;
  padding-bottom: 96px;
}

.showreel-box {
  overflow: hidden;
  align-items: center;
}

.showreel-box::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at center, transparent 0 42%, rgba(255,255,255,.42));
}

.ring {
  z-index: 2;
}

.industries {
  padding-top: 76px;
}

.industry-grid article {
  min-height: 360px;
}

.industry-grid img {
  height: 100%;
  transition: transform .32s ease, opacity .32s ease;
}

.industry-grid article:hover img {
  opacity: .82;
  transform: scale(1.04);
}

.technology {
  padding-top: 86px;
}

.tech-wrap {
  max-width: 900px;
  margin-inline: auto;
}

.tech-wrap h2 {
  max-width: 640px;
  letter-spacing: -.02em;
}

.tech-tabs button {
  min-height: 32px;
  border-radius: 999px;
  transition: color .2s ease, padding .2s ease, background .2s ease;
}

.tech-tabs button.active {
  padding-left: 14px;
  background: #f2f2f2;
}

.tech-item {
  min-width: 0;
  color: #555;
  font-weight: 700;
  overflow-wrap: anywhere;
}

.tech-item::before {
  border: 1px solid #e8e8e8;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.8);
}

.innovation {
  padding-top: 86px;
}

.innovation-card {
  box-shadow: 0 18px 55px rgba(0,0,0,.08);
}

.innovation-card h2 {
  letter-spacing: -.02em;
}

.testimonials {
  overflow: hidden;
  padding-top: 84px;
}

.testimonials h2 {
  margin-bottom: 42px;
}

.testimonial-grid article {
  box-shadow: 0 12px 35px rgba(0,0,0,.06);
}

.testimonial-grid strong {
  display: block;
  margin-bottom: 4px;
}

.latest-blog {
  padding-top: 92px;
  padding-bottom: 92px;
}

.blog-grid article {
  min-width: 0;
}

.blog-grid img {
  display: block;
  transition: transform .25s ease;
}

.blog-grid article:hover img {
  transform: translateY(-3px);
}

.service-marquee {
  background: #fff;
}

.footer {
  border-top-left-radius: 28px;
  border-top-right-radius: 28px;
}

.footer-grid {
  align-items: start;
}

.email-box span {
  color: var(--yellow);
}

.quote-form input:focus,
.quote-form select:focus,
.quote-form textarea:focus {
  outline: 0;
  background: rgba(255,255,255,.28);
}

/* Footer refactor */
.service-marquee {
  position: relative;
  z-index: 1;
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  background: #fff;
}

.footer {
  position: relative;
  z-index: 2;
  clear: both;
  isolation: isolate;
  margin-top: 0;
  padding: 86px 0 0;
  overflow: hidden;
  border-top: 1px solid #303030;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  background:
    radial-gradient(circle at 84% 18%, rgba(255, 215, 15, .12), transparent 28%),
    linear-gradient(180deg, #171717 0%, #101010 100%);
  color: #fff;
  box-shadow: 0 -18px 70px rgba(0,0,0,.1);
}

.footer::before {
  content: "";
  position: absolute;
  left: max(32px, calc((100vw - var(--container)) / 2));
  right: max(32px, calc((100vw - var(--container)) / 2));
  top: 0;
  height: 4px;
  border-radius: 999px;
  background: var(--yellow);
}

.footer-grid {
  grid-template-columns: minmax(0, 1.45fr) minmax(260px, .8fr) minmax(320px, 1fr);
  gap: 24px;
  align-items: start;
}

.footer-brand {
  margin-bottom: 18px;
  padding: 30px;
  border: 1px solid #303030;
  border-radius: 8px;
  background: rgba(255,255,255,.035);
}

.footer-logo {
  display: inline-block;
  margin-bottom: 14px;
  color: #fff;
  font-size: clamp(30px, 3vw, 44px);
  font-weight: 900;
  line-height: 1;
}

.footer-brand p {
  max-width: 520px;
  margin: 0;
  color: #bdbdbd;
  font-size: 15px;
  line-height: 1.6;
}

.email-box,
.achievements,
.footer-menus > div,
.clock-row div {
  border-color: #303030;
  border-radius: 8px;
  background: rgba(255,255,255,.035);
}

.email-box {
  align-items: center;
  min-height: 72px;
  transition: border-color .2s ease, background .2s ease, transform .2s ease;
}

.email-box:hover {
  border-color: rgba(255, 215, 15, .7);
  background: rgba(255,255,255,.065);
  transform: translateY(-2px);
}

.clock-row {
  gap: 12px;
  margin: 14px 0;
}

.clock-row div {
  min-height: 92px;
  padding: 20px 12px;
}

.footer-menus {
  gap: 12px;
}

.footer-menus > div {
  padding: 24px 22px;
}

.footer-menus h3 {
  color: #fff;
  font-size: 16px;
}

.footer-menus a {
  color: #bdbdbd;
  transition: color .18s ease, transform .18s ease;
}

.footer-menus a:hover {
  color: var(--yellow);
  transform: translateX(3px);
}

.achievements {
  padding: 30px 24px;
  background: #f6f6f6;
  color: #111;
  border-color: transparent;
  border-radius: 8px;
}

.achievements h3 {
  margin-top: 0;
}

.achievements div {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.achievements span {
  min-height: 66px;
  border: 1px solid #e7e7e7;
  background: #fff;
}

.quote-form {
  gap: 14px;
  padding: 30px;
  border-radius: 8px;
  box-shadow: 0 22px 60px rgba(0,0,0,.2);
}

.quote-form input,
.quote-form select,
.quote-form textarea {
  border-width: 1px;
  background: rgba(255,255,255,.24);
}

.copyright {
  margin-top: 58px;
  border-top: 1px solid #303030;
  background: rgba(255,255,255,.035);
}

.whatsapp-float {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 80;
  display: grid;
  place-items: center;
  width: 62px;
  height: 62px;
  border-radius: 50%;
  background: #25d366;
  color: #fff;
  box-shadow: 0 16px 38px rgba(37, 211, 102, .38);
  transition: transform .2s ease, box-shadow .2s ease;
}

.whatsapp-float:hover {
  box-shadow: 0 20px 48px rgba(37, 211, 102, .5);
  transform: translateY(-3px) scale(1.04);
}

.whatsapp-float svg {
  width: 36px;
  height: 36px;
  fill: currentColor;
}

@media (max-width: 1000px) {
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .footer-brand,
  .email-box,
  .achievements,
  .quote-form {
    max-width: 100%;
  }

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

@media (max-width: 640px) {
  .footer {
    padding-top: 58px;
  }

  .footer-brand {
    padding: 24px;
  }

  .clock-row,
  .footer-menus,
  .achievements div {
    grid-template-columns: 1fr;
  }

  .copyright {
    margin-top: 34px;
  }

  .whatsapp-float {
    right: 16px;
    bottom: 16px;
    width: 54px;
    height: 54px;
  }

  .whatsapp-float svg {
    width: 31px;
    height: 31px;
  }
}

/* Final section matching overrides */
.trusted {
  min-height: 620px;
  display: grid;
  align-items: center;
  padding: 124px 0 108px;
}

.trusted .section-kicker,
.case-study .section-kicker,
.about .section-kicker,
.process .section-kicker {
  color: #ffd400;
}

.trusted .section-kicker {
  margin-bottom: 24px;
  font-size: 16px;
}

.trusted h2 {
  max-width: 1060px;
  font-size: clamp(30px, 2.1vw, 42px);
  letter-spacing: -.035em;
}

.trusted p {
  max-width: 1230px;
  margin: 12px auto 72px;
  color: #202020;
  font-size: 21px;
  line-height: 1.45;
}

.trusted-logos {
  max-width: 1260px;
  margin-inline: auto;
  padding: 0;
  grid-template-columns: repeat(6, minmax(120px, 1fr));
  gap: 50px 76px;
}

.trusted-logos img {
  max-width: 190px;
  max-height: 58px;
  opacity: .62;
}

.case-study {
  padding-top: 26px;
  padding-bottom: 86px;
}

.case-study .section-kicker {
  margin-bottom: 22px;
  font-size: 14px;
}

.case-study .section-row {
  align-items: center;
  margin-bottom: 46px;
}

.case-study .section-row h2 {
  max-width: 780px;
  font-size: clamp(28px, 2vw, 34px);
  line-height: 1.12;
  letter-spacing: -.02em;
}

.portfolio-card {
  overflow: visible;
  border-radius: 0;
}

.portfolio-card::after {
  display: none;
}

.portfolio-card::before {
  content: "\2197";
  position: absolute;
  right: 8px;
  bottom: -48px;
  color: #111;
  font-size: 20px;
}

.portfolio-card:hover .portfolio-image {
  transform: none;
}

.portfolio-image {
  aspect-ratio: 1.35 / 1;
  border-radius: 8px;
}

.tags {
  padding-top: 24px;
  background: #fff;
}

.about {
  padding-top: 112px;
  padding-bottom: 72px;
}

.text-block,
.services-top,
.design-wrap,
.process .container {
  max-width: 1120px;
}

.lead-small {
  max-width: 1100px;
  color: #1b1b1b;
  font-size: 24px;
  line-height: 1.25;
}

.about h2 {
  max-width: 1120px;
  font-size: 29px;
  line-height: 1.18;
}

.lead-large {
  max-width: 1110px;
  margin-top: 42px;
  color: #050505;
  font-size: clamp(36px, 2.55vw, 44px);
  line-height: 1.18;
}

.lead-large span {
  color: inherit;
}

.about-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 42px;
  margin-top: 54px;
}

.about-stats strong {
  display: block;
  margin-bottom: 8px;
  font-size: clamp(44px, 3.2vw, 64px);
  line-height: .95;
  letter-spacing: -.05em;
}

.about-stats span {
  color: #3d3d3d;
  font-size: 21px;
  font-weight: 500;
}

.services {
  padding: 72px 0 0;
  background: #fff;
  color: #050505;
}

.services-top {
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 120px;
  margin-bottom: 94px;
}

.services-top h2,
.services-top h3,
.services-top p {
  color: #050505;
}

.services-top h2 {
  margin-bottom: 54px;
  font-size: 30px;
}

.services-top h3 {
  font-size: clamp(38px, 3vw, 52px);
  line-height: 1.08;
}

.services-top p {
  max-width: 760px;
  font-size: 21px;
  line-height: 1.38;
}

.services-top .btn-white {
  margin-top: 0;
  background: #111;
  color: #fff;
}

.service-list {
  max-width: 1280px;
  padding-top: 30px;
  padding-bottom: 28px;
  border-top: 1px solid rgba(255,255,255,.22);
  background: #100f05;
  color: #fff;
  box-shadow: 0 0 0 100vmax #100f05;
  clip-path: inset(0 -100vmax);
}

.service-list a {
  min-height: 184px;
  display: flex;
  align-items: center;
  padding: 0 128px 0 210px;
  border-bottom: 1px solid rgba(255,255,255,.22);
  color: rgba(255,255,255,.45);
  font-size: clamp(46px, 4vw, 66px);
  letter-spacing: -.035em;
}

.service-list a:first-child {
  color: #fff;
}

.service-list a::after {
  content: "\2197";
  display: grid;
  place-items: center;
  left: 268px;
  right: auto;
  top: 50%;
  width: 76px;
  height: 76px;
  border-radius: 50%;
  background: var(--yellow);
  color: #050505;
  font-size: 36px;
  font-weight: 700;
  opacity: 0;
  transform: translateY(-50%) scale(.82);
  transition: opacity .25s ease, transform .25s ease;
}

.service-list a:first-child::after,
.service-list a:hover::after {
  opacity: 1;
  transform: translateY(-50%) scale(1);
}

.service-list img {
  position: absolute;
  left: 0;
  top: 50%;
  width: 320px;
  height: 116px;
  object-fit: cover;
  border-radius: 999px;
  opacity: 0;
  transform: translate(-22px, -50%) scale(.94);
  transition: opacity .32s ease, transform .32s ease;
}

.service-list a:first-child img,
.service-list a:hover img {
  opacity: 1;
  transform: translate(0, -50%) scale(1);
}

.service-list a span {
  display: block;
  transform: translateX(0);
  transition: transform .34s ease, color .25s ease;
}

.service-list a:hover span,
.service-list a:focus-visible span {
  transform: translateX(176px);
}

.design-cta {
  padding: 0;
}

.design-wrap {
  min-height: 760px;
  padding-top: 0;
}

.design-title {
  display: block;
  min-height: 108px;
  padding: 26px 0 30px;
  border-bottom: 1px solid #ddd;
  color: #8a8a8a;
  text-align: left;
  font-size: 40px;
  line-height: 1;
}

.design-title .circle-btn {
  display: none;
}

.contact-strip {
  width: 430px;
  margin: 60px auto 0;
  padding: 26px 34px;
  border-radius: 14px;
}

.mascot {
  top: -6px;
  right: 60px;
  bottom: auto;
  width: 260px;
}

.process {
  margin-top: -360px;
  padding-top: 0;
  padding-bottom: 88px;
}

.process h2 {
  max-width: 760px;
  margin-bottom: 36px;
  font-size: 20px;
  font-weight: 800;
}

.process-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.process-grid article,
.process-grid article:first-child {
  min-height: 320px;
  padding: 28px 28px 32px;
  border: 0;
  background: #f3f3f3;
}

.process-grid article:last-child {
  border: 2px solid #111;
  background: #fff;
}

.process-grid h3 {
  font-size: 22px;
  line-height: 1.05;
}

.process-grid p {
  max-width: 250px;
  font-size: 12px;
}

.process-grid article span {
  width: 74px;
  height: 74px;
  margin: 8px 0 72px;
  background: transparent;
  color: #777;
  font-size: 62px;
  box-shadow: none;
}

.header {
  gap: 20px;
  width: min(1540px, calc(100% - 56px));
  padding-inline: 18px;
}

.logo {
  flex-basis: 178px;
}

.logo img {
  width: 154px;
}

.nav {
  gap: 24px;
  font-size: 12px;
}

.nav-link {
  gap: 5px;
}

.nav-btn {
  min-height: 38px;
  margin-left: 34px;
  padding: 9px 19px;
  font-size: 12px;
}

.design-cta {
  padding: 86px 0 96px;
  background:
    radial-gradient(circle at 79% 44%, rgba(255, 215, 15, .12), transparent 26%),
    linear-gradient(180deg, #fff 0%, #fbfbfb 100%);
}

.design-wrap {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  align-items: center;
  gap: 78px;
  min-height: 0;
  padding: 58px 72px;
  overflow: hidden;
  border: 1px solid #ececec;
  border-radius: 8px;
  background: rgba(255,255,255,.86);
  box-shadow: 0 28px 90px rgba(0,0,0,.08);
}

.design-wrap::before {
  content: "";
  position: absolute;
  left: 72px;
  top: 36px;
  width: 82px;
  height: 5px;
  border-radius: 999px;
  background: var(--yellow);
}

.design-wrap::after {
  content: "";
  position: absolute;
  right: 92px;
  top: 50%;
  width: 330px;
  height: 330px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 215, 15, .22), rgba(255, 215, 15, 0) 68%);
  transform: translateY(-50%);
  pointer-events: none;
}

.design-title {
  grid-column: 1;
  display: flex;
  align-items: center;
  gap: 22px;
  min-height: 0;
  max-width: 760px;
  padding: 0;
  border-bottom: 0;
  color: #111;
  font-size: clamp(48px, 5vw, 76px);
  line-height: .95;
  letter-spacing: 0;
}

.design-title span {
  display: block;
}

.design-title .circle-btn {
  position: static;
  display: grid;
  flex: 0 0 66px;
  width: 66px;
  height: 66px;
  box-shadow: 0 14px 35px rgba(255, 215, 15, .32);
  font-size: 28px;
}

.contact-strip {
  grid-column: 1;
  width: min(640px, 100%);
  margin: 34px 0 0;
  padding: 26px 28px 26px 32px;
  border: 1px solid #e6e6e6;
  border-left: 6px solid var(--yellow);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 45px rgba(0,0,0,.07);
}

.contact-strip p {
  color: #161616;
  font-size: 21px;
  line-height: 1.22;
}

.contact-strip .btn {
  min-width: 132px;
  min-height: 52px;
  padding-inline: 28px;
  box-shadow: 0 12px 26px rgba(255, 215, 15, .28);
}

.mascot {
  position: relative;
  z-index: 1;
  grid-column: 2;
  grid-row: 1 / span 2;
  justify-self: center;
  width: 336px;
  aspect-ratio: 1;
  padding: 10px;
  border: 1px solid rgba(255, 215, 15, .88);
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 26px 75px rgba(0,0,0,.18);
  object-fit: cover;
}

.process {
  margin-top: 0;
}

.process {
  position: relative;
  overflow: hidden;
  padding: 104px 0 116px;
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 215, 15, .14), transparent 26%),
    linear-gradient(180deg, #fbfbfb 0%, #fff 100%);
}

.process::before {
  content: "";
  position: absolute;
  inset: 54px max(24px, calc((100vw - 1180px) / 2)) auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,0,0,.16), transparent);
}

.process .container {
  position: relative;
  max-width: 1180px;
}

.process .section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  color: #d7b300;
  font-size: 13px;
}

.process .section-kicker::before {
  content: "";
  width: 34px;
  height: 2px;
  border-radius: 999px;
  background: var(--yellow);
}

.process .lead-small {
  max-width: 560px;
  color: #555;
  font-size: 19px;
  line-height: 1.45;
}

.process h2 {
  max-width: 720px;
  margin: 8px 0 48px;
  color: #111;
  font-size: clamp(34px, 4vw, 54px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0;
}

.process-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.process-grid::before {
  content: "";
  position: absolute;
  left: 13%;
  right: 13%;
  top: 52px;
  height: 2px;
  background: linear-gradient(90deg, rgba(255,215,15,.05), rgba(255,215,15,.95), rgba(255,215,15,.05));
}

.process-grid article,
.process-grid article:first-child,
.process-grid article:last-child {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 360px;
  padding: 30px;
  overflow: hidden;
  border: 1px solid #ececec;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 50px rgba(0,0,0,.07);
  animation: cardRise .72s ease both;
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.process-grid article:nth-child(2) {
  animation-delay: .1s;
}

.process-grid article:nth-child(3) {
  animation-delay: .2s;
}

.process-grid article::before {
  content: "";
  position: absolute;
  inset: auto -34px -50px auto;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background: rgba(255, 215, 15, .16);
  transition: transform .32s ease, opacity .32s ease;
}

.process-grid article:hover {
  border-color: rgba(255, 215, 15, .75);
  box-shadow: 0 28px 70px rgba(0,0,0,.12);
  transform: translateY(-10px);
}

.process-grid article:hover::before {
  opacity: .9;
  transform: scale(1.18);
}

.process-step {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  margin: 0 0 44px;
  border: 1px solid rgba(255, 215, 15, .85);
  border-radius: 50%;
  background: #111;
  color: var(--yellow);
  box-shadow: 0 0 0 8px #fff, 0 12px 28px rgba(0,0,0,.14);
  font-size: 15px;
  font-weight: 900;
}

.process-grid h3 {
  position: relative;
  z-index: 1;
  max-width: 260px;
  margin: 0 0 18px;
  color: #111;
  font-size: 28px;
  font-weight: 900;
  line-height: 1.05;
}

.process-grid p {
  position: relative;
  z-index: 1;
  max-width: 310px;
  margin: 0;
  color: #5d5d5d;
  font-size: 15px;
  line-height: 1.62;
}

.process-grid b {
  position: relative;
  z-index: 1;
  display: block;
  margin-top: auto;
  color: rgba(0,0,0,.13);
  font-size: 68px;
  line-height: .8;
  transition: color .28s ease, transform .28s ease;
}

.process-grid article:hover b {
  color: #111;
  transform: translateX(6px);
}

/* Reference-style process cards and working showreel */
.process {
  padding: 84px 0 74px;
  background: #fff;
}

.process::before {
  display: none;
}

.process .container {
  max-width: 1216px;
}

.process .section-kicker {
  color: #d8b600;
}

.process .lead-small {
  max-width: 680px;
}

.process h2 {
  max-width: 720px;
  margin-bottom: 42px;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.1;
}

.process-grid {
  grid-template-columns: .9fr .9fr 1.25fr;
  gap: 34px;
}

.process-grid::before {
  display: none;
}

.process-grid article,
.process-grid article:first-child,
.process-grid article:last-child {
  min-height: 396px;
  padding: 42px 42px 38px;
  border: 0;
  border-radius: 8px;
  background: #f2f2f2;
  box-shadow: none;
  animation: cardRise .72s ease both;
}

.process-grid article:last-child {
  min-height: 396px;
  border: 2px solid #111;
  background: #fff;
}

.process-grid article::before {
  display: none;
}

.process-grid article:hover {
  border-color: #111;
  box-shadow: 0 22px 55px rgba(0,0,0,.09);
  transform: translateY(-8px);
}

.process-grid h3 {
  max-width: 260px;
  margin-bottom: 22px;
  font-size: clamp(28px, 2.5vw, 38px);
  font-weight: 500;
  line-height: .98;
}

.process-grid p {
  max-width: 330px;
  color: #444;
  font-size: 16px;
  line-height: 1.55;
}

.process-mark {
  position: relative;
  display: block;
  margin-top: auto;
  color: #111;
  transform: none;
  transition: transform .45s ease;
}

.process-grid article:hover .process-mark {
  transform: rotate(8deg) scale(1.04);
}

.mark-arrows {
  width: 82px;
  height: 96px;
}

.mark-arrows::before,
.mark-arrows::after {
  content: "";
  position: absolute;
  inset: 14px 24px;
  border-right: 20px solid #111;
  transform: skewY(36deg);
  box-shadow: -18px 0 0 rgba(0,0,0,.36), -36px 0 0 rgba(0,0,0,.18);
}

.mark-arrows::after {
  inset: 34px 24px 0;
  opacity: .45;
}

.mark-pinwheel {
  width: 104px;
  height: 104px;
  margin: 0 auto auto;
  animation: processSpin 8s linear infinite;
}

.mark-pinwheel::before {
  content: "";
  position: absolute;
  inset: 8px;
  background:
    conic-gradient(from 8deg, #111 0 26deg, transparent 26deg 70deg, rgba(0,0,0,.35) 70deg 96deg, transparent 96deg 140deg, #fff 140deg 166deg, transparent 166deg 210deg, #111 210deg 238deg, transparent 238deg 282deg, rgba(0,0,0,.35) 282deg 308deg, transparent 308deg);
  border: 1px solid rgba(0,0,0,.18);
  border-radius: 50%;
}

.mark-pinwheel::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 20px;
  height: 20px;
  border: 2px solid #111;
  border-radius: 50%;
  background: #fff;
  transform: translate(-50%, -50%);
}

.mark-star {
  width: 250px;
  height: 220px;
  margin: auto auto 0;
}

.mark-star::before,
.mark-star::after {
  content: "";
  position: absolute;
  inset: 0;
  clip-path: polygon(50% 0, 61% 36%, 99% 35%, 68% 57%, 80% 94%, 50% 72%, 20% 94%, 32% 57%, 1% 35%, 39% 36%);
}

.mark-star::before {
  background: conic-gradient(from 20deg, #ffd70f 0 12%, #fff 12% 28%, #ffd70f 28% 42%, #fff 42% 58%, #ffd70f 58% 72%, #fff 72% 100%);
  transform: scale(.84);
}

.mark-star::after {
  background: #fff;
  transform: scale(.72);
  filter: drop-shadow(0 0 0 #111);
}

.mark-star {
  filter:
    drop-shadow(0 2px 0 #111)
    drop-shadow(2px 0 0 #111)
    drop-shadow(-2px 0 0 #111)
    drop-shadow(0 -2px 0 #111);
}

.showreel {
  padding: 34px 0 98px;
  background: #fff;
}

.showreel-box {
  position: relative;
  display: block;
  min-height: 0;
  padding: 0;
  overflow: hidden;
  border-radius: 14px;
  background: #111;
  box-shadow: 0 26px 80px rgba(0,0,0,.18);
}

.showreel-box::before,
.showreel-box::after {
  display: none;
}

.showreel-video,
.showreel-box video {
  position: relative;
  inset: auto;
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  opacity: 1;
}

.video-play {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 2;
  min-width: 92px;
  min-height: 92px;
  border: 0;
  border-radius: 50%;
  background: var(--yellow);
  color: #111;
  box-shadow: 0 18px 46px rgba(0,0,0,.28);
  cursor: pointer;
  font-weight: 900;
  text-transform: uppercase;
  transform: translate(-50%, -50%);
  transition: opacity .2s ease, transform .2s ease;
}

.video-play.is-hidden {
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, -50%) scale(.86);
}

@keyframes processSpin {
  to { transform: rotate(360deg); }
}

/* Tech stack reference layout */
.technology {
  padding: 104px 0 96px;
  background: #fff;
}

.tech-wrap {
  max-width: 980px;
  margin-inline: auto;
}

.tech-wrap h2 {
  max-width: 760px;
  margin: 0;
  color: #191919;
  font-size: clamp(30px, 2.65vw, 38px);
  font-weight: 900;
  line-height: 1.08;
  letter-spacing: 0;
}

.tech-layout {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr);
  gap: 88px;
  align-items: start;
  margin-top: 58px;
}

.tech-tabs {
  display: grid;
  gap: 16px;
  align-content: start;
}

.tech-tabs button {
  min-height: auto;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: #444;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.25;
  text-align: left;
  cursor: pointer;
  transition: color .18s ease, transform .18s ease;
}

.tech-tabs button:hover,
.tech-tabs button.active {
  padding-left: 0;
  background: transparent;
  color: #191919;
  font-weight: 900;
  transform: translateX(4px);
}

.tech-grid {
  display: grid;
  grid-template-columns: repeat(6, 84px);
  justify-content: start;
  gap: 34px 22px;
}

.tech-item {
  display: grid;
  justify-items: center;
  gap: 10px;
  min-width: 0;
  color: #191919;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.05;
  text-align: center;
  overflow-wrap: normal;
  animation: sectionLift .36s ease both;
}

.tech-item::before {
  display: none;
}

.tech-icon {
  display: grid;
  place-items: center;
  width: 84px;
  height: 84px;
  border-radius: 7px;
  background:
    radial-gradient(circle at 30% 22%, hsla(var(--tech-hue), 92%, 62%, .2), transparent 34%),
    #f3f3f3;
  color: hsl(var(--tech-hue), 82%, 42%);
  font-size: 25px;
  font-weight: 900;
  letter-spacing: 0;
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease;
}

.tech-item:hover .tech-icon {
  background: #fff;
  box-shadow: 0 16px 34px rgba(0,0,0,.11);
  transform: translateY(-5px);
}

.trusted {
  position: relative;
  overflow: hidden;
}

.trusted::before {
  content: "";
  position: absolute;
  inset: 92px max(28px, calc((100vw - 1260px) / 2)) 70px;
  border: 1px solid rgba(255, 215, 15, .18);
  border-radius: 28px;
  pointer-events: none;
}

.trusted-logos span {
  display: grid;
  place-items: center;
  min-height: 86px;
  border: 1px solid #ececec;
  border-radius: 8px;
  background: linear-gradient(180deg, #fff, #fafafa);
  box-shadow: 0 12px 34px rgba(0,0,0,.04);
  animation: logoFloat 4.8s ease-in-out infinite;
  transition: border-color .22s ease, box-shadow .22s ease, transform .22s ease;
}

.trusted-logos span:nth-child(2n) {
  animation-delay: .45s;
}

.trusted-logos span:nth-child(3n) {
  animation-delay: .9s;
}

.trusted-logos span:hover {
  animation-play-state: paused;
  border-color: rgba(255, 215, 15, .85);
  box-shadow: 0 18px 42px rgba(0,0,0,.1);
  transform: translateY(-5px);
}

.trusted-logos span:hover img {
  filter: grayscale(0);
  opacity: 1;
}

.case-study {
  overflow: hidden;
}

.case-study .section-row {
  animation: sectionLift .72s ease both;
}

.portfolio-card {
  animation: cardRise .76s ease both;
}

.portfolio-card:nth-child(2) {
  animation-delay: .12s;
}

.portfolio-card::before {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  bottom: 18px;
  right: 18px;
  z-index: 3;
  border-radius: 50%;
  background: var(--yellow);
  color: #050505;
  opacity: 0;
  transform: translateY(10px) rotate(-14deg);
  transition: opacity .24s ease, transform .24s ease;
}

.portfolio-card:hover::before {
  opacity: 1;
  transform: translateY(0) rotate(0);
}

.portfolio-card::after {
  display: block;
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 8px;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.42));
  opacity: .34;
  transition: opacity .25s ease;
}

.portfolio-card:hover::after {
  opacity: .62;
}

.portfolio-image {
  transition: transform .45s ease, filter .45s ease;
}

.portfolio-card:hover .portfolio-image {
  transform: scale(1.045);
  filter: saturate(1.08);
}

.about {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #fff 0%, #fff 58%, #fff8cf 100%);
}

.about::before {
  content: "";
  position: absolute;
  top: 86px;
  right: max(26px, calc((100vw - 1120px) / 2));
  width: 210px;
  height: 210px;
  border: 34px solid rgba(255, 215, 15, .28);
  border-radius: 50%;
}

.about-panel {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 390px;
  gap: 54px;
  align-items: start;
  padding: 48px;
  border: 1px solid #ececec;
  border-radius: 8px;
  background: rgba(255,255,255,.86);
  box-shadow: 0 28px 80px rgba(0,0,0,.08);
  backdrop-filter: blur(10px);
}

.about-copy {
  min-width: 0;
}

.about-stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 0;
}

.about-stats div {
  min-height: 156px;
  padding: 24px;
  border: 1px solid #e8e8e8;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(0,0,0,.05);
}

.about-stats strong::after {
  content: "+";
  margin-left: 4px;
  color: #e1bc00;
  font-size: .62em;
}

.service-list a:first-child {
  color: rgba(255,255,255,.45);
}

.service-list a:hover,
.service-list a:focus-visible {
  color: #fff;
}

.service-list a:first-child::after,
.service-list a:first-child img {
  opacity: 0;
}

.service-list a:first-child:hover::after,
.service-list a:first-child:hover img,
.service-list a:first-child:focus-visible::after,
.service-list a:first-child:focus-visible img {
  opacity: 1;
}

@keyframes logoFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-7px); }
}

@keyframes sectionLift {
  from { opacity: 0; transform: translateY(28px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes cardRise {
  from { opacity: 0; transform: translateY(34px) scale(.985); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@media (max-width: 1280px) {
  .trusted,
  .about,
  .latest-blog {
    padding-block: 74px;
  }

  .services {
    padding: 74px 0 0;
  }

  .service-list img {
    position: absolute;
    left: 0;
    top: 50%;
    width: 280px;
    height: 100px;
    transform: translate(-18px, -50%) scale(.94);
  }

  .service-list a::after {
    left: 232px;
    width: 62px;
    height: 62px;
    font-size: 30px;
  }

  .ring {
    width: 270px;
    height: 270px;
  }

  .showreel-box {
    padding-inline: 82px;
  }
}

@media (max-width: 1000px) {
  .menu-toggle { display: block; }
  .header {
    width: calc(100% - 32px);
    min-height: 64px;
  }

  .logo { flex-basis: auto; }
  .logo img { width: 145px; }
  .nav-btn { margin-left: 0; }

  .nav {
    display: none;
    position: fixed;
    top: 78px;
    left: 32px;
    right: 32px;
    flex-direction: column;
    align-items: stretch;
    padding: 24px;
    border-radius: 14px;
    background: #1c1c1b;
  }
  .nav.is-open { display: flex; }
  .nav-link {
    justify-content: space-between;
    width: 100%;
    padding: 0;
  }
  .nav-item:hover .mega-menu,
  .nav-item:focus-within .mega-menu,
  .nav-item.is-hover .mega-menu {
    opacity: 0;
    pointer-events: none;
    visibility: hidden;
  }
  .nav-item.is-open .mega-menu {
    position: static;
    display: grid;
    width: 100%;
    min-height: 0;
    max-height: 58vh;
    overflow: auto;
    padding: 18px;
    border-radius: 12px;
    grid-template-columns: 1fr;
    gap: 18px;
    opacity: 1;
    pointer-events: auto;
    transform: none;
    visibility: visible;
  }
  .services-mega {
    grid-template-columns: 1fr;
  }
  .service-more {
    padding-top: 0;
  }
  .mega-bottom {
    grid-column: auto;
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .mega-img {
    display: none;
  }
  .mega-grid-list {
    grid-template-columns: 1fr;
  }
  .services-top,
  .innovation-card,
  .tech-layout,
  .footer-grid,
  .about-panel,
  .about,
  .section-row { grid-template-columns: 1fr; }
  .section-row { display: grid; align-items: start; }
  .trusted-logos,
  .portfolio-grid,
  .about-stats,
  .process-grid,
  .industry-grid,
  .testimonial-grid,
  .blog-grid,
  .footer-menus,
  .clock-row { grid-template-columns: 1fr 1fr; }
  .tech-grid { grid-template-columns: repeat(3, 1fr); }
  .mascot { opacity: .28; }

  .section {
    padding: 70px 0;
  }

  .trusted {
    padding-top: 96px;
  }

  .trusted-logos {
    gap: 22px;
  }

  .portfolio-card {
    border-radius: 10px;
  }

  .portfolio-image {
    aspect-ratio: 1.18 / 1;
  }

  .about {
    padding-block: 76px;
  }

  .about-panel {
    padding: 34px;
  }

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

  .lead-large {
    font-size: clamp(30px, 7vw, 44px);
  }

  .service-list a {
    padding: 32px 0;
  }

  .service-list img {
    display: none;
  }

  .service-list a::after {
    right: 4px;
  }

  .design-wrap {
    grid-template-columns: 1fr;
    gap: 32px;
    min-height: 0;
    padding: 48px 34px;
  }

  .design-wrap::before {
    left: 34px;
    top: 28px;
  }

  .design-wrap::after {
    right: 22px;
    top: auto;
    bottom: 56px;
    width: 260px;
    height: 260px;
    transform: none;
  }

  .design-title,
  .contact-strip,
  .mascot {
    grid-column: 1;
    grid-row: auto;
  }

  .design-title .circle-btn {
    position: static;
    display: grid;
    margin-top: 22px;
  }

  .design-title {
    display: block;
  }

  .contact-strip {
    margin-left: 0;
  }

  .process-grid article {
    min-height: 280px;
  }

  .process {
    padding: 82px 0 88px;
  }

  .process-grid {
    grid-template-columns: 1fr;
  }

  .process-grid article,
  .process-grid article:first-child,
  .process-grid article:last-child {
    min-height: 300px;
  }

  .mark-pinwheel {
    margin-left: 0;
  }

  .mark-star {
    width: 220px;
  }

  .service-list {
    max-width: var(--container);
  }

  .service-list a {
    min-height: 128px;
    display: flex;
    padding-right: 62px;
    padding-left: 0;
  }

  .service-list a::after {
    left: auto;
    right: 4px;
    width: 42px;
    height: 42px;
    font-size: 22px;
  }

  .service-list a:hover span,
  .service-list a:focus-visible span {
    transform: translateX(0);
  }

  .design-wrap {
    min-height: auto;
  }

  .mascot {
    justify-self: start;
    width: 260px;
    opacity: 1;
  }

  .process {
    margin-top: 0;
  }

  .showreel {
    padding-bottom: 76px;
  }

  .showreel-box {
    min-height: 450px;
    padding: 58px;
  }

  .ring {
    width: 210px;
    height: 210px;
    border-width: 22px;
  }

  .ring button {
    margin-top: 64px;
  }

  .industry-grid article {
    min-height: 320px;
  }

  .tech-layout {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .tech-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
  }

  .tech-tabs button {
    padding: 8px 12px;
    border-radius: 999px;
    background: #f4f4f4;
  }

  .tech-tabs button.active,
  .tech-tabs button:hover {
    padding-left: 12px;
    background: #ececec;
    transform: none;
  }

  .tech-grid {
    grid-template-columns: repeat(4, 84px);
    justify-content: center;
  }

  .footer-grid {
    gap: 22px;
  }
}

@media (max-width: 640px) {
  .container,
  .header { width: calc(100% - 28px); }
  .hero {
    min-height: 720px;
    border-bottom-left-radius: 24px;
    border-bottom-right-radius: 24px;
  }
  .hero-content { padding-top: 140px; }
  .hero h1 {
    font-size: 48px;
    letter-spacing: -1.5px;
  }
  .dot-info {
    font-size: 12px;
    margin-bottom: 28px;
  }
  .hero p {
    position: static;
    color: rgba(255,255,255,.78);
    margin-top: 22px;
    max-width: 100%;
    font-size: 18px;
  }
  .btn-white { margin-top: 34px; }
  .trusted-logos,
  .about-stats,
  .portfolio-grid,
  .process-grid,
  .industry-grid,
  .testimonial-grid,
  .blog-grid,
  .footer-grid,
  .footer-menus,
  .clock-row { grid-template-columns: 1fr; }

  .section {
    padding: 58px 0;
  }

  .trusted {
    padding-top: 72px;
  }

  .trusted h2,
  .section h2 {
    line-height: 1.14;
  }

  .trusted-logos img {
    max-width: 130px;
  }

  .section-row {
    gap: 18px;
    margin-bottom: 24px;
  }

  .actions {
    width: 100%;
  }

  .actions .mini-btn {
    flex: 1;
    text-align: center;
  }

  .portfolio-logo {
    top: 18px;
    left: 18px;
    width: 108px;
  }

  .portfolio-meta {
    left: 18px;
    bottom: 54px;
  }

  .tags {
    gap: 7px;
  }

  .tags span {
    padding: 7px 10px;
  }

  .lead-small {
    font-size: 17px;
  }

  .about-panel {
    padding: 24px;
  }

  .lead-large {
    margin-top: 24px;
    font-size: 30px;
  }

  .services-top { gap: 20px; }
  .services {
    padding: 62px 0 0;
  }

  .services-top h2 {
    margin-bottom: 24px;
  }

  .service-list a {
    padding: 26px 54px 26px 0;
    font-size: 31px;
  }

  .service-list a::after {
    width: 34px;
    height: 34px;
    font-size: 18px;
    opacity: 1;
    transform: translateY(-50%) scale(.82);
  }

  .design-title { display: block; padding-bottom: 20px; }
  .circle-btn { margin: 18px auto 0; }
  .contact-strip { align-items: flex-start; flex-direction: column; }
  .mascot { display: block; width: min(230px, 78vw); }

  .design-wrap {
    min-height: 0;
    padding: 42px 22px 36px;
  }

  .design-wrap::before {
    left: 22px;
    top: 22px;
    width: 62px;
  }

  .design-wrap::after {
    display: none;
  }

  .contact-strip {
    padding: 22px;
    width: 100%;
  }

  .process-grid article {
    padding: 28px;
  }

  .process {
    margin-top: 0;
    padding: 64px 0 72px;
  }

  .process h2 {
    margin-bottom: 32px;
    font-size: 34px;
  }

  .process-grid article,
  .process-grid article:first-child,
  .process-grid article:last-child {
    min-height: auto;
    padding: 26px;
  }

  .process-step {
    width: 52px;
    height: 52px;
    margin-bottom: 32px;
  }

  .mark-star {
    width: min(220px, 100%);
    height: 130px;
  }

  .video-play {
    min-width: 72px;
    min-height: 72px;
    font-size: 12px;
  }

  .process-grid b {
    margin-top: 38px;
    font-size: 48px;
  }

  .showreel-box {
    min-height: 420px;
    padding: 54px 24px;
    flex-direction: column;
    gap: 28px;
  }

  .showreel-box::before {
    width: 210px;
  }

  .ring {
    width: 160px;
    height: 160px;
    border-width: 18px;
  }

  .ring button {
    width: 50px;
    height: 50px;
    margin-top: 37px;
    border-width: 7px;
  }

  .industry-grid article {
    min-height: 300px;
  }

  .tech-wrap h2 {
    font-size: 28px;
  }

  .tech-grid {
    grid-template-columns: repeat(2, 84px);
    gap: 24px 18px;
  }

  .tech-tabs {
    gap: 8px;
  }

  .innovation-card > div:last-child {
    padding: 30px 24px;
  }

  .innovation-art,
  .innovation-art img:first-child,
  .innovation-art video {
    min-height: 230px;
    height: 230px;
  }

  .innovation-art img:last-child {
    width: 128px;
  }

  .testimonial-grid article {
    min-height: auto;
    padding: 28px;
  }

  .testimonial-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .testimonial-slide {
    min-height: auto;
    padding: 30px 24px;
  }

  .testimonial-avatar {
    position: static;
    width: 76px;
    height: 76px;
    margin-bottom: 22px;
  }

  .testimonial-slide p {
    font-size: 21px;
  }

  .blog-grid {
    gap: 28px;
    margin-top: 26px;
  }

  .latest-blog .section-row {
    align-items: start;
  }

  .blog-grid h3 {
    min-height: 0;
  }

  .service-marquee {
    gap: 36px;
    padding: 22px 18px 32px;
  }

  .footer {
    padding-top: 50px;
  }

  .email-box {
    align-items: center;
    gap: 16px;
    padding: 18px;
    overflow-wrap: anywhere;
  }

  .footer-menus > div,
  .achievements,
  .quote-form {
    padding: 22px;
  }

  .achievements div {
    grid-template-columns: 1fr 1fr;
  }

  .quote-form button {
    justify-self: stretch;
  }
}
