@charset "UTF-8";
/*============================common==================================*/
body {
  margin: 0;
  padding: 0;
  font-size: 0;
  font-family: "Helvetica Neue", Helvetica, "Noto Sans JP";
}

/*pcのみ表示*/
.pc {
  display: block;
}
@media only screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}

.pc-line {
  display: inline-block;
}
@media only screen and (max-width: 767px) {
  .pc-line {
    display: none;
  }
}

/*spのみ表示*/
.sp {
  display: none !important;
}
@media only screen and (max-width: 767px) {
  .sp {
    display: block !important;
  }
}

.sp-line {
  display: none;
}
@media only screen and (max-width: 767px) {
  .sp-line {
    display: inline-block;
  }
}

/*500px表示*/
.sp-middle {
  display: none !important;
}
@media only screen and (max-width: 500px) {
  .sp-middle {
    display: block !important;
  }
}

@media only screen and (min-width: 768px) {
  .pc-middle {
    display: none !important;
  }
}
@media only screen and (max-width: 767px) and (min-width: 501px) {
  .pc-middle {
    display: block !important;
  }
}
@media only screen and (max-width: 500px) {
  .pc-middle {
    display: none !important;
  }
}
@media only screen and (max-width: 767px) and (min-width: 501px) {
  .pc-middle.FB {
    display: flex !important;
  }
}

/* 1000-768px対応 */
.resToMM {
  display: block;
}
@media only screen and (max-width: 1000px) and (min-width: 768px) {
  .resToMM {
    display: none;
  }
}

.resFromMM {
  display: none;
}
@media only screen and (max-width: 1110px) and (min-width: 768px) {
  .resFromMM {
    display: block;
  }
}

/* 1000-768px対応 */
.resToMM {
  display: block;
}
@media only screen and (max-width: 1110px) and (min-width: 768px) {
  .resToMM {
    display: none;
  }
}

.resFromMM {
  display: none;
}
@media only screen and (max-width: 1110px) and (min-width: 768px) {
  .resFromMM {
    display: block;
  }
}

.emphasis {
  color: #DD020F;
}

h1, h2, h3 {
  font-weight: bold;
}

h1, h2, h3, h4, h5, h6, p {
  margin: 0;
  padding: 0;
  text-align: center;
  font-feature-settings: "palt";
}
@media only screen and (max-width: 767px) {
  h1, h2, h3, h4, h5, h6, p {
    margin: 0 auto;
    width: 90%;
  }
}

h1 {
  font-size: 60px;
}

h2 {
  font-size: 36px;
}
@media only screen and (max-width: 767px) {
  h2 {
    font-size: 30px;
  }
}

h3 {
  letter-spacing: 0.1em;
  font-size: 36px;
}
@media only screen and (max-width: 767px) {
  h3 {
    font-size: 28px;
  }
}

h4 {
  letter-spacing: 0.1em;
  font-size: 32px;
}
@media only screen and (max-width: 767px) {
  h4 {
    font-size: 28px;
  }
}

h5 {
  font-size: 20px;
}
@media only screen and (max-width: 767px) {
  h5 {
    font-size: 20px;
  }
}

p {
  font-size: 18px;
  line-height: 2;
}
@media only screen and (max-width: 767px) {
  p {
    font-size: 16px;
  }
}

.fc-white {
  color: #fff;
}

a {
  text-decoration: none;
  color: #333;
  font-size: 18px;
  transition: opacity 0.3s ease;
}
a:hover {
  cursor: pointer;
  opacity: 0.7;
}

ul {
  list-style-type: none;
  color: #333;
}

.FB {
  display: flex;
}
@media only screen and (max-width: 767px) {
  .FB {
    flex-direction: column;
  }
}

.FB-col {
  flex-direction: column;
}

.FB-center {
  justify-content: center;
}

@media only screen and (max-width: 767px) {
  .sp-m-t-50 {
    margin-top: 50px;
  }
}

@media only screen and (max-width: 767px) {
  .sp-m-t-20 {
    margin-top: 20px;
  }
}

@keyframes delayMotive {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
/*============================/common ==================================*/
/*============================ header ==================================*/
header .z_header {
  position: relative;
  z-index: 100;
}
header .z_header .d_pc {
  display: flex;
}
@media only screen and (max-width: 767px) {
  header .z_header .d_pc {
    display: none;
  }
}
header .z_header .d_pc {
  position: fixed;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
  padding: 0 20px;
  width: 100%;
  height: 60px;
  background: white;
  border-bottom: solid 1px #eee;
  box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.05);
}
header .z_header .d_pc > a.link-home{
  position: absolute;
  top: 5px;
  left: 20px;
}
header .z_header .d_pc > a img {
  height: 50px;
}
header .z_header .d_pc .r_header-navi {
  display: flex;
  justify-content: space-between;
  margin-left: 200px;
}
header .z_header .d_pc .r_header-navi a.sec {
  margin-right: 20px;
  font-size: 14px;
}
header .z_header .d_pc .r_header-cv {
  display: flex;
  align-items: center;
  width: 100%;
}
header .z_header .d_pc .r_header-cv .cv {
  position: relative;
  margin: 0 20px;
  text-align: center;
  letter-spacing: 1;
}
header .z_header .d_pc .r_header-cv .cv a {
  display: inline-block;
  height: 60px;
  line-height: 60px;
  font-weight: bold;
  font-size: 14px;
  white-space: nowrap;
}
header .z_header .d_pc .r_header-cv .cv a.triger-menu {
  position: relative;
}
header .z_header .d_pc .r_header-cv .cv a.triger-menu:hover + .below-menu {
  visibility: visible;
  opacity: 1;
}
header .z_header .d_pc .r_header-cv .cv a.triger-menu::after {
  content: "";
  display: block;
  position: absolute;
  top: 22px;
  right: -20px;
  transform: rotate(45deg);
  width: 7px;
  height: 7px;
  border-right: solid 3px #9c9999;
  border-bottom: solid 3px #9c9999;
}
header .z_header .d_pc .r_header-cv .cv > a:hover {
  opacity: 1;
}
header .z_header .d_pc .r_header-cv .below-menu {
  visibility: hidden;
  position: absolute;
  left: -20px;
  background-color: #fff;
  opacity: 0;
  transition: all 0.1s ease-out;
}
header .z_header .d_pc .r_header-cv .below-menu a {
  position: relative;
  margin: 0 25px 0 40px;
  border-bottom: solid 1px #eee;
  text-align: left;
  width: 200px;
}
header .z_header .d_pc .r_header-cv .below-menu a:nth-child(1) {
  top: -1px;
  border-top: solid 1px #eee;
}
header .z_header .d_pc .r_header-cv .below-menu:hover {
  visibility: visible;
  opacity: 1;
}
header .z_header .d_pc .r_header-cv .r_header-cv_inner {
  display: flex;
  justify-content: center;
  align-items: center;
  flex: 1;
}
header .z_header .d_pc .r_header-cv .r_header-cv_btn{
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  display: flex;
}
header .z_header .d_pc .r_header-cv a.cv02 {
  display: flex;
  margin-left: 10px;
  padding: 0 20px;
  width: auto;
  height: 40px;
  background-color: #DD020F;
  border: solid 1px #DD020F;
  border-radius: 50px;
  justify-content: center;
  align-items: center;
  text-align: center;
  line-height: 40px;
  letter-spacing: 1;
  font-weight: bold;
  color: #fff;
  font-size: 14px;
  transition: 0.2s ease;
  white-space: nowrap;
}
header .z_header .d_pc .r_header-cv a.cv02.divide {
  margin-left: 0;
}
header .z_header .d_pc .r_header-cv a.cv02:hover {
  opacity: 1;
  background-color: #fff;
  color: #DD020F;
}
header .z_header .d_pc .r_header-cv a.cv02.red {
  background-color: #fff;
  border: solid 1px #DD020F;
  color: #DD020F;
}
header .z_header .d_pc .r_header-cv a.cv02.red:hover {
  background-color: #DD020F;
  color: #fff;
}
header .z_header .d_pc .r_header-cv a.cv02.blue {
  background-color: #fff;
  border: solid 1px #2d6adc;
  color: #2d6adc;
}
header .z_header .d_pc .r_header-cv a.cv02.blue:hover {
  background-color: #2d6adc;
  color: #fff;
}
header .z_header .d_sp {
  position: fixed;
  display: none;
  box-sizing: border-box;
  padding: 0 20px;
  width: 100%;
  height: 50px;
  background: #fff;
  align-items: center;
  box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.05);
}
@media only screen and (max-width: 767px) {
  header .z_header .d_sp {
    display: flex;
    justify-content: space-between;
  }
}
header .z_header .d_sp .r_link-home {
  font-size: 0;
}
header .z_header .d_sp .r_link-home img {
  height: 45px;
}
header .z_header .d_sp .r_nav-trigger {
  display: block;
  border: none;
  outline: none;
  background: transparent;
  transition: all 0.2s ease-in;
}
header .z_header .d_sp .r_nav-trigger span {
  display: block;
  margin-bottom: 4px;
  width: 30px;
  height: 4px;
  background: #000;
  transition: all 0.4s ease-out;
}
header .z_header .d_sp .r_nav-trigger.active span:nth-child(1) {
  transform: translateY(10px) rotate(135deg);
}
header .z_header .d_sp .r_nav-trigger.active span:nth-child(2) {
  opacity: 0;
}
header .z_header .d_sp .r_nav-trigger.active span:nth-child(3) {
  transform: translateY(-6px) rotate(45deg);
}
header .z_header .d_sp .r_nav-inner {
  display: none;
  position: absolute;
  top: 50px;
  left: 0;
  margin: 0;
  padding: 30px;
  width: 100%;
  box-sizing: border-box;
  background: #fff;
}
header .z_header .d_sp .r_nav-inner li {
  margin: 20px 0;
}
header .z_header .d_sp .r_nav-inner li .cv02 {
  padding: 5px 20px;
  height: 40px;
  line-height: 40px;
  border-radius: 50px;
  transition: all 0.4s ease-out;
}
header .z_header .d_sp .r_nav-inner li .cv02.red {
  background-color: #fff;
  border: solid 1px #DD020F;
  color: #DD020F;
}
header .z_header .d_sp .r_nav-inner li .cv02.red:hover {
  background-color: #DD020F;
  color: #fff;
  opacity: 1;
}
header .z_header .d_sp .r_nav-inner li .cv02.blue {
  background-color: #fff;
  border: solid 1px #72a3ff;
  color: #72a3ff;
}
header .z_header .d_sp .r_nav-inner li .cv02.blue:hover {
  background-color: #72a3ff;
  color: #fff;
  opacity: 1;
}

