@charset "utf-8";

/*----- voice01 -----*/
#voice01 {
  background: url(../img/voice01/bg.webp) no-repeat center top;
  background-size: cover;
  height: 125rem;
}
#voice01 h2 {
  font-size: 5.6rem;
  line-height: 1.2;
} 
#voice01 h2 span {
  color: #666666;
  font-size: 3.4rem;
  font-weight: 400;
} 
#voice01 h2 + img {
  width: 55rem;
}

/* 前へ / 次へボタン */
#voice01 .splide__arrow--prev,
#voice01 .splide__arrow--next {
  display: grid;
  place-content: center;
  width: 5.3rem;
  height: 6.7rem;
  cursor: pointer;
  /* transition: var(--transition); */
  background-color: transparent;
  /* border-radius: 50%; */
  border: none;
}

#voice01 .splide__arrow--prev::after,
#voice01 .splide__arrow--next::after {
  width: 3rem;
  height: 3rem;
  content: "";
  border: solid #ff6d6e;
  border-width: 2px 2px 0 0;
}

#voice01 .splide__arrow--prev::after {
  margin-left: 0.4rem;
  transform: rotate(-135deg);
}

#voice01 .splide__arrow--next::after {
  margin-right: 0.4rem;
  transform: rotate(45deg);
}

#voice01 .splide__arrow:disabled {
  pointer-events: none;
  opacity: 0;
}

#voice01 .splide__arrow:focus-visible {
  outline: 3px solid rgba(180, 233, 0, 0.8);
  outline-offset: 3px;
  z-index: 1;
  transition: none;
}
#voice01 .splide__pagination {
  font-size: 0;
}
#voice01 .splide__slide:focus-visible {
  outline: 3px solid rgba(180, 233, 0, 0.8);
  outline-offset: 3px;
  z-index: 1;
  transition: none;
}
#voice01 .splide__slide img {
 width: 71rem!important;
 
}
#voice01 .splide-wrapper {
  position: relative;
}

#voice01 .splide__arrow>svg {
  display: none;
}

#voice01 .splide-area {
  position: relative;
}

#voice01 .splide__pagination {
  display: flex;
  flex-wrap: wrap;
  gap: 1.2rem 0.8rem;
  justify-content: center;
  margin-top: 3.2rem;
  text-align: center;
}

#voice01 .splide__pagination__page {
  width: 1rem; /* 丸型にするため、widthとheightを同じ値に */
  height: 1rem; /* 丸型にするため、widthとheightを同じ値に */
  background-color: #ccc; /* 背景色 */
  /* border-radius: 50%; */
  display: inline-block;
  margin: 0 5px;
  cursor: pointer;
  border: none;
}

#voice01 .splide__pagination__page.is-active {
  background-color: #ff6d6e;
}

#voice01 .splide__arrow--prev,
#voice01 .splide__arrow--next {
  position: absolute;
  z-index: 6;
  top: 0;
  bottom: 0;
  margin: auto;
}

#voice01 .splide__arrow--prev {
  right: calc(100% - 8rem);
}

#voice01 .splide__arrow--next {
  left: calc(100% - 8rem);
}

#voice01 .slide-media {
  padding-top: 62.5%;
  border-radius: 4px;
}

#voice01 .slide-media img {
  height: calc(100% + 16px);
  transform: translateY(-16px);
}

#voice01 .slide-content {
  padding: 3.2rem 0;
}

#voice01 .slide-date {
  font-size: 1.2rem;
  line-height: 1;
  display: block;
  color: #ff6d6e;
}

#voice01 .slide-title {
  line-height: 1.6;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  height: 3.2em;
  margin-top: 1.6rem;
}

