@charset "UTF-8";

.pc-hide {
  display: none !important;
}

.cy-sec-bnWrap ul {
  display: flex;
  list-style: none;
  justify-content: space-between;
  gap: 15px;
  margin-bottom: 30px;
}

.cy-sec-bnWrap {
  margin: 30px 0;
}

.cy-sec-bn-leaflet {
  text-align: center;
}

.cy-sec-bn-leaflet p {
  display: inline-block;
  padding: 10px 45px;
  border: solid 5px #48ACB1;
  border-radius: 15px;
  font-weight: bold;
}

.cy-sec-kujyou {
  text-align: center;
  margin-top: 100px;
}

.cyber-security-h3 {
  margin-bottom: 40px;
}

.cy-sec-imgWrap {
  margin: 30px auto 40px;
}

.cy-sec-btnWrap {
  margin: auto;
}

.cy-sec-btn {
  font-weight: bold;
  color: #fff;
  background-color: #48ACB1;
  border-radius: 40px;
  display: inline-block;
  padding: 15px 30px 15px 25px;
  position: relative;
  min-width: 200px;
  text-align: center !important;
}

.cy-sec-btn::after {
  content: "";
  position: absolute;
  right: 1.5rem;
  top: 50%;
  transform: translateY(-50%);
  width: 13px;
  height: 12px;
  background-image: url(/imgs/link-arrow-w.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}

.cy-sec-contentsBox {
  margin-bottom: 60px;
}

.cy-sec-senryu,
.cy-sec-leaflet {
  text-align: center;
  /*padding-top: 30px;*/
}

.cy-sec-contentsBox h3 {
  font-weight: bold;
  font-size: 24px;
  margin-bottom: 30px;
  max-width: 700px;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.cy-sec-leaflet-text {
  margin-bottom: 30px;
  text-align-last: left;
}

.cy-sec-kasou-text {
  margin: 40px auto;
  text-align: center;
}

.cy-sec-movie-title {
  margin: 20px auto 20px;
}

.cy-sec-movie-text {
  margin-bottom: 20px;
}

.cy-sec-btn02 {
  padding-right: 40px;
}

.justify_con-center {
  justify-content: center;
}

.cy-sec-hr {
  border-top: 1px dashed #48ACB1;
  width: 100%;
  max-width: 100%;
  margin: 60px auto;
}

.cy-sec-btnOuter .cy-sec-btnWrap {
  display: inline-block;
  margin-left: 0;
  margin-right: 0;

}

.cy-sec-btnOuter {
  display: flex;
  justify-content: center;
  gap: 20px;
}

.cy-sec-wallpaper {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-top: 100px;
}

.cy-sec-wallpaperBox {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
}

.cy-sec-wallpaperBox img {
  height: 100%;
  width: auto;
}

.cy-sec-wallpaperBox .cy-sec-btnWrap {
  margin-top: 20px;
}


.cy-sec-senryu-contets {
  text-align: center;
}

.cy-sec-senryu-contets .cy-sec-wallpaperBox {
  width: 50%;
}

.cy-sec-btnWrap img {
  width: 350px;
  height: auto;
}

.mt20 {
  margin-top: 20px;
}

.mt60 {
  margin-top: 60px;
}

.cy-sec-top-btnWrap {
  border-radius: 10px;
  background-color: #488eb1;
}

.btn .content-wrapper .icon {
  background-color: #48ACB1 !important;
}

#top-return.btn {
  color: #48ACB1 !important;
}

#top-return {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

#top-return.show {
  opacity: 1;
  visibility: visible;
}

.l-section_top01 h1.c-title01 {
  max-width: 700px;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  min-width: auto;
}

.l-section {
  padding-top: 0 !important;
}

@media (max-width: 768px) {
  .pc-hide {
    display: block !important;
  }

  .pc-hide.flex {
    display: flex !important;
  }

  .sp-hide {
    display: none !important;
  }

  .cy-sec-bnWrap ul {
    flex-direction: column;
    align-items: center;
  }

  .cy-sec-bnWrap ul img {
    max-width: 200px;
  }

  .cy-sec-contentsBox p {
    text-align: left;
  }

  .grid-x>.cell-movie:first-child {
    margin-bottom: 40px !important;
  }

  .cy-sec-btnOuter {
    flex-direction: column;
    align-items: center;
  }

  .cy-sec-wallpaper {
    flex-direction: column;
    gap: 40px;
  }

  .cy-sec-wallpaper.senryu-box {
    margin-top: 40px;
  }

  .cy-sec-senryu-contets .cy-sec-wallpaperBox {
    width: 100%;
  }

  .cy-sec-kasou-text {
    text-align-last: left;
  }
}