@charset "utf-8";

.forpc {
  display: block !important;
}
.forsp {
  display: none !important;
}
.forpcinline {
  display: inline !important;
}
.forspinline {
  display: none !important;
}

p.indent-1,
ul.indent-1 > li {
  text-indent: -1em;
  padding-left: 1em;
}
ul.disclist {
  list-style: disc;
  margin-left: 1.8em;
}
ul.disclist > li {
  margin: 0 0 10px;
}

@media (max-width: 768px) {
  .forpc {
    display: none !important;
  }
  .forsp {
    display: block !important;
  }
  .forpcinline {
    display: none !important;
  }
  .forspinline {
    display: inline !important;
  }
  img {
    width: 100%;
  }
}

/* -----------------------------------------------
 bnr_area
------------------------------------------------- */
#bnr_area {
  width: 990px;
  text-align: center;
  margin: 0 auto;
}
#bnr_area .bnr_copy {
  font-size: 23px;
  font-weight: bold;
  background-color: #f1ecf0;
  letter-spacing: 2px;
  margin: 0 0 25px;
  padding: 6px 0;
  position: relative;
}

#bnr_area .bnr_copy::after {
  content: "";
  border-top: solid 10px #f1ecf0;
  border-left: solid 10px transparent;
  border-right: solid 10px transparent;
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%);
}
#bnr_area .wrapper {
  display: flex;
  justify-content: space-between;
}

#bnr_area .wrapper .request a {
  box-shadow: 0px 5px 1px -1px #6e1414;
}

#bnr_area .wrapper .reservation a {
  box-shadow: 0px 5px 1px -1px #070c2c;
}

#bnr_area .wrapper p {
  position: relative;
}

#bnr_area .wrapper p a {
  color: #fff;
  font-size: 32px;
  font-weight: bold;
  letter-spacing: 2px;
  width: 486px;
  border-radius: 10px;
  padding: 22px 0 17px;
  display: inline-block;
}

#bnr_area .wrapper .request a:hover,
#bnr_area .wrapper .reservation a:hover {
  opacity: 0.7;
}

#bnr_area .wrapper .request a {
  background-color: #b62121;
  position: relative;
}

#bnr_area .wrapper .request a::before,
#bnr_area .wrapper .request a::after,
#bnr_area .wrapper .reservation a::before,
#bnr_area .wrapper .reservation a::after {
  content: "";
  position: absolute;
}

#bnr_area .wrapper .request a::before {
  width: 10px;
  height: 10px;
  border-left: solid 3px #b62121;
  border-top: solid 3px #b62121;
  transform: rotate(135deg) translateY(-50%);
  top: 40%;
  right: 55px;
  z-index: 2;
}

#bnr_area .wrapper .request a::after,
#bnr_area .wrapper .reservation a::after {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #fff;
  right: 40px;
  top: 52%;
  transform: translateY(-50%);
}

#bnr_area .wrapper .reservation a {
  background-color: #1b5485;
  position: relative;
}

#bnr_area .wrapper .reservation a::before {
  width: 10px;
  height: 10px;
  border-left: solid 3px #1b5485;
  border-top: solid 3px #1b5485;
  transform: rotate(135deg) translateY(-50%);
  top: 40%;
  right: 55px;
  z-index: 2;
}

#bnr_area .wrapper p a span {
  color: #fff;
}

#bnr_area .wrapper p a span::before {
  content: "";
  margin-right: 15px;
  display: inline-block;
  vertical-align: middle;
  transform: translateY(-3px);
}

#bnr_area .wrapper .request a span::before {
  width: 38px;
  height: 23px;
  background: url("images/s_require.svg") no-repeat;
  background-size: 100%;
}

#bnr_area .wrapper .reservation a span::before {
  width: 26px;
  height: 31px;
  background: url("images/s_reserve.svg") no-repeat;
  background-size: 100%;
}

#bnr_area .matching {
  margin: 63px 0 0;
}

#bnr_area .matching .ms_copy {
  margin: 0 0 12px;
}

#bnr_area .matching .ms_copy span {
  font-size: 23px;
  font-weight: 700;
  width: fit-content;
  -moz-width: fit-content;
  position: relative;
}

#bnr_area .matching .ms_copy span::before,
#bnr_area .matching .ms_copy span::after {
  content: "";
  width: 2px;
  height: 1.3em;
  background: #333;
  position: absolute;
  top: 50%;
  left: -0.6em;
  transform: translateY(-40%) rotate(-20deg);
}

#bnr_area .matching .ms_copy span::after {
  left: inherit;
  right: -0.6em;
  transform: translateY(-40%) rotate(20deg);
}

#bnr_area .matching .ms_btn a {
  color: #fff;
  min-height: 75px;
  font-size: 32px;
  font-weight: 700;
  background: #ff6d46;
  border-radius: 10px;
  box-shadow: 2px 4px 0 rgba(0, 0, 0, 1);
  padding: 22px 66px 17px 32px;
  display: inline-block;
  position: relative;
}

#bnr_area .matching .ms_btn a:hover {
  opacity: 0.7;
}

#bnr_area .matching .ms_btn a::before {
  content: "";
  width: 10px;
  height: 10px;
  border-left: solid 3px #ff6d46;
  border-top: solid 3px #ff6d46;
  transform: rotate(135deg) translateY(-50%);
  position: absolute;
  top: 40%;
  right: 36px;
  z-index: 2;
}

#bnr_area .matching .ms_btn a::after {
  content: "";
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #fff;
  position: absolute;
  right: 21px;
  top: 52%;
  transform: translateY(-50%);
}

@media (max-width: 768px) {
  #bnr_area {
    width: 96%;
    padding-bottom: 25px;
  }

  #bnr_area .bnr_copy {
    font-size: 5vw;
    letter-spacing: 1px;
    margin: 0 0 20px;
    padding: 10px 5px;
    border-radius: 10px;
  }

  #bnr_area .bnr_copy::after {
  }

  #bnr_area .wrapper {
    display: block;
    margin: 0 0 45px;
  }

  #bnr_area .wrapper p a {
    font-size: 26px;
    font-weight: bold;
    width: 100%;
    padding: 15px 0;
  }

  #bnr_area .wrapper .request {
    margin: 0 0 15px;
  }

  #bnr_area .wrapper .request a {
    background-color: #b62121;
    position: relative;
  }

  #bnr_area .wrapper .request a:hover,
  #bnr_area .wrapper .reservation a:hover {
    opacity: 0.7;
  }

  #bnr_area .wrapper .request a::before,
  #bnr_area .wrapper .request a::after,
  #bnr_area .wrapper .reservation a::before,
  #bnr_area .wrapper .reservation a::after {
  }

  #bnr_area .wrapper .request a::before {
    width: 10px;
    height: 10px;
    border-left: solid 2px #b62121;
    border-top: solid 2px #b62121;
    top: 39%;
    right: 34px;
    z-index: 2;
  }

  #bnr_area .wrapper .request a::after,
  #bnr_area .wrapper .reservation a::after {
    width: 28px;
    height: 28px;
    right: 20px;
    top: 52%;
  }

  #bnr_area .wrapper .reservation a {
    background-color: #1b5485;
    position: relative;
  }

  #bnr_area .wrapper .reservation a::before {
    width: 10px;
    height: 10px;
    border-left: solid 2px #1b5485;
    border-top: solid 2px #1b5485;
    top: 39%;
    right: 34px;
  }

  #bnr_area .matching {
    margin: 40px 0 0;
  }

  #bnr_area .matching .ms_copy {
    margin: 0 0 5px;
  }

  #bnr_area .matching .ms_copy span {
    font-size: 18px;
  }

  #bnr_area .matching .ms_copy span::before,
  #bnr_area .matching .ms_copy span::after {
    content: "";
    width: 2px;
    height: 1.3em;
    background: #333;
    position: absolute;
    top: 50%;
    left: -0.6em;
    transform: translateY(-40%) rotate(-20deg);
  }

  #bnr_area .matching .ms_copy span::after {
    left: inherit;
    right: -0.6em;
    transform: translateY(-40%) rotate(20deg);
  }

  #bnr_area .matching .ms_btn a {
    font-size: 26px;
    font-weight: bold;
    width: 100%;
    line-height: 1.19;
    box-shadow: 0 4px 0 rgba(0, 0, 0, 1);
    padding: 15px 0 12px;
  }

  #bnr_area .matching .ms_btn a:hover {
  }

  #bnr_area .matching .ms_btn a::before {
    width: 10px;
    height: 10px;
    border-left: solid 2px #ff6d46;
    border-top: solid 2px #ff6d46;
    top: 42%;
    right: 8.2%;
    z-index: 2;
  }

  #bnr_area .matching .ms_btn a::after {
    width: 28px;
    height: 28px;
    right: 4%;
    top: 52%;
  }
}

/* -----------------------------------------------
 ここが違います
------------------------------------------------- */
#main.difference {
  font-family: "Noto Sans JP", sans-serif;
  margin-top: 0;
}
#main.difference p {
  color: #222;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-weight: normal;
  line-height: 1.8;
}
#main.difference {
}
#main.difference .subContents {
  text-align: left;
  margin: 0 auto;
}
#main.difference .mv {
  text-align: center;
  background: #f4f2e2;
  margin: 0 auto;
  padding: 60px 0;
}
#main.difference .mv h2 {
  font-size: 26px;
  font-weight: bold;
}
#main.difference .mv h2 span {
  position: relative;
}
#main.difference .mv h2 span::before,
#main.difference .mv h2 span::after {
  content: "";
  width: 3px;
  height: 1.05em;
  background: #222;
  position: absolute;
  top: 0.2em;
}
#main.difference .mv h2 span::before {
  left: -1em;
  transform: rotate(-20deg);
}
#main.difference .mv h2 span::after {
  right: -1em;
  transform: rotate(20deg);
}

#main.difference .mv iframe {
  width: 516px;
  aspect-ratio: 16 / 9;
}

#main.difference .h-type1 {
  background: #f1ecf0;
}
#main.difference .h-type1 .subContents {
  width: 1160px;
  display: flex;
  align-items: center;
}
#main.difference .h-type1 .number {
  width: 87px;
  text-align: center;
  background: linear-gradient(to right, rgba(173, 26, 22, 1) 0%, rgba(196, 28, 25, 1) 100%);
  margin: 0 20px 0 0;
  padding: 15px 0;
  position: relative;
}
#main.difference .h-type1 .number::before,
#main.difference .h-type1 .number::after {
  content: "";
  width: 1px;
  height: 100%;
  background: rgba(255, 255, 255, 0.7);
  position: absolute;
  top: 0;
}
#main.difference .h-type1 .number::before {
  left: 5px;
}
#main.difference .h-type1 .number::after {
  right: 5px;
}

#main.difference .h-type1 .number img {
  width: 47px;
}
#main.difference .h-type1 h2 {
  width: calc(100% - 87px - 20px);
  font-size: 40px;
  font-weight: bold;
  text-align: left;
  line-height: 1;
  letter-spacing: 1.5px;
  padding-left: 85px;
  transform: translateX(-53px);
}
#main.difference .h-type2 {
  color: #a2750e;
  font-size: 34px;
  font-weight: bold;
  line-height: 1.38;
  margin: 0 0 10px;
}
#main.difference .h-type3 {
  color: #a0750e;
  font-weight: bold;
  font-size: 44px;
  text-align: center;
  margin: 0 0 35px;
}
#main.difference .h-type4 {
  color: #a2750e;
  font-size: 40px;
  font-weight: bold;
}
#main.difference .h-type4 span {
  color: #a2750e;
  font-size: 48px;
  font-weight: normal;
  font-family: "Century Gothic", sans-serif;
}
#main.difference .block {
  background-size: auto auto;
  background-color: rgba(255, 255, 255, 1);
  background-image: repeating-linear-gradient(-45deg, transparent, transparent 10px, rgba(242, 242, 242, 1) 10px, rgba(242, 242, 242, 1) 11px);
  padding: 70px 0;
}
#main.difference .block .lead {
  font-size: 18px;
  text-align: left;
  margin: 0 0 45px;
}
#main.difference .red {
  color: #b72121 !important;
}
#main.difference .note {
  font-size: 13px;
}
#main.difference .btn1 {
}
#main.difference .btn1 a {
  color: #fff;
  font-weight: bold;
  border-radius: 3px;
  padding: 10px 60px 10px 40px;
  display: inline-block;
  position: relative;
}
#main.difference .btn1 a:hover {
  opacity: 0.7;
}
#main.difference .btn1 a::after {
  content: "";
  width: 10px;
  height: 10px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  position: absolute;
  top: calc(50% - 0.2em);
  right: 15px;
  transform: rotate(45deg);
}
#main.difference .btn1 a.blueBtn {
  background: #2d83cc;
  border-bottom: solid 4px #1c5380;
}
#main.difference .btn1 a.redBtn {
  background: #b52121;
  border-bottom: solid 4px #6e1414;
}
#main.difference #mainv {
  height: 320px;
  text-align: center;
  background: url(images/difference/mainv_bg_pc.jpg) #efece7 no-repeat center center;
  background-size: cover;
  position: relative;
}
#main.difference #mainv h1 {
  color: #fff;
  font-size: 66px;
  font-weight: bold;
  letter-spacing: 2.5px;
  text-shadow: 0px 0px 20px rgba(94, 74, 62, 1);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#main.difference #maincopy {
  font-weight: bold;
  text-align: center;
  font-size: 30px;
  padding: 60px 0;
}
#main.difference .block1 {
  padding-bottom: 60px;
}
#main.difference .block1 .subContents {
  width: 1000px;
}
#main.difference .block1 figure {
  margin: 0 0 35px;
}
#main.difference .block1 .h-type3 {
  margin: 0 0 25px;
}
#main.difference .block1 .lead {
  margin: 0;
}
/*和歌*/
#main.difference .block.wakaBlock {
  background: none;
}
#main.difference .block.wakaBlock .subContents {
  width: 1000px;
  display: grid;
  grid-template-rows: 90px 160px 200px;
  grid-template-columns: 490px auto;
  /* row-gap: 60px; */
  column-gap: 45px;
}
/* #main.difference .block.wakaBlock .textWrap {
  padding: 50px 0 0;
  grid-row: 1 / 2;
  grid-column: 1 / 2;
} */
#main.difference .block.wakaBlock .leadRed {
  color: #B52121;
  font-size: 19px;
  grid-row: 1 / 2;
  grid-column: 2 / 3;
  margin: 30px 0 0;
}
#main.difference .block.wakaBlock .lead {
  grid-row: 3 / 4;
  grid-column: 2 / 3;
  padding: 0;
  margin: 0;
}
#main.difference .block.wakaBlock figure {
  width: 490px;
  grid-row: 1 / 4;
  grid-column: 1 / 3;
}
#main.difference .block.wakaBlock .waka {
  grid-row: 2 / 3;
  grid-column: 2 / 3;
  padding: 0 0 0 55px;
}
#main.difference .block.wakaBlock .waka .top {
  position: relative;
  font-family: serif;
}
#main.difference .block.wakaBlock .waka .top::before {
  position: absolute;
  content: "";
  top: 50%;
  left: -43px;
  transform: translateY(-50%);
  width: 30px;
  border: 1px #B4B4B4 solid;
}
#main.difference .block.wakaBlock .waka .detail {
  color: #6b6b6b;
  font-size: 15px;
  font-family: serif;
  line-height: 1.6;
}

#main.difference .block2 {
  background: #fff;
}
#main.difference .block2 .subContents {
  width: 1160px;
}
#main.difference .block2 .box {
  width: 1160px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
#main.difference .block2 .h-type3 {
  font-size: 44px;
  text-align: center;
  margin: 0 0 25px;
  padding: 0 50px;
}
#main.difference .block2 .box figure {
  width: 380px;
  margin: 0;
  padding: 0;
}
#main.difference .block2 .box figure img {
  width: 100%;
}
#main.difference .block2 .box .text {
  width: 687px;
}
#main.difference .block2 .box .text .h-type2 {
  margin: 0 0 30px;
}
#main.difference .block2 .box .text .lead {
  margin: 0 0 40px;
}
#main.difference .block2 .box ul {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#main.difference .block3 .subContents {
  width: 1000px;
}
#main.difference .block3 .box {
  display: flex;
  justify-content: space-between;
}
#main.difference .block3 .box figure {
  width: 499px;
  border: solid 2px #fff;
  box-shadow: 3px 3px 5px 0px rgba(0, 0, 0, 0.4);
}
#main.difference .block3 .box figure img {
  width: 100%;
}
#main.difference .block3 .box .text {
  width: 420px;
}
#main.difference .block3 .box .text h3 {
  font-size: 34px;
  margin: 0 0 15px;
}
#main.difference .block3 .box .text p {
  margin: 0 0 30px;
}
#main.difference .block4 {
  background: #fff;
}
#main.difference .block4 .subContents {
  width: 1160px;
}
#main.difference .block4 h3,
#main.difference .block5 h3 {
  text-align: left;
  margin: 0 0 20px;
}
#main.difference .block4 .midashi,
#main.difference .block5 .midashi {
  font-size: 24px;
  font-weight: bold;
  text-align: left;
}
#main.difference .block4 .box,
#main.difference .block5 .box {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#main.difference .block4 .box figure,
#main.difference .block5 .box figure {
  width: 500px;
}
#main.difference .block4 .box figure img,
#main.difference .block5 .box figure img {
  width: 100%;
}
#main.difference .block4 .box .text,
#main.difference .block5 .box .text {
  width: 600px;
}
#main.difference .block4 .box .text li,
#main.difference .block5 .box .text li {
  font-size: 22px;
  font-weight: bold;
  line-height: 1.4;
  border-bottom: solid 2px #dbbc7f;
  padding: 15px 0 15px 50px;
  position: relative;
}
#main.difference .block4 .box .text li::before,
#main.difference .block5 .box .text li::before {
  content: "";
  width: 35px;
  height: 31px;
  background: url(./images/difference/point_s_check.png) no-repeat;
  background-size: 100% auto;
  position: absolute;
  top: 15px;
  left: 0;
}
#main.difference .block4 .box .text li .note {
  margin-top: 10px;
}
#main.difference .block4 .mazuha {
  margin: 50px 100px 0;
}
#main.difference .block4 .mazuha .midashi {
  font-size: 22px;
  font-weight: bold;
  text-align: center;
  background: #f1ecf0;
  border-radius: 10px;
  margin: 0 0 20px;
  padding: 10px 0;
  position: relative;
}
#main.difference .block4 .mazuha .midashi::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 12px 12px 0 12px;
  border-color: #f1ecf0 transparent transparent transparent;
  position: absolute;
  bottom: -12px;
  left: 50%;
  transform: translateX(-50%);
}
#main.difference .block4 .mazuha ul {
  display: flex;
  justify-content: space-between;
}
#main.difference .block4 .mazuha ul li {
  width: 470px;
}
#main.difference .block4 .mazuha ul li a {
  color: #fff;
  font-size: 32px;
  font-weight: bold;
  text-align: center;
  border-radius: 10px;
  padding: 18px 0 16px;
  display: block;
  position: relative;
}

#main.difference .block4 .mazuha ul li a span {
  color: #fff;
}
#main.difference .block4 .mazuha ul li a:hover {
  opacity: 0.7;
}
#main.difference .block4 .mazuha ul li:first-child a {
  background: #b62121;
  border-bottom: solid 4px #6e1414;
}
#main.difference .block4 .mazuha ul li:last-child a {
  background: #1b5485;
  border-bottom: solid 4px #070c2c;
}

#main.difference .block4 .mazuha ul li a::after {
  content: "";
  width: 30px;
  height: 30px;
  background: url(./images/difference/s_arrow.png) no-repeat;
  background-size: 100%;
  position: absolute;
  top: 50%;
  right: 15px;
  transform: translateY(-50%);
}
#main.difference .block4 .mazuha ul li a span::before {
  content: "";
  margin-right: 10px;
  display: inline-block;
  vertical-align: middle;
  transform: translateY(-3px);
}

#main.difference .block4 .mazuha ul li:first-child a span::before {
  width: 38px;
  height: 23px;
  background: url("images/s_require.svg") no-repeat;
}

#main.difference .block4 .mazuha ul li:last-child a span::before {
  width: 28px;
  height: 33px;
  background: url("images/s_reserve.svg") no-repeat;
}
#main.difference .block5 {
  padding-bottom: 100px;
}
#main.difference .block5 .subContents {
  width: 1160px;
}
#main.difference .block5 .text ul {
  margin: 0 0 50px;
}
#main.difference .block5 .text > div {
  margin: 0 0 20px;
}
#main.difference .block5 .text > div p {
  font-weight: bold;
  margin-top: 10px;
  margin-right: 15px;
}
#main.difference .block6 {
  background: #fff;
}
#main.difference .block6 .subContents {
  width: 1136px;
}
#main.difference .block6 .subContents .box {
  margin: 0 0 62px;
  display: flex;
  justify-content: space-between;
}
#main.difference .block6 .subContents .box figure {
  width: 487px;
}
#main.difference .block6 .subContents .box figure img {
  width: 100%;
}
#main.difference .block6 .subContents .box .lead {
  width: 590px;
}
#main.difference .block6 .subContents .seikonryo {
  width: 920px;
  height: 240px;
  text-align: center;
  background: url("images/difference/point6_f_01_pc.png");
  background-size: 100% 100%;
  margin: 0 auto;
  padding: 30px 0;
}
#main.difference .block6 .subContents .seikonryo .copy {
  color: #a2750e;
  font-size: 40px;
  font-weight: bold;
  margin: 0 0 20px;
  padding: 0 15px 1px;
  display: inline-block;
  position: relative;
}
#main.difference .block6 .subContents .seikonryo .copy::after {
  content: "";
  width: 100%;
  height: 1px;
  background: repeat;
  background-size: 8px 1px;
  background-image: linear-gradient(to right, #a0750e, #a0750e 3px, transparent 3px, transparent 8px);
  position: absolute;
  bottom: 0;
  left: 0;
}
#main.difference .block6 .subContents .seikonryo .lead {
  text-align: center;
}
#main.difference .block6 .subContents .note {
  text-align: right;
  width: 920px;
  margin: 5px auto 0;
}
#main.difference .block7 .subContents {
  width: 1160px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
#main.difference .block7 .subContents figure {
  width: 410px;
}
#main.difference .block7 .subContents figure img {
  width: 100%;
}
#main.difference .block7 .subContents .box {
  width: 650px;
}
#main.difference .block7 .subContents .box .h-type2 {
  font-size: 34px;
  line-height: 1.38;
  margin: 0 0 30px;
}

