@charset "UTF-8";

html {
  background: #fff;
  overflow-x: hidden;
}
body {
  font-size: 16px;
  color: #444;
  line-height: 200%;
  overflow-x: hidden;
  font-family: "Noto Sans JP", sans-serif;
}
img { width: 100%;}
a {
  opacity: 1;
  transition: all .3s;
  color: #ccc;
  font-family: "Noto Sans JP", sans-serif;
}
a:hover {
  opacity: 0.8;
  transition: all .3s;
}
.pc_only{display: block;}
.sp_only{display: none;}
header img{display: block;width: 100%;}
h2 {
  background-image: linear-gradient(109deg, rgba(247, 238, 12, 1) 5%, rgba(255, 151, 29, 1) 26%, rgba(252, 86, 36, 1) 67%);
  width: 100%;
  padding: 2rem 0;
  display: flex;
  position: relative;
  box-shadow: 0 5px 10px #ccc;
  font-family: "Noto Sans JP", sans-serif;
  display: flex;
  align-items:center;
  justify-content:center;
  margin: 0 auto;
  color:#fff;
  text-align: center;
  font-size: 180%;
  text-shadow: 0 1px 0 #333;
}
h2::before {
  position: absolute;
  bottom: -15px;
  width: 30px;
  height: 15px;
  background-color: #f60;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  content: '';
}
.mv {
  width: 100%;
  position: relative;
}
.icon {
  width: 100px;
  margin-right: 1rem;
}
.icon img{
  border-radius: 50px;
  border:5px solid #fff;
  box-shadow: 0 5px 10px #c44e00;
}
#contents {
  width: 100%;
}
#contents .contents_inner {
  width: 1000px;
  margin: 0 auto;
  background: #fff;
}
#contents .intro {
  width: 90%;
  font-size: 130%;
  text-align: center;
  line-height: 180%;
  margin: 5rem auto;
  border: 4px solid #ff6600;
  border-radius: 20px;
  padding: 2rem 0;
}
#contents .intro p{
  color: #ff6600;
  font-weight: bold;
  font-size: 110%;
}
#contents .intro .att1{
  text-align:left;
  padding: 0 2rem;
  font-size: 100%;
}
#contents .intro .att2{
  background: #f6f6f6;
  border-radius: 10px;
  font-size: 70%;
  padding: 1rem;
  margin-top: 1rem;
  color: #666;
}
.api .api_inner {
  width: 1000px;
  margin:4rem auto;
}
.api .api_inner iframe{
  height: 1700px;
}
.area .area_inner {
  width: 1000px;
  margin: 3rem auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
}
.accordion {
  width: 49%;
}
.question {
  font-size: 20px;
  font-weight: bold;
  padding: 2rem;
  background-color: #f6f6f6;
  color: #555;
  position: relative;
  cursor: pointer;
  border: 1px solid #aaa;
  box-sizing: border-box;
  border-radius: 10px ;
  margin: .5rem 0;
}
.question::before {
  content: "";
  border-left: 4px solid #ff9000;
  margin-right: 1rem;
  padding: 0 !important;
  line-height: 100%
  font-size: 100%;
}
.question:after {
  content: "";
  display: block;
  position: absolute;
  top: 45%;
  right: 8%;
  width: 11px;
  height: 11px;
  border-top: 2px solid #333;
  border-right: 2px solid #333;
  transform: rotate(135deg);
  transition: .3s;
}
.question.open:after {
  transform: rotate(-45deg);
  transition: .3s;
}
.answer {
  padding: 10px;
  display: none;
}
.answer a{
  color: #36c;
  display: block;
  padding: .5rem;
  border-bottom:1px dotted #ccc;
}
.excahnge {
  width: 100%;
  background: #FFE7D6;
  background: linear-gradient(0deg,rgba(255, 231, 214, 1) 0%, rgba(255, 228, 184, 1) 60%, rgba(254, 210, 139, 1) 100%);
}
.excahnge .excahnge_inner{
  width: 1000px;
  margin: 0 auto;
}
.excahnge .excahnge_inner_text{
  text-align: right;
  padding: 1rem 0;
  font-size:110%;
}
.excahnge .excahnge_inner_text a{
  color:#666;
}
.rule .rule_inner .rule_content{
  width: 1000px;
  margin: 0 auto;
}
.rule .rule_inner .rule_content .rule_detail{
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #fff;
  padding: 20px;
  border-radius: 10px;
  box-shadow: 0 5px 10px #ccc;
  border: 1px solid #aaa;
  margin: 2rem auto;
}
.rule .rule_inner .rule_content .rule_detail a{
  color: #3366cc;
}
.rule .rule_inner .rule_content .rule_detail .rule_detail_img {
  width: 20%;
}
.rule .rule_inner .rule_content .rule_detail .rule_detail_img img{
  border: 1px solid #ccc;
}
.rule .rule_inner .rule_content .rule_detail .rule_detail_txt {
  font-size: 120%;
  line-height: 180%;
  width: 75%;
}
.rule .rule_inner .rule_content .rule_detail .rule_detail_txt .txt_title{
  font-size: 110%;
  font-weight:bold;
}
#contents .intro span{
  font-weight: bold;
}
#contents .btn{
  width: 80%;
  margin: 5rem auto 5rem auto;
}
#contents .btn .btn-inner{
  width: 1000px;
  margin:0 auto;
  text-align: center;
}
#contents .btn .btn-01 {
  width: 100%;
  margin:0 auto;
  text-align: center;
}
#contents .btn .btn-01 a{
  position: relative;
  display: inline-block;
  width: 80%;
  margin: 1.5rem auto 0 auto;
  text-align: center;
  color: #fff;
  font-size: 180%;
  font-weight: bold;
  letter-spacing:.1em;
  border-radius: 100px;
  text-decoration: none;
  padding: 3rem 0;
  line-height: 110%;
  background: #ff6600;
  padding-left:2rem;
  padding-right:2rem;
}
#contents .btn .btn-01 a::after{
  content: "》";
  box-sizing: border-box;
  position: absolute;
  right: .5rem;
}
#contents .contents05 {
  margin-bottom: 5rem;
}
#contents .att{
  padding: 2rem;
  margin: 3rem 0;
}
#contents .att span{
  font-weight: bold;
}
#contents .att .red{
  color: #ed4b4b;
}
.contents05 {
  background: #78bc13;
}
.contents05 .item_inner{
  width: 900px;
  margin: 0 auto;
  padding: 5rem 0;
}
.contents05 .item_inner p{
  text-align: center;
  font-weight: bold;
  font-size: 160%;
  color: #fff;
  margin-bottom: 2rem;
  letter-spacing: .1rem;
  line-height: 160%;
}
.contents05 .item_inner p span{
  text-decoration: underline;
  text-decoration-color : #ffff3d;
}
.contents05 .item_inner img{
  width: 700px;
  margin: 0 auto;
}
.slick-prev {
  left: -40px;
  z-index: 1;
}
.slick-next {
  right: -40px;
}
.slick-prev,.slick-next{
  width: 40px;
  height: 40px;
}
 .slick-prev:before, .slick-next:before {
  font-size: 40px;/*少し大きくする*/
}
.slick-dots {
  bottom: -50px;
}
.slick-dots li button:before{
  font-size:20px!important;
}
footer {
  background: #333;
}
footer .footer_inner{
  font-size: 80%;
  color: #ccc;
  width: 1000px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 5vw 0;
}
footer .footer_inner img{
  width: 146px;
}
footer .copy{
  width: 1000px;
  margin: 0 auto;
  border-top: 1px dotted #666;
  font-size: 80%;
  text-align: center;
  color: #888;
  padding: 1vw 0;
}
#formWrap iframe {
  height: 1500px;
}
/* # =================================================================
   # SP
   # ================================================================= */

