/*----- =================================
=== Welcome Backページ専用CSS
================================= -----*/
br.spbr {
  display: none;
}
#comeback .textarea h2 {
  margin-bottom: 36px;
  font-size: min(25px, 5vw);
  font-weight: bold;
  text-align: center;
  color: rgba(15, 15, 15, 1);
}
#comeback .textarea h2 span {
  font-size: min(20px, 3.5vw);
  color: #e91e63;
}
#comeback .textarea p {
  margin-bottom: 20px;
  line-height: 2;
}
#comeback .textarea p:nth-of-type(2) {
  margin-bottom: 28px;
}
#comeback .textarea p .lifestyle {
  font-weight: bold;
}
#comeback .textarea p .lifestyle span {
  color: #e91e63;
}
#comeback .benefits-wrap {
  display: flex;
  align-items: center;
  padding: 50px 0;
  background:
    linear-gradient(
      -45deg,
      rgba(20, 38, 58, 0.7) 40%,
      rgba(0, 0, 0, 0.6) 40%,
      rgba(0, 0, 0, 0.6) 50%,
      rgba(20, 38, 58, 0.7) 50%,
      rgba(20, 38, 58, 0.7) 90%,
      rgba(0, 0, 0, 0.6) 90%,
      rgba(0, 0, 0, 0.6)
    ),
    url(../images/welcomeback/camp_bg.jpg);
  background-repeat: repeat, no-repeat;
  background-attachment: fixed;
  background-size: 5px 5px, cover;
}
#comeback .benefits-wrap h2 {
  width: 480px;
  margin: 0 auto 25px auto;
}
#comeback .benefits-wrap .limit {
  border-top: 0;
  border-bottom: 0;
  margin-top: 0;
  padding: 0 0 20px;
  font-size: 24px;
}
#comeback .benefits-wrap .special {
  position: relative;
  width: 880px;
  max-width: 100%;
  margin-bottom: 40px;
  padding: 15px 25px;
  box-shadow: 0 0 5px #333;
  border: solid 3px #fff42c;
  font-weight: bold;
  text-align: center;
  text-shadow: 0 0 3px #333;
  color: #fff42c;
  background-color: rgba(255, 255, 255, 0.3);
  overflow: hidden;
  background: rgba(20, 38, 58, 0.7);
}
#comeback .benefits-wrap .special > p {
  width: 100%;
  margin: 0 auto 25px auto;
  border-top: none;
  font-size: 20px;
}
#comeback .benefits-wrap .special > h3 {
  margin-bottom: 15px;
  font-size: 28px;
}
#comeback .benefits-wrap .special > h3 + div {
  font-size: 40px;
  letter-spacing: 2px;
}
#comeback .benefits-wrap .special > h3 + div span {
  font-size: 60px;
}
#comeback .benefits-wrap .special > h3 + div + p {
  margin: 0 auto;
  border-bottom: none;
  font-size: 25px;
}
#comeback .benefits-wrap ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
  text-align: center;
  color: #fff42c;
}
#comeback .benefits-wrap ul li {
  position: relative;
  width: 420px;
  padding: 15px 25px;
  box-shadow: 0 0 5px #333;
  border: solid 3px #fff42c;
  font-weight: bold;
  text-shadow: 0 0 3px #333;
  background-color: rgba(255, 255, 255, 0.3);
  overflow: hidden;
  background: rgba(20, 38, 58, 0.7);
}
#comeback .benefits-wrap ul li:before,
#comeback .benefits-wrap .special:before {
  content: "";
  position: absolute;
  top: -20px;
  left: -100px;
  display: block;
  width: 84px;
  height: 300px;
  transform: rotate(-30deg);
  background:
    linear-gradient(
      -90deg,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 1) 50%,
      rgba(255, 255, 255, 0)
    );
  animation: anime1 3.2s ease -2s infinite normal;
}
#comeback .benefits-wrap ul li span {
  display: block;
  margin-bottom: 12px;
  font-size: 28px;
}
#comeback .benefits-wrap ul li i {
  font-size: 20px;
}
#comeback .benefits-wrap ul.transfer {
  display: block;
  margin-top: 30px;
}
#comeback .benefits-wrap ul.transfer li {
  width: 100%;
}
#comeback .benefits-wrap ul.transfer li .title {
  font-size: 20px;
}
#comeback .benefits-wrap ul.transfer li i {
  color: #fff;
  font-weight: normal;
  font-size: 18px;
}
#comeback .benefits-wrap p {
  width: 880px;
  max-width: 100%;
  margin: 45px auto 0 auto;
  padding: 13px 0;
  border-top: solid 1px #fff;
  border-bottom: solid 1px #fff;
  font-size: 26px;
  font-weight: bold;
  text-align: center;
  color: #fff;
}
#comeback .forminfo-wrap {
  display: flex;
  align-items: center;
  padding: 50px 0;
  background:
    url(../images/welcomeback/woman.png),
    url(../images/welcomeback/wall.jpg);
  background-repeat:
    no-repeat,
    repeat;
  background-size:
    auto 100%,
    100% auto;
  background-position:
    right 100px bottom,
    top center;
}
/* お客様の声 */
#comeback .customersvoice-wrap {
  padding: 50px 0;
}
#comeback .customersvoice-wrap h2 {
  margin-bottom: 30px;
}
#comeback .customersvoice-wrap h2 img {
  width: 340px;
  margin: 0 auto;
}
.voice-slider li {
  margin: 0 10px;
}
.prev-arrow,
.next-arrow {
  position: absolute;
  top: 50%;
  width: 19px;
  height: 34px;
  margin-top: -9.5px;
  cursor: pointer;
  background-image: url("../images/welcomeback/arrow.png");
  background-size: contain;
  background-repeat: no-repeat;
  z-index: 2;
}
.prev-arrow {
  left: calc((100% - 950px) / 2);
}
.next-arrow {
  right: calc((100% - 950px) / 2);
  transform: rotate(180deg);
}
.lity-container {
  max-width: 800px;
}
/* お申込みフォーム */
#comeback .forminfo-wrap h2 {
  margin-bottom: 30px;
}
#comeback .forminfo-wrap h2 img {
  width: 265px;
  margin: 0 auto;
}
#comeback .forminfo-wrap .t-wrap {
  display: table;
  margin-bottom: 85px;
}
#comeback .forminfo-wrap .t-wrap .col {
  display: table-cell;
}
#comeback .forminfo-wrap .t-wrap div.col {
  width: 180px;
  padding: 0 12px;
  vertical-align: middle;
  text-align: center;
  color: #fff;
  background-color: #111f33;
}
#comeback .forminfo-wrap .t-wrap div.col h3 {
  margin-bottom: 14px;
  font-size: 14.5px;
  font-weight: bold;
}
#comeback .forminfo-wrap .t-wrap div.col span {
  font-size: 12px;
}
#comeback .forminfo-wrap .t-wrap dl.col {
  width: 690px;
  padding: 25px 0;
  counter-reset: number 0;
}
#comeback .forminfo-wrap .t-wrap dl.col dt {
  position: relative;
  margin-top: 35px;
  padding-left: 85px;
  font-size: 18px;
  font-weight: bold;
}
#comeback .forminfo-wrap .t-wrap dl.col dt:before {
  counter-increment: number 1;
  content: counter(number);
  position: absolute;
  top: 50%;
  left: 35px;
  width: 25px;
  height: 25px;
  margin-top: -12.5px;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  color: #fff;
  background: #ef6100;
}
#comeback .forminfo-wrap .t-wrap dl.col dt:first-child {
  margin-top: 0;
}
#comeback .forminfo-wrap .t-wrap dl.col dt span {
  font-size: 15px;
}
#comeback .forminfo-wrap .t-wrap dl.col dd {
  margin-top: 6px;
  padding-left: 85px;
  font-size: 14px;
}
/* フォームの設定 */
.form-area {
  border-top: solid 5px #e91e63;
  box-shadow: 0 0 17px #aaa;
  background-color: #f4f4f4;
}
.form-area .title {
  font-size: 20px;
  text-align: left;
}
.form-area .table-wrap {
  padding: 25px;
  background-color: #efefef;
}
.form-area .table-wrap .table {
  margin: 0 auto;
}
.form-area .table-wrap .table tr.hide {
  display: none;
}
.form-area .table-wrap .table tr td .cDate {
  display: inline-block;
  width: 200px;
  margin-right: 15px;
}
.form-area .table-wrap .table tr td input {
  box-sizing: border-box;
  width: 100%;
  height: 30px;
  padding: 2px 6px;
}
.form-area .text-box {
  margin-bottom: 5px;
  font-size: 14px;
  line-height: 1.7;
}
.form-area .form-btns {
  padding: 0;
}
.form-area .table-wrap .table tr td select {
  cursor: pointer;
}
#ui-datepicker-div {
  box-shadow: 0 0 4px #888;
}
.ui-datepicker .ui-datepicker-header {
  color: #fff;
  background: #e91e63;
}
.form-area .wpcf7-form-control-wrap.about .wpcf7-list-item {
  display: block;
  padding: 5px 0;
}
@media screen and (max-width: 480px) {
  br.spbr {
    display: block;
  }
  #comeback .benefits-wrap {
    height: auto;
    padding: 10% 0;
  }
  #comeback .benefits-wrap h2 {
    width: 80%;
  }
  #comeback .benefits-wrap .special {
    margin-bottom: 0;
  }
  #comeback .benefits-wrap .special > p {
    font-size: 17px;
  }
  #comeback .benefits-wrap .special:before {
    content: "";
    position: absolute;
    top: -20px;
    left: -100px;
    display: block;
    width: 84px;
    height: 1000px;
    transform: rotate(-30deg);
    background:
      linear-gradient(
        -90deg,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 1) 50%,
        rgba(255, 255, 255, 0)
      );
    animation: anime2 3.2s ease -2s infinite normal;
  }
  #comeback .benefits-wrap ul {
    margin: 0 auto;
  }
  #comeback .benefits-wrap ul li {
    width: 100%;
    margin-top: 30px;
  }
  #comeback .benefits-wrap p {
    width: 100%;
  }
  #comeback .forminfo-wrap {
    padding: 10% 0;
    background-size: auto 85%, 100% auto;
    background-position: right bottom, top center;
  }
  #comeback .forminfo-wrap .t-wrap,
  #comeback .forminfo-wrap .t-wrap div.col,
  #comeback .forminfo-wrap .t-wrap dl.col {
    display: block;
    width: 100%;
  }
  #comeback .forminfo-wrap .t-wrap {
    margin-bottom: 15%;
  }
  #comeback .forminfo-wrap .t-wrap div.col {
    padding: 3% 0;
    text-align: center;
  }
  #comeback .forminfo-wrap .t-wrap div.col h3 {
    margin-bottom: 5px;
    font-size: 20px;
  }
  #comeback .forminfo-wrap .t-wrap dl.col dt,
  #comeback .forminfo-wrap .t-wrap dl.col dd {
    padding-left: 40px;
  }
  #comeback .forminfo-wrap .t-wrap dl.col {
    padding: 9% 0 0 0;
  }
  #comeback .forminfo-wrap .t-wrap dl.col dt:before {
    left: 5px;
  }
  /* お客様の声 */
  .voice-slider li .flex-box,
  .voice-slider li .flex-box .pic,
  .voice-slider li .flex-box .comment {
    display: block;
    width: 100%;
  }
  #comeback .customersvoice-wrap {
    width: 100%;
    padding: 10% 0;
  }
  #comeback .customersvoice-wrap h2 img {
    width: auto;
    height: 12vw;
  }
  .voice-slider {
    width: 80%;
    margin: 0 auto;
  }
  .prev-arrow {
    left: -10%;
  }
  .next-arrow {
    right: -10%;
  }
  /* フォームの設定 */
  #comeback .forminfo-wrap h2 img {
    width: auto;
    height: 12vw;
  }
  .form-area .table-wrap {
    padding: 10px 0;
  }
  .form-area .table-wrap .table tr td .cDate {
    width: 100%;
    margin-bottom: 9px;
    margin-right: 0;
  }
  .form-area .table-wrap .table tr td select {
    width: 100%;
  }
  .form-area .wpcf7-form-control-wrap.about .wpcf7-list-item {
    padding: 10px 0;
  }
}
@keyframes anime1 {
  0% {
    top: -20px;
    left: -100px;
  }
  20% {
    top: -84px;
    left: 110%;
  }
  100% {
    top: -84px;
    left: 110%;
  }
}
@keyframes anime2 {
  0% {
    top: -20px;
    left: -100px;
  }
  20% {
    top: -134px;
    left: 190%;
  }
  100% {
    top: -134px;
    left: 190%;
  }
}
/*----- =================================
=== 施設体験ページ
================================= -----*/
.do {
  margin: 50px 0 100px;
}
.do h3 {
  font-size: min(24px, 6vw);
}
.do h3 span {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  line-height: 1;
  color: #333;
}
.do h3 span::before,
.do h3 span::after {
  width: 2px;
  height: 25px;
  content: "";
  background-color: #333;
}
.do h3 span::before {
  margin-right: 1em;
  transform: rotate(-30deg);
}
.do h3 span::after {
  margin-left: 1em;
  transform: rotate(30deg);
}
.do .do-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 20px auto 60px;
}
.do .do-wrap {
  color: #333;
  width: 32%;
}
.do .title {
  display: flex;
  align-items: center;
  font-weight: bold;
  margin-bottom: 5px;
}
.do .title .num {
  color: #e91e63;
  font-size: 40px;
  margin-right: 5px;
  font-weight: 700;
}
.do .title h4 {
  font-size: 18px;
  line-height: 1.3;
  display: inline-block;
  padding: 5px;
  margin-bottom: 2px;
}
.do .do-content {
  background: #fff;
}
.do .do-content img {
  margin-bottom: 15px;
}
.do .do-content h4 {
  padding: 0 15px 10px;
  text-align: center;
  font-weight: bold;
  font-size: 14px;
}
.do .do-content p {
  padding: 0 15px 20px;
}
.do .do-content p small {
  font-size: 12px;
}
/*.trialform {
	padding-top: 50px;
	margin-top: -50px;
}*/
.trialform form {
  padding-top: 100px;
  margin-top: -100px;
}
.trialform .text-comfirm {
  background: #fff;
  border: 5px solid #999;
  text-align: center;
  padding: 30px;
  font-size: 16px;
  margin-bottom: 30px;
}
.trial-menu {
  margin-bottom: 30px;
}
h3 {
  text-align: center;
  font-size: min(24px, 6vw);
}
.trial-menu h3::after {
  background: url(../images/trial/img-arrow.svg) no-repeat top center / contain;
  content: '';
  display: block;
  height: 20px;
  margin: 10px auto 50px;
  width: 60px;
}
.trial-menu h3 br {
  display: none;
}
/* ▼▼▼ 修正済みセレクタ ▼▼▼ */
.trial-menu [data-name="about"] .wpcf7-radio {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.trial-menu [data-name="about"] .wpcf7-list-item {
  display: block;
  margin: 0 0 20px;
  width: 32%;
}
.trial-menu [data-name="about"] .wpcf7-list-item:nth-child(4) {
  width: 49%;
  padding-left: 17%;
}
.trial-menu [data-name="about"] .wpcf7-list-item:nth-child(5) {
  width: 49%;
  padding-right: 17%;
}
.trial-menu [data-name="about"] input,
.trial-menu [data-name="about"] .wpcf7-list-item-label {
  display: none;
}
.trial-menu [data-name="about"] label {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  border: solid 5px #f3f3f3;
  cursor: pointer !important;
  display: block;
  position: relative;
  padding-top: 60%;
  height: 0;
  width: 100%;
}
.trial-menu [data-name="about"] label::after {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.trial-menu [data-name="about"] .wpcf7-list-item:nth-child(1) label {
  background-image: url(../images/trial/img-menu01-pc.jpg);
}
.trial-menu [data-name="about"] .wpcf7-list-item:nth-child(2) label {
  background-image: url(../images/trial/img-menu02-pc.jpg);
}
.trial-menu [data-name="about"] .wpcf7-list-item:nth-child(3) label {
  background-image: url(../images/trial/img-menu03-pc.jpg?202504);
}
.trial-menu [data-name="about"] .wpcf7-list-item:nth-child(4) label {
  background-image: url(../images/trial/img-menu04-pc_campaign.jpg);
}
.trial-menu [data-name="about"] .wpcf7-list-item:nth-child(5) label {
  background-image: url(../images/trial/img-menu05-pc.jpg);
}
.trial-menu [data-name="about"] label:has(input[type="radio"]:checked) {
  border: solid 5px #e91e63;
  position: relative;
  height: 100%;
  text-align: center;
}
.trial-menu [data-name="about"] label:has(input[type="radio"]:checked)::before {
  content: '選択済み';
  color: #fff;
  font-size: 20px;
  font-weight: 700;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  z-index: 1;
}
label:has(input[type="radio"]:checked)::after {
  content: '';
  background: rgba(0, 0, 0, 0.5);
  display: block;
  position: absolute;
  height: 100%;
  width: 100%;
  z-index: 0;
}
.trial-menu [data-name="about"] label:has(.wpcf7c-conf) {
  border: solid 5px #f3f3f3;
}
.trial-menu .menu-attention {
  text-align: center;
}
.trialform h3.title {
  text-align: center;
}
@media screen and (max-width: 480px) {
  .do {
    margin: 20px 0 100px;
  }
  .do .do-wrap {
    margin-bottom: 40px;
    width: 100%;
  }
  .do .title {
    margin-bottom: 10px;
  }
  .do .title .num {
    font-size: 50px;
  }
  .do .title h4 {
    font-size: 4.5vw;
  }
  .do .title h4 .pcbr {
    display: none;
  }
  .trialform form {
    padding-top: 50px;
    margin-top: -50px;
  }
  .trial-menu h3 br {
    display: block;
  }
  .trial-menu [data-name="about"] .wpcf7-list-item {
    margin: 0 0 5px;
    width: 100%;
  }
  .trial-menu [data-name="about"] .wpcf7-list-item:nth-child(4) {
    width: 100%;
    padding-left: 0;
  }
  .trial-menu [data-name="about"] .wpcf7-list-item:nth-child(5) {
    width: 100%;
    padding-right: 0;
  }
  .trial-menu [data-name="about"] label {
    padding-top: 35%;
  }
  .trial-menu [data-name="about"] .wpcf7-list-item:nth-child(1) label {
    background-image: url(../images/trial/img-menu01-sp.jpg);
  }
  .trial-menu [data-name="about"] .wpcf7-list-item:nth-child(2) label {
    background-image: url(../images/trial/img-menu02-sp.jpg);
  }
  .trial-menu [data-name="about"] .wpcf7-list-item:nth-child(3) label {
    background-image: url(../images/trial/img-menu03-sp.jpg?202504);
  }
  .trial-menu [data-name="about"] .wpcf7-list-item:nth-child(4) label {
    background-image: url(../images/trial/img-menu04-sp_campaign.jpg);
  }
  .trial-menu [data-name="about"] .wpcf7-list-item:nth-child(5) label {
    background-image: url(../images/trial/img-menu05-sp.jpg);
  }
}