:root {
  --main-tx-color: white;
}

html {
  font-size: 62.5%;
  font-family: "Noto Sans JP", sans-serif;
  height: 100%;
}

body {
  color: #595959;
}

main {
  background: #eee;
}

.l-wrap {
  max-width: 500px;
  width: 100%;
  margin: 0 auto;
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
}

.c-en {
  font-family: "Oswald", sans-serif;
}
.c-pink {
  color: #fba8b0;
}
.c-white {
  color: #fff;
}

.c-lightblue {
  color: #7bcde5
}

.c-darkblue {
  color: #5d6379;
}

.c-attention {
  font-size: 1.2rem;
}
.c-txt {
  font-size: 1.8rem;
  line-height: 1.5;
}
.c-txt_small {
  font-size: 1.6rem;
}
.c-txt_center {
  display: block;
  text-align: center;
}
.c-txt_right {
  display: block;
  text-align: right;
}
.c-underLine.-pink {
  background: linear-gradient(transparent 50%, #ffd4d8 0%);
}

.c-underLine.-pink {
  background: linear-gradient(transparent 80%, #ffa0a0b7 0%);
}

.c-underLine.-lightgray {
  background: linear-gradient(transparent 95%, #5d6379 0%);
  font-size: min(9vw, 4rem);
}

.l-flex {
  display: flex;
}
.l-wrap-wrap {
  flex-wrap: wrap;
}
.l-justify-between {
  display: flex;
  justify-content: space-between;
}
.l-justify-center {
  display: flex;
  justify-content: center;
}
.l-align-center {
  display: flex;
  align-items: center;
}
.l-align-end {
  display: flex;
  align-items: flex-end;
}
.l-section {
  padding-bottom: 10%;
}
.l-w_100 {
  width: 100%;
  height: auto;
}
.l-w_90 {
  width: 90%;
  height: auto;
  margin: 0 auto;
}
.l-w_80 {
  width: 80%;
  height: auto;
  margin: 0 auto;
}
.l-w_60 {
  width: 60%;
  height: auto;
  margin: 0 auto;
}
.l-col {
  gap: 1.9rem;
  flex-wrap: wrap;
}
.l-col_2 {
  width: calc(50% - 0.8rem);
}
.l-mt_small {
  margin-top: 3% !important;
}
.l-mt_middle {
  margin-top: 6% !important;
}
.l-mt_large {
  margin-top: 9% !important;
}
.l-mb_small {
  margin-bottom: 3% !important;
}
.l-mb_middle {
  margin-bottom: 6% !important;
}
.l-mb_large {
  margin-bottom: 9% !important;
}
.l-ttl_padding {
  padding: 10% 2% 5%;
}
.l-ttl-sub_padding {
  padding: 0% 2% 5%;
}
.l-inner {
  width: 95%;
  margin: 0 auto;
}
.l-price_col_1 {
  width: 50%;
}
.l-price_col_2 {
  width: 100%;
}
.l-price dt, .l-price dd {
  border: 1px solid #595959;
}
.l-price dt {
  font-size: min(1.6rem, 3.5vw);
  text-align: center;
  padding: 2% 0;
}
.l-price dd {
  font-size: min(3rem, 5.5vw);
  text-align: center;
  line-height: 1;
  padding: 2% 0;
}
.l-price dd span {
  font-size: min(1.4rem, 3.5vw);
  display: block;
  margin-top: 1%;
}
.l-price_white dt, .l-price_white dd {
  border: 1px solid #fff;
  color: #fff;
}
.l-cta {
  margin: 6% 0;
}

.l-square_upper_phrase{
  font-size: min(10vw, 5rem);
  color: #000;
  font-weight: 500;
  margin: 0% 2% 2% 2%;
  text-align: center;
  height: 80px;
  padding-top: 10%;
}

.l-square_space{
  width:90%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: auto;
  line-height: 1.5;
}

.l-square_point{
  background:  #ffffff;
  border: 0px solid #186f8c;
  position: relative;
  width: 30%;
  padding-top: 30%;
  color: #595959;
}

.square_point_sentence{
  position: absolute;
  top: 20%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
  text-align: center;
  margin-top: 5%;
}

.l-square_point img{
  position: absolute;
  top: 70%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 40%;
}

.l-square_point p{
  font-size: min(3.5vw, 1.6rem);
}

#menu .l-fukidashi {
  margin: 0 auto 10%;
  font-size: min(6.5vw, 3rem);
}

#menu .l-fukidashi {
  text-align: center;
}

#menu .l-fukidashi span {
  position: relative;
  color: #fba8b0;
}

#menu .l-fukidashi span:before {
  content: "";
  display: inline-block;
  background: #eb939b;
  width: 1px;
  position: absolute;
  height: min(18vw, 6rem);
  margin: 0 -4%;
  top: 0;
}