/*----- worry -----*/
#worry {
  background: url(../img/worry/bg.webp) no-repeat center top;
  background-size: cover;
  color: #fff;
  height: 123.5rem;
  padding-top: .5rem;
}
#worry h2 {
  font-weight: 400;
}
#worry h2 + img  {
  width: 44.5rem!important;
}
#worry p {
  position: absolute;
  font-size: 2.9rem;
}
#worry p span {
  color: #f67faa;
}
#worry p:nth-of-type(1){
  top: 36rem;
  left: 7.2rem;
}
#worry p:nth-of-type(2){
  top: 49rem;
  left: 7rem;
}
#worry p:nth-of-type(3){
  top: 57rem;
  left: 7.3rem;
}
#worry p:nth-of-type(4){
  top: 70rem;
  left: 7rem;
}
#worry p:nth-of-type(5){
  top: 83.5rem;
  left: 7.2rem;
}

/*----- glp-1 -----*/
#glp-1 {
  background: url(../img/glp-1/bg.webp) no-repeat center top;
  background-size: cover;
  height: 208rem;
  padding: 20rem 4rem 0;
  font-size: 2.6rem;
  margin-top: -0.2rem;
}
#glp-1_img01 {
  width: 55rem;
}
#glp-1_img02 {
  width: 55rem;
}
#glp-1_tsumari {
  width: 30rem!important;
}
#glp-1 p {
  font-weight: 500;
  font-size: 2.7rem;
  letter-spacing: 0.2rem;
}

/*----- diet -----*/
#diet {
  z-index: 2;
  margin-top: -3rem;
}
#diet p {
  font-weight: 500;
  position: absolute;
}
#diet #diet_glp1 {
  width: 60rem!important;
  top: 114rem;
  left: 8rem;
}
#diet .diet_01 p {
}
#diet .diet_01 p:nth-of-type(1) {
  top: 110rem;
  left: 16.4rem;
  font-size: 4.2rem;
  border-bottom: 1px solid;
  padding: 0 2rem;
  letter-spacing: 0.7rem;
  font-weight: 400;
}
#diet .diet_01 p:nth-of-type(2) {
  font-size: 4.5rem;
  top: 134rem;
  left: 15.7rem;
}
#diet .diet_01 p:nth-of-type(3) {
  color: #fff;
  font-size: 4.5rem;
  border-bottom: 1px solid #fff;
  padding: 0 2rem 1rem;
  top: 201rem;
  left: 17rem;
  line-height: 1.3;
}
#diet .diet_01 p:nth-of-type(3) span {
  font-size: 11.5rem;
}
#diet .diet_02  {
  background-color: #fff;
}
#diet .diet_02 p {
  color: #4d4d4d;
  width: 51rem;
  font-size: 3.2rem;
  left: 15.7rem;
}
#diet .diet_02 p:nth-of-type(1) {
  top: 28rem;
}
#diet .diet_02 p:nth-of-type(2) {
  top: 52rem;
}
#diet .diet_02 p:nth-of-type(3) {
  top: 76rem;
}
#diet .diet_03 p:nth-of-type(1) {
  width: 51rem;
  font-size: 3rem;
  line-height: 1.8;
  letter-spacing: 0.1rem;
  top: 63rem;
  left: 12.6rem;
}
#diet .diet_03 p:nth-of-type(2) {
  font-size: 1.8rem;
  width: 57rem;
  background-color: #cccccc;
  padding: 1.5rem;
  color: #666666;
  font-weight: 400;
  top: 147rem;
  left: 9rem;
}
#diet .diet_03 p {
  top: 170rem;
  font-size: 4.3rem;
  left: 16rem;
}
#diet .diet_03 img:nth-of-type(2) {
  top: 178rem;
  left: 9.1rem;
  width: 55rem!important;
}
#diet .diet_03 img:nth-of-type(3) {
  top: 181rem;
  left: 0;
}