#main.difference .block7 .support {
  width: 1061px;
  height: 567px;
  background: url(images/difference/point7_f_01_pc.png);
  background-size: 100% 100%;
  margin: 55px auto 0;
  padding: 30px 0;
  text-align: center;
}

#main.difference .block7 .support .text-wrap .copy {
  color: #a2750e;
  font-size: 40px;
  font-weight: bold;
  width: fit-content;
  margin: 20px auto 40px;
  position: relative;
}

#main.difference .block7 .support .text-wrap .copy::after {
  content: "";
  width: 100%;
  height: 1px;
  background: repeat;
  background-size: 8px 1px;
  background-image: linear-gradient(to right, #a0750e, #a0750e 3px, transparent 3px, transparent 8px);
  bottom: -10px;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
}

#main.difference .block7 .support .text-wrap .copy span {
  color: #b72121;
  font-size: 40px;
  font-weight: bold;
}

#main.difference .block7 .support .text-wrap .lead {
  font-size: 18px;
  width: 850px;
  margin: 0 auto;
}

#main.difference .block7 .support .img-wrap {
  width: 840px;
  margin: 30px auto 0;
  display: flex;
  justify-content: space-between;
}

#main.difference .block7 .support .img-wrap .img-kyoutsu {
  margin-right: 25px;
}

/*#main.difference .block4 {
	background: url(./images/difference/point3_bg_01_pc.png) #faf1e1 no-repeat left top;
}
#main.difference .block4 h3 {
	text-align: center;
	margin: 0 0 50px;
}
#main.difference .block4 ul {
	margin: 0 0 0 430px;
}
#main.difference .block4 ul li {
	background: #fff;
	margin: 0 0 10px;
	box-shadow: 3px 3px 5px 0px rgba(0,0,0,.4);
	padding: 30px 40px 20px;
	position: relative;
}
#main.difference .block4 ul li::after {
	content: "";
	width: 4px;
	height: 100%;
	background: #e9d4e3;
	position: absolute;
	top: 0;
	left: 12px;
}
#main.difference .block4 ul li h4 {
	font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
	font-size: 26px;
	font-weight: bold;
	margin: 0 0 15px;
}
#main.difference .block4 ul li p {
	line-height: 1.5;
}
#main.difference .block4 ul li p .red {
	text-decoration: underline;
}
*/
@media (max-width: 768px) {
  #main.difference p {
    color: #222;
    font-size: 15px;
  }
  #main.difference {
    margin-top: 0;
  }
  #main.difference .subContents {
    width: 100%;
  }
  #main.difference .mv {
    padding: 10vw 5vw;
  }
  #main.difference .mv h2 {
    font-size: 20px;
  }
  #main.difference .mv iframe {
    width: 100%;
  }

  #main.difference .h-type1 {
  }
  #main.difference .h-type1 .subContents {
    width: 100%;
    height: 100%;
    align-items: stretch;
  }
  #main.difference .h-type1 .number {
    width: 50px;
    margin: 0 15px 0 0;
    padding: 0;
    background-size: 100% 100%;
    position: relative;
  }
  #main.difference .h-type1 .number::before,
  #main.difference .h-type1 .number::after {
  }
  #main.difference .h-type1 .number::before {
    left: 3px;
  }
  #main.difference .h-type1 .number::after {
    right: 3px;
  }

  #main.difference .h-type1 .number img {
    width: 7.7vw;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  #main.difference .h-type1 h2 {
    width: calc(100% - 65px);
    font-size: 6.8vw;
    text-align: left;
    line-height: 1.3;
    letter-spacing: 0;
    transform: none;
    padding: 6vw 4vw 6vw 0;
  }
  #main.difference .h-type2 {
    font-size: 6vw;
    margin-bottom: 0;
  }
  #main.difference .h-type3 {
    font-size: 7vw;
  }
  #main.difference .h-type4 {
    font-size: 7vw;
    margin: 0 0 2vw;
  }
  #main.difference .h-type4 span {
    font-size: 8vw;
  }
  #main.difference .block {
    padding: 0 4.5vw 12.8vw;
  }
  #main.difference .block .subContents {
    width: 100%;
  }
  #main.difference .block .subContents .box {
    width: 100%;
  }
  #main.difference .block .subContents .text {
    width: 100%;
  }
  #main.difference .block .subContents > figure {
    width: 100vw;
    margin: 0 calc(50% - 50vw) 30px;
  }
  #main.difference .block .lead {
    font-size: 4vw;
    text-align: left;
    margin: 0 0 20px;
  }
  #main.difference .red {
  }
  #main.difference .note {
    font-size: 12px;
  }
  #main.difference .btn1 a {
    font-size: 3.6vw;
    width: 34vw;
    text-align: left;
    padding: 2.4vw 0 2.4vw 5.5vw;
  }
  #main.difference .btn1 a::after {
    width: 8px;
    height: 8px;
  }
  #main.difference .btn1 a::after {
  }
  #main.difference .btn1 a.blueBtn {
  }
  #main.difference #mainv {
    height: 40vw;
    background-image: url(images/difference/mainv_bg_sp.jpg);
    background-size: 100% auto;
  }
  #main.difference #mainv h1 {
    width: 100%;
    font-size: 36px;
    text-shadow: 0 0 10px rgba(132, 93, 67, 0.3), 0 0 10px rgba(132, 93, 67, 0.3), 0 0 10px rgba(132, 93, 67, 0.3), 0 0 10px rgba(132, 93, 67, 0.3), 0 0 10px rgba(132, 93, 67, 0.3), 0 0 10px rgba(132, 93, 67, 0.3), 0 0 10px rgba(132, 93, 67, 0.3), 0 0 10px rgba(132, 93, 67, 0.3);
  }
  #main.difference #maincopy {
    font-size: 4.5vw;
    padding: 9.6vw 0;
  }
  #main.difference #maincopy em {
  }
  #main.difference #maincopy em::after {
    top: -5vw;
  }

  #main.difference .block1 .box {
    margin: 0;
    display: block;
  }
  #main.difference .block1 .box figure {
    width: 100%;
    margin: 0 0 20px;
  }
  #main.difference .block1 .lead {
    margin: 0;
  }
  #main.difference .block1 .h-type3 {
    margin: 0 0 20px;
  }
  #main.difference .block1 .box .text {
    width: 100%;
  }
  #main.difference .block1 .box .text p {
    margin: 0 0 3vw;
  }

  /*和歌*/
  /* #main.difference .block.wakaBlock {
    background: none;
  } */
  #main.difference .block.wakaBlock .subContents {
    width: 90%;
    margin: 0 auto;
    display: block;
  }
  #main.difference .block.wakaBlock {
    padding: 12vw 0 0;
    margin: 0 0 12vw;
  }
  #main.difference .block.wakaBlock .leadRed {
    color: #B52121;
    font-size: 5vw;
    margin: 0 0 5vw;
  }
  #main.difference .block.wakaBlock .lead {
    font-size: 4vw;
    margin: 0 0 4vw;
  }
  #main.difference .block.wakaBlock picture {
    width: 96vw;
    margin: 0 0 9vw;
    display: block;
  }
  #main.difference .block.wakaBlock .waka {
    padding: 0;
    margin: 0 0 8vw;
  }
  #main.difference .block.wakaBlock .waka .top {
    position: relative;
    font-size: 5.3vw;
    font-family: serif;
    padding: 0 0 0 12vw;
  }
  #main.difference .block.wakaBlock .waka .top::before {
    position: absolute;
    content: "";
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 8.5vw;
    border: 1px #B4B4B4 solid;
  }
  #main.difference .block.wakaBlock .waka .detail {
    line-height: 1.6;
    font-size: 4vw;
    margin: 0;
  }

  #main.difference .block.block2 {
    padding: 20px 5vw 10vw;
  }
  #main.difference .block.block2 .box {
    display: block;
  }
  #main.difference .block.block2 .box figure {
    width: 100%;
    margin: 0 0 9.6vw;
  }
  #main.difference .block.block2 .mainv {
    width: 100vw;
    margin: 0 -5vw 10vw;
  }
  #main.difference .block2 .box .text .h-type2 {
    margin: 0 0 20px;
  }
  #main.difference .block.block2 .box .text .privacy {
    width: 100%;
    padding: 0 2.4vw;
    align-items: flex-start;
  }
  #main.difference .block.block2 .box .text .privacy li {
    padding: 0;
  }
  #main.difference .block.block2 .box .text .privacy li:first-child {
    width: 55%;
  }
  #main.difference .block.block2 .box .text .privacy li:first-child a:nth-child(1) {
    margin: 0 0 12px 1.6vw;
  }
  #main.difference .block.block2 .box .text .privacy li:last-child {
    width: 40%;
  }
  #main.difference .block.block2 .box .text .privacy li a {
    display: block;
  }
  #main.difference .block4 h3,
  #main.difference .block5 h3 {
    margin: 0 0 3vw;
  }
  #main.difference .block4 .midashi,
  #main.difference .block5 .midashi {
    font-size: 5.3vw;
    line-height: 1.4;
    margin: 0 0 5vw;
  }
  #main.difference .block4 .box,
  #main.difference .block5 .box {
    display: block;
  }
  #main.difference .block4 .box .text,
  #main.difference .block5 .box .text {
    width: 100%;
  }
  #main.difference .block4 .box .text li,
  #main.difference .block5 .box .text li {
    font-size: 5vw;
    margin: 0 0 3vw;
    padding: 4vw 0 4vw 40px;
    position: relative;
  }
  #main.difference .block4 .box .text li::before,
  #main.difference .block5 .box .text li::before {
    width: 30px;
    height: 27px;
    top: 15px;
  }
  #main.difference .block4 .box .text li .note {
    font-size: 3vw;
    margin-top: 0;
  }
  #main.difference .block4 .mazuha {
    margin: 8.5vw 0 0;
  }
  #main.difference .block4 .mazuha .midashi {
    font-size: 4.5vw;
    border-radius: 6px;
  }
  #main.difference .block4 .mazuha .midashi::after {
  }
  #main.difference .block4 .mazuha ul {
    display: block;
  }
  #main.difference .block4 .mazuha ul li {
    width: 100%;
    margin: 0 0 10px;
  }
  #main.difference .block4 .mazuha ul li a {
    font-size: 6.7vw;
    border-radius: 6px;
  }
  #main.difference .block4 .mazuha ul li a::after {
    width: 24px;
    height: 24px;
    top: 50%;
    transform: translateY(-50%);
  }
  #main.difference .block.block3 {
    padding: 20px 5vw 13.8vw;
  }
  #main.difference .block.block3 .mainv {
    width: 100vw;
    margin: 0 -5vw 10vw;
  }
  #main.difference .block.block3 figure {
    width: 100%;
    margin: 0 0 30px;
  }
  #main.difference .block3 .text ul {
    margin: 0 0 5vw;
  }
  #main.difference .block3 .text > div {
    display: block;
  }
  #main.difference .block3 .box {
    display: block;
  }
  #main.difference .block3 .box .text h3 {
    font-size: 6vw;
    margin-bottom: 5px;
  }
  #main.difference .block3 .box .text p {
    font-size: 3.8vw;
    margin: 0 0 5vw;
  }
  #main.difference .block4 h3 {
    margin: 0 0 3vw;
  }
  #main.difference .block4 ul {
    margin: 0;
  }
  #main.difference .block4 ul li:last-child {
    margin: 0;
  }
  #main.difference .block4 ul li::after {
    left: 3vw;
  }
  #main.difference .block4 ul li h4 {
    font-size: 6vw;
    margin: 0 0 3vw;
  }
  #main.difference .block4 ul li p {
  }
  #main.difference .block4 ul li p .red {
  }
  .difference .block5 {
    padding-bottom: 13.8vw;
  }
  #main.difference .block5 .subContents {
    width: 100%;
  }
  #main.difference .block5 .text ul {
    margin: 0 0 30px;
  }
  #main.difference .block5 .text > div {
    margin: 0 0 3.8vw;
  }
  #main.difference .block5 .text > div:last-child {
    margin: 0;
  }
  #main.difference .block5 .text > div p {
    font-size: 4.2vw;
    font-weight: bold;
    margin-top: 10px;
    margin-bottom: 5px;
  }
  #main.difference .block5 .text > div p span {
    text-decoration: underline;
  }
  #main.difference .block6 {
  }
  #main.difference .block6 .subContents {
    width: 100%;
  }
  #main.difference .block6 .subContents .box {
    margin: 0 0 10.7vw;
    display: block;
  }
  #main.difference .block6 .subContents .box figure {
    width: 100vw;
    margin: 0 calc(50% - 50vw) 30px;
  }
  #main.difference .block6 .subContents .box figure img {
  }
  #main.difference .block6 .subContents .box .lead {
    width: 100%;
    margin: 0;
  }
  #main.difference .block6 .subContents .seikonryo {
    width: 90vw;
    height: auto;
    background: url("images/difference/point6_f_01_sp.png") no-repeat;
    background-size: 90vw auto;
    margin: 0 auto;
    padding: 8.6vw 7vw 7vw;
  }
  #main.difference .block6 .subContents .seikonryo .copy {
    font-size: 6vw;
    letter-spacing: 0;
    margin: 0 0 4.2vw;
    padding: 0 1vw 2vw;
  }
  #main.difference .block6 .subContents .seikonryo .copy::after {
    background-size: 5px 1px;
    background-image: linear-gradient(to right, #a0750e, #a0750e 2px, transparent 2px, transparent 5px);
  }
  #main.difference .block6 .subContents .seikonryo .lead {
    font-size: 3.6vw;
    text-align: left;
  }
  #main.difference .block6 .subContents .note {
    width: 100%;
  }
  #main.difference .block7 .subContents {
    width: 100%;
    margin: 0;
    display: block;
  }
  #main.difference .block7 .subContents figure {
    width: 100vw;
  }
  #main.difference .block7 .subContents figure img {
  }
  #main.difference .block7 .subContents .box {
    width: 100%;
  }
  #main.difference .block7 .subContents .box .lead {
    margin: 0;
  }
  #main.difference .block7 .subContents .box .h-type2 {
    font-size: 6vw;
    margin: 0 0 20px;
    line-height: 1.3;
  }

  #main.difference .block7 .support {
    width: 90vw;
    height: auto;
    background: url(images/difference/point7_f_01_sp.png) no-repeat;
    background-size: 90vw auto;
    margin: 2.6vw auto 0;
    padding: 5.3vw 0 8vw;
  }

  #main.difference .block7 .support .text-wrap .copy {
    font-size: 5.2vw;
    margin: 0 auto 12vw;
    padding: 7.5vw 0 0;
  }

  #main.difference .block7 .support .text-wrap .copy::after {
    width: 39vw;
  }

  #main.difference .block7 .support .text-wrap .copy span {
    font-size: 5.2vw;
  }

  #main.difference .block7 .support .text-wrap .lead {
    font-size: 3.8vw;
    width: 71.2vw;
    margin: 2.6vw auto 0;
    text-align: left;
  }

  #main.difference .block7 .support .img-wrap {
    width: 71.2vw;
    margin: 2.2vw auto 0;
    display: block;
  }

  #main.difference .block7 .support .img-wrap .img-kyoutsu {
    margin-top: 1.3vw;
  }
}

/* -----------------------------------------------
 会員様の声
------------------------------------------------- */

#main.voice {
  margin-top: 0;
}

#main.voice.archive #mainv {
  color: #fff;
  height: 324px;
  background: url(images/voice/bg_mainv.jpg) no-repeat center center;
  background-size: cover;
  margin: 0 0 52px;
  position: relative;
}
#main.voice.archive #mainv h1 {
  color: #333;
  font-size: 46px;
  font-weight: 700;
  position: absolute;
  top: 50%;
  right: calc(50% + 52px);
  transform: translate(-50%, -50%);
}

#main.voice.archive .lead {
  margin: 0 0 57px;
}

#main.voice.archive .lead p {
  color: #222;
  font-family: "Helvetica Neue", Arial, "Hiragino Sans", "Hiragino Kaku Gothic ProN", "BIZ UDPGothic", Meiryo, sans-serif;
  text-align: center;
}

#main.voice .voiceArea {
  background: #f0efe3;
  padding: 60px 0;
}

#main.voice .cardList {
  margin: 0 0 40px;
  display: grid;
  grid-template-columns: repeat(3, 340px);
  grid-template-rows: auto;
  column-gap: 30px;
  row-gap: 40px;
  justify-content: center;
}

#main.voice .cardList li {
  width: 100%;
  background: #fff;
  padding: 0 18px 17px;
  box-shadow: 0px 0px 6px rgba(0, 0, 0, 0.14);
  box-sizing: border-box;
  position: relative;
}

#main.voice .cardList li:hover {
  background: #f2f7fc;
}

#main.voice .cardList li .new {
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  width: 41px;
  height: 41px;
  text-align: center;
  line-height: 41px;
  background: #c90422;
  box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.3);
  border-radius: 50%;
  position: absolute;
  top: 7px;
  left: 8px;
  z-index: 2;
}

#main.voice .cardList li figure {
  margin: 0 0 15px;
  position: relative;
}

#main.voice .cardList li figure::before {
  content: "※画像はイメージです";
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  text-shadow: 0px 0px 6px rgba(0, 0, 0, 0.7);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

#main.voice .cardList li figure img {
  width: 100%;
  height: 179px;
  object-fit: cover;
}

#main.voice .cardList li .title {
  min-height: 3em;
  margin: 0 0 10px;
  overflow: hidden;
}

#main.voice .cardList li .title span {
  font-size: 19px;
  font-weight: 700;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

#main.voice .cardList li .couple {
  font-size: 14px;
  font-weight: 700;
}

#main.voice .cardList li .couple span {
  margin: 0 1em 0 0;
}

#main.voice .cardList li .couple .man span {
  color: #2775cf;
}

#main.voice .cardList li .couple .woman {
  margin: 5px 0 0;
}

#main.voice .cardList li .couple .woman span {
  color: #ea739a;
}

#main.voice .cardList li .more {
  position: absolute;
  bottom: 15px;
  right: 18px;
}

#main.voice .cardList li .more span {
  color: #1e5486;
  font-size: 13px;
  position: relative;
}

#main.voice .cardList li .more span::before {
  content: "";
  width: 7px;
  height: 7px;
  border: 1px solid;
  border-color: #fff #fff transparent transparent;
  position: absolute;
  top: 50%;
  right: 12px;
  transform: rotate(45deg) translateY(-93%);
}

#main.voice .cardList li .more span::after {
  content: "";
  width: 20px;
  height: 20px;
  background: #1e5486;
  border-radius: 50%;
  margin: 0 0 0 5px;
  display: inline-block;
  vertical-align: sub;
}

#main.voice .webma_pager {
  text-align: center;
  position: relative;
}

#main.voice .webma_pager > div {
  font-weight: 700;
  font-size: 21px;
  width: fit-content;
  -moz-width: fit-content;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}

#main.voice .webma_pager > div span {
  padding: 0 30px;
  position: relative;
}

#main.voice .webma_pager > div span::before,
#main.voice .webma_pager > div span::after {
  content: "";
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 20px solid #b62121;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}

#main.voice .webma_pager > div span::after {
  left: inherit;
  right: 0;
}

#main.voice .pagination {
  width: fit-content;
  -moz-width: fit-content;
}

#main.voice.single {
  padding: 45px 0 0;
}

#main.voice.single .pagetitle {
  color: #c90422;
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  margin: 0 0 45px;
}

#main.voice .postArea {
  margin: 0 0 88px;
}

#main.voice .postArea .subContents {
  width: 1080px;
  margin: 0 auto;
}

#main.voice .postArea .subContents article .mainv {
  background: #fff;
  border-radius: 10px;
  box-shadow: 0px 0px 5px rgba(0, 0, 0, 0.23);
  margin: 0 0 70px;
  padding: 0 50px 0 0;
  box-sizing: border-box;
  display: flex;
  column-gap: 50px;
  justify-content: center;
  align-items: center;
}

#main.voice .postArea .subContents article .mainv .image {
  width: 500px;
  border-radius: 10px 0 0 10px;
  position: relative;
}

#main.voice .postArea .subContents article .mainv .image::before {
  content: "※画像はイメージです";
  color: #fff;
  font-size: 20px;
  font-weight: 700;
  text-shadow: 0px 0px 6px rgba(0, 0, 0, 0.7);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

#main.voice .postArea .subContents article .mainv .image img {
  width: 100%;
  height: 320px;
  object-fit: cover;
}

#main.voice .postArea .subContents article .mainv .textArea {
  width: 480px;
}

#main.voice .postArea .subContents article .mainv .textArea h1 {
  overflow: hidden;
  border-bottom: solid 1px #cbb542;
  margin: 0 0 30px;
  padding: 0 0 20px;
}

#main.voice .postArea .subContents article .mainv .textArea h1 span {
  color: #7d5d11;
  font-size: 30px;
  font-weight: 700;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

#main.voice .postArea .subContents article .mainv .textArea .profile {
  display: flex;
  column-gap: 14px;
  justify-content: center;
}

#main.voice .postArea .subContents article .mainv .textArea .profile li {
  display: flex;
  column-gap: 16px;
  justify-content: center;
}

#main.voice .postArea .subContents article .mainv .textArea .profile li figure {
  width: 70px;
  height: 70px;
}

#main.voice .postArea .subContents article .mainv .textArea .profile li figure img {
  width: 100%;
}

#main.voice .postArea .subContents article .mainv .textArea .profile li .name {
  font-size: 16px;
  font-weight: 700;
}

#main.voice .postArea .subContents article .mainv .textArea .profile li.man .name {
  color: #2775cf;
}

#main.voice .postArea .subContents article .mainv .textArea .profile li.woman .name {
  color: #ea739a;
}

#main.voice .postArea .subContents article .mainv .textArea .profile li .info {
  font-size: 16px;
}

#main.voice .postArea .subContents article .tanto {
  width: 900px;
  margin: 150px auto 0;
  padding: 0 40px;
}
#main.voice .postArea .subContents article .tanto h3 {
  color: #c5a456;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 60px;
  position: relative;
}
#main.voice .postArea .subContents article .tanto h3::after {
  content: "";
  width: 100px;
  height: 3px;
  background: #c5a456;
  position: absolute;
  bottom: -25px;
  left: 50%;
  transform: translateX(-50%);
}
#main.voice .postArea .subContents article .tanto .honbun p {
  font-size: 16px;
}
#main.voice .postArea .subContents article .interview ul {
  width: 900px;
  margin: 0 auto;
}

#main.voice .postArea .subContents article .interview ul li {
  margin: 0 0 46px;
}

