.contents-footer {
	position: relative;
  }
  
  .sub-tl-box {
	gap: 138px;
	margin-top: 11px;
  }
  .sub-tl-lead {
	display: inline-block;
	margin-top: auto;
	flex-basis: 63%;
	max-width: 638px;
  }
  .sub-tl {
	font-size: 50px;
  }
  
  
  section#future {
	position: relative;
	min-height: 966px;
	height: 51vw;
	z-index: 0;
  }
  section#future::before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background-position: center;
	background-image: url(/assets/image/jp/ja/company/group/hfd/60th/future/p-future-bg.png);
	background-size: cover;
	background-repeat: no-repeat;
	z-index: -1;
  }
  section#future::after {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background-position: bottom;
	background-image: url(/assets/image/jp/ja/company/group/hfd/60th/future/p-future-bg-txt.svg);
	background-size: 95%;
	background-repeat: no-repeat;
	z-index: -1;
	bottom: 0;
  }
  .grid.--future {
	max-width: 1275px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(212px, 1fr));
	grid-auto-rows: auto;
	grid-gap: 14px 0;
	justify-items: center;
	padding-top: 73px;
	}
	div.box1 {
	  max-width: 218px;
	  top: 113px;
	}
	div.box2 {
	  max-width: 248px;
	  left: clamp(0rem, -12.326rem + 18.6vw, 2.5rem);
	  top: 29px;
	}
	div.box3 {
	  max-width: 234px;
	  right: clamp(0rem, -1.893rem + 3.94vw, 1.25rem);
	  top: 209px;
	}
	div.box4 {
	  max-width: 250px;
	  left: clamp(0rem, -12.326rem + 18.6vw, 2.5rem);
	}
	div.box5 {
	  max-width: 247px;
	  right: clamp(0rem, -2.764rem + 5.04vw, 1.25rem);
	  top: clamp(6.25rem, -10.613rem + 30.73vw, 13.875rem);
	}
	div.box6 {
	  max-width: 230px;
	  top: 27px;
	}
	div.box1 > img {
	  bottom: 25px;
	}
	div.box2 > img {
	  bottom: 28px;
	}
	div.box3 > img {
	  bottom: 13px;
	  left: 30px;
	}
	div.box4 > img {
	  bottom: 18px;
	  left: 10px;
	}
	div.box4 > img {
	  bottom: 10px;
	  left: 10px;
	}
	div.box6 > img {
	  left: 60px;
	  bottom: 31px;
	}
	div[class^="box"] > img,
	div[class^="box"] {
	  position: relative;
	  z-index: 0;
	}
	div[class^="box"] > div {
	  display: flex;
	  flex-direction: column;
	  position: relative;
	  filter: drop-shadow(4px 4px 4px rgba(0, 0, 0, 0.07));
	}
	div.box1 > div {
	  width: 88%;
	  padding: 18px 10px 18px 20px;
	}
	div.box2 > div {
	  width: min(248px,90%);
	  padding: 18px 15px 14px 20px;
	}
	div.box3 > div {
	  width: clamp(12.688rem, 11.835rem + 1.78vw, 13.25rem);
	  padding: 18px 15px 25px 20px;
	}
	div.box4 > div {
	  width: clamp(11.25rem, 8.22rem + 6.31vw, 13.25rem);
	  padding: 18px 16px 14px 20px;
	}
	div.box5 > div {
	  width: clamp(13.063rem, 10.033rem + 6.31vw, 15.063rem);
	  padding: 18px 15px 23px 20px;
	}
	div.box6 > div {
	  width: 93%;
	  padding: 18px 14px 52px 20px;
	}
  
	div[class^="box"] > div:after {
	  content: '';
	  position: absolute;
	  width: 20px;
	  height: 27px;
	  clip-path: polygon(0% 30%, 0% 100%, 70% 30%);
	  background-color: #fff;
	  bottom: -13px;
	  right: 25%;
	  z-index: 10;
	  border-radius: 9%;
	}
	div.box3 > div:after,
	div.box5 > div:after,
	div.box6 > div:after {
	  width: 20px;
	  height: 27px;
	  clip-path: polygon(0% 30%, 90% 100%, 70% 30%);
	  bottom: -13px;
	  left: 15%;
	}
	div[class^="box"] p {
	  font-weight: 500;
	  line-height: 180%;
	  margin-bottom: 12px !important;
	}
	div[class^="box"] a {
	  color: #000 !important;
	  text-decoration: none !important;
	  position: relative;
	  display: flex;
	  align-items: center;
	  justify-content: flex-end;
	  gap: 8px;
	}
	div[class^="box"] a:after {
	  position: absolute;
	  background-color: #D40000;
	  content: "";
	  width: 110px;
	  height: 1px;
	  bottom: -3px;
	  right: 0;
	}
	span.arrow {
	  content: "";
	  background-image: url(/assets/image/jp/ja/company/group/hfd/60th/future/icon_arrow.png);
	  background-repeat: no-repeat;
	  background-size: contain;
	  width: 19px;
	  height: 19px;
  
	}
	div[class^="box"] > div p::before {
	  position: absolute;
	  z-index: -1;
	  content: "";
	  background: #fff;
	  background-size: contain;
	  background-repeat: no-repeat;
	  top: 0;
	  left: 0;
	  box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.07);
	  border-radius: 10px;
	  width: 100%;
	}
	div.box1 > div p::before {
	  height: 158px;
	}
	div.box2 > div p::before {
	  height: 126px;
	}
	div.box3 > div p::before {
	  height: 167px;
	}
	div.box4 > div p::before {
	  height: 127px;
	}
	div.box5 > div p::before {
	  height: 136px;
	}
	div.box6 > div p::before {
	  height: 160px;
	}
  
  section#future.--en .box1 > div p::before {
	height: 218px;
  }
  section#future.--en div.box2 > div p::before {
	height: 155px;
  }
  section#future.--en div.box3 > div p::before {
	height: 249px;
  }
  section#future.--en div.box4 > div p::before {
	height: 154px;
  }
  section#future.--en div.box5 > div p::before {
	height: 161px;
  }
  section#future.--en div.box6 > div p::before {
	height: 221px;
  }
  
  @media screen and (max-width: 878px) {
	div[class^="box"] {
	  top: unset;
	}
  }
  @media screen and (max-width: 768px) {
	section#future {
	  min-height: fit-content;
	  height: 51vw;
  }
	div.box2,div.box4 {
	  left: 0px;
  }
  .grid.--future {
	grid-template-columns: repeat(2, 1fr);
	padding-top: 40px;
  }
  }
  @media screen and (max-width: 500px) {
	.grid.--future {
	  grid-template-columns: repeat(1, 1fr);
	}
	  div[class^="box"] {
	  top: unset;
	}
  }