@charset "utf-8";
#mv {
  background: #c9e0ea;
  background-size: contain;
}
#mv > div {
  width: 1200px;
  height: calc(100vh - 75px);
  min-width: 1200px;
  margin: 0 auto;
  padding-top: 60px;
  text-align: center;
  background: url("../images/mv.jpg") 50% 100% no-repeat;
}
#mv > div > h2 {
  margin: 20px 0 0;
  font-size: 4rem;
  font-weight: 700;
  font-family: var(--ttl-font);
  line-height: 1.4;
}
#mv > div > h2 > br {
  display: none;
}
#mv > div > h2 > strong {
  color: var(--sub-color3);
}
#mv > div > h2 > span {
  font-size: 0.5em;
  vertical-align: super;
}
#mv > div > .note {
  font-size: 1.8rem;
}
#mv > div > div {
  width: 65%;
  margin: 30px auto 0;
  padding: 20px;
  background: rgba(255,255,255,0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  border-radius: 10px;
}
#mv > div > div h3 {
  width: 100%;
  margin-bottom: 10px;
  font-size: 1.6rem;
  font-weight: 700;
}
#mv > div > div > dl {
  text-align: center;
  line-height: 1.5;
}
#mv > div > div > dl dt {
  font-size: 1.6rem;
}
#mv > div > div > dl dd {
  font-size: 2.2rem;
  font-weight: 700;
}
#mv > div > div > dl:nth-of-type(3) dd {
  color: var(--sub-color3);
}
#mv > div > div > p {
  margin: 0 20px;
  font-size: 2.5rem;
  font-weight: 700;
}
#mv_limited_icon {
  padding: 10px 25px;
  font-size: 1.8rem;
  font-weight: 700;
  font-family: var(--ttl-font);
  color: #fff;
  display: inline;
  border-radius: 100px;
  background: var(--base-color);
}

@media screen and (max-width:768px) {
  #mv > div {
    width: 100%;
    height: calc(100vh - 70px);
    min-width: 100%;
    margin: 0;
    padding: 40px 15px 0;
    text-align: left;
    background-size: cover;
  }
  #mv > div > h2 {
    font-size: 3.3rem;
    line-height: 1.5;
  }
  #mv > div > h2 > br {
    display: block;
  }
  #mv > div > h2 > span {
    font-size: 0.4em;
  }
  #mv > div > .note {
    font-size: 1.1rem;
  }  
  #mv > div > div {
    width: 100%;
    margin: 20px 0 0;
    padding: 15px;
    border-radius: 5px;
    justify-content: space-between;
  }
  #mv > div > div h3 {
    font-size: 1.4rem;
  }
  #mv > div > div > dl {
    text-align: center;
    line-height: 1.5;
  }
  #mv > div > div > dl dt {
    font-size: 1.1rem;
  }
  #mv > div > div > dl dd {
    font-size: 1.6rem;
  }
  #mv > div > div > p {
    margin: 0;
    font-size: 1.6rem;
    font-weight: 700;
  }
  #mv_limited_icon {
    padding: 7px 15px;
    font-size: 1.4rem;
  }
}

/***** point *****/
#point {
  background: url("../images/point_bk_bottom.svg") 0 100% no-repeat var(--base-color);
  background-size: contain;
  position: relative;
}
#point > div {
  background: url("../images/point_bk_top.svg") 0 0 no-repeat;
  background-size: contain;
}
#point > div > div {
  width: 1200px;
  min-width: 1200px;
  margin: 0 auto;
  padding: 100px 0;
}
#point_limited_icon {
  width: 210px;
  margin: 0 auto;
  padding: 3px 0;
  font-size: 1.5rem;
  font-weight: 700;
  font-family: var(--ttl-font);
  text-align: center;
  color: var(--base-color);
  border-radius: 100px;
  background: #fff;
}
#point_box {
  display: flex;
  justify-content: space-between;
}
#point_box > dl {
  width: 31%;
  padding: 40px;
  text-align: center;
  background: #fff;
  border-radius: 5px;
}
#point_box > dl > dt {
  width: 90px;
  margin: 0 auto;
  font-size: 1.6rem;
  font-weight: 700;
  font-family: var(--ttl-font);
  color: #fff;
  background: var(--base-color);
  border-radius: 100px;
}
#point_box > dl > dd > figure {
  margin-top: 20px;
}
#point_box > dl > dd > figure img {
  height: 100px;
}
#point_box > dl > dd > p {
  margin-top: 10px;
  font-size: 2.2rem;
  font-weight: 700;
  font-family: var(--ttl-font);
}
#point_box > dl > dd br {
  display: none;
}
@media screen and (max-width:768px) {
  #point > div > div {
    width: 100%;
    min-width: 100%;
    margin: 0;
    padding: 40px 15px;
  }
  #point_box > dl {
    padding: 15px;
  }
  #point_box > dl > dt {
    width: 80px;
    font-size: 1.4rem;
  }
  #point_box > dl > dd > figure {
    display: none;
  }
  #point_box > dl > dd > figure img {
    height: 60px;
  }
  #point_box > dl > dd > p {
    font-size: 1.6rem;
  }
  #point_box > dl > dd br {
    display: block;
  }
}


