@charset "UTF-8";
/*共通*/
body {
font-size: 17px;
background-color: #F4F4F4;
}
p {
line-height: 1.6;
word-wrap: break-word;
font-family: 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', sans-serif , 'ヒラギノ角ゴ Pro W3';
}
.contents{
margin: 0 auto;
padding: 0;
overflow: hidden;
color: #333;
}
.contents-box{
max-width: 700px;
margin: 0 auto;
padding: 1%;
box-sizing:border-box;
background-color: #fff;
}
a:link, a:visited, a:hover, a:active {
color: #000;
text-decoration: none;
}
a:hover {
opacity: 0.7;
}
.pc_ds{
display: block;
}
.sp_ds{
display: none;
}
img , video{
max-width: 100%;
width: 100%;
}
/*テキスト*/
b {
font-weight: bold;
}
.fo_b{
    font-size: 19px;
}
.fo_b2{
    font-size: 21px;
}
.tyuu{
font-size: 12px;
color: rgb(187, 187, 187);
}
.lin_y{
background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%,#ffffcc 0%) repeat scroll 0 0;
}
.lin_g{
background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%,#cce0f5 0%) repeat scroll 0 0;
}
.lin_p{
background:rgba(0, 0, 0, 0) linear-gradient(transparent 60%,#fae1f0 0%) repeat scroll 0 0;
}
 h3 {
  border-bottom: 7px solid #ff69b4;
  margin-bottom: 30px;
  font-weight: bold;
  font-size: 22px;
  margin-top: 4%;
}
.ta_r{
text-align: right;
}
.ta_c{
text-align: center;
}
/*カラー*/
.co_p{
    color: rgb(235, 19, 152);
}
.co_b{
color: rgb(0, 71, 178);
}


/*margin*/
.mt1{
margin-top: 1%; 
}
.mt2{
margin-top: 2%; 
}
.mt3{
margin-top: 3%; 
}
.mt4{
margin-top: 4%; 
}
.mb1{
margin-bottom: 1%; 
}
.mb2{
margin-bottom: 2%; 
}
.mb3{
margin-bottom: 3%; 
}
.mb4{
margin-bottom: 4%; 
}

/*ポジション*/
.po_r{
position: relative;
}
.po_a{
position: absolute;
}

/*ポジション　上下左右中央*/
.po_ce{
left: 50%;
transform: translateX(-50%);
-webkit-transform: translateX(-50%);
-ms-transform: translateX(-50%);
}
/*ポジション　左右中央*/
.po_lr_ce{
top: 0;
left: 50%;
transform: translateX(-50%);
-webkit-transform: translateX(-50%);
-ms-transform: translateX(-50%);
}

/*----------sp------------*/
@media (max-width: 767px) { 
/*共通*/
.contents{
width: 100%;
}
.sp_ds{
display: block;
}
.pc_ds{
display: none;
}
.pc_ds2{
display: none;
}
.contents_wrapper {
width: 100%;
}
/*テキスト*/
.tyuu{
font-size: 10px;
}
}

/*口コミ*/
 .comment__area {
  width: calc(100% - 20px);
  height: auto;
  border: 1px solid #ccc;
  border-radius: 5px;
  box-shadow: 3px 3px 2px #F4D2DE;
  padding: 10px 10px 15px;
  margin-top: 30px;
  position: relative;
}

 .comment__head {
  position: absolute;
  top: 0;
  left: 0;
  background: #ff80bf;
  border-radius: 5px;
  padding: 3px 5px;
  box-shadow: 2px 2px 2px #888;
}

 .comment__head .head {
  color: #fff;
  font-weight: bold;
  text-shadow: 1px 1px 1px #888;
}

 .comment__img {
  width: 100%;
  height: auto;
}

 .comment__img img {
  width: 100%;
  height: auto;
}

 .comment__detail {
  margin-top: 10px;
}

 .comment__detail .name {
  font-size: 16px;
}

 .comment__detail .text {
  font-size: 14px;
}

 .comment__detail .name+.text {
  margin-top: 1em;
}

 .comment__detail .text+.text {
  margin-top: 1em;
}

 .comment__detail .text .bold {
  font-weight: bold;
}

 .comment__detail .text .underline {
  position: relative;
}

 .comment__detail .text .underline:before {
  content: '';
  width: 100%;
  height: 100%;
  z-index: -1;
  position: absolute;
  bottom: 0;
  left: 0;
  background: linear-gradient(to bottom, transparent 0%, transparent 70%, #ffff00 71%, #ffff00 100%);
}

 .comment__detail .attention {
  font-size: 10px;
  color: #666;
  margin-top: 1.4em;
}

 .comment__detail .attention+.attention {
  margin-top: 1em;
}

 .comment__img video,
 .comment__img iframe {
  width: 100%;
  aspect-ratio: 16/9;
  display: block;
  object-fit: cover;
  margin: 0;
}

 .comment__caption {
  font-size: 12px;
  text-align: right;
  margin-top: 10px;
}



/*アンケート*/
 .anc-wrapper {
  padding: 0 15px 15px;
  /* 枠の色 */
  margin: 0;
  background: linear-gradient(#deebf3, #b9d2e4);
  vertical-align: bottom;
  font-family: serif;
}
 .container {
  /* コンテンツ部分の背景色 */
  background-color: #ffffff;
  padding: 0 0 4%;
}
 .box-title {
  /* Q1部分の背景色 */
  background-color: #deebf3;
  text-align: center;
}
 .tit {
  position: relative;
  bottom: -25px;
  z-index: 1;
  width: 80px;
  height: 80px;
  font-weight: bold;
  /* Q1部分の文字色 */
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
}
 .box-content {
  padding: 0 2%;
  width: 96%;
  margin: 0 auto;
}
.anc-wrapper p {
  margin: 60px 0 0;
  font-size: 1.4em;
  font-weight: bold;
  text-align: center;
  font-family: serif;
}
 .main {
  padding: 10px 2% 10px;
  margin: 0 auto;
  width: 94%;
}
 .questions {
  font-size: 8px;
  margin: 15px auto 0;
}
.to ul, .to li, .to label, .to span , .to1 ul, .to1 li, .to1 label, .to1 span {
  list-style: none;
  padding: 0;
  margin: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline;
  background: transparent;
  max-height: 99999px;
  text-align: center;
  font-family: serif;
}
 .btn_list {
  overflow: hidden;
  padding: 4.68% 5% 5% 5%;
  display: flex;
}
 .btn_list li:first-child {
  padding-right: 2%;
}
 .btn_list li {
  width: 50%;
}
 .radio-input {
  display: none;
}
 input[type="radio"]:checked+.y01,
 input[type="radio"]:checked+.n01,
 .input_img:hover {
  margin-top: 3px;
  /* 選択時のボタン文字色 */
  color: #010346;
  /* 選択時のボタン背景色 */
  background: #b2b7bd;
  /* 選択時のボタン影色 */
  border-bottom: 2px solid #8fa2b0;
}
  .anc-wrapper .input_img {
  display: block;
  width: 100%;
  cursor: pointer;
  background-repeat: no-repeat;
  background-size: contain;
  padding: 10%;
  border-radius: 8px;
  font-size: 8vw;
  line-height: 1;
  /* 非選択時のボタン文字色 */
  color: #fff;
  font-weight: bold;
  /* 非選択時のボタン背景色 */
  background: linear-gradient(#d8b45c, #a9751b);
  /* 非選択時のボタン影色 */
  border-bottom: 5px solid #92610b;
  box-shadow: 0 3px 5px rgba(0, 0, 0, .3);
  transition: all .3s;
  box-sizing: border-box;
}

@media (min-width: 620px) {
    .anc-wrapper .input_img {
    font-size: 42px;
  }
}
 .btn_list li:last-child {
  padding-left: 2%;
}
 .sp {
  display: none;
}
@media (max-width: 750px) {
   .sp {
    display: block;
  }
}

/*全体的な指定*/
.blackwood_box {
  position: relative;
  /*色*/
  color: linear-gradient(#d8b45c, #a9751b);
  /*外側の余白。上下｜左右*/
  margin: 30px 0;
}

 .blackwood_box .selecter {
  display: none;
}

/*アンケートボックス*/
.blackwood_box .selecter+.choice-check {
  /* 非選択時のボタン文字色 */
  color: #fff;
  font-weight: bold;
  /* 非選択時のボタン背景色 */
  background: linear-gradient(#d8b45c, #a9751b);
  display: block;

  /* 非選択時のボタン影色 */
  border-bottom: 5px solid #92610b;
  box-shadow: 0 3px 5px rgba(0, 0, 0, .3);
  transition: all .3s;
  box-sizing: border-box;
  /*アンケート枠の内側余白。上下｜左右*/
  padding: 10px 15px;
  /*アンケート内の文字の太さ*/
  font-weight: bold;
  /*アンケートの角丸*/
  border-radius: 5px;
  /*アンケートボックス外側の下余白*/
  margin-bottom: 18px;
}

/*チェックをした時*/
.blackwood_box .selecter:checked+.choice-check {
  margin-top: 3px;
  /* 選択時のボタン文字色 */
  color: #010346;
  /* 選択時のボタン背景色 */
  background: #b2b7bd;
  /* 選択時のボタン影色 */
  border-bottom: 2px solid #8fa2b0;

  /*アンケートボックスの影。水平の距離｜垂直の距離｜ぼかし具合｜色の指定*/
  box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.5);
  transition: 200ms;
}
/* 画面サイズPCの時のみhover時に反応する様にする。
※SP時に以下の設定があると挙動がおかしくなります。 */
@media (min-width: 601px) {
    .anc-wrapper .input_img {
    font-size: 42px;
  }
}
 .btn_list li:last-child {
  padding-left: 2%;
}
 .sp {
  display: none;
}

 .anc-wrapper.to input[type="radio"]:checked+.y01,
 .anc-wrapper.to input[type="radio"]:checked+.n01,
 .anc-wrapper.to .input_img:hover {
  margin-top: 3px;
  /* 選択時のボタン文字色 */
  color: #010346;
  /* 選択時のボタン背景色 */
  background: #b2b7bd;
  /* 選択時のボタン影色 */
  border-bottom: 2px solid #8fa2b0;
}

.anc-wrapper.to2 input[type="checkbox"] {
  display: none;
  appearance: checkbox;
  box-sizing: border-box;
}

 .anc-wrapper.to2 input[type="checkbox"]+span {
  display: block;
  position: relative;
  padding-left: 35px;
  margin-bottom: 20px;
  font-weight: bold;
  cursor: pointer;
}

 .anc-wrapper.to2 input[type="checkbox"]:checked+span:before {
  width: 10px;
  top: -5px;
  left: 10px;
  border-radius: 0;
  opacity: 1;
  border-top-color: transparent;
  border-right-color: #cd666f;
  border-bottom-color: #cd666f;
  border-left-color: transparent;
  transform: rotate(45deg);
}

 .anc-wrapper.to2 input[type="checkbox"]+span:before {
  content: '';
  display: block;
  width: 20px;
  height: 20px;
  border: 1px solid #000;
  position: absolute;
  left: 0;
  top: 0;
  opacity: .6;
  transition: all .12s, border-color .08s;
}

 .to2 p {
  margin: 60px 0 0;
  font-size: 1.4em;
  font-weight: bold;
  text-align: center;
}

 .to2 .questions {
  font-size: 8px;
  margin: 15px auto 0;
}

 .to2 .questions {
  margin-top: 30px;
  font-size: 16px;
  font-family: sans-serif;
}

/*→*/
 .center {
  text-align: center;
  font-family: serif;
}

 .words {
  /* 数字下の文字色 */
  color: #fff;
  /* 数字下の背景色 */
  background: linear-gradient(to bottom, #1a2287, #010346);
  padding: 20px;
  max-width: unset;
  /* 数字下の文字サイズ */
  font-size: 17px;
  line-height: 1.3em;
  padding: 20px 0 20px 0;
}

 .step_arr {
  position: relative;
  padding-top: 22vw;
  padding-bottom: 3vw;
  margin-top: -4vw;
}

 .step_arr span {
  position: absolute;
  top: 0;
  left: 50%;
  width: 10vw;
  height: 10vw;
  margin-left: -5vw;
  border-left: 1px solid #333;
  border-bottom: 1px solid #333;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  -webkit-animation: sdb 2s infinite;
  animation: sdb 2s infinite;
  opacity: 0;
  box-sizing: border-box;
}

 .step_arr span:nth-of-type(1) {
  -webkit-animation-delay: 0s;
  animation-delay: 0s;
}

 .step_arr span:nth-of-type(2) {
  top: 4vw;
  -webkit-animation-delay: .15s;
  animation-delay: .15s;
}

 .step_arr span:nth-of-type(3) {
  top: 8vw;
  -webkit-animation-delay: .3s;
  animation-delay: .3s;
}

@-webkit-keyframes sdb {
  0% {
    opacity: 0;
  }

  50% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }
}

@keyframes sdb {
  0% {
    opacity: 0;
  }

  50% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }
}

@media (min-width: 620px) {
   .step_arr {
    position: relative;
    padding-top: 136px;
    margin-top: -25px;
  }

   .step_arr span {
    width: 62px;
    height: 62px;
    margin-left: -31px;
  }

   .step_arr span:nth-of-type(2) {
    top: 24.8px;
  }

   .step_arr span:nth-of-type(3) {
    top: 49.6px;
  }
}

/*ボタン*/
 .purupuru {
  /*アニメーション名、動きの速さ0.8s（=0.8秒）、動き具合、開始時間5s(=5秒後)、動く回数infinite(=無限 3=3回など)   */
  animation: purupuru 2s linear 0s infinite;
}

@keyframes purupuru {

  /*アニメーションの最初の動き*/
  0% {
    /*skew = 傾斜変形する、1番目の値はX軸、2番目に値がある場合はY軸に傾斜変形する
    　　　　9deg = 9度*/
    transform: skew(9deg);
  }

  10% {
    transform: skew(-8deg);
  }

  20% {
    transform: skew(7deg);
  }

  30% {
    transform: skew(-6deg);
  }

  40% {
    transform: skew(5deg);
  }

  50% {
    transform: skew(-4deg);
  }

  60% {
    transform: skew(3deg);
  }

  70% {
    transform: skew(-2deg);
  }

  80% {
    transform: skew(1deg);
  }

  90% {
    transform: skew(0deg);
  }

  /*アニメーションの最後の動き*/
  100% {
    transform: skew(0deg);
  }
}

 footer {
  font-size: 13px;
  padding: 5%;
  background: #ECECEC;
  text-align: center;
  margin-top: 10px;
 }
  footer a:link{
  color: #000;
}