/*----- voice02 -----*/
#voice02 {
  background: url(../img/voice02/bg.webp) no-repeat center top;
  background-size: cover;
  z-index: 1;
  color: #4d4d4d;
  margin-top: -5.5rem;
}
#voice02 #user-voice {
  width: 17.2rem;
}
#voice02 h2 {
  font-size: 4.2rem;
  line-height: 1.2;
  border-top: 1px solid #666666;
  border-bottom: 1px solid #666666;
  padding: 1.5rem 2rem;
  width: 45rem;
  letter-spacing: 1rem;
  margin-inline: auto;
} 
#voice02 .splide__slide p {
  line-height: 1.8;
  width: 54rem;
  top: 38rem;
  left: 11.3rem;
}
#voice02 .splide + p {
  padding: 3rem;
}
/* 前へ / 次へボタン */
#voice02 .splide__arrow--prev,
#voice02 .splide__arrow--next {
  display: grid;
  place-content: center;
  width: 5.3rem;
  height: 6.7rem;
  cursor: pointer;
  background-color: transparent;
  border: none;
}

#voice02 .splide__arrow--prev::after,
#voice02 .splide__arrow--next::after {
  width: 3rem;
  height: 3rem;
  content: "";
  border: solid #4d4d4d;
  border-width: 2px 2px 0 0;
}

#voice02 .splide__arrow--prev::after {
  margin-left: 0.4rem;
  transform: rotate(-135deg);
}

#voice02 .splide__arrow--next::after {
  margin-right: 0.4rem;
  transform: rotate(45deg);
}

#voice02 .splide__arrow:disabled {
  pointer-events: none;
  opacity: 0;
}

#voice02 .splide__arrow:focus-visible {
  outline: 3px solid rgba(180, 233, 0, 0.8);
  outline-offset: 3px;
  z-index: 1;
  transition: none;
}
#voice02 .splide__pagination {
  font-size: 0;
}
#voice02 .splide__slide:focus-visible {
  outline: 3px solid rgba(180, 233, 0, 0.8);
  outline-offset: 3px;
  z-index: 1;
  transition: none;
}
#voice02 .splide__slide img {
 width: 66rem!important;
}
#voice02 .splide-wrapper {
  position: relative;
}

#voice02 .splide__arrow>svg {
  display: none;
}

#voice02 .splide-area {
  position: relative;
}

#voice02 .splide__pagination {
  display: flex;
  flex-wrap: wrap;
  gap: 1.2rem 0.8rem;
  justify-content: center;
  text-align: center;
  margin-bottom: 3rem;
}

#voice02 .splide__pagination__page {
  width: 1rem!important;
  height: 1rem!important;
  background-color: #ccc; /* 背景色 */
  /* border-radius: 50%; */
  display: inline-block;
  margin: 0 0.5rem;
  cursor: pointer;
  border: none;
}

#voice02 .splide__pagination__page.is-active {
  background-color: #ff6d6e;
}

#voice02 .splide__arrow--prev,
#voice02 .splide__arrow--next {
  position: absolute;
  z-index: 10;
  top: 0;
  bottom: 0;
  margin: auto;
}

#voice02 .splide__arrow--prev {
  right: calc(100% - 8rem);
}

#voice02 .splide__arrow--next {
  left: calc(100% - 8rem);
}

#voice02 .slide-media {
  padding-top: 62.5%;
  border-radius: 4px;
}

#voice02 .slide-media img {
  height: calc(100% + 16px);
  transform: translateY(-16px);
}

#voice02 .slide-content {
  padding: 3.2rem 0;
}

#voice02 .slide-date {
  font-size: 1.2rem;
  line-height: 1;
  display: block;
  color: #ff6d6e;
}

#voice02 .slide-title {
  line-height: 1.6;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  height: 3.2em;
  margin-top: 1.6rem;
}