/***** title *****/
.ttl {
  margin-bottom: 40px;
  font-size: 3.5rem;
  font-weight: 700;
  font-family: var(--ttl-font);
  letter-spacing: 0.1em;
  text-align: center;
  line-height: 1.5;
}
.ttl > span {
  font-size: 1.7rem;
  font-weight: 500;
  display: block;
}
.ttl_wt {
  color: #fff;
}
.ttl_bl {
  color: var(--base-color);
}
.calculator_ttl {
  margin: 40px 0 15px;
  font-size: 2.8rem;
  font-weight: 500;
  font-family: var(--ttl-font);
  color: var(--base-color);
}
@media screen and (max-width:768px) {
  .ttl {
    margin-bottom: 25px;
    font-size: 2.8rem;
  }
  .ttl > span {
    font-size: 1.7rem;
    font-weight: 500;
    display: block;
  }
  .calculator_ttl {
    margin: 30px 0 10px;
    font-size: 2.2rem;
    font-weight: 500;
    font-family: var(--ttl-font);
    color: var(--base-color);
  }
}

/***** reserve *****/
#reserve_box {
  margin-top: 40px;
  padding: 40px 50px 40px 130px;
  border-radius: 100px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: url("../images/reserve_icon.svg") 40px 50% no-repeat var(--base-color);
  background-size: 70px;
}
#reserve_box > div > h3 {
  font-size: 2.6rem;
  font-weight: 700;
  font-family: var(--ttl-font);
  color: #fff;
}
#reserve_box > div > p {
  margin-top: 7px;
  font-size: 1.6rem;
  line-height: 1.5;
  color: #fff;
}
#reserve_box > ul {
  width: 55%;
  display: flex;
  justify-content: space-between;
}
#reserve_box > ul li {
  width: 48%;
}
#reserve_box > ul li a {
  padding: 15px 0;
  font-size: 2rem;
  font-weight: 700;
  text-align: center;
  text-decoration: none;
  background: #fff;
  display: block;
  border-radius: 100px;
  transition: 0.5s;
}
#reserve_box > ul li:nth-child(1) a span {
  padding-left: 34px;
  color: var(--line-color);
  background: url("../images/line_icon_gr.svg") 0 50% no-repeat;
  background-size: 26px;
}
#reserve_box > ul li:nth-child(1) a:hover {
  background: #dcfae8;
}
#reserve_box > ul li:nth-child(2) a span {
  padding-left: 30px;
  color: var(--base-color);
  background: url("../images/tel_icon_bl.svg") 0 50% no-repeat;
  background-size: 22px;
}
#reserve_box > ul li:nth-child(2) a:hover {
  background: #e0f5fe;
}
@media screen and (max-width:768px) {
  #reserve_box {
    margin-top: 20px;
    padding: 90px 20px 20px;
    border-radius: 5px;
    display: block;
    align-items: center;
    background: url("../images/reserve_icon.svg") 50% 20px no-repeat var(--base-color);
    background-size: 60px;
  }
  #reserve_box > div > h3 {
    font-size: 2rem;
    text-align: center;
  }
  #reserve_box > div > p {
    font-size: 1.4rem;
    text-align: center;
  }
  #reserve_box > ul {
    width: 100%;
    margin-top: 20px;
  }
  #reserve_box > ul li a {
    padding: 7px 0;
    font-size: 1.6rem;
  }
  #reserve_box > ul li:nth-child(1) a span {
    padding-left: 28px;
    background-size: 22px;
  }
  #reserve_box > ul li:nth-child(2) a span {
    padding-left: 26px;
    background-size: 20px;
  }
}