/* 1000-768px対応 */
@media only screen and (max-width: 1000px) and (min-width: 768px) {
  header .z_header .resToMM {
    display: none;
  }
}

/* 1000-768px対応 */
@media only screen and (max-width: 1400px) and (min-width: 768px) {
  header .z_header .d_pc .r_header-cv .r_header-cv_inner {
    display: none;
  }
  header .z_header .resFromMM {
    display: block;
  }
  header .z_header .resToMM {
    display: none;
  }
  header .z_header .d_pc .r_header-cv{
    padding-right: 320px;
    justify-content: flex-end;
  }
}

@media only screen and (max-width: 1599px) and (min-width: 1400px) {
  header .z_header .resFromMM {
    display: none;
  }
  header .z_header .d_pc .r_header-cv{
    padding-right: 300px;
    justify-content: flex-end;
  }
  header .z_header .d_pc .r_header-cv .r_header-cv_inner {
    justify-content: flex-end;
  }
}

/*============================ /header ==================================*/
/*============================ kv ==================================*/
section.kv {
  position: relative;
  min-width: 1200px;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  section.kv {
    min-width: auto;
  }
}
section.kv.page-front {
  height: 50vw;
  min-height: 800px;
}
@media only screen and (max-width: 767px) {
  section.kv.page-front {
    height: 100%;
    min-height: 700px;
  }
}
section.kv .kv-slider .slick-slide {
  opacity: 1 !important;
}
section.kv .kv-slider .slick-slide .slideobject {
  opacity: 0;
  transition: 0s;
}
section.kv .kv-slider .slick-slide .slideobject figure {
  height: 100%;
  max-height: 800px;
  min-height: 500px;
  width: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  transform: scale(1.2);
  transition: 0s;
}
section.kv .kv-slider .slick-slide .slideobject p {
  opacity: 0;
  transition: 0s;
  font-size: 20px;
  line-height: 1.5em;
  width: 10em;
  height: 3em;
  margin: auto;
  position: absolute;
  z-index: 20;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  color: #fff;
  font-weight: bold;
  text-align: center;
  overflow: hidden;
}
section.kv .kv-slider .slick-slide .slideobject::after {
  content: "";
  background-color: rgba(96, 69, 40, 0.3);
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  max-height: 800px;
  min-height: 500px;
}
section.kv .kv-slider .slick-active .slideobject {
  opacity: 1;
  transition: ease 5s;
}
section.kv .kv-slider .slick-active .slideobject figure {
  transform: scale(1.4, 1.4);
  transition: ease 10s;
}
section.kv .kv-slider .slick-active .slideobject p {
  opacity: 1;
  transition: ease 1s;
  transition-delay: 1s;
}
section.kv .kv-slider .slick-continue .slideobject {
  opacity: 1;
  transition: ease 5s;
}
section.kv .kv-slider .slick-continue .slideobject figure {
  transform: scale(1.4, 1.4);
  transition: ease 10s;
}
section.kv .kv-slider .slick-continue .slideobject p {
  opacity: 0;
  transition: ease 1s;
}
section.kv .kv-txt {
  position: absolute;
  bottom: 10%;
  left: 50%;
  transform: translate(-50%, 0);
  white-space: nowrap;
}
@media only screen and (max-width: 767px) {
  section.kv .kv-txt {
    width: 100%;
  }
}
section.kv .kv-txt .kv-txt-inner {
  letter-spacing: 3px;
  text-align: center;
}
section.kv .kv-txt .kv-txt-inner .kv-txt-ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  color: #fff;
  font-weight: 800;
  font-size: 54px;
  text-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
}
@media only screen and (max-width: 767px) {
  section.kv .kv-txt .kv-txt-inner .kv-txt-ttl {
    font-size: 6vw;
    line-height: 1.4;
  }
}
section.kv .kv-txt .kv-txt-inner .kv-txt-lead {
  margin-top: 15px;
  font-family: "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
  color: #fff;
  font-size: 24px;
  text-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
}
@media only screen and (max-width: 767px) {
  section.kv .kv-txt .kv-txt-inner .kv-txt-lead {
    margin-top: 15px;
    font-size: 4vw;
    line-height: 1.6;
  }
}
section.kv .kv-txt .kv-txt-inner .link-btn {
  /* opacity: 0; */
  margin-top: 24px;
  /* animation: delayMotive 1s ease-out forwards; */
}
section.kv .kv-txt .kv-txt-inner .link-btn.FB {
  flex-direction: column;
}
section.kv .kv-txt .kv-txt-inner .link-btn.FB a.red {
  margin-top: 20px;
  flex-direction: column;
}
@media only screen and (max-width: 767px) {
  section.kv .kv-txt .kv-txt-inner .link-btn.FB a.red{
    margin-top: 5vw;
  }
}
section.kv .kv-txt .kv-txt-inner .link-btn div a {
  display: flex;
  padding: 0 20px;
  max-width: 500px;
  height: 70px;
  margin: 0 auto;
  background-color: #DD020F;
  border: solid 1px #DD020F;
  border-radius: 50px;
  justify-content: center;
  align-items: center;
  text-align: center;
  letter-spacing: 1;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  font-feature-settings: palt;
  transition: 0.2s ease;
}
@media only screen and (max-width: 767px) {
  section.kv .kv-txt .kv-txt-inner .link-btn div a {
    width: 80vw;
    padding: 0;
    height: 15vw;
    font-size: 4vw;
  }
}
section.kv .kv-txt .kv-txt-inner .link-btn div a.divide {
  margin-left: 30px;
}
section.kv .kv-txt .kv-txt-inner .link-btn div a:hover {
  opacity: 0.8;
}
section.kv .kv-txt .kv-txt-inner .link-btn div a.red {
  background-color: #fff;
  border: solid 1px #DD020F;
  color: #DD020F;
}
section.kv .kv-txt .kv-txt-inner .link-btn div a.red:hover {
  opacity: 0.8;
}
@media only screen and (max-width: 767px) {
  section.kv .kv-txt .kv-txt-inner .link-btn div a.red {
    margin-top: 10px;
  }
}
section.kv .kv-txt .kv-txt-inner .link-btn div a.blue {
  margin-left: 10px;
  background-color: rgba(255, 255, 255, 0.7);
  border: solid 1px #72a3ff;
  color: #72a3ff;
}
section.kv .kv-txt .kv-txt-inner .link-btn div a.blue:hover {
  background-color: #72a3ff;
  color: #fff;
}
section.kv .kv-txt .kv-txt-inner .link-btn.add-btn div {
  margin-top: 10px;
}
section.kv .kv-txt .kv-txt-inner .link-btn.add-btn div a {
  background-color: #fff;
  border: solid 1px #d1d1d1;
  color: #333;
}
section.kv .kv-txt .kv-txt-inner .link-btn.add-btn div a:hover {
  background-color: #d1d1d1;
  color: #fff;
}

/*============================/kv ==================================*/
/*============================ banner-main (kv下のバナー) ==================================*/
section.banner-main {
  min-width: 1200px;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  section.banner-main {
    min-width: auto;
  }
}
section.banner-main .banner {
  position: relative;
  margin: 0;
  padding: 50px 0;
  background-color: #f6f6f6;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  section.banner-main .banner {
    padding: 20px 0 40px;
  }
}
section.banner-main .banner figure{
  margin: 0;
}
section.banner-main .banner img {
  box-shadow: 0 0 10px 1px rgba(4, 0, 0, 0.1);
}
.cnt-slider-banner{
  display: none;
  max-width: 1100px;
  margin: 0 auto;
}
.cnt-slider-banner.slick-initialized{
  display: block;
}
.cnt-slider-banner .slick-slide{
  height: auto;
  text-align: center;
  z-index: -1;
  padding: 0 20px;
}
@media only screen and (max-width: 767px) {
  .cnt-slider-banner .slick-slide{
    padding: 0 10px;
  }
}
.cnt-slider-banner button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}
.cnt-slider-banner .slide-arrow {
  position: absolute;
  top: 50%;
  margin-top: -15px;
}
.cnt-slider-banner .prev-arrow,
.cnt-slider-banner .next-arrow {
  width: 40px;
  height: 40px;
  border-bottom: solid 2px #9c9999;
  z-index: 1;
}
@media only screen and (max-width: 767px) {
.cnt-slider-banner .prev-arrow,
.cnt-slider-banner .next-arrow {
    display: none !important;
  }
}
.cnt-slider-banner .prev-arrow:hover,
.cnt-slider-banner .next-arrow:hover {
  cursor: pointer;
}
.cnt-slider-banner .prev-arrow {
  left: -30px;
  transform: rotate(45deg);
  border-left: solid 2px #9c9999;
}
.cnt-slider-banner .next-arrow {
  right: -30px;
  transform: rotate(-45deg);
  border-right: solid 2px #9c9999;
}
.cnt-slider-banner .slick-dots {
  bottom: -20px;
}
.cnt-slider-banner .slick-dots li {
  margin: 0 4px;
  width: 50px;
  height: 5px;
}
.cnt-slider-banner .slick-dots li button:before {
  content: "";
  width: 50px;
  height: 5px;
  background: #E0E0E0;
  opacity: 1;
}
.cnt-slider-banner .slick-dots li.slick-active button:before {
  background: #DD020F;
}