#main.voice .postArea .subContents article .interview ul li:last-child {
  margin: 0;
}

#main.voice .postArea .subContents article .interview ul li h2 {
  font-size: 19px;
  font-weight: 700;
  background: #f6f4f1;
  border-top: solid 3px #c5a456;
  margin: 0 0 30px;
  padding: 20px 60px;
  position: relative;
}

#main.voice .postArea .subContents article .interview ul li h2::before {
  content: "Q.";
  color: #b78e2d;
  font-size: 28px;
  font-weight: 700px;
  position: absolute;
  top: 50%;
  left: 15px;
  transform: translateY(-50%);
}

#main.voice .postArea .subContents article .interview ul li .inner {
  padding: 0 30px;
}

#main.voice .postArea .subContents article .interview ul li .inner > div {
  display: grid;
  grid-template-columns: 60px auto;
  grid-template-rows: auto auto;
  grid-column-gap: 16px;
  align-items: flex-start;
  margin: 0 0 25px;
}

#main.voice .postArea .subContents article .interview ul li .inner figure {
  width: 60px;
  height: 60px;
  grid-area: 1 / 1 / 3 / 2;
}
#main.voice .postArea .subContents article .interview ul li .inner .name {
  font-size: 16px;
  font-weight: 700;
  margin: 0 0 5px;
  grid-area: 1 / 2 / 2 / 3;
}

#main.voice .postArea .subContents article .interview ul li .inner .man .name {
  color: #2775cf;
}

#main.voice .postArea .subContents article .interview ul li .inner .woman .name {
  color: #ea739a;
}

#main.voice .postArea .subContents article .interview ul li .inner p {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.62;
  grid-area: 2 / 2 / 3 / 3;
}

#main.voice .postArea .subContents article .interview ul li .inner p span {
  color: #c90422;
}

#main.voice.single .voiceArea {
  padding: 32px 0 60px;
}

#main.voice.single .voiceArea h2 {
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  margin: 0 0 45px;
}

#main.voice.single .voiceArea .cardList {
  margin: 0 0 52px;
}

#main.voice.single .voiceArea .btn {
  margin: 0 auto;
  display: block;
}

#main.voice.single .voiceArea .btn a {
  color: #fff;
  font-size: 20px;
  font-weight: 700;
  width: 423px;
  text-align: center;
  background: #bb2121;
  border-radius: 50vh;
  margin: 0 auto;
  padding: 12px 0;
  display: block;
  position: relative;
}

#main.voice.single .voiceArea .btn a::before {
  content: "";
  width: 10px;
  height: 10px;
  border: 2px solid;
  border-color: #fff #fff transparent transparent;
  position: absolute;
  top: 50%;
  right: 25px;
  transform: translateY(-50%) rotate(45deg);
}

#main.voice.single .voiceArea .btn a:hover {
  opacity: 0.7;
}

@media (max-width: 768px) {
  #main.voice {
    margin-top: 0;
  }

  #main.voice.archive #mainv {
    height: 40vw;
    background-image: url(images/voice/mainv_bg_sp.jpg);
    background-size: 100% auto;
    margin: 0 0 8.5vw;
  }

  #main.voice.archive #mainv h1 {
    font-size: 7.7vw;
    right: 36%;
  }

  #main.voice.archive .lead {
    margin: 0 0 8.5vw;
  }

  #main.voice .lead .subContents {
    margin: 0 4.5vw;
  }

  #main.voice.archive .lead p {
    font-size: 4.3vw;
    text-align: left;
  }

  #main.voice .voiceArea {
    padding: 9.1vw 4.5vw;
  }

  #main.voice .cardList {
    display: block;
    column-gap: 0;
    row-gap: 0;
  }

  #main.voice .cardList li {
    width: 100%;
    margin: 0 0 7.2vw;
    padding: 0 4.9vw 4.8vw;
    box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.14);
  }

  #main.voice .cardList li:last-child {
    margin: 0;
  }

  #main.voice .cardList li:hover {
    background: #fff;
  }

  #main.voice .cardList li .new {
    font-size: 3.6vw;
    width: 11.3vw;
    height: 11.3vw;
    line-height: 11.3vw;
    box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.3);
    top: 2.5vw;
    left: 2.4vw;
  }

  #main.voice .cardList li figure {
    margin: 0 0 4.5vw;
  }

  #main.voice .cardList li figure::before {
    font-size: 3.6vw;
    text-shadow: 0px 0px 14px rgba(0, 0, 0, 0.7);
  }

  #main.voice .cardList li figure img {
    height: 48.9vw;
  }

  #main.voice .cardList li .title {
    min-height: auto;
    margin: 0 0 4.8vw;
  }

  #main.voice .cardList li .title span {
    font-size: 5vw;
  }

  #main.voice .cardList li .couple {
    font-size: 3.8vw;
  }

  #main.voice .cardList li .couple span {
  }

  #main.voice .cardList li .couple .man span {
  }

  #main.voice .cardList li .couple .woman {
    margin: 5px 0 0;
  }

  #main.voice .cardList li .couple .woman span {
  }

  #main.voice .cardList li .more {
    bottom: 3.8vw;
    right: 4.9vw;
  }

  #main.voice .cardList li .more span {
    font-size: 3.6vw;
  }

  #main.voice .cardList li .more span::before {
    width: 1.7vw;
    height: 1.7vw;
    border: 0.3vw solid;
    border-color: #fff #fff transparent transparent;
    right: 3.2vw;
    transform: rotate(45deg) translateY(-104%);
  }

  #main.voice .cardList li .more span::after {
    width: 5.3vw;
    height: 5.3vw;
  }

  #main.voice .webma_pager > div {
    font-size: 4.3vw;
    top: 3vw;
  }

  #main.voice .webma_pager > div span {
    padding: 0 5.2vw;
    position: relative;
  }

  #main.voice .webma_pager > div span::before,
  #main.voice .webma_pager > div span::after {
    border-left: 2vw solid transparent;
    border-right: 2vw solid transparent;
    border-top: 4vw solid #b62121;
  }

  #main.voice .webma_pager > div span::after {
  }

  #main.voice.single {
    padding: 6.6vw 0 0;
  }

  #main.voice.single .pagetitle {
    font-size: 4.8vw;
    margin: 0 0 6.2vw;
  }

  #main.voice .postArea {
    margin: 0 4.5vw 10.8vw;
  }

  #main.voice .postArea .subContents {
    width: 100%;
  }

  #main.voice .postArea .subContents article .mainv {
    width: 100%;
    border-radius: 1.7vw;
    box-shadow: 0px 0px 0.96vw rgba(0, 0, 0, 0.23);
    margin: 0 0 9.6vw;
    padding: 0 0 5vw;
    display: block;
    column-gap: 0;
  }

  #main.voice .postArea .subContents article .mainv .image {
    width: 100%;
    border-radius: 1.7vw 1.7vw 0 0;
    margin: 0 0 4vw;
    position: relative;
  }

  #main.voice .postArea .subContents article .mainv .image::before {
    font-size: 3.62vw;
    text-shadow: 0px 0px 1.69vw rgba(0, 0, 0, 0.7);
  }

  #main.voice .postArea .subContents article .mainv .image img {
    height: 51.4vw;
  }

  #main.voice .postArea .subContents article .mainv .textArea {
    width: 100%;
    padding: 0 4.2vw;
  }

  #main.voice .postArea .subContents article .mainv .textArea h1 {
    margin: 0 0 4.5vw;
    padding: 0 0 3.6vw;
  }

  #main.voice .postArea .subContents article .mainv .textArea h1 span {
    font-size: 5.43vw;
  }

  #main.voice .postArea .subContents article .mainv .textArea .profile {
    display: block;
    column-gap: 0;
  }

  #main.voice .postArea .subContents article .mainv .textArea .profile li {
    column-gap: 3.6vw;
    justify-content: flex-start;
    align-items: center;
    margin: 0 0 2.6vw;
  }

  #main.voice .postArea .subContents article .mainv .textArea .profile li figure {
    width: 19.3vw;
    height: 19.3vw;
  }

  #main.voice .postArea .subContents article .mainv .textArea .profile li figure img {
  }

  #main.voice .postArea .subContents article .mainv .textArea .profile li .name {
    font-size: 3.8vw;
  }

  #main.voice .postArea .subContents article .mainv .textArea .profile li.man .name {
  }

  #main.voice .postArea .subContents article .mainv .textArea .profile li.woman .name {
  }

  #main.voice .postArea .subContents article .mainv .textArea .profile li .info {
    font-size: 3.8vw;
  }

  #main.voice .postArea .subContents article .tanto {
    width: 100%;
    margin: 20vw auto 0;
    padding: 0;
  }
  #main.voice .postArea .subContents article .tanto h3 {
    font-size: 18px;
    margin-bottom: 50px;
  }
  #main.voice .postArea .subContents article .tanto h3::after {
    margin-bottom: 0px;
  }
  #main.voice .postArea .subContents article .tanto .honbun p {
    font-size: 14px;
  }

  #main.voice .postArea .subContents article .interview ul {
    width: 100%;
  }

  #main.voice .postArea .subContents article .interview ul li {
    margin: 0 0 6vw;
  }

  #main.voice .postArea .subContents article .interview ul li:last-child {
  }

  #main.voice .postArea .subContents article .interview ul li h2 {
    font-size: 4.5vw;
    border-top: solid 0.7vw #c5a456;
    margin: 0 0 5.3vw;
    padding: 3.6vw 4.8vw 3.6vw 13.8vw;
  }

  #main.voice .postArea .subContents article .interview ul li h2::before {
    font-size: 6.7vw;
    left: 3.6vw;
  }

  #main.voice .postArea .subContents article .interview ul li .inner {
    padding: 0;
  }

  #main.voice .postArea .subContents article .interview ul li .inner > div {
    display: grid;
    grid-template-columns: 14.4vw auto;
    grid-column-gap: 3.6vw;
    margin: 0 0 5.5vw;
  }

  #main.voice .postArea .subContents article .interview ul li .inner figure {
    width: 14.4vw;
    height: 14.4vw;
  }

  #main.voice .postArea .subContents article .interview ul li .inner .name {
    font-size: 3.8vw;
    font-weight: 700;
  }

  #main.voice .postArea .subContents article .interview ul li .inner .man .name {
  }

  #main.voice .postArea .subContents article .interview ul li .inner .woman .name {
  }

  #main.voice .postArea .subContents article .interview ul li .inner p {
    font-size: 3.8vw;
    line-height: 1.62;
  }

  #main.voice .postArea .subContents article .interview ul li .inner p span {
  }

  #main.voice.single .voiceArea {
    padding: 7.8vw 4.5vw 8.5vw;
  }

  #main.voice.single .voiceArea h2 {
    font-size: 4.8vw;
    font-weight: 700;
    text-align: center;
    margin: 0 0 5.8vw;
  }

  #main.voice.single .voiceArea .cardList {
    margin: 0 0 11vw;
  }

  #main.voice.single .voiceArea .btn {
    margin: 0 auto;
    display: block;
  }

  #main.voice.single .voiceArea .btn a {
    font-size: 4.8vw;
    width: 78vw;
    padding: 3.3vw 0 3.1vw;
  }

  #main.voice.single .voiceArea .btn a::before {
    width: 10px;
    height: 10px;
    border: 2px solid;
    border-color: #fff #fff transparent transparent;
    position: absolute;
    top: 50%;
    right: 25px;
    transform: translateY(-50%) rotate(45deg);
  }

  #main.voice.single .voiceArea .btn a:hover {
    opacity: 1;
  }
}

/* -----------------------------------------------
 会員データ
------------------------------------------------- */

#main.data p {
  color: #000;
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-size: 18px;
  font-weight: normal;
  line-height: 1.8;
}
#main.data {
  margin-top: 0;
}

#main.data .block {
  padding: 60px 0 90px;
}

#main.data .subContents {
  width: 1200px;
  text-align: left;
  margin: 0 auto;
}
#main.data .h-type1 h2 {
  font-size: 40px;
  font-weight: bold;
  text-align: center;
  position: relative;
  padding: 0.4em 0;
}

#main.data .h-type1 h2::after {
  content: "";
  width: 125px;
  height: 5px;
  background: #bb2121;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}

#main.data h3.coupleHeading {
  font-weight: bold;
  font-size: 32px;
  text-align: center;
  letter-spacing: 2px;
  margin: 0 0 68px;
  display: flex;
  align-items: center;
  justify-content: center;
}

#main.data h3.coupleHeading::before,
#main.data h3.coupleHeading::after {
  content: "";
  border-top: solid 2px #bb2121;
  flex-grow: 1;
}

#main.data h3.coupleHeading::before {
  margin-right: 2rem;
}

#main.data h3.coupleHeading::after {
  margin-left: 2rem;
}

#main.data h3.coupleHeading span {
  color: #bb2121;
}

#main.data .btn1 {
  margin: 105px 0 0;
}
#main.data .btn1 a {
  color: #fff;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  width: 450px;
  border-radius: 80px;
  box-shadow: 0px 5px 4px -3px rgba(0, 0, 0, 0.3);
  margin: 0 auto;
  padding: 18px 0;
  display: block;
  background: #bb2121;
  position: relative;
}
#main.data .btn1 a:hover {
  opacity: 0.7;
}
#main.data .btn1 a::before,
#main.data .btn1 a::after {
  content: "";
  width: 3px;
  height: 7px;
  display: inline-block;
  background: #fff;
  position: absolute;
  right: 40px;
}

#main.data .btn1 a::before {
  transform: skewX(35deg);
  bottom: 50%;
}

#main.data .btn1 a::after {
  transform: skewX(-35deg);
  top: 50%;
}

#main.data #mainv {
  background-color: #fffff3;
  background-image: url(../akanekai/images/data/data_p_mainv.png);
  background-repeat: no-repeat;
  background-position: left calc(50% + 300px) top 30px;
  padding: 85px 0;
}

#main.data #mainv h1 {
  color: #000;
  font-size: 48px;
  font-weight: bold;
  width: 1098px;
  margin: 0 auto;
}

#main.data #mainv p {
  font-size: 22px;
  width: 1098px;
  margin: -5px auto 0;
}

#main.data .block1 .lead {
  font-size: 18px;
  text-align: center;
  margin: 45px 0 100px;
}

#main.data .block1 .caution {
  font-size: 10px;
  text-align: right;
  margin: 45px 0 0;
}

#main.data .block1 .couple {
  width: 1098px;
  margin: 25px auto 0;
}

#main.data .block1 .couple ul {
  width: 1000px;
  margin: 0 auto 100px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#main.data .block1 .couple ul li {
  width: 470px;
  border: 2px solid #efbfbf;
  box-shadow: 10px 10px 0 0 #ffebeb;
  border-radius: 20px;
  margin: 100px 0 40px;
  padding: 45px 36px 20px;
  box-sizing: border-box;
  position: relative;
}

#main.data .block1 .couple ul li::before,
#main.data .block1 .couple ul li::after {
  content: "";
  width: 95px;
  height: 74px;
  background-repeat: no-repeat;
  background-size: 100%;
  position: absolute;
  top: -75px;
  transform: translateY(50%);
}

#main.data .block1 .couple ul li::before {
  background-image: url("images/data/datalist_i_m.jpg");
  left: 80px;
}

#main.data .block1 .couple ul li::after {
  background-image: url("images/data/datalist_i_w.jpg");
  right: 80px;
}

#main.data .block1 .couple ul li:nth-last-child(-n + 2) {
  margin-bottom: 0;
}

#main.data .block1 .couple ul li .title {
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  background: #ffebeb;
  letter-spacing: 4px;
  padding: 4px 20px;
  position: absolute;
  top: -100px;
  left: 50%;
  transform: translateX(-50%);
  word-break: keep-all;
  white-space: nowrap;
}

#main.data .block1 .couple ul li .title::before {
  content: "";
  width: 41px;
  height: 36px;
  background: url("images/data/datalist_i_heart.png") #fff no-repeat;
  background-size: 100%;
  position: absolute;
  top: 65px;
  left: 50%;
  transform: translateX(-50%);
}

#main.data .block1 .couple ul li .title::after {
  content: "";
  width: 0;
  height: 0;
  border-top: 10px solid #ffebeb;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  position: absolute;
  top: 42px;
  left: 50%;
  transform: translateX(-50%);
}

#main.data .block1 .couple ul li table {
  position: relative;
  font-weight: 600;
}

#main.data .block1 .couple ul li table tr {
  border-bottom: solid 1px #b7b7b7;
}

#main.data .block1 .couple ul li table tr:last-child {
  border-bottom: none;
}

#main.data .block1 .couple ul li table th {
  color: #bb2121;
  font-size: 16px;
  width: 34px;
  padding: 14px 0 10px;
}

#main.data .block1 .couple ul li table td {
  font-size: 18px;
  width: 180px;
  text-align: center;
  box-sizing: border-box;
  padding: 12px 0;
}

#main.data .block2 {
  background: #f5f5f5;
}

#main.data .block2 .datalist {
  margin: 80px 0 0;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  counter-reset: item;
}

#main.data .block2 .datalist li {
  width: 575px;
  background: #fff;
  border-radius: 25px;
  box-sizing: border-box;
  padding: 22px 28px 60px;
}

#main.data .block2 .datalist li h3 {
  font-size: 24px;
  font-weight: bold;
}

#main.data .block2 .datalist li h3::before {
  counter-increment: item;
  content: "0" counter(item);
  width: 67px;
  height: 67px;
  color: #fff;
  font-size: 28px;
  background: #000;
  border-radius: 50%;
  display: inline-block;
  text-align: center;
  line-height: 67px;
  margin: 0 25px 0 0;
}

#main.data .block2 .datalist li figure {
  width: 410px;
  margin: 65px auto 0;
}

#main.data .block2 .datalist li:first-child figure {
  width: 414px;
}

#main.data .block2 .datalist li .text {
  font-size: 18px;
  text-align: center;
  margin: 65px 0 0;
}

#main.data .block2 .datalist li:nth-child(3) {
  width: 100%;
  margin: 50px 0 0;
  padding-bottom: 45px;
}

#main.data .block2 .datalist li:nth-child(3) .flex {
  width: 1035px;
  display: flex;
  flex-direction: row-reverse;
  justify-content: flex-end;
  align-items: center;
  background: url(../akanekai/images/data/datalist_i_03-2.png) no-repeat right 30px bottom 0 / 115px auto;
  margin: -10px 0 0 83px;
}

#main.data .block2 .datalist li:nth-child(3) .flex figure {
  background: none;
  width: 470px;
  margin: 0;
}

#main.data .block2 .datalist li:nth-child(3) .flex .text {
  width: 368px;
  margin: 0 35px 0 0;
}

#main.data .block2 .caution {
  font-size: 10px;
  text-align: right;
  margin: 20px 0 0;
}

#main.data .block2 .btn1 {
  margin: 50px 0 0;
}

#main.data .blockYoung {
  padding-bottom: 20px;
}

#main.data .blockYoung .subContents {
  width: 990px;
}

#main.data .blockYoung .fukidashi {
  font-size: 26px;
  font-weight: bold;
  text-align: center;
  background: #ffecdd;
  border-radius: 15px;
  margin: 0 0 50px;
  padding: 15px 0;
  position: relative;
}

#main.data .blockYoung .fukidashi::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 20px 15px 0 15px;
  border-color: #ffecdd transparent transparent transparent;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 100%);
}

#main.data .blockYoung ul {
  display: flex;
  justify-content: space-between;
}

#main.data .blockYoung ul li {
  width: 460px;
}

#main.data .blockYoung ul li .bnr img {
  width: 100%;
}

#main.data .blockYoung ul li .shop {
  font-size: 14px;
  margin: 5px 0 0;
}

#main.data .blockYoung ul li .button {
  text-align: center;
  margin: 15px 0 0;
}

#main.data .blockYoung ul li .button a {
  font-size: 22px;
  font-weight: bold;
  display: block;
  border-radius: 50px;
  box-shadow: 2px 2px 2px 0 #aaa;
  padding: 10px;
  position: relative;
  bottom: 0;
  transition: 0.2s all;
}

#main.data .blockYoung ul li .button a:hover {
  box-shadow: 0 0 0 0 #aaa;
  bottom: -2px;
  opacity: 0.8;
}

#main.data .blockYoung ul li.ob .button a {
  border: 2px solid #c22455;
}

#main.data .blockYoung ul li.fiore .button a {
  border: 2px solid #59ad31;
}

#main.data .blockYoung ul li .button a img {
  width: 1em;
  margin-left: 0.5em;
  vertical-align: middle;
}

#main.data .block3 .subContents {
  width: 1140px;
  display: flex;
  justify-content: space-between;
  position: relative;
}

#main.data .block3 .text {
  width: 570px;
  text-align: center;
  margin: 72px 0 0;
}

#main.data .block3 .text h3 {
  font-size: 32px;
  font-weight: bold;
}

#main.data .block3 .text .midashi {
  font-size: 22px;
  font-weight: bold;
  margin: 0;
}

#main.data .block3 .fukidashi {
  font-size: 23px;
  text-align: center;
  width: 425px;
  background: #ffecdd;
  border-radius: 15px;
  position: absolute;
  left: 80px;
  top: 195px;
  padding: 15px 25px;
}

#main.data .block3 .fukidashi::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 16px 0 16px 50px;
  border-color: transparent transparent transparent #ffecdd;
  position: absolute;
  top: 50%;
  right: -50px;
  transform: translateY(-50%);
}

#main.data .block3 figure {
  width: 570px;
}

