@charset "UTF-8";
/*-----------------------------------------------------------------------
 modifier
----------------------------------------------------------------------- */
.is-inline_block_wrap {
  letter-spacing: -0.4em;
}
.is-br {
  display: block;
}
.is-split {
  display: inline-block;
}
.is-pc_br {
  display: block;
}
.is-sp_br {
/*  display: none; */ /* sp to pc */
}
.is-font_bold {
  font-weight: bold;
}
.is-sp_img {
  display: none;
}
.is-before_icon::before,
.is-after_icon::after {
  background-repeat: no-repeat;
  background-size: 100% auto;
  content: '';
  display: inline-block;
  vertical-align: middle;
}
.is-before_symbol::before,
.is-after_symbol::after {
  content: '';
  display: inline-block;
  position: relative;
  vertical-align: middle;
}
.is-disabled {
  display: none;
}
@media screen and (max-width: 583px) {
  .is-pc_br {
    display: none;
  }
  .is-pc_img {
    display:none;
  }
  .is-sp_img {
    display: block;
    margin: 0 auto;
  }
}


/*-----------------------------------------------------------------------
 common
----------------------------------------------------------------------- */
/* content settings */
html {
  font-size: 100%;
}
header{
  border-bottom: 4px solid rgb(15, 79, 107, 0.2);
}
@media screen and (max-width: 479px) {
  header{
    display: none;
  }
}
main a {
  display: inline-block;
  text-decoration: none;
}
main {
  padding: 0
}
@media screen and (min-width: 960px) {
  .nonPC {
    display: none !important;
  }
  .nonSP {
    display: inline;
  }
}
@media screen and (max-width: 959px) {
  .nonPC {
    display: inline;
  }
  .nonSP {
    display: none !important;
  }
}
/* font settings -----*/
main {
	font-family: 'M PLUS 1p', sans-serif;
}
main .is-font_alphanum {
	font-family: 'M PLUS 1p', sans-serif;
}
/* content settings -----*/
.container {
  margin: 0 auto;
}
.com-inner_wrap {
  margin: 0 auto;
  max-width: 1000px;
  width: 88%;
}
.com-order_btn {
  margin: 0 auto;
  width: 56.8%;
}
@media screen and (max-width: 767px) {
  .com-inner_wrap {
    max-width: none;
    width: 92%;
  }
  .com-img_wrap {
    margin: 0 0 5%;
  }
  .com-order_btn {
    width: 60%;
  }
}
@media screen and (max-width: 583px) {
  .com-inner_wrap {
    max-width: 520px;
    width: 92%;
  }
  .com-inner {
    padding: 10% 0 7%;
  }
  .com-head {
    margin: 0 auto 5%;
  }
  .com-order_btn {
    width: 76%;
  }
}
@media screen and (max-width: 479px) {
  .com-order_btn {
    width: 90%;
  }
}
.header__wrap{
  display: flex;
  justify-content: space-between;
  max-width: 1100px;
  height: 64px;
  margin: 0 auto;
  align-items: center;
}
.header__wrap a{
  height: 48px;
  width: auto;
}
/*-----------------------------------------------------------------------
main visual
*----------------------------------------------------------------------- */
.main_visual{
	background: url(../img/bg_main_visual--pc.jpg) center/contain no-repeat;
	background-size: cover;
	margin: 0 auto;
  padding-bottom: 3em;
  position: relative;
}
.--main_offpeak{
  background: url(../img/bg_main_visual_offpeak--pc.jpg) top/cover no-repeat;
}
.main_visual--info{
	max-width: 960px;
  height: 1000px;
  margin: 0 auto;
  margin-bottom: 2em;
	position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.main_visual--info p{
  text-align: left;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.8;
  filter: 
  drop-shadow(0px 0px 1px rgb(255, 255, 255)) 
  drop-shadow(0px 0px 2px rgb(255, 255, 255)) 
  drop-shadow(0px 0px 3px rgb(255, 255, 255)) 
  drop-shadow(0px 0px 4px rgb(255, 255, 255)) 
  drop-shadow(0px 0px 5px rgb(255, 255, 255)) 
  drop-shadow(0px 0px 6px rgb(255, 255, 255))
  drop-shadow(0px 0px 7px rgb(255, 255, 255)) ;
}
.--text_offpeak{
  margin-bottom: 2em;
}
.main_visual--info .small{
  font-size: 1.0rem;
}
.main_visual--content{
  max-width: 1100px;
  background-color: #fff;
  box-shadow: 0 0 5px rgb(67, 97, 181, 0.1);
  margin: 0 auto;
  overflow: hidden;
}
.main_visual--content_title{
  font-size: 3.2rem;
  font-weight: 900;
  margin: 1.5em;
}
.main_visual--content_title .pink_word{
  color: #ED1E79;
  background: linear-gradient(transparent 55%, #FFE9F5 55%, #FFE9F5 95%, transparent 95%);
}
.main_visual--content_wrap{
  display: flex;
  justify-content: space-evenly;
}
.main_visual--content_innner{
  height: 480px;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  align-items: center;
}
.main_visual--innner_title{
  margin: 0;
  font-size: 2.0rem;
  font-weight: bold;
  line-height: 1.2;
  color: #ED1E79;
}
.main_visual--innner_info{
  margin: 0;
  font-size: 1.0rem;
}
.main_visual--table_title{
  font-size: 2.6rem;
  font-weight: bold;
  color: #fff;
  background-color: #ED1E79;
  width: 60%;
  margin: 2.5em auto 1em;
}
.main_visual--table_wrap{
  display: flex;
  flex-direction: column;
  max-width: 856px;
  margin-left: 80px;
  margin-bottom: 80px;
  font-size: 1.6rem;
  font-weight: bold;
  position: relative;
}
.main_visual--table_wrap::after{
  position: absolute;
  top: 0;
  right: -120px;
  content: url(../img/main_visual--table_imoto.png);
}
.main_visual--table_wrap .--first_line{
  margin-left: auto;
  align-items: flex-end;
}
.main_visual--table_wrap p{
  margin: 0;
}
.main_visual--table_inner{
  display: flex;
  align-items: center;
  flex-direction: row;
}
.r01c02{
  color: #fff;
  background-color: #2E3192;
  width: 328px;
  height: auto;
  padding: 16px 0;
  border-radius: 24px 24px 0 0;
}
.r01c03{
  font-size: 2.4rem;
  color: #FFFF00;
  background-color: #ED1E79;
  width: 384px;
  height: auto;
  padding: 20px 0;
  border-radius: 24px 24px 0 0;
  position: relative;
}
.r01c03::after{
  position: absolute;
  top: -56px;
  right: -48px;
  content: url(../img/main_visual--table_effect.png);
}
.c01{
  color: #fff;
  background-color: #2E3192;
  width: 144px;
  padding: 40px 0;
}
.c02{
  width: 328px;
  border-bottom: 1px solid #2E3192;
  color: #2E3192;
  padding: 39px 0;
}
.c03{
  width: 384px;
  border-right: 4px solid #ED1E79; 
  border-left: 4px solid #ED1E79; 
  border-bottom: 1px solid #ED1E79;
  color: #ED1E79;
  background-color: #FFFCD1;
  padding: 19px 0;
}
.r02{
  border-radius: 16px 0 0 0;
  border-bottom: 1px solid #fff;
}
.r04{
  border-radius: 0 0 0 16px;
  border-top: 1px solid #fff;
}
.row4{
  padding: 19px 0;
}
.r-3{
  padding: 18px 0;
}
.r-4{
  padding: 38px 0;
  border-bottom: 4px solid #ED1E79;
}
@media screen and (max-width: 584px) {
}

@keyframes anchorMove {
	0% {
    left: 0%;
    transform:scale(0.4);
	}
	60% {
    left:0%;
    transform:scale(1.3);
  }
  100% {
    left:0%;
    transform:scale(1);
	}
}
@-webkit-keyframes anchorMove {
	0% {
    left: 0%;
    transform:scale(0.4);
	}
	60% {
    left:0%;
    transform:scale(1.3);
  }
  100% {
    left:0%;
    transform:scale(1);
	}
}

@keyframes backanime {
  0%{
     transform: rotate(0deg);
    }
 100%{
     transform: rotate(360deg);
    }
 }

@media screen and (max-width: 768px) {
	.main_visual {
    background: url(../img/bg_main_visual--sp.jpg?20250414v2) top / 100% auto no-repeat;
  }
  .--main_offpeak {
    background: url(../img/bg_main_visual_offpeak--sp.jpg) top/ 100% auto no-repeat;
  }
  .main_visual--info {
    height: 170vw;
  }
  .main_visual--info p{
    font-size: 0.975rem;
    width: calc(100% - 10%);
    margin: 0 auto 1.5em;
    letter-spacing: 0;
  }
  .--text_offpeak {
    margin: 0 auto 1em;
  }
  .main_visual--info .small{
    font-size: 0.75rem;
  }
  .main_visual--info a{
    width: calc(100% - 5%);
    margin: 0 auto;
  }
  .main_visual--content{
    width: calc(100% - 6%);

  }
  .main_visual--content_title{
    font-size: 2.0rem;
    margin: 0.5em 0;
  }
  .main_visual--content_wrap{
    flex-direction: column;
  }
  .main_visual--content_innner{
    justify-content: space-between;
    margin-bottom: 2em;
    height: auto;
  }
  .main_visual--content_innner:last-child{
    margin-bottom: 0;
  }
  .main_visual--innner_title{
    font-size: 1.6rem;
    margin: 0.5em 0;
  }
  .main_visual--table_title{
    font-size: 1.4rem;
    width: calc(100% - 10%);
    margin: 1.5em auto;
  }
  .main_visual--table_wrap{
    width: calc(100% - 5%);
    margin: 0 auto 2em;
    font-size: 0.85rem;
  }
  .main_visual--table_wrap::after{
    display: none;
  }
  .r01c02{
    width: 35vw;
    padding: 12px 0;
    border-radius: 16px 16px 0 0;
  }
  .r01c03{
    width: 40vw;
    font-size: 1.1rem;
    padding: 16px 0;
    border-radius: 16px 16px 0 0;
  }
  .r01c03::after{
    content: "";
    background-image: url(../img/main_visual--table_effect.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    top: -24px;
    right: -12px;
    width: 28px;
    height: 20px;
  }
  .c01{
    writing-mode: vertical-rl;
    width: 14.5vw;
    padding: 56px 16px;
    text-align: center;
    line-height: 2;
  }
  .c02{
    width: 35vw;
    padding: 75px 0;
  }
  .c03{
    width: 40vw;
    padding: 53px 0;
  }
  .row4{
    padding: 53px 0px;
  }
  .r-3{
    padding: 64px 0;
  }
  .r-4{
    padding: 73.5px 0;
  }
}
@media screen and (max-width: 405px) {
  .main_visual--info p{
  }
}
@media screen and (max-width: 380px) {
  .main_visual--info p{
    margin: 0 auto 0.5em;
    letter-spacing: -1px;
  }
}
/*-----------------------------------------------------------------------
 service
----------------------------------------------------------------------- */
.service{
  background: url(../img/bg_service--pc.jpg) center/contain no-repeat;
	background-size: cover;
	margin: 0 auto;
  padding: 5em;
  position: relative;
}
.service--info_title{
  font-size: 3.2rem;
  font-weight: 900;
  color: #fff;
}
.service--info_wrap{
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
}
.service--info_wrap p{
  text-align: left;
  margin: 0;
  background-color: #f4fcfe;
  max-width: 720px;
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 2;
  padding: 32px 24px;
  border: 12px solid #eaf3fa;
}
.service--info_wrap p::after{
  position: absolute;
  top: -48px;
  right: 0px;
  content: url(../img/service--info_imoto_pc.png);
  z-index: 1;
}
.service--content{
  max-width: 1100px;
  margin: 2em auto 0;
  position: relative;
  z-index: 2;
}
.service--content_title{
  margin: 0 auto;
  padding: 2% 1%;
  width: 55%;
  font-size: 2.0rem;
  font-weight: bold;
  background-color: #2E3192;
  color: #fff;
  position: relative;
  top: 1.5em;
}
.service--content_wrap{
  background-color: #fff;
  padding: 5em 0 2.5em;
  border-radius: 24px;
  display: flex;
  justify-content: space-around;
}
.service--content_inner{
  position: relative;
}
.service--content_inner p{
  background-color: #2e3192;
  color: #FCEE21;
  margin: 0.5em 0 0;
  padding: 0.25em 0;
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 1.2;
}
.inner_arrow01::after{
  position: absolute;
  top: 50%;
  right: -56px;
  transform: translateY(-50%);
  content: url(../img/service--inner_arrow01.png);
}
.inner_arrow02:after{
  position: absolute;
  top: 50%;
  right: -56px;
  transform: translateY(-50%);
  content: url(../img/service--inner_arrow02.png);
}
.inner_arrow03::after{
  position: absolute;
  top: 50%;
  right: -56px;
  transform: translateY(-50%);
  content: url(../img/service--inner_arrow03.png);

}
@media screen and (max-width: 768px) {
  .service{
    padding: 2em 3%;
  }
  .service--info_title{
    font-size: 2.0rem;
    margin-bottom: 0.75em;
  }
  .service--info_wrap p{
    font-size: 1.0rem;
    padding: 2%;
    border: 8px solid #eaf3fa;
    letter-spacing: 1px;
    line-height: 1.8;
  }
  .service--info_wrap p::after{
    content: "";
    background-image: url(../img/service--info_imoto_sp.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    top: 50vw;
    left: 0px;
    width: 94vw;
    height: 70vw;
  }
  .service--content{
    margin: 15em auto 0;
  }
  .service--content_title{
    font-size: 1.1rem;
    width: calc(100% - 10%);
  }
  .service--content_wrap{
    flex-wrap: wrap;
    justify-content: space-evenly;
    padding: 3em 0 2em;
  }
  .service--content_inner{
    width: 40%;
  }
  .service--content_inner img{
    width: 80%;
  }
  .service--content_inner p{
    font-size: 1.0rem;
    width: 80%;
    margin: 1em auto;
  }
  .inner_arrow01::after{
    right: -28px;
  }
  .inner_arrow02:after{
    display: none;
  }
  .inner_arrow03::before{
    position: absolute;
    top: 50%;
    left: -8px;
    transform: translateY(-50%);
    content: url(../img/service--inner_arrow02.png);
  }
  .inner_arrow03::after{
    right: -28px;
  }
}
/*-----------------------------------------------------------------------
 share
----------------------------------------------------------------------- */
.share{
  background: url(../img/bg_share--pc.jpg) center/contain no-repeat;
	background-size: cover;
	margin: 0 auto;
  padding: 5em;
  position: relative;
}
.share--info_title{
  font-size: 3.2rem;
  font-weight: 900;
  color: #F15A24;
}
.share--info_description{
  font-size: 1.8rem;
  font-weight: bold;
  margin: 0;
}
.share--info_wrap{
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
}
.share--content{
  max-width: 1100px;
  margin: 0 auto;
  margin-top: 4em;
  padding: 4em 2em;
  background-color: #fff;
  display: flex;
  justify-content: space-evenly;
  align-items: center;
  border-radius: 32px;
  box-shadow: 0 0 5px rgb(175, 104, 69, 0.1);
}
.share--content_img_sp{
  display: none;
}
.share--content_wrap{
  display: flex;
  flex-direction: column;
  width: 60%;
}
.share--content_inner{
  display: flex;
  align-items: center;
  text-align: left;
  margin-bottom: 2em;
}
.share--content_inner:last-child{
  margin-bottom: 0;
}
.share--content_inner--wrap{
  margin-left: 2em;
}
.share--content_inner--title{
  font-size: 1.8rem;
  font-weight: bold;
  color: #F15A24;
  margin: 0;
}
.share--content_inner--text{
  font-size: 1.0rem;
  margin: 1em 0 0;
}
@media screen and (max-width: 768px) {
  .share{
    padding: 2em 3%;
  }
  .share--info_title{
    font-size: 2.0rem;
    letter-spacing: 0;
    margin-bottom: 0.75em;
  }
  .share--info_description{
    text-align: left;
    font-size: 1.0rem;
  }
  .share--content{
    padding: 2em 1em;
    margin-top: 2em;
  }
  .share--content_img_pc{
    display: none;
  }
  .share--content_img_sp{
    display: block;
    margin: 3em auto 0;
    width: calc(100% - 20%);
  }
  .share--content_wrap{
    width: 100%;
  }
  .share--content_inner{
    margin-bottom: 1.5em;
    align-items: flex-start;
  }
  .share--content_inner img{
    width: 20%;
  }
  .share--content_inner--wrap{
    margin-left: 1em;
  }
  .share--content_inner--title{
    font-size: 1.5rem;
  }
  .share--content_inner--text{
    margin: 0.5em 0 0;
  }
}
/*-----------------------------------------------------------------------
 share
----------------------------------------------------------------------- */
.payment{
  background: url(../img/bg_payment--pc.jpg) center/contain no-repeat;
	background-size: cover;
	margin: 0 auto;
  padding: 5em;
  position: relative;
}
.payment--info_title{
  font-size: 3.2rem;
  font-weight: 900;
  color: #1E2584;
}
.payment--info_description{
  font-size: 1.8rem;
  font-weight: bold;
  margin: 0;
}
.payment--content{
  max-width: 1100px;
  margin: 0 auto;
  margin-top: 4em;
  display: flex;
  justify-content: space-around;
}
.payment--content_inner{
  background-color: #fff;
  box-shadow: 0 0 5px rgb(68, 126, 178, 0.1);
  border-radius: 24px;
  padding: 2.5em 2em;
}
.payment--content_inner--title{
  font-size: 1.6rem;
  font-weight: bold;
  color: #1E2584;
  margin: 0;
}
.payment--content_inner--text{
  font-size: 1.0rem;
  margin: 2.5em 0;
}
@media screen and (max-width: 768px) {
  .payment{
    background: url(../img/bg_payment--sp.jpg) center/contain no-repeat;
    background-size: cover;
    margin: 0 auto;
    padding: 2em 3%;
    position: relative;
  }
  .payment--info_title{
    font-size: 2.0rem;
    margin-bottom: 0.75em;
  }
  .payment--info_description{    
    font-size: 1.0rem;
  }
  .payment--content{
    margin-top: 2em;
    flex-direction: column;
  }
  .payment--content_inner{
    width: 90%;
    margin: 0 auto 2em;
  }
  .payment--content_inner--title{
    margin: 1em 0;
    font-size: 1.5rem;
  }
  .payment--content_inner--text{
    margin: 2em 0;
  }
}
/*-----------------------------------------------------------------------
 reserve
----------------------------------------------------------------------- */
.reserve{
  background: url(../img/reserve--pc.jpg) center/contain no-repeat;
	background-size: cover;
	margin: 0 auto;
  padding: 5em;
  position: relative;
}
.reserve--info_wrap{
  max-width: 1100px;
  margin: 0 auto;
  text-align: left;
  position: relative;
}
.reserve--info_wrap::after{
  position: absolute;
  top: -20vh;
  right: -10vw;
  content: url(../img/reserve--info_imoto_pc.png);
}
.reserve--info_inner{
  max-width: 610px;
  text-align: center;
  margin-bottom: 3em;
}
.reserve--info_wrap_sp{
  display: none;
}
@media screen and (max-width: 768px) {
  .reserve{
    background: url(../img/reserve--sp.jpg) center/contain no-repeat;
    background-size: cover;
    margin: 0 auto;
    padding: 0;
    height: 520px;
    position: relative;
  }
  .reserve--info_wrap{
    display: none;
  }
  .reserve--info_wrap_sp{
    display: block;
    position: absolute;
    width: 100vw;
    height: 100vh;
    top: -40px;
    right: 0;
    content: "";
    background-image: url(../img/reserve--info_imoto_sp.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: top right;
  }
}
/*-----------------------------------------------------------------------
 scroll_btn
----------------------------------------------------------------------- */
@media screen and (max-width: 768px) {
  .scroll_btn{
    background: url(../img/reserve_btn--img.png) top / 100% auto no-repeat;
    background-size: cover;
    height: 160px;
    width: 100vw;
    position: fixed;
    left: 0;
    right: 0;
    bottom: -160px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    z-index: 5;
    transition: all 0.5s ease-in-out;
  }
  .scroll_btn a{
    width: calc(100% - 5%);
    margin-bottom: 1em;
  }
  .scroll_btn.show {
    bottom: 0;
  }
  .scroll_btn.fixed {
    position: fixed;
    bottom: 0;
  }
}