/*============================/banner-main (kv下のバナー) ==================================*/
/*============================ section ==================================*/
section.contents {
  margin: auto;
  padding: 100px 0;
  min-width: 1200px;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  section.contents {
    padding: 50px 0;
    min-width: auto;
  }
}
section.contents .content {
  margin: 100px auto;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  section.contents .content {
    margin: 50px auto 20px;
  }
}
section.contents .content p {
  margin: 20px auto;
}
@media only screen and (max-width: 767px) {
  section.contents .content p {
    margin: 10px auto;
  }
}
section.contents .content p span.lead {
  line-height: 2;
}
@media only screen and (max-width: 767px) {
  section.contents .content p span.lead {
    font-size: 16px;
  }
}
@media only screen and (max-width: 767px) {
  section.contents .content video.cnt-col2 {
    margin: auto;
  }
}
section.contents .content figure.FB {
  margin-top: 50px;
  justify-content: center;
}
@media only screen and (max-width: 767px) {
  section.contents .content figure.FB {
    margin: 20px 20px auto;
  }
}
section.contents .content .link-btn {
  margin: 30px auto 0;
  justify-content: center;
}
@media only screen and (max-width: 767px) {
  section.contents .content .link-btn {
    margin-top: 0px;
  }
}
section.contents .content .link-btn div {
  margin: auto 20px;
}
section.contents .content .link-btn div a {
  display: block;
  border: solid 2px #DD020F;
  border-radius: 50px;
  text-align: center;
  line-height: 65px;
  transition: 0.2s ease;
}
@media only screen and (max-width: 767px) {
  section.contents .content .link-btn div a {
    height: 40px;
    line-height: 40px;
  }
}
section.contents .content .link-btn div a span {
  position: relative;
  padding-right: 30px;
  font-weight: bold;
  font-size: 20px;
  color: #DD020F;
}
section.contents .content .link-btn div a span::after {
  content: "";
  display: block;
  position: absolute;
  top: 7px;
  right: 0px;
  width: 7px;
  height: 7px;
  border-top: 3px solid #DD020F;
  border-right: 3px solid #DD020F;
  transform: rotate(45deg);
}
@media only screen and (max-width: 767px) {
  section.contents .content .link-btn div a span::after {
    top: 3px;
  }
}
@media only screen and (max-width: 320px) {
  section.contents .content .link-btn div a span::after {
    display: none;
  }
}
@media only screen and (max-width: 767px) {
  section.contents .content .link-btn div a span {
    padding-right: 20px;
    font-size: 14px;
  }
}
@media only screen and (max-width: 320px) {
  section.contents .content .link-btn div a span {
    padding-right: 0;
  }
}
section.contents .content .link-btn div a:hover {
  opacity: 1;
  border-color: #fff;
  background-color: #DD020F;
}
section.contents .content .link-btn div a:hover span {
  color: #fff;
}
section.contents .content .link-btn div a:hover span:after {
  border-top: 3px solid #fff;
  border-right: 3px solid #fff;
}
section.contents .frame-out {
  margin: -80px auto auto 0;
}
section.contents#atok-about {
  min-width: 1200px;
  background-color: #D4222C;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about {
    min-width: auto;
  }
}
section.contents#atok-about h2 {
  margin-bottom: 50px;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about h2 {
    font-feature-settings: "palt";
    margin-bottom: 25px;
  }
}
section.contents#atok-about .fig-main {
  margin: 50px auto;
}
section.contents#atok-about .fig-main figure {
  margin: 0 20px;
  text-align: center;
}
section.contents#atok-about .fig-main figure img {
  width: 600px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about .fig-main figure img {
    width: 100%;
  }
}
section.contents#atok-about .content.FB {
  margin: 80px auto 40px;
  justify-content: center;
}
section.contents#atok-about .content.FB.pc-middle {
  width: 100%;
  flex-wrap: wrap;
  flex-direction: row;
}
section.contents#atok-about .content.FB.pc-middle .FB-col:nth-child(3):after {
  display: none;
}
section.contents#atok-about .content.FB .FB-col {
  width: 260px;
}
section.contents#atok-about .content.FB .FB-col h4 {
  height: 80px;
  justify-content: center;
  align-items: center;
  line-height: 1.2;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about .content.FB .FB-col h4 {
    height: 50px;
  }
}
section.contents#atok-about .content.FB .FB-col h4 span {
  font-size: 0.8em;
}
@media only screen and (max-width: 767px) and (min-width: 501px) {
  section.contents#atok-about .content.FB .FB-col h4 span {
    font-size: 0.8em;
  }
}
@media only screen and (max-width: 500px) {
  section.contents#atok-about .content.FB .FB-col h4 span {
    font-size: 1em;
  }
}
section.contents#atok-about .content.FB .FB-col figure {
  text-align: center;
}
section.contents#atok-about .content.FB .FB-col figure img {
  width: 120px;
  height: auto;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about .content.FB .FB-col figure img {
    width: 100px;
    margin: auto;
  }
}
section.contents#atok-about .content.FB .FB-col p {
  margin: 0 auto 30px;
  line-height: 1.6;
  font-size: 18px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about .content.FB .FB-col p {
    margin: 0 auto 30px;
    line-height: 1.6;
    font-size: 16px;
  }
}
section.contents#atok-about .content.FB .FB-col:not(:nth-child(1)) {
  position: relative;
}
section.contents#atok-about .content.FB .FB-col:not(:nth-child(1)):after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 80px;
  background-color: rgba(255, 255, 255, 0.5);
}
section.contents#atok-about .content.FB.sp-middle {
  margin-bottom: 60px;
}
section.contents#atok-about .content.FB.sp-middle .FB-col {
  margin: auto;
}
section.contents#atok-about .content.FB.sp-middle .FB-col .FB {
  flex-direction: row;
  align-items: center;
}
section.contents#atok-about .content.FB.sp-middle .FB-col .FB figure {
  margin: 0;
}
section.contents#atok-about .content.FB.sp-middle .FB-col .FB h4 {
  height: unset;
  text-align: left;
}
section.contents#atok-about .content.FB.sp-middle .FB-col p {
  font-size: 16px;
}
section.contents#atok-about .content.FB.sp-middle .FB-col::after {
  display: none;
}
section.contents#atok-about h4 .link-txt {
  position: relative;
  padding-left: 90px;
  letter-spacing: 2;
  font-size: 0.8em;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about h4 .link-txt {
    font-size: 1em;
    padding-left: 50px;
  }
}
section.contents#atok-about h4 .link-txt::before {
  content: "";
  display: block;
  position: absolute;
  top: -40px;
  left: -10px;
  width: 80px;
  height: 100px;
  background-image: url("../images/3.png");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about h4 .link-txt::before {
    top: calc(50% - 5px);
    transform: translateY(-50%);
    width: 50px;
    height: 60px;
  }
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about h4.ttl-cloudService {
    margin: auto;
    padding-left: 80px;
    width: 240px;
    max-width: 100%;
    text-align: left;
  }
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about h4.ttl-cloudService .link-txt {
    padding-left: 0;
    line-height: 1.2;
  }
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about h4.ttl-cloudService .link-txt::before {
    top: calc(50% - 0px);
    width: 60px;
    left: -70px;
  }
}
section.contents#atok-about p.txt-cloudService {
  line-height: 1.6;
}
section.contents#atok-about p span.txt-lead {
  font-size: 1.2em;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about p span.txt-lead {
    font-size: 1em;
  }
}
section.contents#atok-about .btn-course {
  justify-content: center;
  margin-top: 30px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about .btn-course {
    margin-top: 0px;
    margin-bottom: 60px;
    text-align: center;
  }
}
section.contents#atok-about .btn-course figure {
  margin: 10px;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  section.contents#atok-about .btn-course figure:nth-child(1) {
    text-align: right;
  }
}
@media only screen and (min-width: 768px) {
  section.contents#atok-about .btn-course figure:nth-child(2) {
    text-align: left;
  }
}
section.contents#atok-about .content .link-btn div {
  margin: auto 10px;
}
section.contents#atok-about .content .link-btn div a {
  height: 40px;
  width: 250px;
  border: solid 1px #fff;
  line-height: 40px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-about .content .link-btn div a {
    margin: 10px auto;
  }
}
section.contents#atok-about .content .link-btn div a span {
  color: #fff;
  font-size: 14px;
}
section.contents#atok-about .content .link-btn div a span::after {
  top: 5px;
  border-top: 3px solid #fff;
  border-right: 3px solid #fff;
}
section.contents#atok-about .content .link-btn div a span.arrow-below::after {
  top: 3px;
  transform: rotate(135deg);
}
section.contents#atok-about .content .link-btn div a:hover {
  border-color: #DD020F;
  background-color: #fff;
}
section.contents#atok-about .content .link-btn div a:hover span {
  color: #DD020F;
}
section.contents#atok-about .content .link-btn div a:hover span::after {
  border-top: 3px solid #DD020F;
  border-right: 3px solid #DD020F;
}
section.contents#atok-features {
  padding-bottom: 0;
}
section.contents#atok-features h2 {
  position: relative;
}
section.contents#atok-features h2::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -110px;
  left: 50%;
  transform: translateX(-50%);
  width: 50px;
  height: 50px;
  background-image: url("../images/5.png");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-features h2::after {
    bottom: -40px;
    width: 50px;
    height: 30px;
  }
}
section.contents#atok-features .num-txt {
  text-align: center;
  font-family: "Jost", sans-serif;
  font-weight: 200;
  font-size: 200px;
  color: #e6e6e6;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-features .num-txt {
    font-size: 100px;
  }
}
section.contents#atok-features .link-btn a {
  width: 600px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-features .link-btn a {
    margin: auto;
    width: 80%;
    max-width: 400px;
  }
}
section.contents#atok-os {
  padding-bottom: 50px;
}
section.contents#atok-os .content.FB {
  margin-top: 100px;
  justify-content: center;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-os .content.FB {
    margin-top: 20px;
    flex-direction: row;
    flex-wrap: wrap;
  }
}
section.contents#atok-os .content.FB .FB-col {
  display: flex;
  justify-content: flex-end;
  text-align: center;
}
section.contents#atok-os .content.FB .FB-col a figure {
  display: flex;
  position: relative;
  margin: 0 15px;
  width: 160px;
  height: 150px;
  box-sizing: border-box;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  padding: 0 0 18px;
  border: solid 1px #e0e0e0;
  border-radius: 20px;
  box-shadow: 0 0 10px 1px rgba(4, 0, 0, 0.1);
  transition: all 0.2s ease;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-os .content.FB .FB-col a figure {
    margin: 10px;
    padding: 10px 0;
    width: 120px;
    height: 110px;
  }
}
section.contents#atok-os .content.FB .FB-col a figure figcaption {
  margin-top: 10px;
  font-size: 18px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-os .content.FB .FB-col a figure figcaption {
    font-size: 16px;
  }
}
section.contents#atok-os .content.FB .FB-col a img.win {
  width: 93px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-os .content.FB .FB-col a img.win {
    width: 70px;
  }
}
section.contents#atok-os .content.FB .FB-col a img.mac {
  width: 106px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-os .content.FB .FB-col a img.mac {
    width: 76px;
  }
}
section.contents#atok-os .content.FB .FB-col a img.android {
  width: 46px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-os .content.FB .FB-col a img.android {
    width: 38px;
  }
}
section.contents#atok-os .content.FB .FB-col a img.ios {
  width: 46px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-os .content.FB .FB-col a img.ios {
    width: 38px;
  }
}
section.contents#atok-os .content.FB .FB-col a:hover {
  opacity: 1;
}
section.contents#atok-os .content.FB .FB-col a:hover figure {
  box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
  transform: translateY(3px);
}
section.contents#atok-words {
  background-image: url("../images/19.png");
  background-size: cover;
  background-repeat: no-repeat;
}
section.contents#atok-words .content {
  margin: 0 auto;
}
section.contents#atok-words .content .panel {
  display: flex;
  box-sizing: border-box;
  margin: 30px auto;
  padding: 34px 70px 34px 0;
  width: 800px;
  justify-content: center;
  background-color: #fff;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-words .content .panel {
    padding: 60px 0;
    width: 90%;
    max-width: 500px;
    flex-direction: column;
    align-items: center;
  }
}
section.contents#atok-words .content .panel figure {
  margin: 0;
  display: flex;
  width: 200px;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-words .content .panel figure {
    margin: 0 0 20px;
  }
}
section.contents#atok-words .content .panel figure img {
  height: 80px;
}
section.contents#atok-words .content .panel .panel-txt {
  width: 680px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-words .content .panel .panel-txt {
    width: 260px;
  }
}
section.contents#atok-words .content .panel .panel-txt h5 {
  text-align: left;
  white-space: nowrap;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-words .content .panel .panel-txt h5 {
    text-align: justify;
    white-space: normal;
  }
}
section.contents#atok-words .content .panel .panel-txt p {
  margin: 20px 0 0;
  text-align: left;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-words .content .panel .panel-txt p {
    margin: 20px auto 0;
    text-align: justify;
  }
}
section.contents#atok-words .content .panel .panel-txt p span.lead {
  line-height: 1.6;
  font-size: 0.8em;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-words .content .panel .panel-txt p span.lead {
    font-size: 1em;
  }
}
section.contents#atok-words .content .link-btn.FB {
  width: 800px;
  justify-content: right;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-words .content .link-btn.FB {
    width: 220px;
  }
}
section.contents#atok-words .content .link-btn.FB div {
  margin: 0;
}
section.contents#atok-words .content .link-btn.FB div a {
  position: relative;
  padding: 0 50px;
  background-color: #fff;
  border: solid 1px #e0e0e0;
  box-shadow: 0 0 10px 1px rgba(4, 0, 0, 0.1);
  transition: all 0.2s ease;
}
section.contents#atok-words .content .link-btn.FB div a span {
  color: #333;
}
section.contents#atok-words .content .link-btn.FB div a span::after {
  border-top: 3px solid #333;
  border-right: 3px solid #333;
}
section.contents#atok-words .content .link-btn.FB div a:hover {
  box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.1);
  transform: translateY(3px);
}
section.contents#atok-plan {
  background-image: url("../images/18.png");
  background-size: cover;
  background-repeat: no-repeat;
}
section.contents#atok-plan .content {
  margin-top: 0;
}