@media (max-width: 768px) {
  #main.data p {
    font-size: 15px;
  }
  #main.data {
    margin-top: 0px;
  }

  #main.data .block {
    padding: 20px 0 55px;
  }

  #main.data .subContents {
    width: auto;
    margin: 0 5vw;
  }
  #main.data .h-type1 h2 {
    font-size: 6.6vw;
    padding: 0.5em 0 0.8em;
  }

  #main.data .h-type1 h2::after {
  }

  #main.data h3.coupleHeading {
    width: auto;
    font-size: 20px;
    letter-spacing: 1px;
    margin: 78px 0 35px;
  }

  #main.data h3.coupleHeading:first-child {
    margin-top: 0;
  }

  #main.data h3.coupleHeading::before,
  #main.data h3.coupleHeading::after {
    border-top: solid 1px #bb2121;
  }

  #main.data h3.coupleHeading::before {
    margin-right: 1rem;
  }

  #main.data h3.coupleHeading::after {
    margin-left: 1rem;
  }

  #main.data h3.coupleHeading span {
  }

  #main.data .btn1 {
    margin: 70px 0 0;
  }
  #main.data .btn1 a {
    font-size: 18px;
    width: 100%;
    padding: 18px 0;
  }

  #main.data .btn1 a::before,
  #main.data .btn1 a::after {
  }

  #main.data .btn1 a::before {
  }

  #main.data .btn1 a::after {
  }

  #main.data #mainv {
    background-image: url("../akanekai/images/data/data_p_mainv_sp_01.png"), url("../akanekai/images/data/data_p_mainv_sp_02.png");
    background-position: bottom -30px left -20px, bottom -30px right -20px;
    background-size: 117px 138px;
    padding: 50px 0 30px;
  }

  #main.data #mainv h1 {
    font-size: 30px;
    width: auto;
    text-align: center;
    padding-bottom: 15px;
  }

  #main.data #mainv p {
    font-size: 15px;
    width: auto;
    text-align: center;
  }

  #main.data .pagelink {
    margin: 36px 0 0;
  }

  #main.data .pagelink ul {
    display: flex;
    justify-content: space-between;
  }

  #main.data .pagelink ul li {
    width: 48%;
  }

  #main.data .pagelink ul li a {
    width: 100%;
    font-weight: bold;
    font-size: 16px;
    border: 2px solid #dd9090;
    padding: 11px;
    display: block;
    position: relative;
  }

  #main.data .pagelink ul li a::after {
    content: "";
    width: 10px;
    height: 10px;
    border-right: 1px solid #000;
    border-bottom: 1px solid #000;
    display: inline-block;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-75%) rotate(45deg);
  }

  #main.data .block1 .lead {
    font-size: 15px;
    margin: 35px 0 55px;
  }

  #main.data .block1 .caution {
    margin: 35px 0 0;
  }

  #main.data .block1 .couple {
    width: 100%;
    margin: 0;
  }

  #main.data .block1 .couple ul {
    width: 100%;
    margin: 0;
  }

  #main.data .block1 .couple ul:last-child {
    margin-bottom: 0;
  }

  #main.data .block1 .couple ul li {
    width: 97%;
    margin-bottom: 0;
    padding: 0 7.2vw 15px;
    position: relative;
  }

  #main.data .block1 .couple ul li::before,
  #main.data .block1 .couple ul li::after {
    width: 66px;
    height: 51px;
    top: -55px;
  }

  #main.data .block1 .couple ul li::before {
    left: 14.8vw;
    transform: translateY(50%);
  }

  #main.data .block1 .couple ul li::after {
    right: 14.8vw;
    transform: translateY(50%);
  }

  #main.data .block1 .couple ul li:first-child {
    margin: 70px 0 0;
  }

  #main.data .block1 .couple ul li:last-child {
    margin-bottom: 0;
  }

  #main.data .block1 .couple ul li .more {
    width: 100vw;
    height: 200px;
    margin: 0 calc(50% - 50vw);
    padding: 200px 0 50px;
    position: absolute;
    left: 0;
    bottom: -40px;
    text-align: center;
    border-radius: 18px;
    background: linear-gradient(transparent, #fff 65%, #fff);
  }

  #main.data .block1 .couple ul li .more p {
    color: #bb2121;
    font-size: 18px;
    padding: 0 0 5px;
    display: inline-block;
    border-bottom: solid 1px #bb2121;
  }

  #main.data .block1 .couple ul li .more.hide {
    display: none;
  }

  #main.data .block1 .couple ul li .more span {
    color: #bb2121;
    font-size: 20px;
  }

  #main.data .block1 .couple ul li .title {
    font-size: 14px;
    padding: 6px 13px 4px;
    top: -70px;
  }

  #main.data .block1 .couple ul li .title::before {
    width: 28px;
    height: 24px;
    top: 46px;
    left: 50%;
  }

  #main.data .block1 .couple ul li .title::after {
    top: 32px;
    left: 50%;
  }

  #main.data .block1 .couple ul li table {
    width: 100%;
    margin: 25px 0 0;
    font-weight: bold;
  }

  #main.data .block1 .couple ul li table::before,
  #main.data .block1 .couple ul li table::after {
  }

  #main.data .block1 .couple ul li table::before {
  }

  #main.data .block1 .couple ul li table::after {
  }

  #main.data .block1 .couple ul li table th {
    font-size: 13px;
    width: 12%;
    padding: 10px 0 8px;
  }

  #main.data .block1 .couple ul li table td {
    font-size: 14px;
    width: 45%;
    padding: 10px 0 8px;
  }

  #main.data .block2 {
  }

  #main.data .block2 .datalist {
    margin: 40px 0 0;
    display: block;
  }

  #main.data .block2 .datalist li {
    width: 100%;
    border-radius: 10px;
    margin: 0 0 20px;
    padding: 25px 10px;
  }

  #main.data .block2 .datalist li h3 {
    font-size: 17px;
    margin-left: 15px;
  }

  #main.data .block2 .datalist li h3::before {
    width: 40px;
    height: 40px;
    font-size: 16px;
    line-height: 40px;
    margin: 0 14px 0 0;
  }

  #main.data .block2 .datalist li figure {
    width: 100%;
    margin: 25px auto 0;
    padding: 0 15px;
  }

  #main.data .block2 .datalist li .text {
    font-size: 3.8vw;
    margin: 25px 0 0;
  }

  #main.data .block2 .datalist li:nth-child(3) {
    margin: 25px 0 0;
    padding-bottom: 45px;
  }

  #main.data .block2 .datalist li:nth-child(3) .flex {
    width: 100%;
    display: block;
    background: url(../akanekai/images/data/datalist_i_03-2.png) no-repeat right 10px top 200px / 25% auto;
    margin: -10px 0 0 0;
  }

  #main.data .block2 .datalist li:nth-child(3) .flex figure {
    background: none;
    width: 100%;
    margin: 25px 0 80px;
    padding: 0;
  }

  #main.data .block2 .datalist li:nth-child(3) .flex .text {
    width: 100%;
    margin: 25px 0 0;
  }

  #main.data .block2 .caution {
    margin: 20px 0 0;
  }

  #main.data .block2 .btn1 {
    margin: 40px 0 0;
  }

  #main.data .blockYoung {
    padding-bottom: 20px;
  }

  #main.data .blockYoung .subContents {
    width: auto;
  }

  #main.data .blockYoung .fukidashi {
    font-size: 18px;
    border-radius: 10px;
    margin: 0 0 50px;
    padding: 15px 10px;
    position: relative;
  }

  #main.data .blockYoung .fukidashi::after {
    border-width: 22px 10px 0 10px;
  }

  #main.data .blockYoung ul {
    display: block;
  }

  #main.data .blockYoung ul li {
    width: 100%;
  }

  #main.data .blockYoung ul li + li {
    margin: 60px 0 0;
  }

  #main.data .blockYoung ul li .bnr img {
  }

  #main.data .blockYoung ul li .shop {
    font-size: 3vw;
    margin: 5px 0 0;
  }

  #main.data .blockYoung ul li .button {
  }

  #main.data .blockYoung ul li .button a {
    font-size: 17px;
    margin-top: 10px;
    padding: 10px;
  }

  #main.data .blockYoung ul li .button a:hover {
  }

  #main.data .blockYoung ul li.ob .button a {
  }

  #main.data .blockYoung ul li.fiore .button a {
  }

  #main.data .blockYoung ul li .button a img {
  }

  #main.data .block3 {
  }

  #main.data .block3 .subContents {
    width: auto;
    display: block;
    padding: 0;
  }

  #main.data .block3 .text {
    width: auto;
    margin: 40px 0 0;
  }

  #main.data .block3 .text h3 {
    font-size: 28px;
  }

  #main.data .block3 .text .midashi {
    font-size: 17px;
    line-height: 1.2;
    margin: 0;
  }

  #main.data .block3 figure {
    width: 100%;
    margin: 10px 0 0;
  }

  #main.data .block3 .fukidashi {
    font-size: 3.5vw;
    width: 100%;
    border-radius: 15px;
    position: static;
    margin: 20px 0 0;
    padding: 15px 5px;
  }

  #main.data .block3 .fukidashi::after {
    content: none;
  }
}

/* ---------------------------------------------
活動の流れ
--------------------------------------------- */

#join p {
  margin: 0;
}

#join h2 {
  padding: 0;
}

#join #mainv {
  height: 325px;
  text-align: center;
  background: url(images/join/mainv_bg_pc.jpg) no-repeat center top / cover;
  background-size: cover;
  position: relative;
}

#join #mainv h1 {
  color: #fff;
  font-size: 46px;
  font-weight: 700;
  letter-spacing: 2.5px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

#join #step {
  padding: 70px 0 85px;
}

#join #step .flowBlock {
  width: 1075px;
  margin: 0 auto 92px;
}

#join #step .flowBlock img {
  width: 100%;
}

#join #step .stepBlock .balloon {
  width: fit-content;
  -moz-width: fit-content;
  margin: 0 auto 55px;
  position: relative;
}

#join #step .stepBlock .balloon.balInbox {
  margin: 50px auto 0;
}

#join #step .stepBlock .balloon::before {
  content: "";
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
  border-top: 20px solid #b8902d;
  position: absolute;
  left: 50%;
  bottom: -15px;
  transform: translateX(-50%);
}

#join #step .stepBlock .balloon span {
  color: #fff;
  font-size: 30px;
  font-weight: bold;
  width: 439px;
  text-align: center;
  line-height: 1.5;
  letter-spacing: 4px;
  vertical-align: bottom;
  background: #b8902d;
  border-radius: 5px;
  padding: 14px 0;
  display: inline-block;
}

#join #step .stepBlock .balloon span .em {
  font-size: 45px;
  line-height: 1.14;
  display: inline;
}

#join #step .stepBlock > section {
  padding: 40px 0 35px;
}

#join #step .stepBlock > section.sec-first {
  padding-top: 0;
}

#join #step .stepBlock > section.sec-brown {
  background: #fff3e3;
}

#join #step .stepBlock > section.sec-last {
  padding-bottom: 0;
}

#join #step .stepBlock > section .subContents {
  width: 780px;
  margin: 0 auto;
}

#join #step .stepBlock > section.sec-last .subContents {
  width: 500px;
}

#join #step .stepBlock > section .subContents .num {
  color: #cc3737;
  font-size: 19px;
  font-weight: 700;
  text-align: center;
}

#join #step .stepBlock > section .subContents .stepHeading {
  color: #cc3737;
  font-size: 40px;
  font-weight: 700;
  text-align: center;
  margin: 0 0 20px;
}

#join #step .stepBlock > section.sec-last .subContents .stepHeading {
  margin: 0;
}

#join #step .stepBlock > section.sec-last .subtext {
  color: #b8902d;
  font-size: 30px;
  font-weight: bold;
  text-align: center;
  margin: 0 0 20px;
}

#join #step .stepBlock > section .subContents .stepInner {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: center;
}

#join #step .stepBlock > section .subContents .stepInner .box {
  width: 60%;
}

#join #step .stepBlock > section.sec-last .subContents .stepInner .box {
  width: 100%;
}

#join #step .stepBlock > section .subContents .stepInner .box p {
  font-size: 17px;
  line-height: 1.58;
}

#join #step .stepBlock > section.sec-last .subContents .stepInner .box p {
  margin: 0 0 30px;
}

#join #step .stepBlock > section .subContents .stepInner .box p.note {
  color: #717171;
  margin-top: 25px;
}

#join #step .stepBlock > section .subContents .stepInner .box .yellowBox {
  font-size: 17px;
  font-weight: 700;
  text-align: center;
  background: #fded82;
  margin-top: 25px;
  padding: 16px 0 14px;
}

#join #step .stepBlock > section .subContents .stepInner figure {
  width: 35%;
}

#join #step .stepBlock > section.sec-last .subContents .stepInner figure {
  width: 100%;
}

#join #step .stepBlock > section .subContents .stepInner figure img {
  width: 100%;
}

#join #step .stepBlock > section .subContents .shoruiBox {
  background: #fff;
  border: solid 1px #b8902d;
  margin-top: 47px;
  padding: 50px 40px 43px;
  position: relative;
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  cursor: pointer;
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap h3 {
  color: #b8902d;
  font-size: 30px;
  font-weight: 700;
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap .close {
  color: #b8902d;
  font-size: 14px;
  font-weight: bold;
  opacity: 1;
  padding: 0 40px 12px 0;
  float: inherit;
  position: relative;
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap .close::before,
#join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap .close::after {
  content: "";
  width: 21px;
  height: 3px;
  background: #b8902d;
  position: absolute;
  top: calc(50% - 7px);
  right: 0;
  transform: translateY(-50%);
  transition: 0.2s;
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap.cr .close::after {
  transform: translateY(-50%);
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap .close::after {
  transform: translateY(-50%) rotate(90deg);
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap .close .text {
  color: #b8902d;
  font-size: 14px;
  font-weight: bold;
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiList {
  margin: 40px 0 0;
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiList .text {
  font-size: 17px;
  line-height: 1.58;
  margin: 0 0 40px;
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiList ul li {
  margin: 0 0 20px;
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiList ul li h4 {
  font-size: 14px;
  margin: 0 0 10px;
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiList ul li h4::before {
  content: "";
  width: 15px;
  height: 15px;
  background: #b8902d;
  margin: 0 8px 0 0;
  display: inline-block;
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiList ul li h4 span {
  font-size: 20px;
  font-weight: 700;
  margin: 0 5px 0 0;
}

#join #step .stepBlock > section .subContents .shoruiBox .shoruiList ul li div {
  color: #717171;
  font-size: 16px;
}

/* FOR smartphone landscape
***************************************************************************/
@media screen and (max-width: 899px) {
  #join p {
  }

  #join h2 {
  }

  #join #mainv {
    height: 44vw;
    background: url(images/join/mainv_bg_sp.jpg) no-repeat center top;
    background-size: 100% auto;
  }

  #join #mainv h1 {
    font-size: 6.9vw;
    letter-spacing: 0.6vw;
  }

  #join #step {
    padding: 10.9vw 0 0;
  }

  #join #step .flowBlock {
    width: calc(100% - 8vw);
    margin: 0 auto 18.6vw;
  }

  #join #step .flowBlock img {
  }

  #join #step .stepBlock .balloon {
    margin: 0 auto 13.3vw;
  }

  #join #step .stepBlock .balloon.balInbox {
    margin: 10.9vw auto 0;
  }

  #join #step .stepBlock .balloon::before {
    border-left: 4vw solid transparent;
    border-right: 4vw solid transparent;
    border-top: 4vw solid #b8902d;
    bottom: -2.5vw;
  }

  #join #step .stepBlock .balloon span {
    font-size: 5.3vw;
    letter-spacing: 0.5vw;
    width: 68.4vw;
    border-radius: 0.6vw;
    padding: 3vw 0;
  }

  #join #step .stepBlock .balloon span .em {
    font-size: 7.3vw;
    line-height: 1.2;
  }

  #join #step .stepBlock > section {
    padding: 10vw 0 11.2vw;
  }

  #join #step .stepBlock > section.sec-first {
  }

  #join #step .stepBlock > section.sec-brown {
  }

  #join #step .stepBlock > section.sec-last {
  }

  #join #step .stepBlock > section .subContents {
    width: calc(100% - 8vw);
  }

  #join #step .stepBlock > section.sec-last .subContents {
    width: calc(100% - 8vw);
  }

  #join #step .stepBlock > section .subContents .num {
    font-size: 3.7vw;
  }

  #join #step .stepBlock > section .subContents .stepHeading {
    font-size: 6.6vw;
    margin: 0 0 6.1vw;
  }

  #join #step .stepBlock > section.sec-last .subContents .stepHeading {
  }

  #join #step .stepBlock > section.sec-last .subtext {
    font-size: 5.6vw;
    margin: 0 0 6.1vw;
  }

  #join #step .stepBlock > section .subContents .stepInner {
  }

  #join #step .stepBlock > section .subContents .stepInner .box {
    width: 100%;
    margin: 0 0 3vw;
  }

  #join #step .stepBlock > section .subContents .stepInner .box p {
    font-size: 4vw;
    line-height: 1.6;
    margin: 0 0 3.7vw;
  }

  #join #step .stepBlock > section.sec-last .subContents .stepInner .box p {
    margin: 0 0 5.2vw;
  }

  #join #step .stepBlock > section .subContents .stepInner .box p.note {
    margin: 0 0 3vw;
  }

  #join #step .stepBlock > section .subContents .stepInner .box .yellowBox {
    font-size: 4vw;
    margin: 0 0 5vw;
    padding: 2.2vw 0 2.4vw;
  }

  #join #step .stepBlock > section .subContents .stepInner figure {
    width: 100%;
  }

  #join #step .stepBlock > section.sec-last .subContents .stepInner figure {
  }

  #join #step .stepBlock > section .subContents .stepInner figure img {
  }

  #join #step .stepBlock > section .subContents .shoruiBox {
    margin-top: 8.4vw;
    padding: 7.4vw 4.6vw 8.1vw;
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap {
    align-items: center;
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap h3 {
    font-size: 5.6vw;
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap .close {
    font-size: 2.9vw;
    padding: 0 7.3vw 0 0;
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap .close::before,
  #join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap .close::after {
    width: 5.3vw;
    height: 0.8vw;
    top: 50%;
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap .close::after {
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap.cr .close::after {
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiWrap .close .text {
    font-size: 2.9vw;
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiList {
    margin: 2.5vw 0 0;
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiList .text {
    font-size: 4vw;
    line-height: 1.6;
    margin: 0 0 6.5vw;
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiList ul li {
    margin: 0 0 5.6vw;
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiList ul li.last {
    margin-bottom: 0;
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiList ul li h4 {
    font-size: 3.7vw;
    margin: 0 0 2.5vw;
    text-indent: -1.5em;
    padding-left: 1.5em;
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiList ul li h4::before {
    width: 3.4vw;
    height: 3.4vw;
    margin: 0 2vw 0 0;
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiList ul li h4 span {
    font-size: 4.2vw;
    margin: 0;
  }

  #join #step .stepBlock > section .subContents .shoruiBox .shoruiList ul li div {
    font-size: 4vw;
    padding-left: 1.5em;
  }
}

/* ---------------------------------------------
料金ページ
--------------------------------------------- */
#main.price {
  margin-top: 0;
  padding-bottom: 100px;
}
#main.price sup {
  display: inline-block;
}
#main.price,
#main.price p {
  font-size: 17px;
  line-height: 1.55;
  font-family: "Noto Sans JP", sans-serif;
}
#main.price .fontMin,
#main.price p.fontMin {
  font-family: "Noto Serif JP", serif;
}
#main.price .yellow {
  color: #b8902d;
}
#main.price .red {
  color: #bb2121;
}
#main.price .note {
  font-size: 16px;
}

.price {
  color: #000;
  font-weight: normal;
  font-size: 18px;
}

#main.price .subContents {
  width: 1160px;
  text-align: left;
  margin: 0 auto;
}

#main.price #mainv {
  color: #fff;
  height: 324px;
  background: url(images/price/bg_mainv.jpg) no-repeat center center;
  background-size: cover;
  position: relative;
}
#main.price #mainv h1 {
  font-size: 46px;
  font-weight: bold;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#main.price #lead {
  padding: 70px 0 75px;
}
#main.price #lead .nextarrow {
  padding: 0 0 65px;
  position: relative;
}
#main.price #lead .nextarrow::after {
  content: "";
  width: 72px;
  height: 27px;
  background: url(images/price/s_arrow_01.png) no-repeat;
  background-size: 100% auto;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
#main.price #lead .nextarrow .note {
  font-size: 14px;
  margin-top: 35px;
}
#main.price #lead h2 {
  font-size: 42px;
  font-weight: bold;
  text-align: center;
  margin: 0 0 5px;
}
#main.price #lead .lead {
  font-size: 20px;
  text-align: center;
  margin: 0 0 50px;
}
#main.price #lead ol {
  margin: 0 0 30px;
  display: flex;
  justify-content: space-between;
}
#main.price #lead ol li {
  width: calc(100% / 3);
  text-align: center;
  box-sizing: border-box;
  border-right: solid 1px #b8902d;
  padding: 0 15px;
}
#main.price #lead ol li:first-child {
  border-left: solid 1px #b8902d;
}
#main.price #lead ol li + li {
  margin-left: 0 !important;
}
#main.price #lead ol li figure {
  width: 270px;
  text-align: center;
  margin: 0 auto 15px;
}
#main.price #lead ol li h3 {
  font-size: 32px;
  font-weight: bold;
  margin: 0 0 20px;
}
#main.price #lead ol li h3.l1 {
  letter-spacing: 2px;
  line-height: calc(32px * 2 * 1.55);
}
#main.price #lead ol li .box {
  font-size: 16px;
  background: #f4f2e2;
  border-radius: 10px;
  margin: 15px 30px 0;
  padding: 15px 0;
}
#main.price #lead .hoka {
  text-align: center;
  margin: 0 0 80px;
}
#main.price #lead .selectMidashi {
  font-size: 30px;
  font-weight: bold;
  text-align: center;
}
#main.price #areaTab {
  border-bottom: solid 3px #bb2121;
  background: #fff;
}
#main.price #areaTab.mini {
  top: 80px;
  left: 0;
  z-index: 3;
  position: sticky;
}
@media screen and (min-width: 769px) {
  #main.price #areaTab.mini ul {
    padding: 10px 0 0;
    justify-content: center;
    column-gap: 5px;
  }
  #main.price #areaTab.mini ul li {
    font-size: 20px;
    width: 400px;
    padding: 8px 0;
  }
}
#main.price #areaTab ul {
  margin: 0;
  display: flex;
  justify-content: space-between;
}
#main.price #areaTab ul li {
  color: #bb2121;
  font-size: 34px;
  font-weight: bold;
  width: calc(50% - 6px);
  text-align: center;
  background: #eaeaea;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  padding: 15px 0;
  cursor: pointer;
}
#main.price #areaTab ul li + li {
  margin-left: 0 !important;
}
#main.price #areaTab ul li.cr {
  color: #fff;
  background: #bb2121;
}
#main.price .tabContents {
}
#main.price .tabContents .hoho {
  background: #fff3e3;
  padding: 70px 0;
}
#main.price .tabContents .hoho .subContents {
  text-align: center;
}
#main.price .tabContents .hoho h2 {
  font-size: 44px;
  font-weight: bold;
  margin: 0 0 10px;
}
#main.price .tabContents .hoho .lead {
  font-size: 20px;
  margin: 0 0 40px;
}
#main.price .tabContents .hoho ul {
  margin: 0 50px 50px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#main.price .tabContents .hoho ul li {
  width: calc(50% - 10px);
  background: #fff;
  border-radius: 10px;
  margin: 0 0 20px;
  padding: 30px;
}
#main.price .tabContents .hoho ul li figure {
  width: 208px;
  margin: 0 auto 20px;
}
#main.price .tabContents .hoho ul li figure img {
  width: 100%;
}
#main.price .tabContents .hoho ul li h3 {
  font-size: 30px;
  font-weight: bold;
  margin: 0 0 10px;
}
#main.price .tabContents .hoho .hohobtn {
  margin: 0 150px;
}
#main.price .tabContents .hoho .hohobtn a {
  color: #bb2121;
  font-size: 25px;
  font-weight: bold;
  text-align: center;
  background: #f1dcdc;
  border: solid 2px #bb2121;
  border-radius: 10px;
  padding: 15px 0;
  display: block;
  position: relative;
  transition: all 0.2s;
}
#main.price .tabContents .hoho .hohobtn a::after {
  content: "";
  width: 10px;
  height: 10px;
  border-top: solid 2px #bb2121;
  border-right: solid 2px #bb2121;
  position: absolute;
  top: 50%;
  right: 30px;
  transform: rotate(45deg) translateY(-3px);
}
#main.price .tabContents .hoho .hohobtn a:hover {
  color: #fff;
  background: #bb2121;
}
#main.price .tabContents .hoho .hohobtn a:hover::after {
  border-color: #fff;
}