/***** fee *****/
#fee {
  width: 1200px;
  min-width: 1200px;
  margin: 0 auto;
  padding: 70px 0;
}
#type {
  margin-top: 30px;
  display: flex;
  justify-content: space-between;
}
#type > dl {
  width: 49%;
  padding: 40px;
  background: #fff;
  border-radius: 10px;
}
#type > dl > dt {
  font-size: 2.5rem;
  font-weight: 700;
  font-family: var(--ttl-font);
  color: var(--base-color);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#type > dl > dt > span {
  font-size: 2.2rem;
  color: #000;
}
#type > dl > dd {
  margin-top: 10px;
  font-size: 1.8rem;
}
.limited_box {
  margin-bottom: 20px;
  padding: 40px;
  border-radius: 10px;
  background: var(--sub-color4);
}
.limited_icon {
  width: 13em;
  padding: 3px 0;
  font-size: 1.6rem;
  font-weight: 500;
  text-align: center;
  color: #fff;
  background: var(--base-color);
  border-radius: 100px;
}
.limited_box > dl {
  margin-top: 10px;
}
.limited_box > dl > dt {
  font-size: 2.2rem;
  font-weight: 700;
  font-family: var(--ttl-font);
}
.limited_box > dl > dd strong {
  color: var(--sub-color3);
}
.type_example_ttl {
  margin-top: 20px;
  padding: 5px;
  font-size: 1.5rem;
  font-weight: 700;
  text-align: center;
  color: var(--base-color);
  background: var(--sub-color2);
  border-radius: 5px;
}
.type_example {
  margin-top: 15px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.type_example > dl {
  text-align: center;
  line-height: 1.5;
}
.type_example > dl dt {
  font-size: 1.4rem;
}
.type_example > dl dd {
  font-size: 2.2rem;
  font-weight: 700;
}
.type_example > dl:nth-of-type(2) dd {
  color: var(--sub-color3);
}
.type_example > dl:nth-of-type(3) dd {
  color: var(--base-color);
}
.type_example > p {
  font-size: 2.5rem;
  font-weight: 700;
}
@media screen and (max-width:768px) {
  #fee {
    width: 100%;
    min-width: 100%;
    margin: 0;
    padding: 40px 15px;
  }
  #type {
    display: block;
  }
  #type > dl {
    width: 100%;
    margin-bottom: 15px;
    padding: 20px;
    border-radius: 5px;
  }
  #type > dl > dt {
    font-size: 2rem;
    display: block;
  }
  #type > dl > dt > span {
    font-size: 1.8rem;
    display: block;
  }
  #type > dl > dd {
    margin-top: 10px;
  }
  .limited_box {
    margin-bottom: 15px;
    padding: 20px;
    border-radius: 5px;
  }
  .limited_icon {
    padding: 3px 0;
    font-size: 1.4rem;
  }
  .limited_box > dl dt {
    font-size: 2rem;
  }
  .type_example > dl dt {
    font-size: 1.1rem;
  }
  .type_example > dl dd {
    font-size: 1.6rem;
  }
  .type_example > p {
    font-size: 1.6rem;
  }
}

/***** choose *****/
#choose {
  width: 1200px;
  margin: 0 auto;
}
#choose_box {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
#choose_box > div {
  width: 32%;
  margin-right: 2%;
  margin-bottom: 2%;
  padding: 35px;
  box-shadow: 0 0 10px 1px rgba(150, 150, 150, .2);
  border-radius: 5px;
}
#choose_box > div:nth-child(3n) {
  margin-right: 0;
}
#choose_box > div > p {
  width: 6em;
  margin: 0 auto;
  padding: 10px 0;
  font-size: 1.6rem;
  font-weight: 700;
  font-family: var(--ttl-font);
  text-align: center;
  line-height: 1;
  color: #fff;
  background: var(--base-color);
  border-radius: 100px;
}
#choose_box > div > dl {
  margin-top: 15px;
}
#choose_box > div > dl dt {
  font-size: 2.2rem;
  font-weight: 700;
  font-family: var(--ttl-font);
  text-align: center;
  color: var(--base-color);
}
#choose_box > div > dl dd {
  margin-top: 10px;
  font-size: 1.8rem;
}
@media screen and (max-width:768px) {
  #choose {
    width: 100%;
    padding: 0 15px;
  }
  #choose_box {
    margin-top: 40px;
    display: block;
  }
  #choose_box > div {
    width: 100%;
    margin-right: 0;
    margin-bottom: 40px;
    padding: 20px;
    box-shadow: 0 0 10px 1px rgba(150, 150, 150, .2);
    border-radius: 5px;
  }
  #choose_box > div > p {
    margin-top: -35px;
  }
  #choose_box > div > dl dt {
    font-size: 2rem;
  }
  #choose_box > div > dl dd {
    margin-top: 5px;
    font-size: 1.6rem;
  }
}