/*============================/section ==================================*/
/*============================ parts ==================================*/
section.blank {
  height: 60px;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  section.blank {
    height: 50px;
  }
}

section.gnav-top {
  height: 50px;
  width: 100%;
  min-width: 1200px;
  background-color: #000;
  justify-content: center;
}
@media only screen and (max-width: 767px) {
  section.gnav-top {
    height: 50px;
    min-width: auto;
  }
}
section.gnav-top .FB {
  width: 200px;
  justify-content: center;
  align-items: center;
}
section.gnav-top .FB a {
  display: inline-block;
  width: 100%;
  height: 50px;
  text-align: center;
  line-height: 50px;
  color: #fff;
  font-size: 14px;
}
@media only screen and (max-width: 767px) {
  section.gnav-top .FB a {
    height: 50px;
    line-height: 50px;
  }
}
section.gnav-top .FB a.current {
  color: #ED6464;
}
section.gnav-top .FB a:hover {
  background-color: rgba(255, 255, 255, 0.3);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.1);
}
@media only screen and (max-width: 767px) {
  section.gnav-top.FB {
    flex-direction: row;
  }
}

section.kv.device {
  z-index: inherit;
  min-height: 350px;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  section.kv.device {
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
  }
  section.kv.device.os-w {
    background-image: url(/local/images/kv-pc-win.png);
  }
  section.kv.device.os-m {
    background-image: url(/local/images/kv-pc-mac.png);
  }
  section.kv.device.os-ap {
    background-image: url(/local/images/kv-pc-and-pro.png);
  }
  section.kv.device.os-a {
    background-image: url(/local/images/kv-pc-and.png);
  }
  section.kv.device.os-ip {
    background-image: url(/local/images/kv-pc-ios-pro.png);
  }
}
@media only screen and (max-width: 767px) {
  section.kv.device {
    height: auto;
    min-height: unset;
  }
}
section.kv.device .kv-txt {
  top: 50%;
  left: 220px;
}
@media only screen and (max-width: 767px) {
  section.kv.device .kv-txt {
    left: 20px;
  }
}
section.kv.device .kv-txt .kv-txt-inner .kv-txt-shoulder {
  font-size: 20px;
}
@media only screen and (max-width: 767px) {
  section.kv.device .kv-txt .kv-txt-inner .kv-txt-shoulder {
    font-size: 14px;
  }
}
section.kv.device .kv-txt .kv-txt-inner .kv-txt-ttl {
  margin: 20px 0 40px;
  position: relative;
  padding-left: 100px;
  font-weight: 600;
  font-size: 45px;
  color: #000;
}
@media only screen and (max-width: 767px) {
  section.kv.device .kv-txt .kv-txt-inner .kv-txt-ttl {
    display: flex;
    align-items: center;
    margin: 20px 0 30px;
    padding-left: 70px;
    height: 60px;
    font-size: 20px;
  }
}
section.kv.device .kv-txt .kv-txt-inner .kv-txt-ttl::before {
  content: "";
  display: block;
  position: absolute;
  top: -5px;
  left: -10px;
  width: 90px;
  height: 90px;
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}
@media only screen and (max-width: 767px) {
  section.kv.device .kv-txt .kv-txt-inner .kv-txt-ttl::before {
    top: -3px;
    width: 70px;
    height: 70px;
  }
}
section.kv.device .kv-txt .kv-txt-inner .kv-txt-ttl.win::before {
  background-image: url(/local/images/logo-regular.png);
}
section.kv.device .kv-txt .kv-txt-inner .kv-txt-ttl.mac::before {
  background-image: url(/local/images/logo-regular.png);
}
section.kv.device .kv-txt .kv-txt-inner .kv-txt-ttl.ios::before {
  background-image: url(/local/images/logo-passport.png);
}
section.kv.device .kv-txt .kv-txt-inner .kv-txt-ttl.ios-pro::before {
  background-image: url(/local/images/logo-passport-pro.png);
}
section.kv.device .kv-txt .kv-txt-inner .kv-txt-ttl.android::before {
  background-image: url(/local/images/logo-passport.png);
}
section.kv.device .kv-txt .kv-txt-inner .kv-txt-ttl.android-pro::before {
  background-image: url(/local/images/logo-passport-pro.png);
}
section.kv.device .kv-txt .kv-txt-inner .link-btn div a {
  display: flex;
  padding: 0 20px;
  width: 100px;
  height: 40px;
  background-color: #DD020F;
  border: solid 1px #DD020F;
  border-radius: 50px;
  justify-content: center;
  align-items: center;
  text-align: center;
  line-height: 40px;
  letter-spacing: 1;
  font-weight: bold;
  color: #fff;
  font-size: 14px;
  transition: 0.2s ease;
}
section.kv.device .kv-txt .kv-txt-inner .link-btn div a.divide {
  margin-left: 30px;
}
section.kv.device .kv-txt .kv-txt-inner .link-btn div a:hover {
  opacity: 1;
  background-color: #fff;
  color: #DD020F;
}
section.kv.device .kv-txt .kv-txt-inner .link-btn.add-btn div {
  margin-top: 10px;
}
section.kv.device .kv-txt .kv-txt-inner .link-btn.add-btn div a {
  background-color: #fff;
  border: solid 1px #d1d1d1;
  color: #333;
}
section.kv.device .kv-txt .kv-txt-inner .link-btn.add-btn div a:hover {
  background-color: #d1d1d1;
  color: #fff;
}

