.kv_section {
  position: relative;
  z-index: 2;
}
@media (min-width: 769px) {
  .kv_section {
    padding: 0 10px 4.5rem;
  }
}
@media (max-width: 768px) {
  .kv_section {
    padding: 3.6rem 20px 5rem;
  }
}
.kv_section::after {
  content: "";
  position: absolute;
  background-position: center top;
  background-repeat: no-repeat;
  background-size: contain;
  left: 0;
  right: 0;
  top: calc(100% - 1px);
  margin: 0 auto;
  pointer-events: none;
}
@media (min-width: 769px) {
  .kv_section::after {
    background-image: url(../img/top/kv_bg_pc.png);
    width: 26rem;
    height: calc(5.5rem + 1px);
  }
}
@media (max-width: 768px) {
  .kv_section::after {
    background-image: url(../img/top/kv_bg_sp.png);
    width: 19.5rem;
    height: calc(4.3rem + 1px);
  }
}

.kv_image {
  position: relative;
}
@media (min-width: 769px) {
  .kv_image {
    max-width: 102.6rem;
    margin: 0 auto;
  }
}
@media (max-width: 768px) {
  .kv_image {
    width: 100dvw;
    margin: 0 -20px;
  }
}

.kv_lead {
  letter-spacing: 0.05em;
  font-weight: 700;
  color: #282896;
}
@media (min-width: 769px) {
  .kv_lead {
    padding-top: 2.5rem;
    line-height: 1.546;
    font-size: 2.2rem;
    text-align: center;
  }
  .kv_lead > p {
    font: inherit;
  }
  .kv_lead > p:first-of-type {
    margin-top: -0.272em;
  }
  .kv_lead > p:last-of-type {
    margin-bottom: -0.272em;
  }
}
@media (max-width: 768px) {
  .kv_lead {
    display: flex;
    justify-content: center;
    padding-top: 3rem;
    line-height: 1.715;
    font-size: 1.4rem;
  }
  .kv_lead > p {
    font: inherit;
  }
  .kv_lead > p:first-of-type {
    margin-top: -0.357em;
  }
  .kv_lead > p:last-of-type {
    margin-bottom: -0.357em;
  }
}

.techs_section {
  position: relative;
  background: #00bee6;
}
@media (min-width: 769px) {
  .techs_section {
    padding: 12rem 5px 28.5rem;
  }
}
@media (max-width: 768px) {
  .techs_section {
    padding: 8rem 0 22.3rem;
  }
}
.techs_section::after {
  content: "";
  position: absolute;
  background-image: url(../img/top/bottom.png);
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: contain;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
  pointer-events: none;
}
@media (min-width: 769px) {
  .techs_section::after {
    width: 24.6rem;
    height: 22.7rem;
  }
}
@media (max-width: 768px) {
  .techs_section::after {
    width: 21.1rem;
    height: 19.5rem;
  }
}

.techs_section_lead {
  color: #282896;
  text-align: center;
  font-weight: 700;
}
@media (min-width: 769px) {
  .techs_section_lead {
    margin-bottom: 7rem;
    line-height: 1.546;
    font-size: 2.2rem;
  }
  .techs_section_lead > p {
    font: inherit;
  }
  .techs_section_lead > p:first-of-type {
    margin-top: -0.272em;
  }
  .techs_section_lead > p:last-of-type {
    margin-bottom: -0.272em;
  }
}
@media (max-width: 768px) {
  .techs_section_lead {
    margin-bottom: 4rem;
    line-height: 1.715;
    font-size: 1.4rem;
  }
  .techs_section_lead > p {
    font: inherit;
  }
  .techs_section_lead > p:first-of-type {
    margin-top: -0.357em;
  }
  .techs_section_lead > p:last-of-type {
    margin-bottom: -0.357em;
  }
}

.techs_list {
  display: grid;
  justify-content: center;
  margin: 0 auto;
}
@media (min-width: 769px) {
  .techs_list {
    grid-template-columns: repeat(3, 1fr);
    gap: 6.4rem 3.2rem;
    max-width: 112rem;
  }
  .techs_list.nomore::after {
    content: "";
    display: block;
    background-image: url(../img/top/link_bg_comingsoon.png);
    background-position: right bottom;
    background-repeat: no-repeat;
    background-size: contain;
  }
}
@media (max-width: 768px) {
  .techs_list {
    gap: 3.5rem;
    grid-template-columns: 30.2rem;
    padding-right: 0.2rem;
  }
}