/*----- plan -----*/
#plan01 {
  background: url(../img/plan01/bg.webp) no-repeat center top;
  background-size: cover;
  padding-top: 23rem;
  height: 201rem;
  z-index: 3;
}
#day-price {
  width: 59.4rem!important;
}
#plan01 #planning {
  width: 64rem!important;
}
#plan01 > img:nth-of-type(4){
  /* width: 25rem; */
}
#plan01 > img:nth-of-type(5){
  /* width: 28rem; */
}
#plan01 > p {
  color: #666666;
}
#plan01 .m_box {
  /* margin-bottom: 8rem; */
}
/* モーダル */
#position-modal {
  width: 100%;
  overflow: hidden;
}
#modal-base, #modal-cont {
  margin-left: -100vw;
  opacity: 0;
  -webkit-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
  position: fixed;
}
#modal-base {
  width: 100%;
  height: 100vh;
  background: #000;
  left: 0;
  top: 0;
  z-index: 101;
}
#modal-cont {
  width: 69rem;
  color: #FFF;
  background: #a8adbc;
  border-radius: 1.5rem;
  padding: 2rem 3rem;
  left: 50%;
  top: 50%;
  z-index: 110;
  -webkit-transform: translate(-50%, -50%);
}
#modal-cont h4 {
  margin-bottom: 1.5rem;
  border-bottom: 1px solid #fff;
}
#modal-close {
  position: absolute;
  right: 3rem;
  top: 2rem;
  width: 3.3rem!important;
  cursor: pointer;
  transition: opacity 0.2s ease-out;
}


/*----- plan02 -----*/

/* タブ */
.tab-btn {
  width: 24.8%;
  padding: 10px 0;
  text-align: center;
  list-style: none;
  cursor: pointer;
  border-radius: 0.6rem 0.6rem 0 0;
  background: #ffe4de;
  color: #000;
}
.tab-btn.show {
  background: #ff3c5a;
  color: #fff;
}
.plan02_bln {
  position: absolute;
  top: -5rem;
  left: 0;
  right: 0;
  margin: 0 auto;
}
/* タブコンテンツ */
.tab-contents-wrap {
  padding-top: 4.5rem;
}
.tab-contents {
  display: none;
  position: relative;
}
.tab-contents.show {
  display: block;
}
#plan02_notes {
  position: absolute;
  top: -3rem;
  left: 0;
  right: 0;
  margin: 0 auto;
  text-align: center;
}


/*----- lead -----*/
.lead {
  background: url(../img/lead/bg.webp) no-repeat center top;
  background-size: cover;
  margin-top: -0.1rem;
}
.lead .coupon-section, .lead .online-consultation {
  /* margin-bottom: 20px; */
}
.lead .coupon-text p {
  /* margin: 10px 0;
  font-size: 18px; */
}
.lead .discount {
  text-align: left;
}
.lead .coupon-apply {
  width: 16rem!important;
  top: 32.7rem;
  left: 51.3rem;
}
.lead00 .coupon-apply  {
  width: 15rem !important;
  top: 13.7rem;
  left: 55.6rem;
}
.coupon-apply button {
  padding: 0;
  cursor: pointer;
  background: none;
}
.lead .online-consultation {
  /* background-color: #f39c12;
  padding: 20px;
  border-radius: 10px; */
}
.lead .reservation-btn {
  /* display: inline-block;
  background-color: #e74c3c;
  color: #fff;
  padding: 10px 20px;
  border-radius: 5px;
  text-decoration: none;
  margin-top: 10px; */
}
.lead .reservation-btn:hover {
  /* background-color: #c0392b; */
}
.apply-coupon {
  border: none;
}
.lead_btn {
  top: 51rem;
  left: 5.5rem;
}
.lead_btn p {
  letter-spacing: 0.4rem;
  font-weight: 500;
}
.lead_btn .btn_box {
  width: 64rem;
  padding: 3.7rem 2.7rem 4rem 1rem;
  font-size: 4rem;
}