section.contents .content.box {
  margin-top: 0;
  margin-bottom: 140px;
}
section.contents .content.box p.add-icon {
  display: inline-block;
}
section.contents .content.box p.add-icon.up::after {
  content: "UP!";
  background-color: orange;
}
section.contents .content.box p.add-icon.new::after {
  content: "NEW!";
  background-color: red;
}
section.contents .content.box p.add-icon {
  position: relative;
}
section.contents .content.box p.add-icon::after {
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: -80px;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  line-height: 50px;
  text-align: center;
  font-weight: bold;
  font-size: 16px;
  color: #fff;
}
@media screen and (min-width: 768px) {
  section.contents .content.box p.add-icon.up::after {
    border: solid 5px orange;
    background-color:  orange;
  }
  section.contents .content.box p.add-icon.new::after {
    border: solid 5px #DD020F;
    background-color: #dd020f;
  }
}
@media screen and (max-width: 767px) {
  section.contents .content.box p.add-icon {
    margin-top: 40px;
    width: unset;
  }
  section.contents .content.box p.add-icon::after {
    top: -40px;
    transform: unset;
    left: 0;
    width: 70px;
    height: 35px;
    border-radius: 10px;
    line-height: 35px;
    font-size: 18px;
  }
  section.contents .content.box p.add-icon::before {
    content: "";
    display: block;
    position: absolute;
    top: -22px;
    left: 24px;
    width: 30px;
    height: 20px;
    transform: rotate(24deg);
  }
  section.contents .content.box p.add-icon.up::before {
    background: orange;
  }
  section.contents .content.box p.add-icon.new::before {
    background: rgb(221, 2, 15);
  }
}

@media only screen and (max-width: 767px) {
  section.contents .content.box {
    margin-bottom: 110px;
  }
}
@media only screen and (max-width: 767px) {
  section.contents .content.box h4 {
    margin-bottom: 10px;
  }
}
@media only screen and (max-width: 767px) {
  section.contents .content.box p.txt-left {
    width: 85%;
    max-width: 500px;
    text-align: justify;
  }
}
section.contents .content.box .cnt-slider, section.contents .content.box .cnt-slider-1 {
  margin: auto;
  max-width: 800px;
}
section.contents .content.box .cnt-slider p span, section.contents .content.box .cnt-slider-1 p span {
  line-height: 2;
}
section.contents .content.box .cnt-slider img, section.contents .content.box .cnt-slider-1 img {
  margin: auto;
}
@media only screen and (max-width: 767px) {
  section.contents .content.box .cnt-slider img, section.contents .content.box .cnt-slider-1 img {
    min-width: 80%;
  }
}
section.contents .content.box .cnt-slider-2 {
  margin: auto;
  width: 550px;
  max-width: 100%;
}
section.contents .content.box .cnt-slider-2 > div {
  text-align: center;
}
section.contents .content.box .cnt-slider-2 img, section.contents .content.box .cnt-slider-2 video {
  margin: auto;
  width: 550px;
  max-width: 100%;
}
@media only screen and (max-width: 767px) {
  section.contents .content.box .cnt-slider-2 img, section.contents .content.box .cnt-slider-2 video {
    max-width: 90%;
  }
}
section.contents#cloud {
  margin-top: 0;
  background-color: #ecf2f8;
}
section.contents#cloud p.lead {
  margin: 50px auto 0;
}
section.contents#cloud .content {
  width: 1000px;
  flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
  section.contents#cloud .content {
    width: 100%;
  }
}
section.contents#cloud .content .content-wrap {
  flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
  section.contents#cloud .content .content-wrap {
    flex-direction: row;
    justify-content: space-around;
  }
}
@media only screen and (max-width: 767px) {
  section.contents#cloud .content .content-wrap .FB-col {
    width: 50%;
  }
}
section.contents#cloud .content .content-wrap .FB-col p {
  margin-bottom: 20px;
  font-size: 14px;
}
@media only screen and (max-width: 767px) {
  section.contents#cloud .content .content-wrap .FB-col p {
    font-size: 12px;
  }
}
@media only screen and (max-width: 767px) {
  section.contents#cloud .content .content-wrap .FB-col figure {
    text-align: center;
  }
}
@media only screen and (max-width: 767px) {
  section.contents#cloud .content .content-wrap .FB-col figure img {
    width: 100%;
  }
}
section.contents#spec {
  background-color: #f3f3f3;
}
section.contents#spec .content {
  margin: auto;
  width: 800px;
  align-items: center;
}
@media only screen and (max-width: 767px) {
  section.contents#spec .content {
    box-sizing: border-box;
    padding: 0 20px;
    width: 100%;
  }
}
section.contents#spec .content p {
  font-weight: bold;
  text-align: left;
}
section.contents#spec .content p small {
  font-size: 0.8em;
}
@media only screen and (max-width: 767px) {
  section.contents#spec .content p small {
    font-size: 1em;
  }
}
section.contents#spec .content p.txt-note {
  margin-bottom: 0;
}
section.contents#spec .content ul {
  font-size: 14px;
}
@media only screen and (max-width: 767px) {
  section.contents#spec .content ul {
    padding-left: 5px;
  }
}
section.contents#spec .content ul li {
  margin: 10px auto;
  padding-left: 1em;
  text-indent: -1em;
  font-feature-settings: "palt";
  text-align: justify;
}
section.contents#spec .content .link-btn {
  margin: 75px auto 0;
  justify-content: space-around;
}
section.contents#spec .content .link-btn div {
  margin: auto 20px;
}
@media only screen and (max-width: 767px) {
  section.contents#spec .content .link-btn div {
    margin: 10px 20px;
  }
}
section.contents#spec .content .link-btn div a {
  display: block;
  width: 300px;
  height: 45px;
  border: solid 1px #DD020F;
  border-radius: 50px;
  background-color: #fff;
  text-align: center;
  line-height: 45px;
  transition: 0.2s ease;
}
@media only screen and (max-width: 767px) {
  section.contents#spec .content .link-btn div a {
    margin: auto;
  }
}
section.contents#spec .content .link-btn div a span {
  position: relative;
  padding-right: 0px;
  font-weight: bold;
  font-size: 14px;
  color: #DD020F;
}
section.contents#spec .content .link-btn div a span::after {
  display: none;
}
section.contents#spec .content .link-btn div a:hover {
  opacity: 1;
  border-color: #fff;
  background-color: #DD020F;
}
section.contents#spec .content .link-btn div a:hover span {
  color: #fff;
}
section.contents#toTop {
  padding: 0;
}
section.contents#toTop .link-btn.FB {
  width: 800px;
  justify-content: center;
}
@media only screen and (max-width: 767px) {
  section.contents#toTop .link-btn.FB {
    width: 200px;
  }
}
section.contents#toTop .link-btn.FB div {
  margin: 0;
}
section.contents#toTop .link-btn.FB div a {
  position: relative;
  padding: 0 50px;
  background-color: #fff;
  border: solid 1px #e0e0e0;
  box-shadow: 0 0 10px 1px rgba(4, 0, 0, 0.1);
  transition: all 0.2s ease;
}
section.contents#toTop .link-btn.FB div a span {
  padding-right: 0;
  color: #333;
}
section.contents#toTop .link-btn.FB div a span::after {
  display: none;
}
section.contents#toTop .link-btn.FB div a:hover {
  box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.1);
  transform: translateY(3px);
}

.note p.txt-note {
  margin: auto;
  width: 650px;
  font-size: 14px;
  text-align: left;
}
@media only screen and (max-width: 767px) {
  .note p.txt-note {
    width: 90%;
  }
}

