* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Satoshi', Arial, sans-serif;
  background: #1C1B23;
  color: #DFDBD6;
  font-size: 16px;
  overflow-x: hidden;
}

header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 24px 48px;
  max-width: 1180px;
  margin: 0 auto;
  position: relative;
  z-index: 10;
}

.logo { height: 32px; width: auto; }

.logo-text {
  font-family: 'DM Serif Display', serif;
  font-size: 20px;
  color: #DFDBD6;
  text-decoration: none;
  letter-spacing: -0.02em;
}

nav a {
  margin-left: 28px;
  color: #6b6a72;
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  position: relative;
  transition: color 0.2s;
}

nav a::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 1px;
  background: #20becd;
  transition: width 0.25s ease;
}

nav a:hover { color: #DFDBD6; }
nav a:hover::after { width: 100%; }

.hero {
  position: relative;
  padding: 110px 48px 120px;
  max-width: 1180px;
  margin: 0 auto;
  z-index: 1;
}

.eyebrow {
  color: #20becd;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 32px;
}

h1 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(48px, 7vw, 88px);
  line-height: 1.0;
  letter-spacing: -0.02em;
  font-weight: 400;
  margin-bottom: 32px;
  max-width: 900px;
  color: #DFDBD6;
}

h1 em { font-style: italic; color: #20becd; }

.intro {
  font-size: 18px;
  line-height: 1.7;
  color: #8a8994;
  max-width: 580px;
  margin-bottom: 44px;
}

.button {
  display: inline-block;
  background: #20becd;
  color: #1C1B23;
  text-decoration: none;
  padding: 14px 28px;
  font-size: 14px;
  font-weight: 500;
  border-radius: 6px;
  transition: background 0.2s, transform 0.15s;
}

.button:hover { background: #2dd4e8; transform: translateY(-2px); }

.statement-section {
  padding: 100px 48px 110px;
  max-width: 1180px;
  margin: 0 auto;
  border-top: 1px solid #28272f;
  position: relative;
  z-index: 1;
}

.teal-line {
  width: 48px;
  height: 3px;
  background: #20becd;
  margin-bottom: 40px;
  border-radius: 2px;
}

.statement {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(36px, 5.5vw, 68px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 400;
  color: #DFDBD6;
  max-width: 820px;
  margin-bottom: 32px;
}

.statement-section p {
  color: #8a8994;
  max-width: 580px;
  font-size: 17px;
  line-height: 1.75;
}

.services {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 0 100px;
  position: relative;
  z-index: 1;
}

.service {
  border-top: 1px solid #28272f;
  padding: 36px 48px;
  display: grid;
  grid-template-columns: 64px 1fr 1.2fr auto;
  gap: 32px;
  align-items: center;
  text-decoration: none;
  transition: background 0.25s ease;
  cursor: pointer;
}

.service:last-child { border-bottom: 1px solid #28272f; }

.service .num {
  color: #20becd;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  transition: color 0.25s;
}

.service h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(26px, 3.5vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 400;
  color: #DFDBD6;
  transition: color 0.25s;
}

.service p {
  color: #8a8994;
  font-size: 16px;
  line-height: 1.7;
  max-width: 460px;
  transition: color 0.25s;
}

.service .arrow {
  color: #28272f;
  font-size: 22px;
  transition: color 0.25s, transform 0.25s;
  justify-self: end;
}

.service:hover { background: #20becd; }
.service:hover .num { color: #1C1B23; }
.service:hover h2 { color: #1C1B23; }
.service:hover p { color: #0d4a52; }
.service:hover .arrow { color: #1C1B23; transform: translateX(4px); }

.service.tapped { background: #20becd; }
.service.tapped .num { color: #1C1B23; }
.service.tapped h2 { color: #1C1B23; }
.service.tapped p { color: #0d4a52; }
.service.tapped .arrow { color: #1C1B23; }

.clients-section {
  padding: 90px 48px 110px;
  max-width: 1180px;
  margin: 0 auto;
  border-top: 1px solid #28272f;
  position: relative;
  z-index: 1;
}

.clients-label {
  color: #20becd;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 40px;
}

.clients-statement {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(28px, 4vw, 52px);
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-weight: 400;
  color: #DFDBD6;
  max-width: 820px;
}

.clients-statement em { font-style: italic; color: #20becd; }

.closing-wrap {
  padding: 60px 48px 80px;
  position: relative;
  z-index: 1;
}

.closing {
  background: #DFDBD6;
  border-radius: 16px;
  padding: 80px 64px;
  max-width: 1180px;
  margin: 0 auto;
}

.closing h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(32px, 4.5vw, 58px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 400;
  max-width: 640px;
  margin-bottom: 20px;
  color: #1C1B23;
}

.closing p {
  font-size: 17px;
  color: #5a5855;
  max-width: 520px;
  line-height: 1.7;
  margin-bottom: 40px;
}

.button-dark {
  display: inline-block;
  background: #1C1B23;
  color: #DFDBD6;
  text-decoration: none;
  padding: 14px 28px;
  font-size: 14px;
  font-weight: 500;
  border-radius: 6px;
  transition: background 0.2s, transform 0.15s;
}

.button-dark:hover { background: #20becd; color: #1C1B23; transform: translateY(-2px); }

footer {
  border-top: 1px solid #28272f;
  padding: 28px 48px 44px;
  max-width: 1180px;
  margin: 0 auto;
  color: #4e4d55;
  font-size: 13px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  z-index: 1;
}

footer a { color: #20becd; text-decoration: none; }

@media (max-width: 768px) {
  header { padding: 20px; align-items: center; }
  .logo { height: 24px; }
  nav { display: flex; align-items: center; }
  nav a { margin-left: 16px; font-size: 13px; }
  .hero { padding: 60px 20px 70px; }
  .statement-section { padding: 60px 20px 70px; }
  .services { padding: 0 0 60px; }
  .service {
    padding: 28px 20px;
    grid-template-columns: 40px 1fr auto;
    grid-template-rows: auto auto;
    gap: 12px;
  }
  .service p { grid-column: 2 / 4; font-size: 15px; }
  .service .arrow { align-self: start; padding-top: 6px; }
  .clients-section { padding: 60px 20px 70px; }
  .closing-wrap { padding: 40px 20px 60px; }
  .closing { padding: 48px 32px; border-radius: 12px; }
  footer { padding: 24px 20px 36px; flex-direction: column; align-items: flex-start; gap: 8px; }
}1~* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Satoshi', Arial, sans-serif;
  background: #1C1B23;
  color: #DFDBD6;
  font-size: 16px;
  overflow-x: hidden;
}

header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 24px 48px;
  max-width: 1180px;
  margin: 0 auto;
  position: relative;
  z-index: 10;
}

.logo { height: 32px; width: auto; }

.logo-text {
  font-family: 'DM Serif Display', serif;
  font-size: 20px;
  color: #DFDBD6;
  text-decoration: none;
  letter-spacing: -0.02em;
}

nav a {
  margin-left: 28px;
  color: #6b6a72;
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  position: relative;
  transition: color 0.2s;
}

nav a::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 1px;
  background: #20becd;
  transition: width 0.25s ease;
}

nav a:hover { color: #DFDBD6; }
nav a:hover::after { width: 100%; }

.hero {
  position: relative;
  padding: 110px 48px 120px;
  max-width: 1180px;
  margin: 0 auto;
  z-index: 1;
}

.eyebrow {
  color: #20becd;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 32px;
}

h1 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(48px, 7vw, 88px);
  line-height: 1.0;
  letter-spacing: -0.02em;
  font-weight: 400;
  margin-bottom: 32px;
  max-width: 900px;
  color: #DFDBD6;
}

h1 em { font-style: italic; color: #20becd; }

.intro {
  font-size: 18px;
  line-height: 1.7;
  color: #8a8994;
  max-width: 580px;
  margin-bottom: 44px;
}

.button {
  display: inline-block;
  background: #20becd;
  color: #1C1B23;
  text-decoration: none;
  padding: 14px 28px;
  font-size: 14px;
  font-weight: 500;
  border-radius: 6px;
  transition: background 0.2s, transform 0.15s;
}

.button:hover { background: #2dd4e8; transform: translateY(-2px); }

.statement-section {
  padding: 100px 48px 110px;
  max-width: 1180px;
  margin: 0 auto;
  border-top: 1px solid #28272f;
  position: relative;
  z-index: 1;
}

.teal-line {
  width: 48px;
  height: 3px;
  background: #20becd;
  margin-bottom: 40px;
  border-radius: 2px;
}

.statement {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(36px, 5.5vw, 68px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 400;
  color: #DFDBD6;
  max-width: 820px;
  margin-bottom: 32px;
}

.statement-section p {
  color: #8a8994;
  max-width: 580px;
  font-size: 17px;
  line-height: 1.75;
}

.services {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 0 100px;
  position: relative;
  z-index: 1;
}

.service {
  border-top: 1px solid #28272f;
  padding: 36px 48px;
  display: grid;
  grid-template-columns: 64px 1fr 1.2fr auto;
  gap: 32px;
  align-items: center;
  text-decoration: none;
  transition: background 0.25s ease;
  cursor: pointer;
}

.service:last-child { border-bottom: 1px solid #28272f; }

.service .num {
  color: #20becd;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  transition: color 0.25s;
}

.service h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(26px, 3.5vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 400;
  color: #DFDBD6;
  transition: color 0.25s;
}

.service p {
  color: #8a8994;
  font-size: 16px;
  line-height: 1.7;
  max-width: 460px;
  transition: color 0.25s;
}

.service .arrow {
  color: #28272f;
  font-size: 22px;
  transition: color 0.25s, transform 0.25s;
  justify-self: end;
}

.service:hover { background: #20becd; }
.service:hover .num { color: #1C1B23; }
.service:hover h2 { color: #1C1B23; }
.service:hover p { color: #0d4a52; }
.service:hover .arrow { color: #1C1B23; transform: translateX(4px); }

.service.tapped { background: #20becd; }
.service.tapped .num { color: #1C1B23; }
.service.tapped h2 { color: #1C1B23; }
.service.tapped p { color: #0d4a52; }
.service.tapped .arrow { color: #1C1B23; }

.clients-section {
  padding: 90px 48px 110px;
  max-width: 1180px;
  margin: 0 auto;
  border-top: 1px solid #28272f;
  position: relative;
  z-index: 1;
}

.clients-label {
  color: #20becd;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 40px;
}

.clients-statement {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(28px, 4vw, 52px);
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-weight: 400;
  color: #DFDBD6;
  max-width: 820px;
}

.clients-statement em { font-style: italic; color: #20becd; }

.closing-wrap {
  padding: 60px 48px 80px;
  position: relative;
  z-index: 1;
}

.closing {
  background: #DFDBD6;
  border-radius: 16px;
  padding: 80px 64px;
  max-width: 1180px;
  margin: 0 auto;
}

.closing h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(32px, 4.5vw, 58px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 400;
  max-width: 640px;
  margin-bottom: 20px;
  color: #1C1B23;
}

.closing p {
  font-size: 17px;
  color: #5a5855;
  max-width: 520px;
  line-height: 1.7;
  margin-bottom: 40px;
}

.button-dark {
  display: inline-block;
  background: #1C1B23;
  color: #DFDBD6;
  text-decoration: none;
  padding: 14px 28px;
  font-size: 14px;
  font-weight: 500;
  border-radius: 6px;
  transition: background 0.2s, transform 0.15s;
}

.button-dark:hover { background: #20becd; color: #1C1B23; transform: translateY(-2px); }

footer {
  border-top: 1px solid #28272f;
  padding: 28px 48px 44px;
  max-width: 1180px;
  margin: 0 auto;
  color: #4e4d55;
  font-size: 13px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  z-index: 1;
}

footer a { color: #20becd; text-decoration: none; }

@media (max-width: 768px) {
  header { padding: 20px; align-items: center; }
  .logo { height: 24px; }
  nav { display: flex; align-items: center; }
  nav a { margin-left: 16px; font-size: 13px; }
  .hero { padding: 60px 20px 70px; }
  .statement-section { padding: 60px 20px 70px; }
  .services { padding: 0 0 60px; }
  .service {
    padding: 28px 20px;
    grid-template-columns: 40px 1fr auto;
    grid-template-rows: auto auto;
    gap: 12px;
  }
  .service p { grid-column: 2 / 4; font-size: 15px; }
  .service .arrow { align-self: start; padding-top: 6px; }
  .clients-section { padding: 60px 20px 70px; }
  .closing-wrap { padding: 40px 20px 60px; }
  .closing { padding: 48px 32px; border-radius: 12px; }
  footer { padding: 24px 20px 36px; flex-direction: column; align-items: flex-start; gap: 8px; }
}