/* Modal styles */
.lead .modal, .lead00 .modal {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  z-index: 1;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: rgba(0, 0, 0, 0.4);
  display: flex;
  justify-content: center;
  align-items: center;
  transition: visibility 0s, opacity 0.3s ease-in-out;
}
.lead .modal.show, .lead00 .modal.show {
  visibility: visible;
  opacity: 1;
}
.lead .modal-content, .lead00 .modal-content {
  margin: 5% auto;
  width: 80%;
  max-width: 300px;
  text-align: center;
  position: relative;
  justify-content: center;
  align-items: center;
}
.heartbeat {
	-webkit-animation: heartbeat 1.5s ease-in-out infinite both;
	        animation: heartbeat 1.5s ease-in-out infinite both;
}
 @-webkit-keyframes heartbeat {
  from {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-transform-origin: center center;
            transform-origin: center center;
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  10% {
    -webkit-transform: scale(0.91);
            transform: scale(0.91);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  17% {
    -webkit-transform: scale(0.98);
            transform: scale(0.98);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  33% {
    -webkit-transform: scale(0.87);
            transform: scale(0.87);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  45% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
}
@keyframes heartbeat {
  from {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-transform-origin: center center;
            transform-origin: center center;
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  10% {
    -webkit-transform: scale(0.91);
            transform: scale(0.91);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  17% {
    -webkit-transform: scale(0.98);
            transform: scale(0.98);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  33% {
    -webkit-transform: scale(0.87);
            transform: scale(0.87);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  45% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
}

/*----- point -----*/
#point {
  background: url(../img/point/bg.webp) no-repeat center top;
  background-size: cover;
  height: 624rem;
}
#point #three-points {
  width: 45.1rem!important;
}
#point > img:nth-of-type(2) {
  width: 8.6rem;
  margin-bottom: 14rem;
  padding-left: 10rem;
  padding-right: 10rem;
}
#point .point01, #point .point02 {
  background-color: #fcfcfc;
  box-shadow: 5px 5px 15px -5px #fcfcfc;
  margin-bottom: 16rem;
}
#point .point03 {
  background-color: #fcfcfc;
  box-shadow: 5px 5px 15px -5px #fcfcfc;
  margin-bottom: 8rem;
}
#point .num {
  margin-top: -12.7rem;
  width: 16.6rem!important;
}
#point h2 {
  font-size: 5rem;
}
#point h3 {
  font-size: 5.4rem;
  line-height: 1.3;
  /* letter-spacing: 0.6rem; */
}
#point h4 {
  background-color: #ffcdd8;
  padding: 2rem;
}
#point h4+img {
  width: 58rem;
}
#point .point02 .plr30 {
  border: 1px solid #ff6d6e;
  border-radius: 1rem;
  width: 63rem;
  margin-inline: auto;
  letter-spacing: 0.2rem;
}
#point h3+img {
  width: 62rem;
  padding: 0 3rem;
}
.point01 > p, .point02 > p, .point03 > p {
  padding: 2rem;
  margin-top: 1.5rem
}
.point03 p + img {
  width: 66rem;
  padding: 0 2rem;
}

/*----- flow -----*/
#flow {
  background: url(../img/flow/bg.webp) no-repeat center top;
  background-size: cover;
  height: 368.4rem;
}
#flow > .box {
}
.flow_box {
  padding-top: 4rem;
}
.flow_box .mb30 img {
  width: 69.1rem!important;
}
.flow_box img:nth-of-type(1){
  margin-top: -0.5rem;
}
.flow_box p {
  margin-top: 3rem;
  padding-left: 6rem;
  padding-right: 5rem;
  line-height: 1.7;
}
.flow_num {
  display: flex;
  position: absolute;
  left: -2rem;
}
.flow_num:nth-of-type(1) {
  top: -1rem;
  left: 0;
}
.flow_num:nth-of-type(2) {
  top: 73.5rem;
}
.flow_num > img {
  width: 22.8rem;
}
.flow_num + img {
  width: 63rem;
}
#flow > img {
  width: 10rem!important;
}
#flow h3 {
  font-size: 4.5rem;
  font-weight: 400;
  margin-left: 2rem;
}
.flow_num h3:nth-of-type(2) {
  font-size: 4.2rem;
  font-weight: 400;
}
#flow h2 {
  color: #666666;
  font-size: 4.5rem;
  line-height: 1.2;
  border-top: 1px solid #666666;
  border-bottom: 1px solid #666666;
  padding: 1.5rem 2rem;
  width: 60rem;
  letter-spacing: 1rem;
  margin-inline: auto;
}
.flow_arw {
  width: 10rem!important;
}
/*----- qa -----*/
#subscription {
}
#subscription .ttl_line + img, #qa .ttl_line + img {
  width: 43.7rem!important;
}
#subscription .ttl_line, #qa .ttl_line {
  font-weight: 400;
  line-height: 1.3;
}
#subscription .box > img:nth-of-type(1) {
  width: 25.3rem!important;
  ;
}
#qa .box > img:nth-of-type(1) {
  width: 10.8rem!important;
}