/*============================/parts ==================================*/
/*============================ container-info ==================================*/
.container-info {
  margin: 100px auto;
  width: 900px;
}
@media only screen and (max-width: 767px) {
  .container-info {
    margin: 50px auto;
    width: 100%;
  }
}
.container-info .txt-lead-limited {
  margin: 20px auto 0;
  width: 540px;
  height: 40px;
  border: solid 1px #DD020F;
  line-height: 40px;
  text-align: center;
  font-size: 20px;
}
@media only screen and (max-width: 767px) {
  .container-info .txt-lead-limited {
    width: 90%;
    max-width: 400px;
  }
}
.container-info section.info-lead {
  margin: 100px auto;
}
.container-info section.info-lead .content {
  margin-top: 50px;
}
@media only screen and (max-width: 767px) {
  .container-info section.info-lead .content {
    margin: 50px 20px 0;
  }
}
.container-info section.info-lead .content h5 {
  margin-bottom: 20px;
}
.container-info section.info-lead .content p {
  font-size: 18px;
  line-height: 2;
}
@media only screen and (max-width: 767px) {
  .container-info section.info-lead .content p {
    text-align: justify;
  }
}
.container-info section.info-lead .content figure.FB {
  margin: 40px auto;
  justify-content: center;
}
.container-info section.info-lead .content .txt-note-left {
  font-size: 14px;
  text-align: center;
  font-feature-settings: "palt";
}
@media only screen and (max-width: 767px) {
  .container-info section.info-lead .content .txt-note-left {
    text-align: justify;
  }
}
.container-info section.dic-panel {
  padding-bottom: 50px;
  width: 900px;
}
@media only screen and (max-width: 767px) {
  .container-info section.dic-panel {
    width: 100%;
  }
}
.container-info section.dic-panel .content.FB {
  margin-top: 100px;
  justify-content: center;
  flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
  .container-info section.dic-panel .content.FB {
    flex-direction: row;
  }
}
.container-info section.dic-panel .content.FB .FB-col {
  display: flex;
  justify-content: flex-end;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .container-info section.dic-panel .content.FB .FB-col a {
    margin: auto;
  }
}
.container-info section.dic-panel .content.FB .FB-col a figure {
  display: flex;
  position: relative;
  margin: 5px;
  width: 260px;
  height: 200px;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  padding: 25px 0 50px;
  border: solid 1px #e0e0e0;
  border-radius: 5px;
  box-shadow: 0 0 10px 1px rgba(4, 0, 0, 0.1);
  transition: all 0.2s ease;
}
.container-info section.dic-panel .content.FB .FB-col a figure figcaption {
  height: 50px;
  margin-bottom: 15px;
  font-weight: bold;
  font-size: 18px;
}
.container-info section.dic-panel .content.FB .FB-col a figure figcaption.FB {
  align-items: center;
}
@media only screen and (max-width: 767px) {
  .container-info section.dic-panel .content.FB .FB-col a figure figcaption {
    height: auto;
    margin-bottom: 0;
    padding-right: 20px;
  }
}
.container-info section.dic-panel .content.FB .FB-col a figure::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 20px;
  transform: rotate(45deg);
  width: 10px;
  height: 10px;
  border-right: solid 3px #929292;
  border-bottom: solid 3px #929292;
}
@media only screen and (max-width: 767px) {
  .container-info section.dic-panel .content.FB .FB-col a figure::after {
    top: calc(50% - 8px);
    right: 30px;
  }
}
@media only screen and (max-width: 767px) {
  .container-info section.dic-panel .content.FB .FB-col a figure img {
    display: none;
  }
}
@media only screen and (max-width: 767px) {
  .container-info section.dic-panel .content.FB .FB-col a figure {
    width: 300px;
    padding: 15px 0;
    height: auto;
    border-radius: 50px;
  }
}
.container-info section.dic-panel .content.FB .FB-col a:hover {
  opacity: 1;
}
.container-info section.dic-panel .content.FB .FB-col a:hover figure {
  box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
  transform: translateY(3px);
}
.container-info section.cnts-reg {
  margin-bottom: 150px;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg {
    margin-bottom: 30px;
  }
}
.container-info section.cnts-reg.cnts-engine {
  margin-bottom: 100px;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg.cnts-engine {
    margin-bottom: 30px;
  }
}
.container-info section.cnts-reg.cnts-engine .cnt-reg-ttl {
  margin: 100px auto 50px;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg.cnts-engine .cnt-reg-ttl {
    margin: 30px 20px;
  }
}
.container-info section.cnts-reg.cnts-engine .cnt-reg {
  margin-bottom: 60px;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg.cnts-engine .cnt-reg {
    margin-bottom: 50px;
  }
}
.container-info section.cnts-reg.cnts-engine .cnt-reg .cnt-txt figure {
  margin-bottom: 30px 0;
}
.container-info section.cnts-reg .cnt-reg-ttl {
  position: relative;
  margin: 100px auto;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg-ttl {
    margin: 30px 20px;
  }
}
.container-info section.cnts-reg .cnt-reg-ttl .txt-ttl-shoulder {
  position: absolute;
  top: -40px;
  padding: 5px 40px;
  border: solid 1px #DD020F;
  color: #DD020F;
  font-size: 20px;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg-ttl .txt-ttl-shoulder {
    left: 50%;
    transform: translateX(-50%);
    width: 200px;
  }
}
.container-info section.cnts-reg .cnt-reg-ttl h4 {
  margin-top: 20px;
  text-align: left;
  font-feature-settings: "palt";
  line-height: 1.2;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg-ttl h4 {
    text-align: center;
    line-height: 1.6;
  }
}
.container-info section.cnts-reg .cnt-reg-ttl p {
  margin: 40px auto 0;
  text-align: justify;
  font-size: 18px;
  line-height: 2;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg-ttl p {
    font-size: 16px;
  }
}
.container-info section.cnts-reg .cnt-reg-ttl .cnt-txt-tag {
  display: flex;
  margin-top: 15px;
  align-items: center;
  font-size: 16px;
}
.container-info section.cnts-reg .cnt-reg-ttl .cnt-txt-tag span:nth-child(1) {
  margin-right: 5px;
}
.container-info section.cnts-reg .cnt-reg-ttl .cnt-txt-tag span:not(:nth-child(1)) {
  display: inline-block;
  margin: 0 3px;
  padding: 5px 10px;
  background-color: #999999;
  border-radius: 15px;
  color: #fff;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg-ttl .cnt-txt-tag {
    font-size: 10px;
  }
}
.container-info section.cnts-reg .cnt-reg-ttl .cnt-txt-box {
  margin-top: 20px;
  border-left: solid 3px #e0e0e0;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg-ttl .cnt-txt-box {
    margin: 20px 20px;
  }
}
.container-info section.cnts-reg .cnt-reg-ttl .cnt-txt-box p {
  margin: 10px 0 10px 30px;
  text-align: justify;
  font-feature-settings: "palt";
}
.container-info section.cnts-reg .cnt-reg-ttl figure {
  align-items: center;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg-ttl figure {
    display: flex;
  }
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg-ttl figure img {
    max-width: 100%;
  }
}
.container-info section.cnts-reg .cnt-reg {
  margin-bottom: 100px;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg {
    margin-bottom: 50px;
  }
}
.container-info section.cnts-reg .cnt-reg .cnt-txt {
  margin: 50px auto;
  width: 700px;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg .cnt-txt {
    width: 90%;
  }
}
.container-info section.cnts-reg .cnt-reg .cnt-txt .c-lead {
  margin-bottom: 20px;
  font-weight: bold;
  font-size: 24px;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg .cnt-txt .c-lead {
    font-size: 20px;
  }
}
.container-info section.cnts-reg .cnt-reg .cnt-txt p {
  text-align: justify;
  font-feature-settings: "palt";
  font-size: 18px;
  line-height: 2;
}
.container-info section.cnts-reg .cnt-reg .cnt-txt figure {
  margin: 30px 0 50px;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg .cnt-txt figure {
    text-align: center;
  }
}
.container-info section.cnts-reg .cnt-reg .cnt-txt figure figcaption {
  font-size: 20px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg .cnt-txt figure figcaption {
    font-size: 4.4vw;
  }
}
.container-info section.cnts-reg .cnt-reg .cnt-txt figure figcaption.bnr-limited {
  display: inline-block;
  margin-bottom: 5px;
  padding: 5px 40px;
  border: solid 1px #DD020F;
  color: #DD020F;
}
.container-info section.cnts-reg .cnt-reg .cnt-txt figure figcaption.bnr-basic {
  display: inline-block;
  margin-bottom: 5px;
  padding: 5px 40px;
  border: solid 1px #333;
}
.container-info section.cnts-reg .cnt-reg .cnt-txt figure img {
  max-width: 100%;
}
.container-info section.cnts-reg .cnt-reg .cnt-txt .FB {
  justify-content: space-around;
}
.container-info section.cnts-reg .cnt-reg .cnt-txt .FB.cnt-pc {
  margin-left: 20px;
}
.container-info section.cnts-reg .cnt-reg .cnt-txt .txt-note-left {
  font-size: 14px;
  font-feature-settings: "palt";
}
.container-info section.cnts-reg .cnt-reg .cnt-txt.txt-panel {
  border: solid 1px #ddd;
  box-shadow: 0px 2px 4px -2px rgba(0, 0, 0, 0.3);
}
.container-info section.cnts-reg .cnt-reg .cnt-txt.txt-panel .panel-upper,
.container-info section.cnts-reg .cnt-reg .cnt-txt.txt-panel .panel-lower {
  padding: 10px 20px;
}
.container-info section.cnts-reg .cnt-reg .cnt-txt.txt-panel .panel-upper {
  border-bottom: solid 1px #ddd;
  background-color: #fbfbfb;
}
.container-info section.cnts-reg .cnt-reg .cnt-txt.txt-panel li {
  list-style: disc;
  font-size: 14px;
  font-feature-settings: "palt";
}
@media only screen and (max-width: 767px) {
  .container-info section.cnts-reg .cnt-reg .cnt-txt.txt-panel li {
    text-align: justify;
    font-size: 14px;
  }
}