#menu .l-fukidashi span:after {
  content: "";
  display: inline-block;
  background: #eb939b;
  width: 1px;
  position: absolute;
  height: min(18vw, 6rem);
  margin: 0 -4%;
  top: 0;
}

#menu .l-fukidashi span:before {
  left: 0;
  transform: rotate(-25deg);
}

#menu .l-fukidashi span:after {
  right: 0;
  transform: rotate(25deg);
}

.l-fukidashi {
  text-align: center;
  padding-top: 10%;
}
.l-fukidashi span {
  position: relative;
  color: #595959;
}
.l-fukidashi span:before, .l-fukidashi span:after {
  content: "";
  display: inline-block;
  background: #595959;
  width: 1px;
  position: absolute;
  height: min(8vw, 4rem);
  margin: 0 -4%;
  top: 0;
}
.l-fukidashi span:before {
  left: 0;
  transform: rotate(-25deg);
}
.l-fukidashi span:after {
  right: 0;
  transform: rotate(25deg);
}

.c-center{
  text-align: center;
}

.notojp{
  font-family: "Noto Sans JP";
}

.c-min-weight300{
  font-size: min(3vw, 1.5rem);
  font-weight: 300;
}

.c-min1-weight300{
  font-size: min(4vw, 2rem);
  font-weight: 300;
}

.c-mid2-weight {
  font-size: min(4.5vw, 2.2rem);
}

.c-mid-weight300{
  font-size: min(9vw, 5rem);
  font-weight: 300;
}

.c-mid1-weight300{
  font-size: min(7vw, 3rem);
  font-weight: 300;
}

.c-big-weight300{
  font-size: min(12vw, 7rem);
  font-weight: 300;
}

.c-big2-weight300{
  font-size: min(17vw, 9rem);
  font-weight: 300;
}

.c-big3-weight300 {
  font-size: min(29vw, 19rem);
  font-weight: 300;
}

.l-mv_pct{
  height: 500px;
  position: relative;
}

.l-mv_pct .main_pct{
  object-fit: none;
  object-position: 70% 40%;
  zoom: 0.7;
  height: 100%;
}

.l-mt_middle .main_pct{
  object-fit: none;
  object-position: 60% 40%;
  zoom: 0.7;
  height: 100%;
}

.l-mv {
  /**background: url(../img/mv.jpg) no-repeat center top/100%;
  width: 100%;
  padding-top: 200%;
  position: relative;
  **/
}
.l-mv_pct::before {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background: linear-gradient(to bottom, rgba(204, 128, 65, 0.3), 20%, transparent);
}

.l-mv_pct::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
  background: -moz-linear-gradient(180deg, transparent 0 60%, rgba(204, 128, 65, 0.2) 100%);
  background: -webkit-linear-gradient(180deg, transparent 0 60%, rgba(204, 128, 65, 0.2) 100%);
	background: linear-gradient(180deg, transparent 0 60%, rgba(204, 128, 65, 0.2) 100%);
  z-index: 1;
}



.l-mv_upper {
  position: absolute;
  top: 5%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
  text-align: center;
  z-index: 2;
}

.upper_phrase{
  font-size: min(8vw, 4rem);
  font-weight: 300;
  color: var(--main-tx-color);
  text-shadow: rgba(178,157,144,0.46) 1px 1px 6px;
  font-family: serif, Koz Go Pr6 N;
}

.l-mv_middle_upper {
  position: absolute;
  top: 10%;
  left: 1%;
  white-space: nowrap;
  text-align: center;
  max-width: 160px;
  width: 30%;
  z-index: 2;
}

.middle_upper_phrase{
  font-size: min(4vw, 2rem);
  font-weight: 100;
  color: #e2cf85;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.perrate_sentence{
  margin-bottom: -20px;
  font-size: min(5vw, 2.5rem);
}

.perrate_num{
  margin-top: -20%;
  margin-left: 5%;
}

.l-mv_middle_lower {
  position: absolute;
  white-space: nowrap;
  z-index: 2;
  top: 75%;
  left: 40%;
  transform: translate(-50%, -50%);
}

.middle_lower_phrase{
  font-size: min(7.5vw, 3.5rem);
}

.medical_diet_img{
}

.middle_lower_phrase_sentence{
  background: #fff;
  padding: 20px 10px 25px 10px;
  display: inline-block;
  margin: -10px 0 0 0;
  z-index: -99;
  position: absolute;
  font-weight: 500;
}

.l-mv_lower {
  position: absolute;
  top: 90%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
  text-align: center;
  font-weight: 500;
  z-index: 2;
  padding-bottom: 10%;
}