.faq_ttl {
  background: #ffd8d9;
  padding: 4rem 6rem 4rem 11rem;
  border-radius: 0 3rem 0 3rem;
  margin-top: 3rem;
  position: relative;
  cursor: pointer;
  color: #4d4d4d;
  font-size: 3rem;
  font-weight: 500;
}
.faq_ttl::before {
  content: "";
  display: block;
  width: 5.6rem;
  height: 5.6rem;
  background: url(../img/faq/q.svg) no-repeat left top;
  background-size: 5.6rem;
  position: absolute;
  top: 3.4rem;
  left: 3.2rem;
}
.faq_ttl::after {
  content: "";
  display: block;
  width: 3.2rem;
  height: 3.2rem;
  background: url(../img/faq/close.svg) no-repeat left;
  background-size: 3.2rem;
  position: absolute;
  top: calc(50% - 1.6rem);
  right: 2rem;
  transition: 0.3s;
}
.faq_ttl.active::after {
  background: url(../img/faq/open.svg) no-repeat left top;
  background-size: 3.2rem;
}
.faq_area {
  padding: 3rem 1rem 2rem 3rem;
  border-radius: 0.9rem;
  display: none;
}
.faq_content {
  display: flex;
  align-items: flex-start;
}
.faq_content img {
  width: 5.6rem!important;
}
.faq_area h4 {
  color: #ff5a3c;
  padding: 1rem 0 1rem 4rem;
  position: relative;
  font-size: 2.6rem;
}
.faq_area h4::before {
  content: "";
  display: block;
  width: 3rem;
  height: 2.5rem;
  background: url(../img/faq/a.svg) no-repeat left top;
  background-size: 3rem;
  position: absolute;
  top: 1.8rem;
  left: 0.3rem;
}
.faq_area p {
  background: #fff;
  padding: 0 1rem 3rem 3rem;
  border-radius: 0.9rem;
  font-size: 2.2rem;
}