/*============================/container-info ==================================*/
/*============================ footer ==================================*/
.z_footer {
  width: 100%;
  min-width: 1200px;
  background-color: #f3f3f3;
}
@media only screen and (max-width: 767px) {
  .z_footer {
    padding: 10px 0 0 0;
    min-width: auto;
  }
}
.z_footer .footer-contents {
  margin: auto;
  width: 1100px;
}
@media only screen and (max-width: 767px) {
  .z_footer .footer-contents {
    box-sizing: border-box;
    padding: 0 30px;
    width: 100%;
  }
}
.z_footer .footer-contents .footer-upper {
  padding: 30px 0;
  border-bottom: solid 2px #979898;
}
.z_footer .footer-contents .footer-upper img {
  width: 340px;
}
@media only screen and (max-width: 767px) {
  .z_footer .footer-contents .footer-upper img {
    width: 200px;
  }
}
.z_footer .footer-contents .footer-content {
  margin: 0 auto 60px;
  width: 1000px;
  justify-content: space-between;
}
@media only screen and (max-width: 767px) {
  .z_footer .footer-contents .footer-content {
    width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .z_footer .footer-contents .footer-content .FB-col {
    padding: 0 0 30px 20px;
  }
}
.z_footer .footer-contents .footer-content .FB-col .ttl {
  margin-bottom: 10px;
  font-weight: bold;
  font-size: 18px;
}
.z_footer .footer-contents .footer-content .FB-col .ttl a {
  font-size: 18px;
}
.z_footer .footer-contents .footer-content .FB-col .ttl.lower {
  margin-top: 50px;
}
@media only screen and (max-width: 767px) {
  .z_footer .footer-contents .footer-content .FB-col .ttl.lower {
    margin-top: 15px;
  }
}
.z_footer .footer-contents .footer-content .FB-col .ttl.txt-jp {
  margin-top: 30px;
}
@media only screen and (max-width: 767px) {
  .z_footer .footer-contents .footer-content .FB-col .ttl.txt-jp {
    margin-top: 15px;
  }
}
.z_footer .footer-contents .footer-content .FB-col ul {
  padding-left: 30px;
}
.z_footer .footer-contents .footer-content .FB-col ul li {
  position: relative;
}
.z_footer .footer-contents .footer-content .FB-col ul li a {
  display: inline-block;
  padding: 10px 0;
  font-size: 14px;
}
.z_footer .footer-contents .footer-content .FB-col ul li:after {
  content: "";
  display: block;
  position: absolute;
  top: 16px;
  left: -13px;
  width: 5px;
  height: 5px;
  border-right: solid #333 2px;
  border-bottom: solid #333 2px;
  transform: rotate(-45deg);
}
.z_footer .footer-contents .footer-content .FB-col ul li.txt-jp:after {
  top: 19px;
}
.z_footer .footer-content-sns {
  width: 100%;
  height: 100px;
  background-color: #dfdfdf;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 767px) {
  .z_footer .footer-content-sns {
    flex-direction: row;
  }
}
.z_footer .footer-content-sns a {
  display: inline-block;
  padding: 10px;
}
.z_footer .footer-content-bottom {
  position: relative;
  padding: 20px 0;
  width: 100%;
  background-color: #000;
}
.z_footer .footer-content-bottom .FB {
  flex-direction: row;
  justify-content: center;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .z_footer .footer-content-bottom .FB {
    flex-direction: column;
  }
}
.z_footer .footer-content-bottom .FB a {
  padding: 0 25px;
  color: #fff;
  font-size: 12px;
}
@media only screen and (max-width: 767px) {
  .z_footer .footer-content-bottom .FB a {
    padding: 10px 0;
  }
}
.z_footer .footer-content-bottom .FB a:not(:nth-child(1)) {
  border-left: solid 1px #fff;
}
@media only screen and (max-width: 767px) {
  .z_footer .footer-content-bottom .FB a:not(:nth-child(1)) {
    border-left: none;
  }
}
.z_footer .footer-content-bottom p {
  margin-top: 15px;
  font-size: 12px;
  color: #fff;
}

/*============================/footer ==================================*/
/*============================ add ==================================*/
.txt-more {
  display: block;
  margin: auto;
  position: relative;
  padding-top: 20px;
  padding-left: 25px;
  width: 130px;
  font-size: 14px;
  text-align: center;
  color: #6B9FFF;
}
.txt-more::before {
  content: "";
  display: block;
  position: absolute;
  top: 25px;
  width: 14px;
  height: 14px;
  background-image: url(/local/images/download.svg);
  background-repeat: no-repeat;
  background-size: cover;
}
@media only screen and (max-width: 767px) {
  .txt-more::before {
    top: 15px;
    width: 10px;
    height: 10px;
  }
}
@media only screen and (max-width: 767px) {
  .txt-more {
    padding-top: 10px;
    width: 110px;
    font-size: 14px;
  }
}

/*============================/add ==================================*/
/*============================ page-extra ==================================*/
.cnt-cloud {
  margin: auto;
  border: solid 1px #ddd;
  max-width: 800px;
}
@media only screen and (max-width: 767px) {
  .cnt-cloud {
    margin: auto 15px;
  }
}
.cnt-cloud p {
  font-size: 14px;
}
.cnt-cloud .content {
  margin-top: 0;
  margin-bottom: 0;
  justify-content: space-around;
}
.cnt-cloud .content .content-wrap .FB-col {
  margin-bottom: 30px;
}
.cnt-cloud .content .content-wrap .FB-col p {
  position: relative;
  margin-top: 30px;
  font-size: 14px;
}
.cnt-cloud .content .content-wrap .FB-col p::before, .cnt-cloud .content .content-wrap .FB-col p::after {
  content: "";
  display: block;
  position: absolute;
  left: calc(50% - 3px);
}
.cnt-cloud .content .content-wrap .FB-col p::before {
  top: 40px;
  left: calc(50% - 3px);
  width: 8px;
  height: 12px;
}
.cnt-cloud .content .content-wrap .FB-col p::after {
  top: 50px;
  left: calc(50% - 8px);
  border: 9px solid transparent;
}
.cnt-cloud .content .content-wrap .FB-col figure {
  margin: 50px 0 0;
  text-align: center;
}
.cnt-cloud .content .content-wrap .FB-col figure img {
  width: 250px;
  margin: auto;
}
@media only screen and (max-width: 767px) {
  .cnt-cloud .content .content-wrap .FB-col figure img {
    width: 100%;
    max-width: 300px;
  }
}
.cnt-cloud .content .content-wrap .FB-col:nth-child(1) p {
  color: #00a2e8;
}
.cnt-cloud .content .content-wrap .FB-col:nth-child(1) p::before {
  background: #00a2e8;
}
.cnt-cloud .content .content-wrap .FB-col:nth-child(1) p::after {
  border-top: 10px solid #00a2e8;
}
.cnt-cloud .content .content-wrap .FB-col:nth-child(2) p {
  color: #2e52c8;
}
.cnt-cloud .content .content-wrap .FB-col:nth-child(2) p::before {
  background: #2e52c8;
}
.cnt-cloud .content .content-wrap .FB-col:nth-child(2) p::after {
  border-top: 10px solid #2e52c8;
}
.cnt-cloud .content .content-wrap .FB-col:nth-child(3) p {
  color: #1aa944;
}
.cnt-cloud .content .content-wrap .FB-col:nth-child(3) p::before {
  background: #1aa944;
}
.cnt-cloud .content .content-wrap .FB-col:nth-child(3) p::after {
  border-top: 10px solid #1aa944;
}

.cnt-cloud-table .cnt-txt table {
  display: block;
  margin-bottom: 0;
  border-collapse: collapse;
  font-size: 14px;
}
@media only screen and (max-width: 767px) {
  .cnt-cloud-table .cnt-txt table {
    font-size: 12px;
  }
}
.cnt-cloud-table .cnt-txt table tbody tr {
  opacity: 1;
  transition: all 0.4s ease 0s;
}
.cnt-cloud-table .cnt-txt table tbody tr td {
  display: inline-block;
}
.cnt-cloud-table .cnt-txt table tbody tr:nth-of-type(odd) {
  background-color: #eee;
}
.cnt-cloud-table .cnt-txt table tbody tr.is-hidden {
  opacity: 0;
  height: 0;
  margin: 0;
  display: none;
}
/* @media only screen and (max-width: 767px) {
  .cnt-cloud-table .cnt-txt table tbody tr.is-hidden {
    display: none;
  }
} */
.cnt-cloud-table .cnt-txt table tbody tr.is-hidden td {
  padding: 0;
  height: 0;
  border: none;
}
.cnt-cloud-table .cnt-txt table tbody.t-upper tr:nth-child(2) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-headword.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(2) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-local.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(3) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-showbiz.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(4) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-music.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(5) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-sports.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(6) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-leisure.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(7) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-travel.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(8) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-vehicle.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(9) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-anime.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(10) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-anime.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(11) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-game.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(12) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-fashion.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(13) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-gourmet.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(14) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-pet.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(15) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-health.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(16) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-living.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(17) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-education.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(18) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-lit_his.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(19) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-art.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(20) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-it.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(21) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-specialty.png);
}
.cnt-cloud-table .cnt-txt table tbody.t-lower tr:nth-child(22) td:nth-child(1)::before {
  background-image: url(/info/features/local/images/cloud/icon/w-nongenre.png);
}
.cnt-cloud-table .cnt-txt table tr th,
.cnt-cloud-table .cnt-txt table tr td {
  border: solid 1px #c1c1c1;
  padding: 10px 30px;
  height: 43px;
}
@media only screen and (max-width: 767px) {
  .cnt-cloud-table .cnt-txt table tr th,
.cnt-cloud-table .cnt-txt table tr td {
    padding: 5px 10px;
  }
}
.cnt-cloud-table .cnt-txt table tr th:nth-child(1),
.cnt-cloud-table .cnt-txt table tr td:nth-child(1) {
  padding-left: 50px;
}
.cnt-cloud-table .cnt-txt table tr td {
  position: relative;
  border-top: none;
}
.cnt-cloud-table .cnt-txt table tr td::before {
  content: "";
  display: block;
  position: absolute;
  top: 3px;
  left: 15px;
  width: 30px;
  height: 30px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media only screen and (max-width: 767px) {
  .cnt-cloud-table .cnt-txt table tr td::before {
    top: 10px;
  }
}
.cnt-cloud-table .cnt-txt table tr th:nth-child(1),
.cnt-cloud-table .cnt-txt table tr td:nth-child(1) {
  box-sizing: border-box;
  width: 200px;
  border-right: none;
  text-align: left;
}
@media only screen and (max-width: 767px) {
  .cnt-cloud-table .cnt-txt table tr th:nth-child(1),
.cnt-cloud-table .cnt-txt table tr td:nth-child(1) {
    width: 40%;
    height: 50px;
  }
}
.cnt-cloud-table .cnt-txt table tr th:nth-child(2),
.cnt-cloud-table .cnt-txt table tr td:nth-child(2) {
  box-sizing: border-box;
  width: 490px;
  text-align: left;
}
@media only screen and (max-width: 767px) {
  .cnt-cloud-table .cnt-txt table tr th:nth-child(2),
.cnt-cloud-table .cnt-txt table tr td:nth-child(2) {
    width: 60%;
    height: 50px;
  }
}
.cnt-cloud-table .cnt-txt table tr:nth-child(1) td {
  border-top: solid 1px #c1c1c1;
}
.cnt-cloud-table .cnt-txt .btn-cloud-more button {
  display: block;
  position: relative;
  width: 100%;
  height: 50px;
  border: none;
  background: none;
}
.cnt-cloud-table .cnt-txt .btn-cloud-more button:hover {
  cursor: pointer;
}
.cnt-cloud-table .cnt-txt .btn-cloud-more button::after {
  content: "";
  display: block;
  position: absolute;
  top: 33px;
  left: calc(50% - 3px);
  width: 6px;
  height: 6px;
  border-right: solid 2px #333;
  border-bottom: solid 2px #333;
  transform: rotate(45deg);
}

.cnt-slider-2 p strong, .cnt-slider-3 p strong {
  font-size: 1.2em;
}
.cnt-slider-2 button, .cnt-slider-3 button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}
.cnt-slider-2 .slide-arrow, .cnt-slider-3 .slide-arrow {
  position: absolute;
  top: 50%;
  margin-top: -15px;
}
.cnt-slider-2 .prev-arrow,
.cnt-slider-2 .next-arrow, .cnt-slider-3 .prev-arrow,
.cnt-slider-3 .next-arrow {
  width: 40px;
  height: 40px;
  border-bottom: solid 2px #9c9999;
}
@media only screen and (max-width: 767px) {
  .cnt-slider-2 .prev-arrow,
.cnt-slider-2 .next-arrow, .cnt-slider-3 .prev-arrow,
.cnt-slider-3 .next-arrow {
    display: none !important;
  }
}
.cnt-slider-2 .prev-arrow:hover,
.cnt-slider-2 .next-arrow:hover, .cnt-slider-3 .prev-arrow:hover,
.cnt-slider-3 .next-arrow:hover {
  cursor: pointer;
}
.cnt-slider-2 .prev-arrow, .cnt-slider-3 .prev-arrow {
  left: -40px;
  transform: rotate(45deg);
  border-left: solid 2px #9c9999;
}
.cnt-slider-2 .next-arrow, .cnt-slider-3 .next-arrow {
  right: -40px;
  transform: rotate(-45deg);
  border-right: solid 2px #9c9999;
}
.cnt-slider-2 .slick-dots, .cnt-slider-3 .slick-dots {
  bottom: -20px;
}
.cnt-slider-2 .slick-dots li, .cnt-slider-3 .slick-dots li {
  margin: 0 4px;
  width: 50px;
  height: 5px;
}
.cnt-slider-2 .slick-dots li button:before, .cnt-slider-3 .slick-dots li button:before {
  content: "";
  width: 50px;
  height: 5px;
  background: #E0E0E0;
  opacity: 1;
}
.cnt-slider-2 .slick-dots li.slick-active button:before, .cnt-slider-3 .slick-dots li.slick-active button:before {
  background: #DD020F;
}