#main.price .tabContents .plan {
  background: #fff;
  padding: 70px 0 0;
}
#main.price .tabContents .plan h2 {
  font-size: 44px;
  font-weight: bold;
  line-height: 1.25;
  text-align: center;
  margin: 0 0 40px;
}
#main.price .tabContents.east .plan h2 {
  margin: 0 0 100px;
}
#main.price .tabContents .plan h2 span {
  color: #bb2121;
  font-size: 136%;
}
#main.price .tabContents .plan .tab-plan {
  display: none;
}

#main.price .tabContents .plan .plans {
  margin: 0 0 60px;
}
#main.price .tabContents .plan .plans > li {
  margin: 0;
}
#main.price .tabContents .plan .plans > li + li {
  margin-top: 35px;
}
#main.price .tabContents .plan .plans > li h3 {
  color: #fff;
  font-size: 36px;
  font-weight: bold;
  width: 450px;
  text-align: center;
  padding: 15px 0 13px;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  position: relative;
}
#main.price .tabContents .plan .plans > li h3 span {
  color: #fff;
  font-size: 54%;
  display: inline;
}
#main.price .tabContents .plan .plans > li.plan-ladys h3 {
  background: #c26159;
}
#main.price .tabContents .plan .plans > li.plan0 h3 {
  background: #ba3a27;
}
#main.price .tabContents .plan .plans > li.plan1 h3 {
  background: #b99c2d;
}
#main.price .tabContents .plan .plans > li.plan2 h3 {
  background: #a07a13;
}
#main.price .tabContents .plan .plans > li.plan3 h3 {
  background: #ef784e;
}
#main.price .tabContents .plan .plans > li.plan_choosable h3 {
  background: #267059;
}

#main.price .tabContents .plan .plans > li.plan3 h3::after {
  content: "";
  width: 300px;
  height: 116px;
  background: url(images/price/s_tokubetsu.png) no-repeat left top/100% auto;
  position: absolute;
  top: -12px;
  left: 426px;
}

#main.price .tabContents .plan .plans > li > div {
  padding: 15px;
  display: flex;
  justify-content: space-between;
}
#main.price .tabContents .plan .plans > li.plan-ladys > div {
  background: #f4e5e5;
}
#main.price .tabContents .plan .plans > li.plan0 > div {
  background: #f4e5e5;
}
#main.price .tabContents .plan .plans > li.plan1 > div {
  background: #fff0de;
}
#main.price .tabContents .plan .plans > li.plan2 > div {
  background: #f1e9cf;
}
#main.price .tabContents .plan .plans > li.plan3 > div {
  background: #fbd7cb;
}
#main.price .tabContents .plan .plans > li.plan_choosable > div {
  background: #f1e9cf;
}

#main.price .tabContents .plan .plans > li > div .left {
  width: 565px;
}
#main.price .tabContents .plan .plans > li > div .right {
  width: 550px;
  background: rgba(255, 255, 255, 0.4);
  padding: 50px 0 0;
}
#main.price .tabContents .plan .plans > li > div .left > ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#main.price .tabContents .plan .plans > li > div .left > ul > li {
  width: calc(50% - 3px);
  text-align: center;
  background: #fff;
  border-radius: 4px;
  margin: 0 0 6px;
  padding: 25px 30px 25px;
}

#main.price .tabContents .plan .plans > li > div .left > ul > li:last-nth-child(1),
#main.price .tabContents .plan .plans > li > div .left > ul > li:last-nth-child(2) {
  margin-bottom: 0;
}

#main.price .tabContents .plan .plans > li.plan_choosable > div .left > ul > li {
  width: 100%;
}

#main.price .tabContents .plan .plans > li > div .left > ul > li h4 {
  font-size: 18px;
  font-weight: bold;
}
#main.price .tabContents .plan .plans > li.plan_choosable > div .left > ul > li h4 {
  margin: 0 0 15px;
}
#main.price .tabContents .plan .plans > li.plan_choosable > div .left > ul > li h4 span {
  color: #dd3852;
}

#main.price .tabContents .plan .plans > li.plan_choosable > div .left > ul > li .link a {
  color: #dd3852;
  text-decoration: underline;
}
#main.price .tabContents .plan .plans > li.plan_choosable > div .left > ul > li .link a:hover {
  text-decoration: none;
}
#main.price .tabContents .plan .plans > li > div .left > ul > li .btn {
  color: #267059;
  font-size: 1.25em;
  border: solid 1px #267059;
  border-radius: 5px;
  display: inline-block;
  margin: 0 auto;
  padding: 10px 20px;
}
#main.price .tabContents .plan .plans > li > div .left > ul > li .btn:hover {
  background: #c9ece1;
}
#main.price .tabContents .plan .plans > li > div .left > ul > li .price {
  font-size: 24px;
  font-weight: bold;
  line-height: 1.3;
}

#main.price .tabContents .plan .plans > li.plan_choosable > div .left > ul > li .price {
  font-size: 40px;
}
#main.price .tabContents .plan .plans > li > div .left > ul > li .price span {
  font-size: 196%;
}
#main.price .tabContents .plan .plans > li > div .left > ul > li .price.red span {
  color: #bb2121;
}
#main.price .tabContents .plan .plans > li > div .left > ul > li .note {
  font-size: 14px;
}
#main.price .tabContents .plan .plans > li > div .left > ul > li .alert1 {
  font-size: 16px;
  line-height: 1.3;
  background: #ffeb80;
  border-radius: 10px;
  padding: 5px 0;
}
#main.price .tabContents .plan .plans > li > div .left > ul > li .alert2 {
  color: #bb2121;
  font-size: 16px;
  line-height: 1.3;
  background: #ecbebe;
  border-radius: 20px;
  padding: 8px 0;
}
#main.price .tabContents .plan .plans > li.plan-ladys > div .left > ul > li .alert2 {
  color: #bb2121;
  background: #ecbebe;
}
#main.price .tabContents .plan .plans > li.plan1 > div .left > ul > li .alert2 {
  color: #a07a13;
  background: #ddd0ad;
}
#main.price .tabContents .plan .plans > li.plan2 > div .left > ul > li .alert2 {
  color: #a07a13;
  background: #ddd0ad;
}
#main.price .tabContents .plan .plans > li.plan3 > div .left > ul > li .alert2 {
  color: #5a5a5a;
  background: #dcdcdc;
}

#main.price .tabContents .plan .plans > li > div .right > ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
#main.price .tabContents .plan .plans > li > div .right > ul > li {
  width: 160px;
  text-align: center;
  margin: 0 10px 5px;
}
#main.price .tabContents .plan .plans > li > div .right > ul > li figure {
  width: 108px;
  background: none;
  margin: 0 auto 5px;
}
#main.price .tabContents .plan .plans > li > div .right > ul > li figure img {
  width: 108px;
}
#main.price .tabContents .plan .plans > li > div .right > ul > li p {
  font-size: 16px;
  line-height: 1.17;
}
#main.price .tabContents .plan .columnBox {
  border: solid 4px #d5d5d5;
  padding: 50px 60px;
}

#main.price .tabContents .plan .columnBox .fontBold {
  font-weight: bold;
}
#main.price .tabContents .plan .columnBox .indent {
  text-indent: -2.5em;
  padding-left: 2.5em;
}

#main.price .tabContents .plan .columnBox h5 {
  font-size: 18px;
  font-weight: bold;
  border-bottom: dashed 1px #d5d5d5;
  margin: 30px 0 15px;
  padding: 0 0 5px;
}

#main.price .tabContents .plan .columnBox p,
#main.price .tabContents .plan .columnBox li {
  font-size: 14px;
  margin: 0;
}

#main.price .tabContents .plan .columnBox .set {
  font-size: 16px;
}
#main.price .tabContents .plan .columnBox ul.set {
  font-size: 16px;
}
#main.price .tabContents .plan .columnBox ul.set li {
  list-style: disc !important;
  text-indent: -1em;
  padding-left: 1em;
  margin: 0 0 3px;
}
#main.price .tabContents .plan .columnBox ul.set li + li {
  margin-left: 0;
}

#main.price #links {
  height: 410px;
  background: url(images/price/links_p_01.jpg) no-repeat center center;
  background-size: cover;
  margin-top: 80px;
  position: relative;
}
#main.price #links ul {
  width: fit-content;
  -moz-width: fit-content;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  justify-contents: center;
}
#main.price #links ul li {
  width: 430px;
  margin: 0 10px;
}
#main.price #links ul li a {
  color: #bb2121;
  font-size: 25px;
  font-weight: bold;
  text-align: center;
  background: rgba(255, 255, 255, 0.9);
  border: solid 2px #bb2121;
  border-radius: 10px;
  padding: 30px 0;
  display: block;
  position: relative;
  transition: all 0.2s;
}
#main.price #links ul li a::before {
  content: "";
  height: 72px;
  background-repeat: no-repeat;
  background-size: 100% auto;
  position: absolute;
  top: 15px;
  left: 25px;
}
#main.price #links ul li.nyukai a::before {
  width: 74px;
  background-image: url(images/price/links_s_nyukaiflow.png);
}
#main.price #links ul li.katsudo a::before {
  width: 56px;
  background-image: url(images/price/links_s_katsudoflow.png);
}

#main.price #links ul li a::after {
  content: "";
  width: 10px;
  height: 10px;
  border-top: solid 2px #bb2121;
  border-right: solid 2px #bb2121;
  position: absolute;
  top: 50%;
  right: 30px;
  transform: rotate(45deg) translateY(-6px);
}
#main.price #links ul li a:hover {
  color: #fff;
  background: #bb2121;
}
#main.price #links ul li a:hover::after {
  border-color: #fff;
}
#main.price #links ul li.nyukai a:hover::before {
  background-image: url(images/price/links_s_nyukaiflow_hover.png);
}
#main.price #links ul li.katsudo a:hover::before {
  background-image: url(images/price/links_s_katsudoflow_hover.png);
}

/*テーブルデザイン*/
#main.price .priceTable.pc {
  display: inline-table;
}
#main.price .priceTable.sp {
  display: none;
}
#main.price .priceTable {
  font-size: 22px;
  line-height: 1.4;
  width: 100%;
  margin: 0 0 20px;
}
#main.price .priceTable tr {
  border-bottom: 1px solid #C8C8C8;
}
#main.price .priceTable tr td {
  text-align: center;
  width: calc(100% / 7);
}
/*プラン名*/
#main.price .priceTable tr:first-child td {
  line-height: 1.2;
  border-right: 1px solid #FFF;
  border-radius: 15px 15px 0 0;
  padding: 15px 0;
}
#main.price .priceTable tr:first-child td,
#main.price .priceTable tr:first-child td span {
  color: #FFF;
  font-size: 20px;
  font-weight: bold;
}
#main.price .priceTable tr:first-child td span {
  font-size: 14px;
}
#main.price .priceTable tr:first-child td:nth-child(2) {
  background: #b99c2d;
  position: relative;
}
#main.price .priceTable tr:first-child td:nth-child(2) .catch {
  position: absolute;
  content: "";
  color: #ba3a27;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.4;
  background: #fffbd6;
  border-radius: 20px;
  border: 4px solid #ba3a27;
  width: 165px;
  padding: 5px;
  top: -70px;
  left: 50%;
  transform: translateX(-50%);
}
#main.price .priceTable tr:first-child td:nth-child(2) .catch::before {
  content: "";
  position: absolute;
  top: 54px;
  left: 50%;
  transform: translateX(-50%) rotate(90deg);
  border: 10px solid transparent;
  border-left: 20px solid #fffbd6;
  z-index: 1;
}
#main.price .priceTable tr:first-child td:nth-child(2) .catch::after {
    content: "";
    position: absolute;
    top: 62px;
    left: 50%;
    transform: translateX(-50%) rotate(90deg);
    border: 10px solid transparent;
    border-left: 20px solid #ba3a27;
}
#main.price .priceTable tr:first-child td:nth-child(3) {
  background: #00659c;
}
#main.price .priceTable tr:first-child td:nth-child(4),
#main.price .priceTable tr:first-child td:nth-child(5),
#main.price .priceTable tr:first-child td:nth-child(6) {
  background: #ba3a27;
}
#main.price .priceTable tr:first-child td:nth-child(7) {
  background: #267059;
}
/*灰色線*/
#main.price .priceTable tr:not(:first-child) td {
  border-left: 1px solid #C8C8C8;
  border-right: 1px solid #C8C8C8;
}
/*項目名*/
#main.price .priceTable tr:not(:first-child) td:first-child {
  background: #fff9f2;
}
#main.price .priceTable tr:not(:first-child) td:first-child span {
  font-size: 12px;
  vertical-align: super;
}
/*入会初期費用*/
#main.price .priceTable tr:nth-child(2) td {
  padding: 15px 0;
}
/*会員期間・月会費*/
#main.price .priceTable tr:nth-child(3) td,
#main.price .priceTable tr:nth-child(4) td {
  padding: 20px 0;
}
/*定期紹介・申込数*/
#main.price .priceTable tr:nth-child(5) td {
  padding: 10px 0;
}
#main.price .priceTable tr td .plus {
  color: #ba3a27;
  font-size: 16px;
  background: #fff0de;
  border-radius: 10px;
  width: 130px;
  margin: 20px auto 0;
  padding: 10px 0;
  display: block !important;
}
#main.price .priceTable tr:nth-child(4) td .plus {
  margin: 0 0 0 20px;
  display: inline-block !important;
}
#main.price .priceTable .detailBtn {
  font-size: 18px;
  background: #267059;
  border-radius: 10px;
  box-shadow: 0px 5px 0px 0px rgba(19, 82, 62, 1);
  width: 140px;
  margin: 0 auto;
  padding: 20px 0;
  display: block;
  transform: translateY(-5px);
}
@media (hover: hover) and (pointer: fine) {
  #main.price .priceTable .detailBtn:hover {
    box-shadow: none;
    transform: translateY(0);
    transition-duration: .1s;
  }
}
#main.price .priceTable .detailBtn span {
  color: #FFF;
  position: relative;
  margin: 0 15px 0 0;
}
#main.price .priceTable .detailBtn span::before {
  position: absolute;
  content: "";
  bottom: 3px;
  right: -23px;
  border: 8px solid transparent;
  border-left: 9px solid #FFF;
}

#main.price .priceTable {
  font-size: 22px;
  line-height: 1.4;
  width: 100%;
  margin: 0 0 20px;
}

#main.price .note {
  font-size: 14px;
  text-align: right;
  margin: 0 0 60px;
}

/*サポート*/
#main.price .support {
  background: #fcf3f3;
  margin: 0 0 140px;
  padding: 40px 0;
}
#main.price .support .red {
  font-size: 34px;
  text-align: center;
  margin: 0 0 60px;
}
#main.price .support ul {
  display: flex;
  column-gap: 20px;
  justify-content: center;
}
#main.price .support ul li {
  width: 185px;
}
#main.price .support ul li figure {
  width: 100%;
  margin: 0 0 15px;
}
#main.price .support ul li p {
  font-size: 22px;
  text-align: center;
}
#main.price .support ul li p span {
  font-size: 10px;
  vertical-align: super;
}