.lower_phrase{
  font-size: min(11vw, 5.5rem);
  color: white;
  font-weight: 300;
  text-shadow: rgba(178,157,144,1) 1px 0 10px;
}

.l-mv .l-fukidashi {
  margin: 0 auto 10%;
  font-size: min(4.5vw, 2rem);
}
.l-mv_price {
  padding-bottom: 5%;
  background-color: rgba(204, 128, 65, 0.1);
}
.l-mv_price_block {
  position: relative;
  max-width: 469px;
  width: 100%;
  margin: 0 auto;
  outline: 2px solid #fba8b0;
  outline-offset: -0.5rem;
  background: #fff;
  border-radius: 0.7vw;
}
.l-mv_price_inner {
  position: relative;
  height: min(26vw, 12rem);
  width: 93%;
  margin: 0 auto;
}
.l-mv_price_ttl {
  width: 63%;
  margin: 0 auto;
  position: absolute;
  top: -11%;
  left: 0;
  right: 0;
}
.l-mv_price_about {
  position: absolute;
  left: 2%;
  bottom: 11%;
  width: 40%;
}
.l-mv_price_explanation {
  border: 1.5px solid #fba8b0;
  color: #fba8b0;
  padding: 0 2%;
  border-radius: 2rem;
  font-size: min(4vw, 1.65rem);
  font-weight: 300;
  display: inline-block;
  line-height: 1.3;
  width: 100%;
  text-align: center;
  margin: 7% 0%;
}
.l-mv_price_name {
  font-size: min(5vw, 2.5rem);
  font-weight: 500;
  display: block;
  line-height: 1;
  text-align: center;
  margin-bottom: 0.5rem;
}
.l-mv_price_price {
  display: flex;
  align-items: flex-end;
  position: absolute;
  right: 2%;
  bottom: 11%;
  color: #595959;
}
.l-mv_price_yen {
  display: flex;
  font-size: min(9vw, 4rem);
  flex-direction: column;
  align-items: center;
  line-height: 1.2;
  font-weight: 400;
}
.l-mv_price_tax {
  font-size: min(4vw, 1.8rem);
  line-height: 1;
  font-weight: 400;
}
.l-mv_price_day {
  font-size: min(6vw, 2.2rem);
  line-height: 1.2;
}
.l-mv_price_num {
  font-size: min(17vw, 7.5rem);
  line-height: 1;
  font-weight: 300;
  letter-spacing: -0.3rem;
}
.l-mv_price_high {
  font-size: min(5vw, 3rem);
  line-height: 2;
}
.l-trouble {
  background: url(../img/trouble_bg.jpg) #f4f1ec;
}
.l-trouble_ttl {
  width: 80%;
  min-width: 320px;
}

.l-trouble_middle{
  margin-bottom: 10%;
  position: relative;
}

.glp-pct-txt {
  width: 35%;
  margin: 0 auto;
  height: 50px;
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: min(2rem, 4vw);
}

.glp-pct-txt-area{
  display: flex;
  justify-content: space-evenly;
  align-items: flex-end;
  width: 100%;
  white-space: nowrap;
}