@media (max-width: 750px) {
  .pc_only{display: none;}
  .sp_only{display: block;}
  h2 {
    font-size: 120%;
    margin: 0 auto;
    padding: 1rem 0;
    text-align: left !important;
  }
  h2::before {
    position: absolute;
    bottom: -.5rem;
    left: 46%;
    width: 2rem;
    height: 1rem;
  }
  h2 p{
    width: 80%
  }
  .icon {
    text-align: center;
    width: 20%;
    margin-left: 1rem;
    margin-right: .6rem;
  }
  #contents .contents_inner {
    width: 100%;
  }
  #contents .intro {
    width: 90%;
    margin: 2rem auto;
    padding: 0.8rem;
    font-size: 100%;
  }
  #contents .intro p{
    margin: 0;
    padding: 0;
    line-height: 140%;
    font-size: 120%;
  }
  #contents .intro .att1{
    padding: 0;
  }
  #contents .btn{
    width: 90%;
    margin: 0 auto 3rem auto;
  }
  #contents .btn .btn-inner{
    width:100%;
  }
  #contents .btn .btn-01 a{
    display: block;
    margin-top: 2rem;
    width: 95% !important;
    padding: 1.7rem 0;
    line-height: 110%;
    font-size: 110%;
  }
  .api .api_inner {
    width: 100%;
    margin:0rem auto;
  }
  .api .api_inner iframe{
    height: 670px;
  }
  .area .area_inner {
    width: 95%;
    margin: 2rem auto;
    display: flex;
  }
  .rule .rule_inner {
    padding: 1rem 0;
  }
  .rule .rule_inner .rule_content{
    width: 95%;
    margin: 0rem auto 2rem auto;
  }
  .accordion {
    width: 47%;
  }
  .question {
    padding: 1rem;
    font-size: 100%;
  }
  .question::before {
    border-left: 3px solid #ff9000;
    margin-right: .4rem;
  }
  .question:after {
    content: "";
    display: block;
    position: absolute;
    top: 40%;
    right: 8%;
    width: 8px;
    height: 8px;
    border-top: 2px solid #333;
    border-right: 2px solid #333;
  }
  #contents .att{
    padding: 1rem;
    margin: 2rem 0;
  }
  .slick-prev {
    left: 0px;
    z-index: 1;
  }
  .slick-next {
    right: 0px;
  }
  .rule .rule_inner .rule_content .rule_detail{
    margin: 1rem auto;
    padding: 1rem;
  }
  .rule .rule_inner .rule_content .rule_detail .rule_detail_txt {
    font-size: 90%;
    line-height: 120%;
    width: 70%;
  }
  .rule .rule_inner .rule_content .rule_detail .rule_detail_img {
    width: 26%;
  }
  .rule .rule_inner .rule_content .rule_detail .rule_detail_img img{
    width:100%;
  }
  .rule .rule_inner .rule_content .rule_detail .rule_detail_txt .txt_title{
    font-size: 110%;
    line-height: 100%;
    margin-bottom: .5rem;
  }
  .rule .rule_inner .rule_content .rule_detail .rule_detail_txt .txt_title a{
    line-height: 110%;
  }
  .contents05 .item_inner{
    width: 100%;
    padding: 3rem 0;
  }
  .contents05 .item_inner img{
    width:90%;
  }
  .contents05 .item_inner p{
    font-size: 110%;
  }
  footer .footer_inner{
    width: 90%;
  }
  footer .footer_inner p{
    font-size: 80%;
  }
  footer .footer_inner img{
    width: 50px;
  }
  footer .copy{
    width: 100%;
    font-size: 80%;
    padding: 3vw 0;
  }
  #formWrap iframe {
    height: 1800px;
  }
}


/* # =================================================================
   # UTFP
   # ================================================================= */

#utfp .btn02 {
    width: 100%;
    margin: 0 auto;
}
#utfp .btn02 a{
    display: block;
    width: 90%;
    margin: 0 auto;
    color: #fff;
    font-size: 200%;
    font-weight: bold;
    background: #f66;
    border-radius: 50px;
    padding: 2rem 0;
    text-decoration: none;
    text-align: center;
    letter-spacing: .1rem;
    text-shadow: 0 1px 0 #333;
}

/* # =================================================================
   # UTFP SP
   # ================================================================= */
@media (max-width: 750px) {
  #utfp .btn02 a{
      width: 95%;
      font-size: 150%;
      padding: 1rem 0;
  }
}