@media (max-width: 768px) {
  #main.price {
    padding-bottom: 10vw;
  }
  #main.price,
  #main.price p {
    font-size: 16px;
  }
  #main.price .fontMin,
  #main.price p.fontMin {
    font-family: "Noto Serif JP", serif;
  }
  #main.price .note {
    font-size: 13px;
  }

  .price {
    font-size: 16px;
  }

  #main.price .subContents {
    width: 100vw;
    padding: 0 4.5vw;
    box-sizing: border-box;
  }

  #main.price #mainv {
    height: 44vw;
    background-size: auto 44vw;
  }
  #main.price #mainv h1 {
    font-size: 7vw;
    width: 100%;
    text-align: center;
  }
  #main.price #lead {
    padding: 10vw 0 10vw;
  }
  #main.price #lead .nextarrow {
    padding: 0 0 10vw;
  }
  #main.price #lead .nextarrow::after {
  }
  #main.price #lead .nextarrow .note {
    font-size: 12px;
    margin: 5vw 0;
  }
  #main.price #lead h2 {
    font-size: 6vw;
    margin: 0 0 2vw;
  }
  #main.price #lead .lead {
    font-size: 4vw;
    text-align: center;
    margin: 0 0 5vw;
  }
  #main.price #lead ol {
    margin: 0 0 6vw;
    display: block;
  }
  #main.price #lead ol li {
    width: 100%;
    margin: 0 0 5vw;
    padding: 0 0 5vw;
    border-bottom: solid 1px #b8902d;
    border-right: none;
  }
  #main.price #lead ol li:first-child {
    border-top: solid 1px #b8902d;
    border-left: none;
    padding-top: 5vw;
  }
  #main.price #lead ol li > div {
    margin: 0 5px 5vw;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  #main.price #lead ol li figure {
    width: 46%;
    margin: 0;
  }
  #main.price #lead ol li h3 {
    width: 50%;
    font-size: 6.5vw;
    margin: 0;
  }
  #main.price #lead ol li h3.l1 {
    height: 1.6;
  }
  #main.price #lead ol li .box {
    text-align: center;
    margin: 15px 0 0;
    padding: 15px 0;
    display: block;
  }
  #main.price #lead .hoka {
    margin: 0 0 10vw;
  }
  #main.price #lead .selectMidashi {
    font-size: 6vw;
    margin: 0;
  }
  #main.price #lead .selectMidashi span {
    display: inline !important;
  }
  #main.price #areaTab.mini {
    position: relative;
    top: 0;
  }
  #main.price #areaTab {
    border-bottom-width: 2px;
  }
  #main.price #areaTab ul li {
    font-size: 18px;
    width: calc(50% - 2px);
    padding: 10px 0 5px;
  }
  #main.price #areaTab ul li.cr {
  }
  #main.price .tabContents {
  }
  #main.price .tabContents .hoho {
    padding: 10vw 0 10vw;
  }
  #main.price .tabContents .hoho .subContents {
  }
  #main.price .tabContents .hoho h2 {
    font-size: 7vw;
  }
  #main.price .tabContents .hoho .lead {
    font-size: 16px;
    margin: 0 0 4vw;
  }
  #main.price .tabContents .hoho ul {
    margin: 0 0 5vw;
    display: block;
  }
  #main.price .tabContents .hoho ul li {
    width: 100%;
    margin: 0 0 5vw !important;
    padding: 5vw;
    display: flex !important;
    justify-content: space-between;
  }
  #main.price .tabContents .hoho ul li figure {
    width: 42%;
    margin: 0;
  }
  #main.price .tabContents .hoho ul li figure img {
  }
  #main.price .tabContents .hoho ul li > div {
    width: 50%;
  }
  #main.price .tabContents .hoho ul li h3 {
    font-size: 5vw;
  }
  #main.price .tabContents .hoho ul li p {
    font-size: 4vw;
  }
  #main.price .tabContents .hoho ul li.renmei {
    padding-bottom: 2.5em;
    position: relative;
  }
  #main.price .tabContents .hoho ul li.renmei .forsp {
    font-size: 12px;
    width: 100%;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
  }
  #main.price .tabContents .hoho .hohobtn {
    margin: 0;
  }
  #main.price .tabContents .hoho .hohobtn a {
    font-size: 5vw;
    padding: 10px 0;
    transition: none;
  }
  #main.price .tabContents .hoho .hohobtn a::after {
  }
  #main.price .tabContents .hoho .hohobtn a:hover {
    color: #bb2121;
    background: #f1dcdc;
  }
  #main.price .tabContents .hoho .hohobtn a:hover::after {
    border-color: #bb2121;
  }
  #main.price .tabCon1 .plan .subContents {
    overflow: visible;
  }
  #main.price .tabContents .plan {
    padding: 8vw 0 0;
  }
  #main.price .tabContents .plan h2 {
    font-size: 6vw;
    margin: 0 0 4vw;
  }
  #main.price .tabContents.east .plan h2 {
    margin: 0 0 20vw;
  }
  #main.price .tabContents .plan h2 span {
    font-size: 150%;
  }

  #main.price .tabContents .plan .tab-plan {
    margin: 0 0 15px;
    display: flex;
    justify-content: space-between;
  }

  #main.price .tabContents .plan .tabWrap {
    background: #fff;
    top: 60px;
    left: 0;
    position: sticky;
    z-index: 3;
  }

  #main.price .tabContents .plan #tab-east li {
    width: calc((100% - 5vw) / 5);
  }
  #main.price .tabContents .plan #tab-west li {
    width: calc((100% - 4vw) / 2);
  }

  #main.price .tabContents .plan .tab-plan li {
    color: #808080;
    line-height: 1.1;
    font-size: 2.3vw;
    font-weight: bold;
    text-align: center;
    background: #e5e5e5;
    display: flex !important;
    justify-content: center;
    align-items: center;
    position: relative;
    padding: 13px 2px;
  }
  #main.price .tabContents .plan .tab-plan li + li {
    margin-left: 1vw !important;
  }
  #main.price .tabContents .plan .tab-plan li span {
    color: #808080;
    font-size: 200%;
  }
  #main.price .tabContents .plan .tab-plan li,
  #main.price .tabContents .plan .tab-plan li span {
    color: #fff;
  }
  #main.price .tabContents .plan .tab-plan li.plan-ladys {
    background: #c26159;
  }
  #main.price .tabContents .plan .tab-plan li.plan0 {
    background: #ba3a27;
  }
  #main.price .tabContents .plan .tab-plan li.plan1 {
    background: #b99c2d;
  }
  #main.price .tabContents .plan .tab-plan li.plan2 {
    background: #a07a13;
  }
  #main.price .tabContents .plan .tab-plan li.plan3 {
    background: #ef784e;
  }
  #main.price .tabContents .plan .tab-plan li.plan_choosable {
    background: #267059;
  }

  #main.price .tabContents .plan .tab-plan li.cr::after {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 6px 7px 0 7px;
    border-color: #007bff transparent transparent transparent;
    position: absolute;
    bottom: -6px;
    left: 50%;
    transform: translateX(-50%);
  }
  #main.price .tabContents .plan .tab-plan li.plan-ladys.cr::after {
    border-top-color: #c26159;
  }
  #main.price .tabContents .plan .tab-plan li.plan0.cr::after {
    border-top-color: #ba3a27;
  }
  #main.price .tabContents .plan .tab-plan li.plan1.cr::after {
    border-top-color: #b99c2d;
  }
  #main.price .tabContents .plan .tab-plan li.plan2.cr::after {
    border-top-color: #a07a13;
  }
  #main.price .tabContents .plan .tab-plan li.plan3.cr::after {
    border-top-color: #ef784e;
  }
  #main.price .tabContents .plan .tab-plan li.plan_choosable.cr::after {
    border-top-color: #267059;
  }

  #main.price .tabContents .plan .plans {
    margin: 0 0 5vw;
  }
  #main.price .tabContents .plan .plans > li {
    padding: 0 0 5vw 0;
  }
  #main.price .tabContents .plan .plans > li + li {
    margin-top: 0;
    margin-left: 0 !important;
  }
  #main.price .tabContents .plan .plans > li h3 {
    font-size: 6vw;
    width: 100%;
    padding: 12px 0 10px;
  }
  #main.price .tabContents .plan .plans > li h3 span {
  }
  #main.price .tabContents .plan .plans > li.plan3 h3 {
    text-align: left;
    padding-left: 5vw;
  }
  #main.price .tabContents .plan .plans > li.plan3 h3::after {
    width: 38vw;
    height: calc(38vw / 300 * 116);
    top: -2vw;
    left: 50vw;
  }
  #main.price .tabContents .plan .plans > li > div {
    padding: 3vw;
    display: block;
  }
  #main.price .tabContents .plan .plans > li > div .left {
    width: 100%;
  }
  #main.price .tabContents .plan .plans > li > div .right {
    width: 100%;
    padding: 5vw 0 3vw;
  }
  #main.price .tabContents .plan .plans > li > div .left > ul {
    display: block;
  }
  #main.price .tabContents .plan .plans > li > div .left > ul > li {
    width: 100%;
    margin: 0 0 5px;
    padding: 4vw;
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  #main.price .tabContents .plan .plans > li > div .left > ul > li + li {
    margin-left: 0 !important;
  }
  #main.price .tabContents .plan .plans > li.plan_choosable > div .left > ul > li:last-child {
    flex-direction: column;
  }
  #main.price .tabContents .plan .plans > li > div .left > ul > li:last-nth-child(1),
  #main.price .tabContents .plan .plans > li > div .left > ul > li:last-nth-child(2) {
    margin-bottom: 5px;
  }
  #main.price .tabContents .plan .plans > li > div .left > ul > li h4 {
    font-size: 4vw;
    width: 32vw;
  }
  #main.price .tabContents .plan .plans > li.plan_choosable > div .left > ul > li:last-child h4 {
    width: 100%;
  }
  #main.price .tabContents .plan .plans > li > div .left > ul > li > div {
    width: calc(100% - 35vw);
  }
  #main.price .tabContents .plan .plans > li.plan_choosable > div .left > ul > li:last-child > div {
    width: 100%;
  }
  #main.price .tabContents .plan .plans > li > div .left > ul > li .price,
  #main.price .tabContents .plan .plans > li.plan_choosable > div .left > ul > li .price {
    font-size: 5vw;
  }
  #main.price .tabContents .plan .plans > li > div .left > ul > li .price span {
    font-size: 175%;
  }
  #main.price .tabContents .plan .plans > li > div .left > ul > li .price.red span {
  }
  #main.price .tabContents .plan .plans > li > div .left > ul > li .alert1 {
    font-size: 12px;
  }
  #main.price .tabContents .plan .plans > li > div .left > ul > li .alert2 {
    font-size: 14px;
    padding: 5px 0;
  }
  #main.price .tabContents .plan .plans > li > div .left > ul > li > div .link {
    font-size: 14px;
  }
  #main.price .tabContents .plan .plans > li > div .right > ul {
  }
  #main.price .tabContents .plan .plans > li > div .right > ul > li {
    width: 30%;
    margin: 0 0 5px;
  }
  #main.price .tabContents .plan .plans > li > div .right > ul > li figure {
    width: 90%;
  }
  #main.price .tabContents .plan .plans > li > div .right > ul > li figure img {
    width: 100%;
  }
  #main.price .tabContents .plan .plans > li > div .right > ul > li p {
    font-size: 3vw;
    line-height: 1.17;
  }

  #main.price .tabContents .plan .columnBox {
    border: solid 2px #d5d5d5;
    padding: 5vw;
  }
  #main.price .tabContents .plan .columnBox h5 {
    font-size: 14px;
    margin: 5vw 0 15px;
    text-indent: -1em;
    padding-left: 1em;
  }
  #main.price .tabContents .plan .columnBox p,
  #main.price .tabContents .plan .columnBox li {
    font-size: 12px;
  }
  #main.price .tabContents .plan .columnBox .set {
    font-size: 12px;
  }
  #main.price .tabContents .plan .columnBox ul.set {
    font-size: 12px;
  }
  #main.price .tabContents .plan .columnBox ul.set li {
  }
  #main.price .tabContents .plan .columnBox ul.set li + li {
    margin-left: 0 !important;
  }

  #main.price #links {
    height: auto;
    background: url(images/price/links_p_01_sp.jpg) no-repeat center center;
    background-size: 100vw auto;
    margin-top: 8vw;
    padding: 18vw 0;
  }
  #main.price #links .subContents {
    text-align: center;
  }

  #main.price #links ul {
    width: auto;
    margin: 0 auto;
    position: static;
    transform: none;
    display: block;
  }
  #main.price #links ul li {
    width: 70vw;
    margin: 0 auto 8vw;
  }
  #main.price #links ul li + li {
    margin-left: 0 !important;
    margin-bottom: 0;
  }

  #main.price #links ul li a {
    font-size: 4vw;
    line-height: 1;
    background: #fff;
    padding: 20px 0;
    display: block;
    position: relative;
    transition: none;
  }

  #main.price #links ul li a::before {
    height: 36px;
    top: 10px;
    left: 20px;
  }
  #main.price #links ul li.nyukai a::before {
    width: 37px;
  }
  #main.price #links ul li.katsudo a::before {
    width: 28px;
  }

  #main.price #links ul li a::after {
    right: 20px;
  }
  #main.price #links ul li a:hover {
    color: #bb2121;
    background-color: #fff;
  }
  #main.price #links ul li a:hover::after {
    border-color: #bb2121;
  }

  #main.price #links ul li.nyukai a:hover::before {
    background-image: url(images/price/links_s_nyukaiflow.png);
  }
  #main.price #links ul li.katsudo a:hover::before {
    background-image: url(images/price/links_s_katsudoflow.png);
  }

  /*テーブルデザイン*/
  #main.price .priceTable.pc {
    display: none;
  }
  #main.price .priceTable.sp {
    display: block;
  }
  #main.price .priceTable {
    font-size: 3.7vw;
    margin: 0 0 4vw;
  }
  #main.price .priceTable tr td:not(:first-child) {
    width: 20vw;
  }
  #main.price .priceTable tr td:first-child {
    width: 12vw;
  }
  /*プラン名*/
  #main.price .priceTable tr:first-child td {
    padding: 2.5vw 0;
    font-size: 3.5vw;
  }
  #main.price .priceTable tr:first-child td span {
    font-size: 3vw;
  }
  #main.price .priceTable tr:first-child td:nth-child(2) .catch {
    position: absolute;
  }
  #main.price .priceTable tr:first-child td:nth-child(5) {
    background: #267059;
  }
  /*項目名*/
  #main.price .priceTable tr:not(:first-child) td:first-child {
   font-size: 3vw;
  }
  #main.price .priceTable tr:not(:first-child) td.small {
   font-size: 2.6vw;
  }
  #main.price .priceTable tr:not(:first-child) td:first-child span {
    font-size: 2vw;
  }

  #main.price .priceTable tr:first-child td:nth-child(2) .catch {
    font-size: 3vw;
    width: 33vw;
    padding: 1.5vw 0;
    top: -15.5vw;
    border: .8vw solid #ba3a27;
    border-radius: 15px;
  }
  #main.price .priceTable tr:first-child td:nth-child(2) .catch::before {
    top: 11.5vw;
    border: 2vw solid transparent;
    border-left: 4.5vw solid #fffbd6;
  }
  #main.price .priceTable tr:first-child td:nth-child(2) .catch::after {
    top: 12.6vw;
    border: 2.2vw solid transparent;
    border-left: 4.5vw solid #ba3a27;
  }

  /*入会初期費用*/
  #main.price .priceTable tr:nth-child(2) td {
    padding: 10vw 0;
  }
  /*会員期間・月会費*/
  #main.price .priceTable tr:nth-child(3) td,
  #main.price .priceTable tr:nth-child(4) td {
    padding: 3vw 0;
  }
  #main.price .priceTable tr:nth-child(3) td.left span.num,
  #main.price .priceTable tr:nth-child(5) td.left span.num {
    padding: 0 0 1rem 1rem;
  }

  /*定期紹介・申込数*/
  #main.price .priceTable tr:nth-child(5) td {
    padding: 2vw 0;
  }
  #main.price .priceTable tr:nth-child(5) td:last-child {
    font-size: 3.7vw;
  }
  #main.price .priceTable tr td .plus {
    font-size: 2.5vw;
    width: 16vw;
    margin: 2vw auto 0;
    padding: 2vw 0;
  }
  #main.price .priceTable tr td .plus .big {
    color: #ba3a27;
    font-size: 3vw;
  }
  #main.price .priceTable tr:nth-child(4) td .plus {
    margin: 0 0 0 4vw;
    display: inline-block !important;
  }
  #main.price .priceTable .detailBtn {
    font-size: 3.5vw;
    font-weight: bold;
    width: 17vw;
    padding: 6vw 0;
    transform: none;
  }

  #main.price .note {
    font-size: 2.7vw;
  }

  /*サポート*/
  #main.price .support {
    background: #fcf3f3;
    margin: 0 0 15vw;
    padding: 10vw 0;
    width: calc(100% + 9vw);
    transform: translateX(-4.5vw);
  }
  #main.price .support .red {
    font-size: 6.6vw;
    text-align: center;
    margin: 0 0 8vw;
  }
  #main.price .support ul {
    flex-wrap: wrap;
    row-gap: 4vw;
    column-gap: 2vw;
    justify-content: space-between;
    width: 83vw;
    margin: 0 auto;
  }
  #main.price .support ul li {
    width: 40vw;
    margin: 0!important;
  }
  #main.price .support ul li figure {
    margin: 0 0 2vw;
  }
  #main.price .support ul li p {
    font-size: 4.1vw;
  }
  #main.price .support ul li p span {
    font-size: 2vw;
  }
  #main.price .priceTable .detailBtn span::before {
    bottom: .5vw;
    right: -5.5vw;
    border: 2vw solid transparent;
    border-left: 2.1vw solid #FFF;
  }
}
/* -----------------------------------------------
パーティー・イベントスケジュール
------------------------------------------------- */
#main.event {
  margin-top: 0px;
}
#main.event,
#main.event p {
  color: #222;
  font-size: 15px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: normal;
  line-height: 1.8;
}
#main.event #mainv {
  height: 325px;
  background: url("images/event/mainv_bg_pc.webp") no-repeat 40% center;
  background-size: cover;
  position: relative;
}
#main.event #mainv h1 {
  color: #fff;
  font-size: 46px;
  font-weight: bold;
  white-space: nowrap;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#main.event #maincopy {
  text-align: center;
  margin: 0 0 55px;
  padding: 60px 0 0;
}
#main.event #maincopy h2 {
  color: #b72121;
  font-size: 42px;
  font-weight: bold;
}
#main.event #maincopy .lead {
  font-size: 20px;
  line-height: 1.75;
}
#main.event #mainnav {
  width: 1060px;
  margin: 0 auto 100px;
}
#main.event #mainnav ul {
  margin: 0;
  display: flex;
  justify-content: space-between;
}
#main.event #mainnav ul li {
  width: 330px;
  border-radius: 10px;
}
#main.event #mainnav ul li a {
  width: 100%;
  height: 188px;
  border-radius: 10px;
  display: block;
}
#main.event #mainnav ul li img {
  border-radius: 10px;
  box-shadow: 3px 3px 6px rgba(0, 0, 0, 0.18);
}
#main.event #mainnav ul li:hover img {
  opacity: 0.7;
}
#main.event #events {
  width: 100%;
  margin: 0 auto;
}
#main.event #events .block {
  width: 100%;
  height: 460px;
  margin: 0 auto 68px;
  display: flex;
  align-items: center;
  box-sizing: content-box;
  position: relative;
}
#main.event #events .block figure {
  width: calc(50% - 50px);
  height: 460px;
  position: absolute;
}
#main.event #events .block figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 50%;
}
#main.event #events .block .inner {
  width: 1160px;
  margin: 0 auto;
}
#main.event #events .block .text {
  width: 600px;
}
#main.event #events .block .text .h-type1 {
  color: #b48c2d;
  font-size: 34px;
  font-weight: bold;
  letter-spacing: 3px;
  margin: 0 0 22px;
}
#main.event #events .block .text p {
  font-size: 18px;
  line-height: 1.8;
  margin: 0 0 50px;
}
#main.event #events .block .text .schdBtn {
  width: 434px;
  margin: 0 auto;
}
#main.event #events .block .text .schdBtn a {
  color: #fff;
  font-size: 22px;
  font-weight: bold;
  width: 100%;
  text-align: center;
  letter-spacing: 1.5px;
  background: #c18812;
  border-radius: 8px;
  box-shadow: 0px 5px 1px -1px #a26f13;
  padding: 28px 0;
  display: inline-block;
  position: relative;
}
#main.event #events .block .text .schdBtn a:hover {
  opacity: 0.7;
}
#main.event #events .block .text .schdBtn a:active {
  transform: translateY(5px);
  box-shadow: none;
}
#main.event #events .block .text .schdBtn a::before {
  content: "";
  width: 14px;
  height: 14px;
  border-left: solid 3px #fff;
  border-top: solid 3px #fff;
  transform: rotate(135deg) translateY(-50%);
  position: absolute;
  top: 40%;
  right: 35px;
}
#main.event #events div.even {
  flex-direction: row-reverse;
}
#main.event #events div.even .text {
  width: 580px;
  margin: 0 0 0 auto;
}
#main.event #events div.even figure {
  right: calc(50% + 50px);
  top: 0;
}
#main.event #events div.odd {
  justify-content: flex-start;
}
#main.event #events div.odd figure {
  left: calc(50% + 50px);
  top: 0;
}
#main.event #areaLinks {
  width: 1160px;
  margin: 0 auto 100px;
}
#main.event #areaLinks ul {
  display: flex;
  justify-content: space-between;
}
#main.event #areaLinks ul li figure {
  width: 376px;
  position: relative;
  border-radius: 10px;
  box-shadow: 4px 4px 6px rgba(0, 0, 0, 0.18);
}
#main.event #areaLinks ul li figure:hover {
  opacity: 0.7;
}
#main.event #areaLinks ul li figure img {
  width: 100%;
}
#main.event #areaLinks ul li figure figcaption {
  color: #fff;
  font-size: 22px;
  font-weight: bold;
  width: 100%;
  background: rgba(68, 68, 68, 0.6);
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
  box-sizing: border-box;
  padding: 25px 30px;
  position: absolute;
  bottom: 0;
  left: 0;
}
#main.event #areaLinks ul li figure figcaption::before {
  content: "";
  width: 14px;
  height: 14px;
  border-left: solid 3px #fff;
  border-top: solid 3px #fff;
  transform: rotate(135deg) translateY(-50%);
  position: absolute;
  top: 39%;
  right: 40px;
}
#main.event #generalLinks {
  background: #f1f1f1;
  text-align: center;
  padding: 68px 0;
}
#main.event #generalLinks .h-type2 {
  color: #b48c2d;
  font-size: 30px;
  font-weight: bold;
  letter-spacing: 2.5px;
  margin: 0 0 95px;
  position: relative;
}
#main.event #generalLinks .h-type2::before {
  content: "";
  width: 0px;
  height: 0px;
  border-right: solid 36px transparent;
  border-top: solid 27px #cfb573;
  border-left: solid 36px transparent;
  transform: translateX(-50%);
  position: absolute;
  bottom: -55px;
  left: 50%;
}
#main.event #generalLinks .h-type2::after {
  content: "";
  width: 0px;
  height: 0px;
  border-right: solid 36px transparent;
  border-top: solid 14px #f1f1f1;
  border-left: solid 36px transparent;
  transform: translateX(-50%);
  position: absolute;
  bottom: -42px;
  left: 50%;
}
#main.event #generalLinks ul {
  width: 945px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
#main.event #generalLinks ul li {
  position: relative;
}
#main.event #generalLinks ul li a:hover {
  opacity: 0.7;
}
#main.event #generalLinks ul li a {
  display: block;
}
#main.event #generalLinks ul li figure {
  width: 450px;
  border-radius: 10px;
}
#main.event #generalLinks ul li figure img {
  width: 100%;
}
#main.event #generalLinks ul li .inner {
  padding-bottom: 30px;
  position: absolute;
  top: 42%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#main.event #generalLinks ul li .inner::after {
  content: "";
  width: 15px;
  height: 15px;
  border-right: solid 3px #fff;
  border-top: solid 3px #fff;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: rotate(45deg) translateX(-50%);
}
#main.event #generalLinks ul li .inner p {
  color: #fff;
  text-align: center;
}
#main.event #generalLinks ul li .inner .label {
  font-size: 13px;
  font-weight: normal;
  border: solid 1px #fff;
  border-radius: 30px;
  padding: 1px 15px;
  margin: 0 0 10px;
  display: inline-block;
}
#main.event #generalLinks ul li .inner .txt {
  font-size: 22px;
  font-weight: bold;
  white-space: nowrap;
}
#main.event #generalLinks ul li .inner .txt span {
  color: #fff;
}
#main.event #generalLinks ul li .note {
  font-size: 15px;
  font-feature-settings: "palt";
  letter-spacing: 0.04em;
  text-indent: -0.04em;
  margin-top: 10px;
}
#main.event #generalLinks ul li:hover .note {
  opacity: 1;
}
@media (max-width: 1160px) {
  #main.event #events .block {
    width: 1160px;
  }
}
@media (max-width: 768px) {
  #main.event {
    margin: 0;
    padding: 0 4.5vw;
  }
  #main.event,
  #main.event p {
    font-size: 15px;
  }
  #main.event #mainv {
    width: 100vw;
    height: 44vw;
    background-size: auto 44vw;
    margin: 0 calc(50% - 50vw) 0;
  }
  #main.event #mainv h1 {
    font-size: 7vw;
    width: 100%;
    text-align: center;
  }
  #main.event #maincopy {
    margin: 0 0 12vw;
    padding: 10.4vw 0 0;
  }
  #main.event #maincopy h2 {
    font-size: 7vw;
  }
  #main.event #maincopy .lead {
    font-size: 4vw;
    text-align: center;
    line-height: 1.8;
    font-feature-settings: "palt";
  }
  #main.event #mainnav {
    width: 100vw;
    margin: 0 calc(50% - 50vw) 16vw;
  }
  #main.event #mainnav ul {
    margin: 0;
    display: flex;
    justify-content: flex-start;
  }
  #main.event #mainnav ul li {
    height: 40vw;
    border-radius: 0;
  }
  #main.event #mainnav ul li:nth-child(1) {
    width: 36%;
    clip-path: polygon(0 0, 100% 0, 88% 100%, 0% 100%);
  }
  #main.event #mainnav ul li:nth-child(2) {
    width: 38%;
    margin-left: -4.2%;
    clip-path: polygon(11% 0, 100% 0, 89% 100%, 0% 100%);
  }
  #main.event #mainnav ul li:nth-child(3) {
    width: 36%;
    margin-left: -4.2%;
    clip-path: polygon(12% 0, 100% 0, 100% 100%, 0% 100%);
  }
  #main.event #mainnav ul li a {
    height: auto;
    border-radius: 0;
  }
  #main.event #mainnav ul li img {
    width: 100%;
    height: 40vw;
    border-radius: 0;
    box-shadow: none;
  }
  #main.event #events {
    width: 100%;
    margin: 0;
  }
  #main.event #events .block {
    width: 100%;
    height: auto;
    margin: 0 auto 16.6vw;
    display: block;
  }
  #main.event #events #block1 {
    margin: 0 0 6.2vw;
  }
  #main.event #events .block figure img {
  }
  #main.event #events .block .inner {
    width: 100%;
    margin: 0;
  }
  #main.event #events .block .text {
    width: 100%;
  }
  #main.event #events .block .text .h-type1 {
    font-size: 5.8vw;
    width: 100vw;
    background: linear-gradient(100deg, rgba(180, 140, 45, 0.1) 0%, rgba(180, 140, 45, 0.1) 85%, rgba(180, 140, 45, 0.2) 85%, rgba(180, 140, 45, 0.2) 100%);
    letter-spacing: 2px;
    margin: 0 calc(50% - 50vw) 4vw;
    padding: 2.6vw 4.5vw;
  }
  #main.event #events .block p {
    font-size: 4vw;
    line-height: 2;
    margin: 0 0 6.6vw;
  }
  #main.event #events .block .schdBtn {
    width: 100%;
    margin: 0;
  }
  #main.event #events .block .schdBtn a {
    color: #fff;
    font-size: 4vw;
    font-weight: bold;
    width: 100%;
    text-align: center;
    background: #c18812;
    letter-spacing: 1.5px;
    border-radius: 5px;
    box-shadow: 0px 5px 1px -1px #a26f13;
    padding: 4.6vw 0;
    display: inline-block;
    position: relative;
  }
  #main.event #events .block .schdBtn a:hover {
    opacity: none;
  }
  #main.event #events .block .schdBtn a:active {
    transform: translateY(5px);
    box-shadow: none;
  }
  #main.event #events .block .schdBtn a::before {
    content: "";
    width: 8px;
    height: 8px;
    transform: rotate(135deg) translateY(-50%);
    border-left: solid 2px #fff;
    border-top: solid 2px #fff;
    position: absolute;
    top: 40%;
    right: 25px;
  }
  #main.event #events div.even {
    padding-right: 0;
  }
  #main.event #events div.even .text {
    width: 100%;
    margin: 0 0 0 auto;
  }
  #main.event #events div.odd {
    padding-right: 0;
  }
  #main.event #events .block figure {
    width: 100%;
    height: auto;
    margin: 0 0 3vw;
    position: static;
  }
  #main.event #areaLinks {
    width: 100%;
    margin: 0 auto 15vw;
  }
  #main.event #areaLinks ul {
    display: block;
  }
  #main.event #areaLinks ul li:not(:last-child) {
    margin: 0 0 6.6vw;
  }
  #main.event #areaLinks ul li figure {
    width: 100%;
    border-radius: 5px;
  }
  #main.event #areaLinks ul li figure:hover {
  }
  #main.event #areaLinks ul li figure img {
  }
  #main.event #areaLinks ul li figure figcaption {
    font-size: 4vw;
    padding: 2.6vw 18.4vw;
  }
  #main.event #areaLinks ul li figure figcaption::before {
    width: 8px;
    height: 8px;
    border-left: solid 2px #fff;
    border-top: solid 2px #fff;
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
    position: absolute;
    top: 39%;
    right: 20px;
  }
  #main.event #generalLinks {
    width: 100vw;
    text-align: center;
    margin: 0 calc(50% - 50vw);
    padding: 14vw 4.5vw;
  }
  #main.event #generalLinks .h-type2 {
    font-size: 5.3vw;
    margin: 0 0 21.6vw;
  }
  #main.event #generalLinks .h-type2::before {
    border-right: solid 25px transparent;
    border-top: solid 19px #cfb573;
    border-left: solid 25px transparent;
    bottom: -42px;
    left: 50%;
  }
  #main.event #generalLinks .h-type2::after {
    border-right: solid 25px transparent;
    border-top: solid 9px #f1f1f1;
    border-left: solid 25px transparent;
    bottom: -32px;
    left: 50%;
  }
  #main.event #generalLinks ul {
    width: 100%;
    margin: 0;
  }
  #main.event #generalLinks ul li {
    width: 42.6vw;
  }
  #main.event #generalLinks ul li:hover {
  }
  #main.event #generalLinks ul li a {
  }
  #main.event #generalLinks ul li figure {
    width: 100%;
    border-radius: 5px;
  }
  #main.event #areaLinks ul li figure:hover {
  }
  #main.event #generalLinks ul li figure img {
  }
  #main.event #generalLinks ul li .inner {
    padding-bottom: 5.7vw;
    top: 35%;
  }
  #main.event #generalLinks ul li .inner::after {
    width: 10px;
    height: 10px;
    border-right: solid 2px #fff;
    border-top: solid 2px #fff;
  }
  #main.event #generalLinks ul li .inner p {
  }
  #main.event #generalLinks ul li .inner .label {
    font-size: 3.2vw;
    margin: 0 0 3.2vw;
  }
  #main.event #generalLinks ul li .inner .txt {
    font-size: 3.2vw;
  }
  #main.event #generalLinks ul li .inner .txt span {
    color: #fff;
    font-size: 4vw;
  }
  #main.event #generalLinks ul li .note {
    font-size: 3.2vw;
    margin-top: 2vw;
  }
  #main.event #generalLinks ul li:hover .note {
    opacity: none;
  }
}