.trouble_circle{
  width: 120px;
  height: 120px;
  background-color: #fea1aa;
  border-radius: 50%;
  color: #fff;
  text-align: center;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.trouble_circle_txt {
  position: absolute;
  top: 50%;
  left: 55%;
  transform: translate(-50%, -50%);
  font-size: min(6vw, 2rem);
  font-weight: 100;
  width: 100%;
}

.trouble-pct-effect-area{
  display: flex;
  justify-content: space-evenly;
  align-items: flex-end;
  margin: 4% 0%;
  width: 100%;
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
  z-index: 2;
}

.trouble-double-circle {
  width: 30%;
  padding-top: 30%;
  height: 0px;
  border-radius: 50%;
  background: radial-gradient(circle, #7ccee5 0% 65%, #fff 65% 67%, #7ccee5 67% 100%);
  position: relative;
}

.trouble-double-circle p {
  font-size: min(5vw, 2.5rem);
  font-weight: 500;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
  text-align: center;
  color: #fff;
}

.trouble-pct-upper-txt {
  background: #fff;
  padding: 2.5%;
  min-width: 200px;
  width: 80%;
  position: absolute;
  top: 10%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.trouble-pct-upper-txt p {
  font-size: min(2.5rem, 5vw);
  line-height: 1;
}

.improve_txt  {
  text-align: center;
  font-size: min(6vw, 4rem);
}

.lightblue_ballon{
  margin: 30px;
  position: relative;
  padding: 25px;
  background-color: #7ccee5;
}

.lightblue_ballon::before{
  content: '';
  position: absolute;
  display: block;
  width: 0;
  height: 0;
  left: 0;
  right: 0;
  bottom: -15px;
  margin: 0 auto;
  border-top: 15px solid #7ccee5;
  border-right: 15px solid transparent;
  border-left: 15px solid transparent;
}

.lightblue_ballon_txt{
  text-align: center;
  color: white;
  font-size: min(6vw, 3rem);
}

.ballon_lower_txt{
  text-align: center;
  font-size: min(5.5vw, 2.5rem);
  font-weight: 500;
  color: #5d6379;
} 

.l-reason {
  background: #f2f0ee;
}
.rating_area{
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  text-align: center;
}

/* 星評価　*/

.st-skyblue {
  color: #b6d4e5;
}

.st-orange {
  color: #ffb7b3;
}

.st-gray {
  color: #b1b0ab;
}

.rating_txt{
  color: #fff;
  font-size: 2em;
  border: 1.5px solid #fff;
  border-right: none;
  padding: 0% 7%;
}

.star5_rating{
  position: relative;
  z-index: 0;
  display: inline-block;
  white-space: nowrap;
  font-size: 20px;
  border: 1.5px solid #fff;
  padding: 0 20px;
}

.star5_rating:before, .star5_rating:after{
  white-space: pre-wrap;
  content: '★ ★ ★ ★ ★';
}

.star5_rating:after{
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  overflow: hidden;
  white-space: nowrap;
  color: #ffcf32;
  padding: 0 20px;
}

.star5_rating:before{
}

.star5_rating[data-rate="5"]:after{ width: 100%; } /* 星5 */
.star5_rating[data-rate="4.5"]:after{ width: 90%; } /* 星4.5 */
.star5_rating[data-rate="4"]:after{ width: 75%; } /* 星4 */
.star5_rating[data-rate="3.5"]:after{ width: 70%; } /* 星3.5 */
.star5_rating[data-rate="3"]:after{ width: 60%; } /* 星3 */
.star5_rating[data-rate="2.5"]:after{ width: 50%; } /* 星2.5 */
.star5_rating[data-rate="2"]:after{ width: 40%; } /* 星2 */
.star5_rating[data-rate="1.5"]:after{ width: 30%; } /* 星1.5 */
.star5_rating[data-rate="1"]:after{ width: 20%; } /* 星1 */
.star5_rating[data-rate="0.5"]:after{ width: 10%; } /* 星0.5 */
.star5_rating[data-rate="0"]:after{ width: 0%; } /* 星0 */


.l-reason{
  background:url(../img/reason_bg.jpg) #f2f0ee;
}

.l-reason_ttl{
  width: 80%;
  min-width: 320px;
}

.l-reason-sub_ttl{
  width: 70%;
}

.l-reason-point{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.l-reason-txt {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
  text-align: center;
  font-weight: 500;
}

.l-reason-img{
  width: 45%;
  margin: 3% 2%;
  position: relative;
}

.l-reason-pct{
  margin: 0 0 -10%;
}

.l-reason-pct img{
  object-fit: none;
  object-position: 60% 70%;
  zoom: 0.7;
  margin-top: -30%;
}

.l-whatglp{
  background:#dfeef1;
}

.l-whatglp_ttl{
  width: 80%;
  min-width: 320px;
}

.l-whatglp-pct{
  margin-top: -40%;
}

.l-whatglp-pct img {
  object-fit: none;
  object-position: 20% 50%;
  zoom: 0.7;
  height: 450px;
  width: 400px;
  margin: auto;
}

.l-whatglp-pct-txt {
  font-size: min(5vw, 2.7rem);
  font-weight: 500;
  color: #5d6379;
  line-height: 2;
}

.l-whatglp-pct-txt_explanation {
  color: #fba8b0;
}

.l-whatglp-pct-emp{
  text-align: center;
  font-size: min(5vw, 2.7rem);
  font-weight: 500;
  color: #5d6379;
  line-height: 2;
}

.l-whatglp-ba-pct{
  display: flex;
  padding: 10% 0;
  justify-content: center;
  height: 250px;
}

.l-whatglp-before-pct{
  width: 50%;
}

.l-whatglp-before-pct img{
  object-fit: none;
  object-position: 10% 10%;
  zoom: 0.6;
  height: 100%;
}

.l-whatglp-after-pct{
  width: 50%;
}

.l-whatglp-after-pct img{
  object-fit: none;
  object-position: 80% 60%;
  zoom: 0.6;
  height: 100%;
}

.l-box_border {
  border: 1.5px solid #858585;
  padding: 2%;
  background: #fff;
  margin-bottom: 4.5%;
}
.l-box_ttl {
  font-size: min(7vw, 18px);
  line-height: 1.6;
}
.l-case {
  background: #fff;
}
.l-case_ttl {
  width: 70%;
  min-width: 260px;
}
.l-case-pct-txt{
  font-size: min(5vw, 2.2rem);
  font-weight: 500;
  line-height: 1.5;
}

.l-menu {
  background: #fdede2;
}
.l-menu_ttl {
  width: 70%;
  min-width: 260px;
}
.l-ticket {
  padding: 3.5% 0;
  margin-top: -8px;
}
.l-ticket_block {
  margin-bottom: 10%;
}
.l-ticket_head {
  border-radius: 0.8rem 0.8rem 0 0;
  padding: 3.5% 0 6% 0;
}


.corner_cut {
  clip-path: polygon(1rem 0px, calc(100% - 1rem) 0px, 100% 1rem, 100% calc(100% - 1rem), calc(100% - 1rem) 100%, 1rem 100%, 0px calc(100% - 1rem), 0px 1rem);
  margin-top: 0;
}

.corner_cut_under {
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 1rem), calc(100% - 1rem) 100%, 1rem 100%, 0 calc(100% - 1rem));
  margin-top: 0;
}

.corner_cut_top {
  clip-path: polygon(1rem 0, calc(100% - 1rem) 0, 100% 1rem, 100% 100%, 0 100%, 0 1rem);
  margin-top: 0;
}

.both_border {
  border-bottom: 3px dotted #fff;
  border-top: 3px dotted #fff;
}

.bottom_border {
  border-bottom: 3px dotted #fff;
}

.l-ticket_bottom {
  border-radius: 0 0 0.8rem 0.8rem;
  padding: 3.5% 0 6% 0;
}
.l-ticket_reccomend {
  width: 60%;
  max-width: 280px;
  margin-left: -2%;
}

.l-ticket_target{
  display: flex;
  text-align: center;
  color: #fff;
}

.l-ticket_target_box{
  width: 40vw;
  font-size: min(1.8rem, 3.2vw);
  justify-content: center;
  align-items: center;
  display: flex;
  flex-direction: column;
  font-weight: 600;
  height: 15vw;
  max-width: 120px;
  max-height: 80px;
}

.bg-pink{
  background: #f383b0;
}

.bg-purple {
  background: #bd8cb3;
}

.bg-purple2 {
  background: #d7a0c9;
}

.bg-yellow {
  background: #e8cd82;
}

.bg-yellow2 {
  background-color: #d9d081;
}

.bg-lightyellow {
  background: #e5dea3;
}

.bg-orange {
  background: #f38c70;
}

.bg-gray {
  background:#7f8481;
}

.bg-lightblue {
  background-color: #9fc6da;
}

.l-ticket_target_box_txt {
  padding-left: 3%;
  flex-grow: 1;
  text-align: left;
  max-width: 300px;
  margin: auto;
}

.l-ticket_plan {
  text-align: center;
  font-size: min(2.2rem, 4.5vw);
  font-weight: bold;
  color: #fff;
}

.l-ticket_plan_box {
  border: 1px solid #fff;
  padding: 10% 5% 2% 5%;
  max-width: 95%;
  margin: 8% auto 0 auto;
}


.plan_x {
  text-align: center;
  font-size: 600%;
  font-weight: 100;
  color: #fff;
}

.plan-x{
  position: relative;
  width: 50px;
  height: 50px;
  margin: 20px auto;
}
.plan-x hr:nth-of-type(1){
  position: absolute;
  top: 0px;
  transform: rotate(45deg);
  width: 71px;
  border: 0;
  border-top: 1px solid #fff;
  margin: 0;
  padding: 0;
  transform-origin: 0% 0%;
}

.plan-x hr:nth-of-type(2){
  transform: rotate(-45deg);
  width: 71px;
  border: 0;
  border-top: 1px solid #fff;
  margin: 0;
  padding: 0;
  transform-origin: 0% 0%;
  position: absolute;
  top: 50px;
}

.l-ticket_plan_menu {
  background: #fff;
  padding: 2.5%;
  min-width: 200px;
  width: 50%;
  margin: -17.5% auto 0 auto;
}
.l-ticket_plan_menu p {
  font-size: min(2rem, 4vw);
  line-height: 1;
}
.l-ticket_plan_price {
  font-size: 5.5rem;
  color: #fff;
  font-weight: 300;
  line-height: 1;
}
.l-ticket_plan_yen {
  font-size: 3.5rem;
  color: #fff;
  font-weight: 300;
  display: flex;
  justify-content: center;
  flex-direction: column;
  line-height: 1;
  padding-bottom: 0.5rem;
}
.l-ticket_plan_tax {
  font-size: 1.6rem;
  color: #fff;
}
.l-ticket_plan_slash {
  height: 5rem;
  width: 0.2rem;
  display: block;
  background: #fff;
  transform: rotate(18deg);
  margin: 0 1rem 0.3rem 1.4rem;
}
.l-ticket_plan_unit {
  font-size: 4.3rem;
  color: #fff;
  font-weight: 300;
  line-height: 1;
  padding-bottom: 0.5rem;
}
.l-ticket_plan_unit_small {
  font-size: 2.5rem;
  letter-spacing: -0.5rem;
}
.l-ticket.-purple {
  background: #bd8cb3;
}
.l-ticket.-purple .l-ticket_plan_menu {
  color: #bd8cb3;
}
.l-ticket.-purple2 {
  background: #d7a0c9;
}
.l-ticket.-purple2 .l-ticket_plan_menu {
  color: #d7a0c9;
}

.l-ticket.-purple2 {
  background: #d7a0c9;
}
.l-ticket.-purple2 .l-ticket_plan_menu {
  color: #d7a0c9;
}

.l-ticket.-skyBlue.-purple2 .l-ticket_off {
  color: #d7a0c9;
}
.l-ticket.-skyBlue.-purple2 .l-ticket_off_slash {
  background: #d7a0c9;
}

.l-mv_price_price .l-ticket_off_slash {
  background: #595959;
}

.l-ticket.-paleGreen {
  background-color: #b0c4b0;
}
.l-ticket.-green {
  background-color: #98c297;
}
.l-ticket.-skyBlue {
  background: #9fc6da;
}
.l-ticket.-gray {
  background: #979486;
}

.l-ticket.-gray .l-ticket_plan_menu {
  color: #979486;
}

.l-ticket.-yellow {
  background-color: #d9d081;
}

.l-ticket.-yellow .l-ticket_plan_menu {
  color: #d9d081;
}

.l-ticket.-skyBlue .l-ticket_off {
  color: #bd8cb3;
}
.l-ticket.-skyBlue .l-ticket_off_slash {
  background: #bd8cb3;
}

.l-ticket.-skyBlue_pink .l-ticket_off {
  color: #f383b0;
}
.l-ticket.-skyBlue_pink .l-ticket_off_slash {
  background: #f383b0;
}
.l-ticket.-skyBlue_rightOrange .l-ticket_off {
  color: #f38c70;
}
.l-ticket.-skyBlue_rightOrange .l-ticket_off_slash {
  background: #f38c70;
}

.l-ticket.-skyBlue_gray .l-ticket_off {
  color: #979486;
}
.l-ticket.-skyBlue_gray .l-ticket_off_slash {
  background: #979486;
}

.l-ticket.-gray_yellow .l-ticket_off {
  color: #d9d081;
}
.l-ticket.-gray_yellow .l-ticket_off_slash {
  background: #d9d081;
}

.l-ticket.-gray_yellow .l-ticket_off .l-ticket_off_gyokai{
  color: #979486;
}


.l-ticket.-purple .l-ticket_off {
  color: #d7a0c9;
}

.l-ticket.-purple .l-ticket_off .l-ticket_off_slash{
  background-color: #d7a0c9;
}


.l-ticket.-paleGreen .l-ticket_off {
  color: #b0c4b0;
}

.l-ticket.-paleGreen .l-ticket_off .l-ticket_off_gyokai{
  color: #84827b;
}

.l-ticket.-paleGreen .l-ticket_off .l-ticket_off_slash{
  background-color: #b0c4b0;
}

.l-ticket.-green .l-ticket_plan_menu{
  color: #98c297;
}

.l-ticket.-rightOrange {
  background: #f38c70;
}
.l-ticket.-rightOrange .l-ticket_plan_menu {
  color: #f38c70;
}
.l-ticket.-orange {
  background: #fc8f89;
}
.l-ticket.-orange .l-ticket_plan_menu {
  color: #fc8f89;
}
.l-ticket.-orange .l-ticket_off {
  color: #ff736c;
}
.l-ticket.-orange .l-ticket_off_slash {
  background: #ff736c;
}
.l-ticket.-deepOrange {
  background: #ff736c;
}
.l-ticket.-deepOrange .l-ticket_plan_menu {
  color: #ff736c;
}
.l-ticket.-pink {
  background: #f383b0;
}
.l-ticket.-pink .l-ticket_plan_menu {
  color: #f383b0;
}
.l-ticket_name {
  color: #fff;
  font-size: min(3.8rem, 8vw);
  text-align: center;
  margin-bottom: 2%;
}

.l-ticket_name.-cm {
  font-size: min(3rem, 6vw);
  margin: 4% auto;
}

.l-ticket_border {
  position: relative;
  width: 101%;
  height: 16px;
  margin: -8px auto 0 auto;
  left: -0.5%;
}
.l-ticket_box {
  border: 1px solid #fff;
  padding: 10%;
}
.l-ticket_off {
  background: #fff;
  padding: 1% 1% 3% 1%;
  position: relative;
  margin-top: 10%;
}
.l-ticket_off::before {
  content: "";
  position: absolute;
  top: -20%;
  left: 0;
  right: 0;
  margin: auto;
  background: url(../img/menu_arrow.png) no-repeat;
  width: 10rem;
  height: 5rem;
  background-size: 100%;
}

.l-ticket_off.-last::before {
  content: "";
  position: absolute;
  top: -20%;
  left: 0;
  right: 0;
  margin: auto;
  background: url(../img/menu_arrow2.png) no-repeat;
  width: 10rem;
  height: 5rem;
  background-size: 100%;
}

.l-ticket_off_price {
  font-size: 6.5rem;
  font-weight: 300;
  line-height: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  text-align: left;
  letter-spacing: -0.1rem;
}
.l-ticket_off_subscription {
  font-size: 1.8rem;
  letter-spacing: 0;
}
.l-ticket_off_gyokai {
  max-width: 87px;
  margin: 0 0 0;
  position: absolute;
  right: -11px;
  top: -35px;
}


.ticket_gyokai_circle {
  border-radius: 59px;
  height: 87px;
  width: 87px;
  border-radius: 50%;
}

.ticket_gyokai_circle p{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space:nowrap;
  text-align: center;
  font-size: min(6vw, 2rem);
}



.ticket_gyokai_txt{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space:nowrap;
  text-align: center;
  font-size: min(6vw, 2rem);
}

.l-ticket_off_yen {
  font-size: 4.5rem;
  font-weight: 300;
  display: flex;
  justify-content: center;
  flex-direction: column;
  line-height: 1;
  padding-bottom: 0.5rem;
}
.l-ticket_off_tax {
  font-size: 1.8rem;
}
.l-ticket_off_slash {
  height: 5rem;
  width: 0.2rem;
  display: block;
  transform: rotate(18deg);
  margin: 0 1rem 0.3rem 1.4rem;
}
.l-ticket_off_unit {
  font-size: min(5.5rem, 7.5vw);
  font-weight: 300;
  line-height: 1;
  padding-bottom: 0.5rem;
}
.l-ticket_off_unit_small {
  font-size: min(3.5rem, 5.5vw);
  letter-spacing: -0.5rem;
}
.l-ticket_times {
  max-width: 30px;
  min-width: 25px;
  margin: 3% auto;
}
.l-ticket_times img {
  width: 100%;
  height: auto;
}
.l-column {
  padding: 5%;
  margin-top: 25%;
  background: #fff;
}
.l-column_head {
  margin-top: -24%;
}
.l-column .c-txt {
  padding-top: 5%;
}

.l-priceList_head_ribbon {
  display: inline-block;
  position: relative;
  height: 45px;
  text-align: center;
  box-sizing: border-box;
  width: 100%;
}
.l-priceList_head_ribbon:before {/*左側のリボン端*/
  content: '';
  position: absolute;
  width: 10px;
  bottom: -15px;
  left: 5%;
  border: 22px solid #eb939b;
  border-left-color: transparent;/*山形に切り抜き*/
}

.l-priceList_head_ribbon:after {/*右側のリボン端*/
  content: '';
  position: absolute;
  width: 10px;
  bottom: -15px;
  right: 5%;
  border: 22px solid #eb939b;
  border-right-color: transparent;/*山形に切り抜き*/
}

.l-priceList_head_ribbon h3 {
  display: inline-block;
  position: relative;
  margin: 0;
  padding: 3px 25%;
  line-height: 40px;
  font-size: min(6vw, 3.4rem);
  z-index: 1;
  color: #FFF;
  background: #fba8b0;/*真ん中の背景色*/
}
.l-priceList_head_ribbon h3:before {
  position: absolute;
  content: '';
  top: 100%;
  left: 0;
  border: none;
  border-bottom: solid 10px transparent;
}
.l-priceList_head_ribbon h3:after {
  position: absolute;
  content: '';
  top: 100%;
  right: 0%;
  border: none;
  border-bottom: solid 10px transparent;
}

.l-priceList_list {
  border: 1px solid #595959;
  margin-top: 2rem;
}
.l-priceList_list_head {
  border-bottom: 1px solid #595959;
  text-align: center;
  line-height: 1.2;
  font-size: min(5vw, 1.8rem);
  padding: 3% 0;
}
.l-priceList_list_head.-purple {
  background: #bd8cb3;
}
.l-priceList_list_head.-orange {
  background: #fc8f89;
}
.l-priceList_list_head.-rightOrange {
  background: #f38c70;
}
.l-priceList_list_head.-pink {
  background: #f383b0;
}

.l-priceList_list_head.-lightBlue {
  background-color: #9fc6da;
}

.l-priceList dl {
  display: flex;
  flex-wrap: wrap;
  color: #595959;
}
.l-priceList dl dt {
  display: flex;
  align-items: center;
  width: 95px;
  text-align: left;
  padding-left: 2%;
  font-size: min(1.8rem, 4.5vw);
  line-height: 2;
  border-bottom: 2px solid #fff;
  font-weight: bold;
}
.l-priceList dl dt:last-child {
  border-bottom: none;
}
.l-priceList dl dd {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: calc(100% - 95px);
  text-align: right;
  padding-right: 2%;
  font-size: min(5.5vw, 2.2rem);
  line-height: 2;
  border-bottom: 2px solid #fff;
}

.l-priceList .-cm dl dt {
  display: flex;
  align-items: center;
  width: 95px;
  text-align: left;
  padding-left: 2%;
  font-size: min(1.8rem, 4.5vw);
  line-height: 2;
  border-bottom: 1px solid #595959;
  font-weight: bold;
}

.l-priceList .-cm dl dd {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: calc(100% - 95px);
  text-align: right;
  padding-right: 2%;
  font-size: min(5.5vw, 2.2rem);
  line-height: 2;
  border-bottom: 1px solid #595959;
}


.l-priceList dl dd:last-of-type {
  border-bottom: none;
}
.l-priceList dl dt:last-of-type {
  border-bottom: none;
}

.l-priceList dl dd:last-child {
  border-bottom: none;
}

.priceList_list_effect{
  padding-left: 2%;
  padding-bottom: 2%;
  display: flex;
}

.priceList_list_effect img{
  width: 20%;
  height: 20%;
  margin: -20px 20px 10px;
  max-width: 100px;
  max-height: 100px;
}

.l-point {
  background: #efd1ca;
  padding-top: 10%;
}
.l-point_head {
  position: relative;
  font-size: 2.4rem;
  color: #fc8f89;
  display: flex;
  align-items: center;
  border-bottom: 2px solid #fc8f89;
  padding-bottom: 0.5rem;
  margin-bottom: 1rem;
}
.l-point_head::before {
  content: "";
  width: 2.8rem;
  height: 2.8rem;
  background: url(../img/point_icon_check.png) no-repeat center center;
  background-size: 100%;
  margin-right: 0.5rem;
  display: block;
}
.l-flow {
  background: #fff;
}
.l-flow_box {
  border: 1.5px solid #fba8b0;
  border-radius: 0 1rem 1rem 1rem;
  background: #fff;
  padding-bottom: 1rem;
  margin-bottom: 1.6rem;
}
.l-flow_num {
  color: #fff;
  background: #fba8b0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 3.5rem;
  padding: 0.2rem;
  font-size: 2.4rem;
  border-radius: 0 0 0.5rem 0;
}
.l-flow_head {
  font-size: 2.5rem;
  color: #fba8b0;
  margin-top: -2rem;
  line-height: 1.2;
}
.l-flow_ttl {
  width: 80%;
  max-width: 280px;
}
.l-flow_list {
  display: flex;
  background: #f6e9e2;
  margin-bottom: 5rem;
  position: relative;
}
.l-flow_list p {
  display: flex;
  width: 100%;
}
.l-flow_list:after {
  content: "";
  background: url(../img/flow_arrow.png) no-repeat center center/100%;
  left: 0;
  right: 0;
  top: calc(100% + 1.5rem);
  margin: auto;
  width: 5rem;
  height: 2rem;
  position: absolute;
}
.l-flow_list:nth-last-of-type(1) {
  margin-bottom: 0;
}
.l-flow_list:nth-last-of-type(1):after {
  display: none;
}
.l-flow_step {
  background: #fc8f89;
  font-size: 2.2rem;
  color: #fff;
  width: 90px;
  padding: 2% 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 300;
}
.l-flow_txt {
  width: calc(100% - 90px);
  font-size: 2.2rem;
  padding: 1rem 1.5rem;
  line-height: 1.5;
}
.l-qa {
  background: #fff;
}
.l-qa_ttl {
  width: 80%;
  max-width: 220px;
}
.l-qa_box {
  background: #fdede2;
  padding: 5%;
  margin-bottom: 2rem;
}
.l-qa_box_head {
  font-size: 2.2rem;
  color: #fc8f89;
  display: flex;
  align-items: center;
  line-height: 1.4;
}
.l-qa_box_head::before {
  content: "";
  width: 3rem;
  height: 3rem;
  display: block;
  background: url(../img/qa_icon.png) no-repeat center center/100%;
  margin-right: 0.5rem;
  padding: 2rem;
}
.l-access {
  background: #fff;
}/*# sourceMappingURL=style.css.map */