.techs_link {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  background-position: right bottom;
  background-repeat: no-repeat;
  background-size: contain;
}
@media (min-width: 769px) {
  .techs_link {
    row-gap: 2rem;
    height: 27.6rem;
    padding: 5rem 3.5rem 0 3.7rem;
  }
}
@media (max-width: 768px) {
  .techs_link {
    row-gap: 1.5rem;
    height: 23.68rem;
    padding: 4.25rem 3rem 0 3.2rem;
  }
}
.techs_link::before {
  content: "";
  position: absolute;
  background-image: url(../img/top/link_hover.png);
  background-position: right bottom;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  width: 10.796%;
  height: 13.769%;
  right: 3.694%;
  bottom: 10.145%;
  pointer-events: none;
}
@media (min-width: 769px) {
  .techs_link::before {
    opacity: 0;
  }
}
.techs_link:hover::before {
  opacity: 1;
}
.techs_link.col1 {
  background-image: url(../img/top/link_bg1.png);
}
.techs_link.col2 {
  background-image: url(../img/top/link_bg2.png);
}
.techs_link.col3 {
  background-image: url(../img/top/link_bg3.png);
}
.techs_link.col4 {
  background-image: url(../img/top/link_bg4.png);
}
.techs_link_number {
  width: 18.858%;
}
.techs_link_h2 {
  letter-spacing: 0.05em;
  font-weight: 700;
  text-align: center;
  color: #282896;
}
@media (min-width: 769px) {
  .techs_link_h2 {
    line-height: 1.364;
    font-size: 2.2rem;
  }
  .techs_link_h2 > h2 {
    font: inherit;
  }
  .techs_link_h2 > h2:first-of-type {
    margin-top: -0.181em;
  }
  .techs_link_h2 > h2:last-of-type {
    margin-bottom: -0.181em;
  }
}
@media (max-width: 768px) {
  .techs_link_h2 {
    line-height: 1.445;
    font-size: 1.8rem;
  }
  .techs_link_h2 > h2 {
    font: inherit;
  }
  .techs_link_h2 > h2:first-of-type {
    margin-top: -0.222em;
  }
  .techs_link_h2 > h2:last-of-type {
    margin-bottom: -0.222em;
  }
}
.techs_link_p {
  letter-spacing: 0.05em;
  text-align: justify;
}
@media (min-width: 769px) {
  .techs_link_p {
    line-height: 1.715;
    font-size: 1.4rem;
  }
  .techs_link_p > p {
    font: inherit;
  }
  .techs_link_p > p:first-of-type {
    margin-top: -0.357em;
  }
  .techs_link_p > p:last-of-type {
    margin-bottom: -0.357em;
  }
}
@media (max-width: 768px) {
  .techs_link_p {
    line-height: 1.667;
    font-size: 1.2rem;
  }
  .techs_link_p > p {
    font: inherit;
  }
  .techs_link_p > p:first-of-type {
    margin-top: -0.333em;
  }
  .techs_link_p > p:last-of-type {
    margin-bottom: -0.333em;
  }
}
.techs_link_image {
  position: absolute;
}
.techs_link_image.pos1 {
  width: 21.023%;
  right: 8.807%;
  top: -6.521%;
}
.techs_link_image.pos2 {
  width: 27.841%;
  right: 5.682%;
  top: -2.536%;
}
.techs_link_image.pos3 {
  width: 20.171%;
  right: 5.398%;
  top: -8.695%;
}
.techs_link_image.pos4 {
  width: 11.932%;
  right: 13.637%;
  top: -6.884%;
}
.techs_link_image.pos5 {
  width: 24.432%;
  right: 9.66%;
  top: -5.434%;
}
.techs_link_image.pos6 {
  width: 15.91%;
  right: 10.228%;
  top: -8.695%;
}
.techs_link_image.pos7 {
  width: 18.182%;
  right: 10.228%;
  top: -4.347%;
}

.techs_lead {
  letter-spacing: 0.05em;
  font-weight: 700;
  color: #282896;
}
@media (min-width: 769px) {
  .techs_lead {
    padding-top: 10rem;
    line-height: 1.637;
    font-size: 2.2rem;
    text-align: center;
  }
  .techs_lead > p {
    font: inherit;
  }
  .techs_lead > p:first-of-type {
    margin-top: -0.318em;
  }
  .techs_lead > p:last-of-type {
    margin-bottom: -0.318em;
  }
}
@media (max-width: 768px) {
  .techs_lead {
    display: flex;
    justify-content: center;
    padding-top: 4.5rem;
    line-height: 1.715;
    font-size: 1.4rem;
  }
  .techs_lead > p {
    font: inherit;
  }
  .techs_lead > p:first-of-type {
    margin-top: -0.357em;
  }
  .techs_lead > p:last-of-type {
    margin-bottom: -0.357em;
  }
}

.techs_note {
  position: absolute;
}
@media (min-width: 769px) {
  .techs_note {
    right: calc(50% + 56rem);
    bottom: 2rem;
    padding-left: 10px;
    translate: 100% 0;
    white-space: nowrap;
  }
}
@media (max-width: 768px) {
  .techs_note {
    left: 1.3rem;
    bottom: 1.25rem;
  }
}
.techs_note_link {
  letter-spacing: 0.05em;
  text-decoration: underline;
  color: #282896;
}
@media (min-width: 769px) {
  .techs_note_link {
    line-height: 1.5;
    font-size: 1.2rem;
  }
}
@media (max-width: 768px) {
  .techs_note_link {
    line-height: 1.5;
    font-size: 1rem;
  }
}
.techs_note_link:hover {
  text-decoration: none;
}