main.info_archive {
}

main.info_archive #mainv,
main.info_single #mainv {
  height: 320px;
  text-align: center;
  background: url(images/info/mainv_bg_pc.jpg) #efece7 no-repeat center center;
  background-size: cover;
  position: relative;
}
main.info_archive #mainv h1,
main.info_single #mainv h1 {
  color: #fff;
  font-size: 44px;
  font-weight: bold;
  letter-spacing: 2.5px;
  text-shadow: 0px 0px 20px rgba(94, 74, 62, 1);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

main.info_archive #news_list {
  margin: 100px 70px 0;
}

main.info_archive #news_list .n_list {
  border-top: 1px solid #c8c8c8;
}

main.info_archive #news_list .n_list li {
}

main.info_archive #news_list .n_list li a {
  font-size: 18px;
  width: 100%;
  min-height: 100px;
  border-bottom: 1px solid #c8c8c8;
  padding: 15px 25px 15px 15px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  position: relative;
}

main.info_archive #news_list .n_list li a:hover {
  background: #fafafa;
}

main.info_archive #news_list .n_list li a::after {
  content: "";
  width: 10px;
  height: 10px;
  border-top: 2px solid #b2b2b2;
  border-right: 2px solid #b2b2b2;
  display: inline-block;
  transform: rotate(45deg);
  margin-left: auto;
  flex-shrink: 0;
}

main.info_archive #news_list .n_list li a:hover::after {
  border-color: #c90021;
}

main.info_archive #news_list .n_list li a span {
  color: #a0a0a0;
  font-size: 14px;
  margin: 0 40px 0 0;
  flex-shrink: 0;
}

main.info_archive .webma_pager {
  text-align: center;
}

@media (max-width: 768px) {
  main.info_archive {
  }

  main.info_archive #mainv,
  main.info_single #mainv {
    height: 40vw;
    background-image: url(images/info/mainv_bg_sp.jpg);
    background-size: 100% auto;
  }
  main.info_archive #mainv h1,
  main.info_single #mainv h1 {
    width: 100%;
    font-size: 24px;
  }
  main.info_archive #news_list {
    margin: 50px 0 0;
  }

  main.info_archive #news_list .n_list {
  }

  main.info_archive #news_list .n_list li {
  }

  main.info_archive #news_list .n_list li a {
    font-size: 15px;
    min-height: auto;
    padding: 15px 30px 15px 8px;
    display: block;
    position: relative;
  }

  main.info_archive #news_list .n_list li a:hover {
  }

  main.info_archive #news_list .n_list li a::after {
    width: 8px;
    height: 8px;
    border-top: 1px solid #b2b2b2;
    border-right: 1px solid #b2b2b2;
    position: absolute;
    top: 50%;
    right: 15px;
    transform: translateY(-50%) rotate(45deg);
  }

  main.info_archive #news_list .n_list li a:hover::after {
  }

  main.info_archive #news_list .n_list li a span {
    font-size: 12px;
    margin: 0 0 5px;
    display: block;
  }
}

main.media_archive {
}

main.media_archive #mainv,
main.media_single #mainv {
  height: 320px;
  text-align: center;
  background: url(images/media/mainv_bg_pc.jpg) #efece7 no-repeat center center;
  background-size: cover;
  position: relative;
}
main.media_archive #mainv h1,
main.media_single #mainv h1 {
  color: #fff;
  font-size: 44px;
  font-weight: bold;
  letter-spacing: 2.5px;
  text-shadow: 0px 0px 20px rgba(94, 74, 62, 1);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

main.media_archive #media_list {
  margin: 75px 70px 0;
}

main.media_archive #media_list .htype_year {
  color: #c90021;
  font-size: 26px;
  font-weight: bold;
  border-bottom: 1px solid #c90021;
  padding: 0.4em 0;
}

main.media_archive #media_list .n_list + .htype_year {
  margin: 55px 0 0;
}

main.media_archive #media_list .n_list {
  border-top: 1px solid #c8c8c8;
}

main.media_archive #media_list .n_list li {
}

main.media_archive #media_list .n_list li a {
  font-size: 18px;
  width: 100%;
  min-height: 100px;
  border-bottom: 1px solid #c8c8c8;
  padding: 15px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  position: relative;
}

main.media_archive #media_list .n_list li a:hover {
  background: #fafafa;
}

main.media_archive #media_list .n_list li a::after {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 2px solid #b2b2b2;
  border-right: 2px solid #b2b2b2;
  display: inline-block;
  transform: rotate(45deg);
  margin-left: auto;
  flex-shrink: 0;
}

main.media_archive #media_list .n_list li a:hover::after {
  border-color: #c90021;
}

main.media_archive #media_list .n_list li a span {
  color: #a0a0a0;
  font-size: 14px;
  font-weight: bold;
  margin: 0 30px 0 0;
  flex-shrink: 0;
}

main.media_archive #media_list .n_list li a i {
  color: #fff;
  font-feature-settings: "palt";
  font-size: 12px;
  font-style: normal;
  font-weight: bold;
  text-align: center;
  min-width: 115px;
  background: #c90021;
  display: inline-block;
  margin-right: 20px;
  padding: 3px 10px;
}

main.media_archive #media_list .n_list li a i.tv {
  background: #389bbc;
}
main.media_archive #media_list .n_list li a i.paper {
  background: #449576;
}
main.media_archive #media_list .n_list li a i.radio {
  background: #ff6d46;
}

@media (max-width: 768px) {
  main.media_archive {
  }

  main.media_archive #mainv,
  main.media_single #mainv {
    height: 40vw;
    background-image: url(images/media/mainv_bg_sp.jpg);
    background-size: 100% auto;
  }
  main.media_archive #mainv h1,
  main.media_single #mainv h1 {
    width: 100%;
    font-size: 26px;
  }
  main.media_archive #media_list {
    margin: 35px 0 0;
  }

  main.media_archive #media_list .htype_year {
    font-size: 22px;
  }

  main.media_archive #media_list .n_list + .htype_year {
    margin: 50px 0 0;
  }

  main.media_archive #media_list .n_list {
  }

  main.media_archive #media_list .n_list li {
  }

  main.media_archive #media_list .n_list li a {
    font-size: 15px;
    width: 100%;
    min-height: auto;
    padding: 8px 55px 15px 10px;
    display: block;
    position: relative;
  }

  main.media_archive #media_list .n_list li a::after {
    width: 8px;
    height: 8px;
    border-top: 2px solid #b2b2b2;
    border-right: 2px solid #b2b2b2;
    position: absolute;
    top: 50%;
    right: 15px;
  }

  main.media_archive #media_list .n_list li a:hover::after {
  }

  main.media_archive #media_list .n_list li a span {
    font-size: 12px;
    margin: 0 8px 0 0;
  }

  main.media_archive #media_list .n_list li a i {
    font-size: 12px;
    min-width: 105px;
    margin-right: auto;
    margin-bottom: 3px;
    padding: 3px 10px;
  }

  main.media_archive #media_list .n_list li a i.tv {
  }
  main.media_archive #media_list .n_list li a i.paper {
  }
}

/* -----------------------------------------------
 店舗一覧
------------------------------------------------- */
.s-fixed {
  width: 100%;
  height: 100%;
  position: fixed;
  overflow: scroll;
}

#main.salon {
  font-size: 18px;
  line-height: 1.33;
  margin: 0;
}

#main.salon p {
  font-family: "Helvetica Neue", Arial, "Hiragino Sans", "Hiragino Kaku Gothic ProN", "BIZ UDPGothic", Meiryo, sans-serif;
}

#main.salon ul {
  margin: 0;
}

#main.salon h2 {
  font-size: 46px;
  font-weight: 700;
  text-align: center;
  background: #fff8f8;
  margin: 0 0 50px;
  padding: 75px 0;
}

#main.salon .map {
  margin: 0 0 100px;
}

#main.salon .map .inner {
  width: fit-content;
  -moz-width: fit-content;
  margin: 0 auto;
  position: relative;
}

#main.salon .map picture {
  text-align: center;
  display: block;
}

#main.salon .map ul li {
  position: absolute;
}

#main.salon .map ul li.shinjuku {
  right: -125px;
  bottom: 139px;
}
#main.salon .map ul li.yokohama {
  right: -91px;
  bottom: 88px;
}
#main.salon .map ul li.st-shiga {
  top: 120px;
  left: 27px;
}
#main.salon .map ul li.st-kyoto {
  top: 163px;
  left: 27px;
}
#main.salon .map ul li.shinsaibashi {
  right: 65px;
  bottom: 23px;
}
#main.salon .map ul li.st-umeda {
  right: 50px;
  bottom: -10px;
}
#main.salon .map ul li.st-kobe {
  top: 205px;
  left: 27px;
}

#main.salon .map ul li a {
  font-size: 17px;
  font-weight: 700;
}

#main.salon .map ul li a[href^="#st-"] {
  font-size: 15px;
  font-weight: 400;
}
@media (hover: hover) {
  #main.salon .map ul li a:hover {
    color: #c90021;
    text-decoration: underline;
  }
}

#main.salon .office {
  width: 1000px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  column-gap: 60px;
}

#main.salon .office .honsha {
  width: 100%;
}

#main.salon .office .satellite {
  width: calc(50% - 30px);
}

#main.salon .office section:not(:last-child) {
  margin: 0 0 100px;
}

#main.salon .office h3 {
  font-size: 30px;
  border-bottom: 2px solid #ccc;
  padding: 0 0 15px;
  margin: 0 0 20px;
  position: relative;
}

#main.salon .office h3::before {
  content: "";
  width: 200px;
  height: 2px;
  background: #cc3737;
  position: absolute;
  left: 0;
  bottom: -2px;
}

#main.salon .office h3 span.caution {
  color: #ff0000;
  font-size: 13px;
  vertical-align: middle;
  background: #fbf1f3;
  border-radius: 5px;
  margin: 0 0 5px 18px;
  padding: 5px 8px;
  display: inline-block;
}

#main.salon .office h3 span.caution::before {
  content: "\0021";
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  text-align: center;
  line-height: 11px;
  vertical-align: baseline;
  width: 15px;
  height: 15px;
  background: #ff0000;
  border-radius: 50%;
  margin: 0 0.5em 0 0;
  padding: 3px;
  display: inline-block;
}

#main.salon .office .mapBlock {
  margin: 0 0 30px;
  display: flex;
  column-gap: 28px;
}

#main.salon .office .mapBlock iframe {
  width: 700px;
}

#main.salon .office .mapBlock ul.images {
  width: 272px;
}

#main.salon .office .mapBlock .images li {
  min-height: 172px;
  position: relative;
}

#main.salon .office .mapBlock .images li:not(:last-child) {
  margin: 0 0 26px;
}

#main.salon .office .mapBlock .images li figure img {
  width: 272px;
  height: 172px;
  object-fit: cover;
  object-position: 0 10%;
}

#main.salon .office .mapBlock .images li .open {
  width: 31px;
  height: 31px;
  position: absolute;
  right: 10px;
  bottom: 10px;
  cursor: pointer;
}
/*画像モーダル*/
#main.salon .modal {
  width: 100%;
  height: 100vh;
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 601;
}

#main.salon .modal-bg {
  width: 100%;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.7);
  position: absolute;
  z-index: 101;
}

#main.salon .modal-content {
  width: fit-content;
  -mox-width: fit-content;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 102;
}

@media screen and (max-width: 640px) {
  #main.salon .modal-content {
    width: 80vw;
  }
}

#main.salon .modal-inner {
  width: 100%;
  position: relative;
}

#main.salon .btn_close {
  color: #fff;
  font-size: 15px;
  text-decoration: none;
  display: block;
  position: absolute;
  top: -30px;
  right: 0;
  z-index: 601;
  cursor: pointer;
}

#main.salon .btn_close span {
  color: #fff;
  font-size: 25px;
  vertical-align: middle;
}

#main.salon .office .infoBlock {
  display: flex;
  column-gap: 60px;
}

#main.salon .office .infoBlock dl {
  width: 100%;
  min-width: calc(50% - 30px);
}

#main.salon .office .infoBlock dl > div {
  border-bottom: solid 1px #e5e5e5;
  padding: 22px 0 18px;
  display: flex;
  align-items: center;
}

#main.salon .office .infoBlock dl > div:first-child {
  border-top: solid 1px #e5e5e5;
}

#main.salon .office .satellite .infoBlock dl > div:first-child {
  border-top: none;
  padding: 0 0 18px;
}

#main.salon .office .infoBlock dl > div dt {
  font-size: 13px;
  font-weight: 400;
  width: 28%;
}

#main.salon .office .infoBlock dl > div dd {
  font-size: 15px;
  width: 72%;
}

#main.salon .office .infoBlock dl > div dd p {
  font-size: 15px;
  line-height: 1.33;
}

#main.salon .office .infoBlock dl > div dd a[href^="tel:"] {
  pointer-events: none;
  text-decoration: none;
}

#main.salon .office .infoBlock dl > div dd .places li:not(:last-child) {
  margin: 0 0 28px;
}

#main.salon .office .infoBlock dl > div dd .mapLink a {
  color: #006df1;
  font-size: 13px;
  width: 150px;
  border: solid 1px #006df1;
  border-radius: 5px;
  background: linear-gradient(0deg, rgba(220, 220, 220, 1) 0%, rgba(223, 223, 223, 1) 1.89%, rgba(241, 241, 241, 1) 16.33%, rgba(252, 252, 252, 1) 31.63%, rgba(255, 255, 255, 1) 49.11%);
  padding: 4px 8px 2px 11px;
  display: block;
  position: relative;
}

#main.salon .office .infoBlock dl > div dd .mapLink a::before {
  content: "";
  vertical-align: text-top;
  width: 10px;
  height: 13px;
  background: url("./images/salon/s_map.svg") no-repeat;
  margin: 0 5px 0 0;
  display: inline-block;
}

#main.salon .office .infoBlock dl > div dd .access li {
  padding-left: 0.9em;
  text-indent: -0.9em;
  font-feature-settings: "palt";
}

#main.salon .office .infoBlock dl > div dd .access li::before {
  content: "";
  vertical-align: middle;
  width: 0.6em;
  height: 0.6em;
  background: #000;
  border-radius: 50%;
  margin: 0 0.3em 0.2em 0;
  display: inline-block;
}

#main.salon .office .infoBlock dl > div dd .caution {
  color: #ff0000;
  font-size: 13px;
  text-align: center;
  vertical-align: middle;
  background: #fbf1f3;
  border-radius: 5px;
  margin: 0 0 15px;
  padding: 5px 8px;
}

#main.salon .office .infoBlock dl > div dd .caution::before {
  content: "\0021";
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  text-align: center;
  line-height: 11px;
  vertical-align: baseline;
  width: 15px;
  height: 15px;
  background: #ff0000;
  border-radius: 50%;
  margin: 0 0.5em 0 0;
  padding: 3px;
  display: inline-block;
}

@media (max-width: 768px) {
  .s-fixed {
    width: 100%;
    height: 100%;
    position: fixed;
    overflow: scroll;
  }

  #main.salon {
    font-size: 13px;
    line-height: 1.53;
  }

  #main.salon p {
    font-family: "Helvetica Neue", Arial, "Hiragino Sans", "Hiragino Kaku Gothic ProN", "BIZ UDPGothic", Meiryo, sans-serif;
  }

  #main.salon ul {
  }

  #main.salon h2 {
    font-size: 6.9vw;
    margin: 0 0 8.8vw;
    padding: 16vw 0;
  }

  #main.salon .map {
    margin: 0 0 15vw;
    padding: 0 4.5vw;
  }

  #main.salon .map .inner {
  }

  #main.salon .map picture {
    width: 80.2vw;
  }

  #main.salon .map picture img {
    width: 100%;
    height: auto;
  }

  #main.salon .map ul li {
  }

  #main.salon .map ul li.shinjuku {
    right: 14vw;
    bottom: 5.8vw;
  }
  #main.salon .map ul li.yokohama {
    right: 14vw;
    bottom: -2.4vw;
  }
  #main.salon .map ul li.st-shiga {
    top: 9.2vw;
    left: -2vw;
  }
  #main.salon .map ul li.st-kyoto {
    top: 18.5vw;
    left: -2vw;
  }
  #main.salon .map ul li.shinsaibashi {
    left: 8.2vw;
    right: inherit;
    bottom: 5.5vw;
  }
  #main.salon .map ul li.st-umeda {
    left: 1.5vw;
    right: inherit;
    bottom: -2.5vw;
  }
  #main.salon .map ul li.st-kobe {
    top: 27vw;
    left: -2vw;
  }

  #main.salon .map ul li a {
    font-size: 3.4vw;
  }

  #main.salon .map ul li a[href^="#st-"] {
    font-size: 3.4vw;
  }

  @media (hover: hover) {
    #main.salon .map ul li a:hover {
    }
  }

  #main.salon .office {
    width: 100%;
    margin: 0;
    padding: 0 4.5vw;
  }

  #main.salon .office .honsha {
    width: 100%;
  }

  #main.salon .office .satellite {
    width: 100%;
  }

  #main.salon .office section:not(:last-child) {
    margin: 0 0 16vw;
  }

  #main.salon .office h3 {
    font-size: 4.5vw;
    border-bottom: 0.26vw solid #ccc;
    padding: 0 0 1.6vw;
    margin: 0 0 5.6vw;
  }

  #main.salon .office h3::before {
    width: 40vw;
    height: 0.26vw;
    bottom: -0.26vw;
  }

  #main.salon .office h3 span.caution {
    font-size: 3vw;
    border-radius: 0.6vw;
    margin: 0 0 0.3em 2vw;
    padding: 1vw 2.2vw;
  }

  #main.salon .office h3 span.caution::before {
    font-size: 3.2vw;
    line-height: 3.2vw;
    width: 4vw;
    height: 4vw;
    margin: 0 0.5em 0 0;
  }

  #main.salon .office .mapBlock {
    margin: 0 0 6.6vw;
    display: block;
    column-gap: 0;
  }

  #main.salon .office .mapBlock iframe {
    width: 100%;
    height: 53.3vw;
  }

  #main.salon .office .mapBlock ul.images {
    width: 100%;
    display: flex;
    column-gap: 2vw;
  }

  #main.salon .office .mapBlock .images li {
    min-height: 0;
  }

  #main.salon .office .mapBlock .images li:not(:last-child) {
    margin: 0;
  }

  #main.salon .office .mapBlock .images li figure img {
    width: 44vw;
    height: 27.8vw;
  }

  #main.salon .office .mapBlock .images li .open {
    width: 5.3vw;
    height: 5.3vw;
    right: 1.3vw;
    bottom: 1.3vw;
    cursor: auto;
  }
  /*画像モーダル*/
  #main.salon .modal {
    width: 100%;
    height: 100vh;
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 601;
  }

  #main.salon .modal-bg {
    width: 100%;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.7);
    position: absolute;
    z-index: 101;
  }

  #main.salon .modal-content {
    width: fit-content;
    -mox-width: fit-content;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 102;
  }

  @media screen and (max-width: 640px) {
    #main.salon .modal-content {
      width: 80vw;
    }
  }

  #main.salon .modal-inner {
    width: 100%;
    position: relative;
  }

  #main.salon .modal-inner img {
    width: 80vw;
    height: auto;
  }

  #main.salon .btn_close {
    font-size: 3.4vw;
    top: -7vw;
    cursor: auto;
  }

  #main.salon .btn_close span {
    font-size: 5.5vw;
  }

  #main.salon .office .infoBlock {
    width: 100%;
    display: block;
    column-gap: 0;
  }

  #main.salon .office .infoBlock dl {
    width: 100%;
    min-width: auto;
    margin: 0;
  }

  #main.salon .office .infoBlock dl > div {
    border-bottom: solid 0.2vw #e5e5e5;
    padding: 4vw 0 3.7vw;
  }

  #main.salon .office .infoBlock dl > div:first-child {
    border-top: solid 0.2vw #e5e5e5;
  }

  #main.salon .office .satellite .infoBlock dl > div:first-child {
    border-top: none;
    padding: 0 0 3.7vw;
  }

  #main.salon .office .infoBlock dl:not(:first-child) > div:first-child {
    border-top: 0;
  }

  #main.salon .office .infoBlock dl > div dt {
    font-size: 3.2vw;
    width: 23%;
  }

  #main.salon .office .infoBlock dl > div dd {
    font-size: 3.4vw;
    width: 77%;
  }

  #main.salon .office .infoBlock dl > div dd p {
    font-size: 3.4vw;
    line-height: 1.53;
  }

  #main.salon .office .infoBlock dl > div dd a[href^="tel:"] {
    pointer-events: auto;
  }

  #main.salon .office .infoBlock dl > div dd .places li:not(:last-child) {
    margin: 0 0 4.4vw;
  }

  #main.salon .office .infoBlock dl > div dd .mapLink a {
    font-size: 3.2vw;
    width: 37.8vw;
    border: solid 0.26vw #006df1;
    border-radius: 1.3vw;
    background: linear-gradient(0deg, rgba(220, 220, 220, 1) 0%, rgba(223, 223, 223, 1) 1.89%, rgba(241, 241, 241, 1) 16.33%, rgba(252, 252, 252, 1) 31.63%, rgba(255, 255, 255, 1) 49.11%);
    padding: 4px 8px 2px 11px;
  }

  #main.salon .office .infoBlock dl > div dd .mapLink a::before {
    width: 2.4vw;
    height: 3.2vw;
    margin: 0 0.5em 0 0;
  }

  #main.salon .office .infoBlock dl > div dd .access li {
    padding-left: 0.9em;
    text-indent: -0.9em;
  }

  #main.salon .office .infoBlock dl > div dd .access li::before {
    width: 0.6em;
    height: 0.6em;
    margin: 0 0.3em 0.2em 0;
  }

  #main.salon .office .infoBlock dl > div dd .caution {
    font-size: 3vw;
    border-radius: 0.6vw;
    margin: 0 0 2.6vw;
    padding: 1vw 2.2vw;
  }

  #main.salon .office .infoBlock dl > div dd .caution::before {
    font-size: 3.2vw;
    line-height: 3.8vw;
    width: 4vw;
    height: 4vw;
    margin: 0 0.5em 0 0;
    padding: 0.4vw 0 0;
  }
}