a.txt-os-link {
  margin: 50px auto;
  align-items: center;
  font-size: 14px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  a.txt-os-link {
    margin: 0 auto;
    font-size: 14px;
  }
}
a.txt-os-link span {
  position: relative;
}
a.txt-os-link span::after {
  content: "";
  display: block;
  position: absolute;
  width: 5px;
  height: 5px;
  border-right: solid 2px #333;
  border-bottom: solid 2px #333;
  transform: rotate(-45deg);
  top: calc(50% - 3.5px);
  right: -10px;
}
@media only screen and (max-width: 767px) {
  a.txt-os-link span::after {
    top: calc(50% - 2.5px);
  }
}

section.contents.btn-link-andr {
  padding: 0;
}
section.contents.btn-link-andr .content {
  margin: 0;
}
@media only screen and (max-width: 767px) {
  section.contents.btn-link-andr .content {
    margin-top: 30px;
  }
}
section.contents.btn-link-andr .content .link-btn.FB div a {
  width: 500px;
  max-width: 100%;
  line-height: 40px;
  border: solid 2px #000;
}
section.contents.btn-link-andr .content .link-btn.FB div a:hover {
  background-color: #000;
}
section.contents.btn-link-andr .content .link-btn.FB div a:hover span {
  color: #fff;
}
section.contents.btn-link-andr .content .link-btn.FB div a:hover span::after {
  border-top: 3px solid #fff;
  border-right: 3px solid #fff;
}
section.contents.btn-link-andr .content .link-btn.FB div a span {
  color: #000;
}
section.contents.btn-link-andr .content .link-btn.FB div a span::after {
  border-top: 3px solid #000;
  border-right: 3px solid #000;
}

section.contents.floatingmenu, section.contents.floatingmenu-os {
  display: none;
  position: fixed;
  z-index: 100;
  bottom: 0;
  margin: 0;
  padding: 0;
}
section.contents.floatingmenu .inner, section.contents.floatingmenu-os .inner {
  background-color: rgba(255, 255, 255, 0.8);
  transition: all 0.3s ease;
}
section.contents.floatingmenu .inner:hover, section.contents.floatingmenu-os .inner:hover {
  background-color: #fff;
}
section.contents.floatingmenu .inner .content, section.contents.floatingmenu-os .inner .content {
  margin: 0;
  padding: 10px 0;
}
@media only screen and (max-width: 767px) {
  section.contents.floatingmenu .inner .content, section.contents.floatingmenu-os .inner .content {
    padding: 5px 0;
  }
}
section.contents.floatingmenu .inner .content .link-btn, section.contents.floatingmenu-os .inner .content .link-btn {
  margin: 0 0 env(safe-area-inset-bottom);
}
section.contents.floatingmenu .inner .content .link-btn div a, section.contents.floatingmenu-os .inner .content .link-btn div a {
  background-color: #DD020F;
  border: solid 1px #DD020F;
  line-height: 50px;
}
@media only screen and (max-width: 767px) {
  section.contents.floatingmenu .inner .content .link-btn div a, section.contents.floatingmenu-os .inner .content .link-btn div a {
    height: 40px;
    line-height: 40px;
  }
}
section.contents.floatingmenu .inner .content .link-btn div a span, section.contents.floatingmenu-os .inner .content .link-btn div a span {
  padding-right: unset;
  padding: 0 200px;
  color: #fff;
}
@media only screen and (max-width: 767px) {
  section.contents.floatingmenu .inner .content .link-btn div a span, section.contents.floatingmenu-os .inner .content .link-btn div a span {
    padding: 0 80px;
  }
}
section.contents.floatingmenu .inner .content .link-btn div a span::after, section.contents.floatingmenu-os .inner .content .link-btn div a span::after {
  display: none;
}
section.contents.floatingmenu .inner .content .link-btn div a:hover, section.contents.floatingmenu-os .inner .content .link-btn div a:hover {
  background-color: #fff;
  border: solid 1px #DD020F;
}
section.contents.floatingmenu .inner .content .link-btn div a:hover span, section.contents.floatingmenu-os .inner .content .link-btn div a:hover span {
  color: #DD020F;
}

section.contents#atok-infomation {
  padding: 1px 0;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-infomation {
    padding: 50px 0;
  }
}
section.contents#atok-infomation .content {
  width: 1100px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-infomation .content {
    width: 90%;
  }
}
section.contents#atok-infomation .content .pannel-body {
  margin-top: 50px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-infomation .content .pannel-body {
    margin-top: 20px;
  }
}
section.contents#atok-infomation .content .pannel-body dl {
  display: flex;
  margin: 0;
  padding: 20px 0;
  border-bottom: solid 1px #ddd;
  align-items: center;
  font-size: 18px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-infomation .content .pannel-body dl {
    flex-direction: column;
    align-items: unset;
  }
}
section.contents#atok-infomation .content .pannel-body dl:nth-child(1) {
  border-top: solid 1px #ddd;
}
section.contents#atok-infomation .content .pannel-body dl dt {
  margin-left: 30px;
  color: #D4222C;
  font-size: 0.8em;
}
section.contents#atok-infomation .content .pannel-body dl dd {
  margin-right: 30px;
}
@media only screen and (max-width: 767px) {
  section.contents#atok-infomation .content .pannel-body dl dd {
    margin: 10px 30px 0;
  }
}
section.contents#atok-infomation .content .pannel-body dl dd a {
  font-feature-settings: "palt";
  font-size: 0.8em;
}

p.cnt-note {
  font-size: 14px;
}

.cloud-service.-cnt-reg-ttl {
  position: relative;
  margin: 100px auto;
}
@media only screen and (max-width: 767px) {
  .cloud-service.-cnt-reg-ttl {
    margin: 70px 20px;
  }
}
.cloud-service.-cnt-reg-ttl .txt-ttl-shoulder {
  position: absolute;
  top: -40px;
  left: 50%;
  padding: 5px 40px;
  transform: translateX(-50%);
  border: solid 1px #DD020F;
  color: #DD020F;
  font-size: 20px;
}
@media only screen and (max-width: 767px) {
  .cloud-service.-cnt-reg-ttl .txt-ttl-shoulder {
    width: 200px;
  }
}

.cloud-service.content .link-btn.FB div a {
  line-height: 45px;
  background-color: #fff;
  border: solid 1px #DD020F;
}
.cloud-service.content .link-btn.FB div a span {
  margin-right: 20px;
  padding: 0 40px;
  font-size: 0.8em;
  font-weight: 400;
}
.cloud-service.content .link-btn.FB div a span::after {
  top: 3px;
}
@media only screen and (max-width: 767px) {
  .cloud-service.content .link-btn.FB div a {
    height: 45px;
  }
}
@media only screen and (max-width: 767px) {
  .cloud-service.content .link-btn.FB div:nth-child(2) {
    margin-top: 10px;
  }
}

section.contents.txt-info-ios {
  margin: 0;
  padding: 0;
}
section.contents.txt-info-ios .panel {
  margin: 30px auto 0;
  width: 600px;
  height: 50px;
  background-color: #f5f5f5;
  border: solid 2px #e3e3e3;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  section.contents.txt-info-ios .panel {
    width: 80%;
    max-width: 400px;
  }
}
section.contents.txt-info-ios .panel a {
  line-height: 50px;
  font-size: 16px;
}
@media only screen and (max-width: 767px) {
  section.contents.txt-info-ios .panel a {
    font-size: 14px;
  }
}

section.contents#announce {
  padding-bottom: 0;
  min-width: unset;
  width: 1000px;
}
@media only screen and (max-width: 767px) {
  section.contents#announce {
    width: 90%;
  }
}
section.contents#announce + #toTop {
  min-width: 1000px;
}
@media only screen and (max-width: 767px) {
  section.contents#announce + #toTop {
    min-width: auto;
  }
}
section.contents#announce .content h4 {
  padding-bottom: 20px;
  border-bottom: solid 2px #ddd;
}
@media only screen and (max-width: 767px) {
  section.contents#announce .content h4 {
    text-align: left;
  }
}
section.contents#announce .content .date {
  margin-top: 10px;
  color: #D4222C;
  font-size: 14px;
  text-align: right;
}
section.contents#announce .content .txt-head {
  margin-top: 50px;
}
@media only screen and (max-width: 767px) {
  section.contents#announce .content .txt-head {
    margin-top: 30px;
  }
}
section.contents#announce .content p {
  text-align: justify;
}
section.contents#announce .content ul {
  font-size: 18px;
  list-style-type: disc;
}
@media only screen and (max-width: 767px) {
  section.contents#announce .content ul {
    font-size: 16px;
  }
}