/*----- form -----*/
#form .box:first-child {
  background-color: #ffcdd8
}
dl {
  color: #4d4d4d;

  font-weight: 500;
}
dl dt {
  position:relative;
  display:inline-block;
  font-size: 3.2rem;
}
dl dd {
  margin-bottom: 3rem;
}
dt .req {
  display:inline-block;
  color: #fff;
  padding: 0 1rem;
  font-size: 2.2rem;
  position: absolute;
  top: 0.6rem;
  right: -7rem;
  background:#ff6d6e;
}
dt .req.opt {
  background:#808080
}
input,select,textarea {
  vertical-align:bottom;
  box-sizing:border-box;
  border:1px solid #4d4d4d;
  border-radius:.6rem;
  height:6.4rem;
  width:100%;
  padding:0 1rem;
  font-size: 2.8rem;
  font-weight: normal;
}
select {
  padding: 0 3rem 0 1rem;
  -webkit-appearance: none;
  appearance: none;
  color: #000;
  background: #fff;
}
select::-ms-expand {
  display: none; /* デフォルトの矢印を非表示(IE用) */
}
.select {
  position: relative;
  display: inline-block;
  width: fit-content;
}
.select::after{
  content: "";
  display: block;
  background: #000000;
  height: calc(tan(60deg)* 0.6rem / 2);
  width: 1rem;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  position: absolute;
  top: calc(50% - 0.25rem);
  right: 1rem;
}
textarea {
  height:26rem;
  padding: 1rem;
  line-height: 1.5;
}
input.date {
  width:37rem;
  display: inline-block;
}
select.hour {
  width:25rem;
  display: inline-block;
}
input[type=image]{
  padding:0;
  height:auto;
  border:none;
}
#ui-datepicker-div th {
  padding: 0.5em 0;
}
.ui-datepicker th span {
  padding: 0.2em 0.3em;
  display: block;
}
.ui-datepicker th:nth-child(1) span {
  background: #ff5a3c;
  color: #FFF;
}
.ui-datepicker th:nth-child(7) span {
  background: #3c69ff;
  color: #FFF;
}
#ui-datepicker-div td {
  opacity: 1;
}
#ui-datepicker-div td span {
  background: #666666;
  color: #000000;
}
.ui-datepicker td:nth-child(1) a {
  color: #ff5a3c;
}
.ui-datepicker td:nth-child(7) a {
  color: #3c69ff;
}
#ui-datepicker-div .ui-datepicker-today{
  opacity:1
}
#ui-datepicker-div .ui-datepicker-today .ui-state-default{
  border:1px solid #dad55e;
  background:#fffa90;
}
form .sec div {
  width: 49%;
}
form .sec div .select {
  width: 100%;
}
#form button {
  display: block;
  width: 63.4rem;
  height: 12.3rem;
  background: url(../img/form/btn.webp) no-repeat left top;
  background-size: contain;
  text-indent: -74.4rem;
  overflow: hidden;
  border: none;
  cursor: pointer;
}

.km_valid_error {
  margin-top: .1rem;
  color: #ff6d6e;
  font-size: 1.8rem;
  position: absolute;
}
#calendar2_wrap .km_valid_error {
  /* margin-top: 7rem; */
}

.radio li {
  margin-right: 2rem;
}
input[type="radio"] {
  height: 3rem;
  width: 3rem;
  vertical-align: middle;
  margin: 0;
  padding: 0;
}
.radio label {
  vertical-align: middle;
}



input[type="checkbox"] {
  display: none;
}
input[type="checkbox"] + span {
  display: none;
  cursor: pointer;
  display: inline-block;
  position: relative;
  padding-left: 4rem;
}

input[type="checkbox"] + span::before {
  content: "";
  width: 3rem;
  height: 3rem;
  display: block;
  position: absolute;
  top: calc(50% - 1.3rem);
  left: 0;
  border-radius: 3rem;
  box-sizing: border-box;
  background-color: #fff;
  border: 1px solid #cccccc;
}

input[type="checkbox"]:checked+span::after {
  content: '';
  display: block;
  width: 0.9rem;
  height: 1.8rem;
  border-right: 0.5rem solid #ff5a3c;
  border-bottom: 0.5rem solid #ff5a3c;
  position: absolute;
  top: 0.8rem;
  left: 0.5rem;
  transform: rotate(45deg) translate3d(0, 2px, 0) scale3d(.7, .7, 1);
  transition: transform .2s ease-in-out, opacity .2s ease-in-out;
}


/*----- footer -----*/
#footer_box {
  background: #ffcdd8;
  padding: 2rem 3rem;
  border-radius: 1.5rem;
  color: #666666;
}
footer .box img {
  width: 37.2rem!important;
}
#footer_box ul {
  margin-left: auto;
  margin-right: auto;
}
#footer_box li:nth-child(1) {
  width: fit-content;
  margin-right: 3rem;
}
#footer_box li:nth-child(2) {
  width: fit-content;
}
.copyright {
  color: #aaaaaa;
}

@media screen and (min-width:600px) {

}

@media screen and (max-width:599px){
  input,select,textarea{
    font-size:3.2rem
  }
  #voice01 .splide__pagination__page, #voice02 .splide__pagination__page {
    /* height: 2rem!important; */
  }
}