/* -----------------------------------------------
 会社概要
------------------------------------------------- */

#main.company {
  font-size: 18px;
  line-height: 1.16;
  margin: 96px 0 0;
}

#main.company section {
  width: 1000px;
  margin: 0 auto 160px;
}

#main.company section h2 {
  font-size: 40px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.15em;
  margin: 0 0 63px;
  position: relative;
}

#main.company section h2::before {
  color: #bb2121;
  font-size: 16px;
  font-family: "Cormorant Garamond", serif;
  letter-spacing: 0;
  position: absolute;
  left: 50%;
  bottom: -4px;
  transform: translateX(-50%);
}

#main.company section:first-child h2::before {
  content: "Company";
}

#main.company section:nth-child(2) h2::before {
  content: "Company History";
}

#main.company section h3 {
  color: #bb2121;
  font-size: 22px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.05em;
  background: #ececec;
  padding: 9px 0 6px;
}

#main.company section .corpList dl {
  margin: 0 0 70px;
}

#main.company section .corpList dl:first-child {
  margin: 0 0 46px;
}

#main.company section .corpList dl div {
  border-top: solid 1px #ebebeb;
  border-bottom: solid 1px #ebebeb;
  padding: 28px 0 23px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

#main.company section .corpList dl div dt {
  width: 167px;
}

#main.company section .corpList dl div dd {
  font-feature-settings: "palt";
  width: 833px;
}

#main.company section .corpList dl div dd .slash {
  color: #c8c8c8;
}

#main.company section .historyList dl div {
  padding: 28px 0 23px;
  display: flex;
}

#main.company section .historyList dl div dt {
  color: #bb2121;
  width: 136px;
  padding: 0 0 0 30px;
}

#main.company section .historyList dl div:nth-child(odd) {
  background: #ececec;
}

#main.company section .historyList dl div dd {
  width: 864px;
}

#main.company .slideImage ul li {
  width: 480px !important;
  height: auto;
  position: relative;
}

#main.company .slideImage ul li img {
  width: 480px !important;
}

@media (max-width: 768px) {
  #main.company {
    font-size: 4vw;
    line-height: 1.6;
    margin: 12.8vw 0 0;
  }

  #main.company section {
    width: 100%;
    margin: 0 0 17.3vw;
    padding: 0 4.5vw;
    box-sizing: border-box;
  }

  #main.company section h2 {
    font-size: 6.4vw;
    margin: 0 0 8.8vw;
  }

  #main.company section h2::before {
    font-size: 4.8vw;
    bottom: -2.5vw;
  }

  #main.company section:first-child h2::before {
  }

  #main.company section:nth-child(2) h2::before {
  }

  #main.company section h3 {
    font-size: 4.8vw;
    padding: 0.83vw 0 0.63vw;
  }

  #main.company section .corpList dl {
    margin: 0 0 10.6vw;
  }

  #main.company section .corpList dl:first-child {
    margin: 0 0 9.3vw;
  }

  #main.company section .corpList dl div {
    padding: 6.5vw 0;
  }

  #main.company section .corpList dl div dt {
    width: 34%;
  }

  #main.company section .corpList dl div dd {
    width: 66%;
  }

  #main.company section .historyList dl div {
    padding: 5.3vw 0;
    align-items: center;
  }

  #main.company section .historyList dl div dt {
    width: 20%;
    padding: 0 0 0 3.2vw;
  }

  #main.company section .historyList dl div:nth-child(odd) {
  }

  #main.company section .historyList dl div dd {
    width: 80%;
    padding: 0 3vw 0 0;
  }

  #main.company .slideImage ul li {
    width: 85.3vw !important;
    height: auto;
    position: relative;
  }

  #main.company .slideImage ul li img {
    width: 85.3vw !important;
  }
}

/* -----------------------------------------------
 よくあるご質問
------------------------------------------------- */

#main.faq {
  margin: 67px 0 107px;
}

#main.faq p {
  font-family: "Helvetica Neue", Arial, "Hiragino Sans", "Hiragino Kaku Gothic ProN", "BIZ UDPGothic", Meiryo, sans-serif;
}

#main.faq section {
  width: 1000px;
  margin: 0 auto;
}

#main.faq section h2 {
  font-size: 46px;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-align: center;
  margin: 0 0 28px;
  padding: 0 0 15px;
  position: relative;
}

#main.faq section h2::before {
  content: "";
  width: 60px;
  height: 2px;
  background: #bb2121;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
}

#main.faq section .text {
  font-size: 24px;
  text-align: center;
  margin: 0 0 90px;
}

#main.faq section .faqArea details {
  margin: 0 0 15px;
}

#main.faq section .faqArea details summary {
  background: #f4f2e2;
  position: relative;
}

#main.faq section .faqArea details summary::-webkit-details-marker {
  display: none;
}

#main.faq section .faqArea details summary::before {
  content: "";
  width: 70px;
  height: 70px;
  background: #fff;
  border: solid 2px #bb2121;
  box-sizing: border-box;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}
#main.faq section .faqArea details:hover summary::before {
  background: #bb2121;
}

#main.faq section .faqArea details[open] summary::before {
  background: #fff;
  border: solid 2px #646464;
}

#main.faq section .faqArea details summary span.icon {
  width: 26px;
  margin-left: 6px;
  display: block;
  position: relative;
  flex-shrink: 0;
  transform-origin: center 43%;
  transition: transform 0.4s;
}

#main.faq section .faqArea details[open] summary span.icon {
  transform: rotate(180deg);
}

#main.faq section .faqArea details summary span.icon::before,
#main.faq section .faqArea details summary span.icon::after {
  content: "";
  display: block;
  width: 16px;
  height: 3px;
  background-color: #bb2121;
  position: absolute;
}

#main.faq section .faqArea details summary span.icon::before {
  left: 0;
  transform: rotate(45deg);
}

#main.faq section .faqArea details summary span.icon::after {
  right: 0;
  transform: rotate(-45deg);
}

#main.faq section .faqArea details:hover summary span.icon::before,
#main.faq section .faqArea details:hover summary span.icon::after {
  background-color: #fff;
}

#main.faq section .faqArea details[open] summary span.icon::before,
#main.faq section .faqArea details[open] summary span.icon::after {
  background-color: #646464;
}

#main.faq section .faqArea details summary span.inner {
  font-size: 23px;
  box-sizing: border-box;
  padding: 21px 19px 16px 97px;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  position: relative;
  cursor: pointer;
}

#main.faq section .faqArea details summary span.inner::before {
  content: "Q";
  color: #fff;
  font-size: 22px;
  font-weight: 400;
  text-align: center;
  line-height: 41px;
  width: 41px;
  height: 41px;
  background: #bb2121;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 25px;
  transform: translateY(-50%);
}

#main.faq section .faqArea details p {
  font-size: 20px;
  line-height: 1.75;
  background: #fff;
  border: solid 3px #f4f2e2;
  border-top: none;
  box-sizing: border-box;
  padding: 41px 90px 41px 87px;
  position: relative;
}

#main.faq section .faqArea details p::before {
  content: "A";
  color: #bb2121;
  font-size: 22px;
  font-weight: 700;
  text-align: center;
  line-height: 41px;
  width: 41px;
  height: 41px;
  background: #fff;
  border: solid 1px #bb2121;
  border-radius: 50%;
  box-sizing: border-box;
  position: absolute;
  top: 47px;
  left: 25px;
}

#main.faq section .faqArea details p a {
  color: #bb2121;
  text-decoration: underline;
}

#main.faq section .faqArea details p a:hover {
  text-decoration: none;
}

@media (max-width: 768px) {
  #main.faq {
    margin: 13.8vw 0 0;
  }

  #main.faq p {
  }

  #main.faq section {
    width: calc(100% - 9.8vw);
  }

  #main.faq section h2 {
    font-size: 6.1vw;
    letter-spacing: 0.07em;
    margin: 0 0 3vw;
    padding: 0 0 2vw;
  }

  #main.faq section h2::before {
    width: 8vw;
    height: 0.36vw;
  }

  #main.faq section .text {
    font-size: 3.2vw;
    margin: 0 0 6vw;
  }

  #main.faq section .faqArea details {
    margin: 0 0 4vw;
  }

  #main.faq section .faqArea details summary {
  }

  #main.faq section .faqArea details summary::before {
    width: 10.6vw;
    height: 10.6vw;
    border: solid 0.5vw #bb2121;
    right: 4.1vw;
  }
  #main.faq section .faqArea details:hover summary::before {
    background: #fff;
  }

  #main.faq section .faqArea details[open] summary::before {
    border: solid 0.5vw #646464;
  }

  #main.faq section .faqArea details summary span.icon {
    width: 4.5vw;
    top: 0.2vw;
    right: 1.6vw;
  }

  #main.faq section .faqArea details[open] summary span.icon {
  }

  #main.faq section .faqArea details summary span.icon::before,
  #main.faq section .faqArea details summary span.icon::after {
    width: 2.8vw;
    height: 0.5vw;
  }

  #main.faq section .faqArea details summary span.icon::before {
    left: 0;
    transform: rotate(45deg);
  }

  #main.faq section .faqArea details summary span.icon::after {
    right: 0;
    transform: rotate(-45deg);
  }

  #main.faq section .faqArea details:hover summary span.icon::before,
  #main.faq section .faqArea details:hover summary span.icon::after {
    background-color: #bb2121;
  }

  #main.faq section .faqArea details[open] summary span.icon::before,
  #main.faq section .faqArea details[open] summary span.icon::after {
    background-color: #646464;
  }

  #main.faq section .faqArea details summary span.inner {
    font-size: 4vw;
    font-feature-settings: "palt";
    line-height: 1.6;
    padding: 5.3vw 4.5vw 5.4vw 13vw;
    column-gap: 7vw;
  }

  #main.faq section .faqArea details summary span.inner::before {
    font-size: 3.6vw;
    font-weight: 500;
    line-height: 6.8vw;
    width: 6.6vw;
    height: 6.6vw;
    top: 9.6vw;
    left: 3.5vw;
  }

  #main.faq section .faqArea details p {
    font-size: 4vw;
    border: solid 0.5vw #f4f2e2;
    border-top: none;
    padding: 6.6vw 17.7vw 6.6vw 14vw;
  }

  #main.faq section .faqArea details p::before {
    font-size: 4vw;
    font-weight: 500;
    line-height: 6vw;
    width: 6.6vw;
    height: 6.6vw;
    border: solid 0.4vw #bb2121;
    top: 7.6vw;
    left: 3.8vw;
  }

  #main.faq section .faqArea details p a {
  }

  #main.faq section .faqArea details p a:hover {
    text-decoration: underline;
  }
}

/* -----------------------------------------------*/
main.single article#contents .sub_head {
  padding-top: 80px;
  padding-bottom: 20px;
  border-bottom: 1px solid #c90021;
}

main.single article#contents .sub_head::after {
  content: none;
}

main.single article#contents .sub_head .title {
  font-size: 26px;
  font-weight: bold;
  text-align: left;
  padding: 0;
}

main.single article#contents .sub_head nav {
}

main.single article#contents .sub_head nav ul {
  display: flex;
  align-items: center;
}

main.single article#contents .sub_head nav li {
  text-align: left;
}

main.single article#contents .sub_head nav li + li {
  margin-left: 30px;
}

main.single article#contents .sub_head nav li time {
  color: #a0a0a0;
  font-size: 14px;
  font-weight: bold;
}

main.single article#contents .sub_head nav li i {
  color: #fff;
  font-feature-settings: "palt";
  font-size: 12px;
  font-style: normal;
  font-weight: bold;
  text-align: center;
  min-width: 115px;
  background: #c90021;
  display: inline-block;
  margin-right: 20px;
  padding: 3px 10px;
}

main.single article#contents .sub_head nav li i.tv {
  background: #389bbc;
}
main.single article#contents .sub_head nav li i.paper {
  background: #449576;
}
main.single article#contents .sub_head nav li i.radio {
  background: #ff6d46;
}

main.single article#contents .sub_head nav {
}

main.single article#contents .shere-block {
  border-top: 1px solid #c8c8c8;
  border-bottom: 1px solid #c8c8c8;
  margin: 0 0 50px;
  padding: 15px 0 20px;
}

main.single article#contents .shere-block p {
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  margin: 0 0 15px;
}

main.single article#contents .shere-block ul {
  display: flex;
  justify-content: center;
  align-items: center;
}

main.single article#contents .shere-block ul li + li {
  margin-left: 12px;
}

main.single article#contents #page_nav_single {
}

main.single article#contents #page_nav_single ul {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

main.single article#contents #page_nav_single ul li {
  position: relative;
}

main.single article#contents #page_nav_single ul li.gotoichiran {
}

main.single article#contents #page_nav_single ul li.gotoichiran a {
  border: 1px solid #c90021;
  border-radius: 50px;
  padding: 10px 65px;
  position: relative;
}

main.single article#contents #page_nav_single ul li.gotoichiran a::before {
  content: "";
  width: 7px;
  height: 12px;
  background: url(/wp-content/themes/akanekai/images/i_back_arrow.png) no-repeat 0 0 / 100% auto;
  display: inline-block;
  margin-right: 15px;
}

main.single article#contents #page_nav_single ul li.gotoichiran a:hover {
  background: #c90021;
}

main.single article#contents #page_nav_single ul li.gotoichiran a:hover span {
  color: #fff;
}

main.single article#contents #page_nav_single ul li.gotoichiran a:hover::before {
  background-image: url(/wp-content/themes/akanekai/images/i_back_arrow_hover.png);
}

main.single article#contents #page_nav_single ul li.gotoichiran a {
}

main.single article#contents #page_nav_single ul li a[rel="prev"] {
  line-height: 1;
  white-space: nowrap;
  position: absolute;
  top: -8px;
  left: 0;
}

main.single article#contents #page_nav_single ul li a[rel="prev"]::before {
  content: "";
  width: 1em;
  height: 1em;
  text-align: center;
  background: url(/wp-content/themes/akanekai/images/i_prev_arrow.png) no-repeat center center / 10px auto;
  background-color: #5a5a5a;
  border-radius: 50%;
  display: inline-block;
  margin-right: 0.5em;
  vertical-align: middle;
  position: relative;
  top: -2px;
}

main.single article#contents #page_nav_single ul li a[rel="next"] {
  line-height: 1;
  white-space: nowrap;
  position: absolute;
  top: -8px;
  right: 0;
}

main.single article#contents #page_nav_single ul li a[rel="next"]::after {
  content: "";
  width: 1em;
  height: 1em;
  text-align: center;
  background: url(/wp-content/themes/akanekai/images/i_next_arrow.png) no-repeat center center / 10px auto;
  background-color: #5a5a5a;
  border-radius: 50%;
  display: inline-block;
  margin-left: 0.5em;
  vertical-align: middle;
  position: relative;
  top: -2px;
}

main.single article#contents #page_nav_single ul li a[rel="prev"]:hover,
main.single article#contents #page_nav_single ul li a[rel="next"]:hover {
  color: #0071bc;
  text-decoration: underline;
}

main.single article#contents #page_nav_single ul li a[rel="prev"]:hover::before,
main.single article#contents #page_nav_single ul li a[rel="next"]:hover::after {
  background-color: #0071bc;
}

@media (max-width: 768px) {
  main.single article#contents .sub_head {
    padding-top: 40px;
    padding-bottom: 10px;
  }

  main.single article#contents .sub_head::after {
  }

  main.single article#contents .sub_head .title {
    font-size: 26px;
    padding: 0;
  }

  main.single article#contents .sub_head nav {
  }

  main.single article#contents .sub_head nav li {
  }

  main.single article#contents .sub_head nav li time {
    font-size: 14px;
  }

  main.single article#contents .sub_head nav {
  }

  main.single article#contents .shere-block {
    margin: 0 0 25px;
    padding: 10px 0 15px;
  }

  main.single article#contents .shere-block p {
    font-size: 13px;
    margin: 0 0 15px;
  }

  main.single article#contents .shere-block ul {
  }

  main.single article#contents .shere-block ul li + li {
    margin-left: 10px;
  }

  main.single article#contents #page_nav_single {
  }

  main.single article#contents #page_nav_single ul {
    width: 100%;
    align-items: flex-start;
  }

  main.single article#contents #page_nav_single ul li {
  }

  main.single article#contents #page_nav_single ul li.gotoichiran {
    margin-top: 60px;
  }

  main.single article#contents #page_nav_single ul li.gotoichiran a {
    font-size: 14px;
    border: 1px solid #c90021;
    padding: 10px 50px;
  }

  main.single article#contents #page_nav_single ul li.gotoichiran a::before {
    margin-right: 10px;
  }

  main.single article#contents #page_nav_single ul li.gotoichiran a:hover {
  }

  main.single article#contents #page_nav_single ul li.gotoichiran a:hover span {
  }

  main.single article#contents #page_nav_single ul li.gotoichiran a:hover::before {
  }

  main.single article#contents #page_nav_single ul li a[rel="prev"] {
    font-size: 14px;
  }

  main.single article#contents #page_nav_single ul li a[rel="prev"]::before {
    background-size: 8px 8px;
  }

  main.single article#contents #page_nav_single ul li a[rel="next"] {
    font-size: 14px;
  }

  main.single article#contents #page_nav_single ul li a[rel="next"]::after {
    background-size: 8px 8px;
  }

  main.single article#contents #page_nav_single ul li a[rel="prev"]:hover,
  main.single article#contents #page_nav_single ul li a[rel="next"]:hover {
  }

  main.single article#contents #page_nav_single ul li a[rel="prev"]:hover::before,
  main.single article#contents #page_nav_single ul li a[rel="next"]:hover::after {
  }
}

/* ----------------- ページネーションは共通 -------- */

.pagination,
.pnavi {
  margin: 40px auto 0;
}

.pagination li span:hover,
.pnavi span:hover {
  background-color: #fff;
}

.pagination li span.current,
.pagination li a,
.pnavi span.current,
.pnavi a {
  color: #8c8c8c;
  padding: 6px 13px;
  border-radius: 2px;
  margin: 0 5px;
}

.pagination li span.current,
.pnavi span.current {
  color: #fff;
  background: #8c8c8c;
  border: 1px solid #8c8c8c;
}

.pagination li a.prev,
.pnavi a.prev {
  color: #fff;
  background: #b1b1b1;
  border: solid 1px #b1b1b1;
  margin-right: 7px;
}
.pagination li a.prev:hover,
.pnavi a.prev:hover {
  background: #ccc;
  border-color: #ccc;
}
.pagination li a.next,
.pnavi a.next {
  margin-left: 7px;
}

@media (max-width: 768px) {
  .pagination,
  .pnavi {
    margin: 50px auto 0;
  }

  .pagination li span.current,
  .pagination li a,
  .pnavi span.current,
  .pnavi a {
    padding: 6px 13px;
    margin: 0 5px;
  }

  .pagination li span.current,
  .pnavi span.current {
    border: 1px solid #8c8c8c;
  }

  .pagination li a.prev,
  .pnavi a.prev {
    margin-right: 7px;
  }
  .pagination li a.prev:hover,
  .pnavi a.prev:hover {
  }
  .pagination li a.next,
  .pnavi a.next {
    margin-left: 7px;
  }
}