/***** flow *****/
#flow {
  margin-top: 80px;
  padding: 80px 0;
  background: var(--sub-color4);
}
#flow > div {
  width: 1200px;
  min-width: 1200px;
  margin: 0 auto;
}
#flow_box {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#flow_box > dl {
  padding: 30px;
  background: #fff;
  border-radius: 10px;
}
#flow_box > dl dt {
  margin-bottom: 15px;
  padding-bottom: 5px;
  font-size: 2.2rem;
  font-weight: 700;
  font-family: var(--ttl-font);
  color: var(--base-color);
  border-bottom: var(--base-color) 1px solid;
}
#flow_box > p {
  color: var(--base-color);
  line-height: 1;
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent;
  border-width: 30px 15px;
  border-left-color: currentColor;
  border-right: 0;
}
#flow_box > dl dd {
  font-size: 1.8rem;
}
@media screen and (max-width:768px) {
  #flow {
    margin-top: 40px;
    padding: 40px 15px;
  }
  #flow > div {
    width: 100%;
    min-width: 100%;
    margin: 0 auto;
  }
  #flow_box {
    display: block;
  }
  #flow_box > dl {
    padding: 20px;
  }
  #flow_box > dl dt {
    font-size: 2rem;
    text-align: center;
  }
  #flow_box > dl dd {
    font-size: 1.6rem;
    text-align: center;
  }
  #flow_box > p {
    color: var(--base-color);
    line-height: 1;
    width: 0;
    height: 0;
    margin: 15px auto;
    border-style: solid;
    border-color: transparent;
    border-width: 15px 40px;
    border-top-color: currentColor;
    border-bottom: 0;
  }  
}

/***** faq *****/
#faq {
  width: 1200px;
  margin: 80px auto;
  padding: 50px;
  border-radius: 10px;
  box-shadow: 0 0 20px 1px rgba(150, 150, 150, .2);
}
.faq_box {
  margin-bottom: 30px;
}
.faq_box:nth-of-type(1) {
  padding-top: 30px;
  border-top: #ddd 1px solid;
}
.faq_box dl {
  display: flex;
}
.faq_box dl dt {
  width: 50px;
  height: 50px;
  margin-right: 20px;
  font-size: 2.2rem;
  font-weight: 700;
  font-family: var(--ttl-font);
  line-height: 1;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50px;
}
.faq_box dl dd {
  padding-top: 5px;
  flex: 1;
}
.faq_box dl:nth-child(2) {
  margin-top: 15px;
  padding-bottom: 30px;
  border-bottom: #ddd 1px solid;
}
.faq_box dl:nth-child(2) {
  padding-bottom: 30px;
  border-bottom: #ddd 1px solid;
}
.faq_box dl:nth-child(1) dt {
  background: var(--sub-color3);
}
.faq_box dl:nth-child(1) dd {
  font-size: 2.2rem;
  font-weight: 700;
}
.faq_box dl:nth-child(2) dt {
  background: var(--base-color);
}
@media screen and (max-width:768px) {
  #faq {
    width: auto;
    margin: 40px 15px;
    padding: 30px;
  }
  .faq_box {
    margin-bottom: 15px;
  }
  .faq_box:nth-of-type(1) {
    padding-top: 15px;
  }
  .faq_box dl dt {
    width: 40px;
    height: 40px;
    margin-right: 15px;
    font-size: 1.8rem;
  }
  .faq_box dl dd {
    padding-top: 3px;
    flex: 1;
  }
  .faq_box dl:nth-child(2) {
    margin-top: 15px;
    padding-bottom: 15px;
  }
  .faq_box dl:nth-child(2) {
    padding-bottom: 15px;
  }
  .faq_box dl:nth-child(1) dd {
    font-size: 2rem;
  }
}