@charset "utf-8";


/* ---------------------------------------------------------
 * common
** --------------------------------------------------------- */
body {
  color: #333;
  font-size: 16px;
  line-height: 1.6;
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
}
:root {
  --vw: 1vw;
}


/* .wrapper */
.wrapper {
  max-width: 1240px;
  padding: 0 20px;
  margin-inline: auto;
}
.wrapper.n {
  max-width: 1040px;
}


/* ---------------------------------------------------------
 * Main
** --------------------------------------------------------- */
/* -------------------- header -------------------- */
header {
  position: absolute;
  left: 10px;
  top: 10px;
}
header img {
  width: 163px;
}
@media (max-width: 519px) {
  header {
    left: calc(calc(var(--vw) * 1000) / 430);
    top: calc(calc(var(--vw) * 1000) / 430);
  }
  header img {
    width: calc(calc(var(--vw) * 16300) / 430);
  }
}


/* -------------------- #fv -------------------- */
#fv {
}
#fv > img {
  width: 100%;
  vertical-align: middle;
}
#fv .btn_area {
  position: absolute;
  right: calc(calc(var(--vw) * 7000) / 1500);
  top: calc(calc(var(--vw) * 41200) / 1500);
  width: calc(calc(var(--vw) * 54000) / 1500);
}
#fv .btn_area a {
  position: relative;
  display: block;
  padding: calc(calc(var(--vw) * 2600) / 1500) 0;
  background-color: #2F72D1;
  border-radius: 100px;
  box-shadow: 0 calc(calc(var(--vw) * 1300) / 1500) 0 #004EBC;
  color: #fff;
  font-size: calc(calc(var(--vw) * 3000) / 1500);
  font-weight: bold;
  text-align: center;
}
#fv .btn_area a::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: calc(calc(var(--vw) * 4000) / 1500);
  display: block;
  width: calc(calc(var(--vw) * 1700) / 1500);
  height: calc(calc(var(--vw) * 1700) / 1500);
  margin-top: auto;
  margin-bottom: auto;
  border-top: calc(calc(var(--vw) * 300) / 1500) solid #fff;
  border-right: calc(calc(var(--vw) * 300) / 1500) solid #fff;
  transform: rotate(45deg);
}
@media (max-width: 519px) {
  #fv .btn_area {
    left: 0;
    right: 0;
    top: calc(calc(var(--vw) * 66700) / 430);
    width: calc(calc(var(--vw) * 40000) / 430);
    margin-inline: auto;
  }
  #fv .btn_area a {
    padding: calc(calc(var(--vw) * 2000) / 430) 0;
    box-shadow: 0 calc(calc(var(--vw) * 1000) / 430) 0 #004EBC;
    font-size: calc(calc(var(--vw) * 2235) / 430);
  }
  #fv .btn_area a::before {
    right: calc(calc(var(--vw) * 4000) / 430);
    width: calc(calc(var(--vw) * 1700) / 430);
    height: calc(calc(var(--vw) * 1700) / 430);
    border-top: calc(calc(var(--vw) * 300) / 430) solid #fff;
    border-right: calc(calc(var(--vw) * 300) / 430) solid #fff;
  }
}


/* -------------------- #plan -------------------- */
#plan {
  position: relative;
  z-index: 2;
  padding-top: 90px;
  padding-bottom: 70px;
  background-color: #FFEE81;
}
#plan::after {
  content: "";
  position: absolute;
  bottom: -58px;
  left: 0;
  right: 0;
  width: 320px;
  height: 60px;
  margin-inline: auto;
  background-color: #FFEE81;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}
#plan h2 {
  text-align: center;
}
#plan h2 span {
  display: inline-block;
  background-image: linear-gradient(to top, #FFA311 16px, transparent 16px);
  font-size: 44px;
  font-weight: bold;
  line-height: 1.2;
}
#plan .box {
  margin-top: 40px;
  padding: 20px;
  background-color: #fff;
  border-radius: 20px;
}
#plan .recommend {
  padding: 15px 0 0;
  font-size: 26px;
  font-weight: bold;
  text-align: center;
  line-height: 1.4;
}
#plan .blue {
  color: #005ADB;
}
#plan .planA {
  color: #FB4B00;
  font-size: 38px;
}
#plan .box > img {
  max-width: 100%;
}
#plan .note {
  position: relative;
  margin-top: 20px;
  padding-left: 30px;
  padding-bottom: 15px;
  font-size: 15px;
}
#plan .note::before {
  content: "※1";
  position: absolute;
  left: 0;
  top: 0;
}
@media (max-width: 519px) {
  #plan {
    padding-top: calc(calc(var(--vw) * 4000) / 430);
    padding-bottom: calc(calc(var(--vw) * 3000) / 430);
  }
  #plan::after {
    bottom: calc(calc(var(--vw) * -5800) / 430);
    width: calc(calc(var(--vw) * 28000) / 430);
    height: calc(calc(var(--vw) * 6000) / 430);
  }
  #plan h2 span {
    background-image: linear-gradient(to top, #FFA311 calc(calc(var(--vw) * 1600) / 430), transparent calc(calc(var(--vw) * 1600) / 430));
    font-size: calc(calc(var(--vw) * 3500) / 430);
  }
  #plan .box {
    margin-top: calc(calc(var(--vw) * 3000) / 430);
    padding: calc(calc(var(--vw) * 2000) / 430) 0;
    border-radius: calc(calc(var(--vw) * 2000) / 430);
  }
  #plan .recommend {
    padding: calc(calc(var(--vw) * 1000) / 430) calc(calc(var(--vw) * 2000) / 430) 0;
    font-size: calc(calc(var(--vw) * 2200) / 430);
    line-height: 1.2;
  }
  #plan .planA {
    font-size: calc(calc(var(--vw) * 3300) / 430);
  }
  #plan .box > img {
    margin-top: calc(calc(var(--vw) * 2000) / 430);
  }
  #plan .note {
    margin-top: calc(calc(var(--vw) * 2000) / 430);
    padding-left: calc(calc(var(--vw) * 5000) / 430);
    padding-right: calc(calc(var(--vw) * 2000) / 430);
    padding-bottom: 0;
    font-size: calc(calc(var(--vw) * 1500) / 430);
  }
  #plan .note::before {
    left: calc(calc(var(--vw) * 2000) / 430);
  }
}


/* -------------------- #dekisugi -------------------- */
#dekisugi {
  position: relative;
  z-index: 1;
  padding-top: 110px;
  padding-bottom: 90px;
  background-image: url("../img/dekisugi_bg.png");
  background-position: top center;
}
#dekisugi h2 {
  text-align: center;
}
#dekisugi h2 img {
  max-width: 100%;
}
#dekisugi .box {
  margin-top: 30px;
  padding: 40px 21px;
  background-color: #fff;
  border: 4px solid #2F72D1;
  border-radius: 20px;
  box-shadow: 4px 4px 0 #2F72D1;
}
#dekisugi .img_list {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px;
}
#dekisugi .img {
}
#dekisugi .img img {
  max-width: 100%;
}
#dekisugi .list {
}
#dekisugi .list ul {
}
#dekisugi .list li {
  position: relative;
  padding-left: 45px;
  padding-top: 10px;
  padding-bottom: 10px;
  border-bottom: 1px dotted #2F72D1;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.5;
}
#dekisugi .list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 5px;
  display: block;
  width: 38px;
  height: 39px;
  background-image: url("../img/dekisugi_check.png");
}
#dekisugi .list span {
  color: #FB4B00;
}
#dekisugi .step {
  margin-top: 30px;
}
#dekisugi .step img {
  width: 100%;
}
#dekisugi .note {
  margin-top: 30px;
  font-size: 30px;
  font-weight: bold;
  text-align: center;
}
#dekisugi .note span {
  color: #FB4B00;
}
@media (max-width: 519px) {
  #dekisugi {
    padding-top: calc(calc(var(--vw) * 7500) / 430);
    padding-bottom: calc(calc(var(--vw) * 6000) / 430);
/*    background-image: url("../img/dekisugi_bg.png");*/
  }
  #dekisugi .box {
    margin-top: calc(calc(var(--vw) * 3500) / 430);
    padding: calc(calc(var(--vw) * 1800) / 430) calc(calc(var(--vw) * 1000) / 430) calc(calc(var(--vw) * 2500) / 430);
    border: calc(calc(var(--vw) * 400) / 430) solid #2F72D1;
    border-radius: calc(calc(var(--vw) * 2000) / 430);
    box-shadow: calc(calc(var(--vw) * 400) / 430) calc(calc(var(--vw) * 400) / 430) 0 #2F72D1;
  }
  #dekisugi .img_list {
    flex-direction: column;
    gap: calc(calc(var(--vw) * 1500) / 430);
  }
  #dekisugi .img {
    text-align: center;
  }
  #dekisugi .img img {
    width: calc(24800% / 370);
  }
  #dekisugi .list li {
    padding-left: calc(calc(var(--vw) * 3400) / 430);
    padding-top: calc(calc(var(--vw) * 2100) / 430);
    padding-bottom: calc(calc(var(--vw) * 2100) / 430);
    font-size: calc(calc(var(--vw) * 2000) / 430);
    line-height: 1.4;
  }
  #dekisugi .list li::before {
    top: calc(calc(var(--vw) * 2000) / 430);
    width: calc(calc(var(--vw) * 3000) / 430);
    height: calc(calc(var(--vw) * 3000) / 430);
    background-image: url("../img/dekisugi_check_sp.png");
    background-size: cover;
  }
  #dekisugi .step {
    margin-top: 30px;
  }
  #dekisugi .note {
    margin-top: calc(calc(var(--vw) * 2000) / 430);
    font-size: calc(calc(var(--vw) * 2700) / 430);
  }
}


/* -------------------- #qa -------------------- */
#qa {
  padding: 80px 0;
  background-color: #F0F8FF;
}
#qa h2 {
  text-align: center;
}
#qa h2 span {
  display: inline-block;
  background-image: linear-gradient(to top, #FFE500 16px, transparent 16px);
  font-size: 44px;
  font-weight: bold;
  line-height: 1.2;
}
#qa .qa_lists {
  margin-top: 50px;
}
#qa dl {
}
#qa dl > div {
  margin-top: 30px;
  padding: 20px 30px;
  background-color: #fff;
  border-radius: 20px;
  box-shadow: 5px 5px 0 #2F72D1;
  cursor: pointer;
}
#qa dt {
  position: relative;
}
#qa dt::before,
#qa dt::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  display: block;
  margin-top: auto;
  margin-bottom: auto;
}
#qa dt::before {
  right: 10px;
  width: 24px;
  height: 24px;
  background-color: #2F72D1;
  border-radius: 50px;
}
#qa dt::after {
  right: 15px;
  width: 14px;
  height: 2px;
  background-color: #fff;
  border-radius: 10px;
}
#qa dt .inner {
  position: relative;
  padding: 10px 0 10px 47px;
  font-size: 22px;
}
#qa dt .inner::before,
#qa dt .inner::after {
  content: "";
  position: absolute;
  display: block;
}
#qa dt .inner::before {
  left: 0;
  top: 10px;
  width: 26px;
  height: 32px;
  background-image: url("../img/qa_q.png");
}
#qa dt .inner::after {
  top: 0;
  bottom: 0;
  right: 21px;
  width: 2px;
  height: 14px;
  margin-top: auto;
  margin-bottom: auto;
  background-color: #fff;
  border-radius: 10px;
  transition: all ease 0.3s;
}
#qa .open dt .inner::after {
  height: 0;
}
#qa dd {
  max-height: 0px;
  overflow: hidden;
  transition: all ease 0.3s;
}
#qa .open dd {
  max-height: var(--max-height);
}
#qa dd .inner {
  position: relative;
  padding-top: 20px;
  padding-left: 47px;
  border-top: 1px dotted #2F72D1;
}
#qa dd .inner::before {
  content: "";
  left: 0;
  top: 20px;
  position: absolute;
  display: block;
  width: 21px;
  height: 24px;
  background-image: url("../img/qa_a.png");
}
@media (max-width: 519px) {
  #qa {
    padding: calc(calc(var(--vw) * 5000) / 430) 0;
  }
  #qa h2 span {
    background-image: linear-gradient(to top, #FFE500 calc(calc(var(--vw) * 1600) / 430), transparent calc(calc(var(--vw) * 1600) / 430));
    font-size: calc(calc(var(--vw) * 3500) / 430);
  }
  #qa .qa_lists {
    margin-top: calc(calc(var(--vw) * 3000) / 430);
  }
  #qa dl > div {
    margin-top: calc(calc(var(--vw) * 2000) / 430);
    padding: calc(calc(var(--vw) * 2000) / 430);
    border-radius: calc(calc(var(--vw) * 2000) / 430);
    box-shadow: calc(calc(var(--vw) * 500) / 430) calc(calc(var(--vw) * 500) / 430) 0 #2F72D1;
  }
  #qa dt::before {
    right: 0;
    width: calc(calc(var(--vw) * 2800) / 430);
    height: calc(calc(var(--vw) * 2800) / 430);
    border-radius: 100px;
  }
  #qa dt::after {
    right: calc(calc(var(--vw) * 700) / 430);
    width: calc(calc(var(--vw) * 1400) / 430);;
  }
  #qa dt .inner {
    padding: 0 calc(calc(var(--vw) * 3000) / 430) 0 calc(calc(var(--vw) * 4000) / 430);
    font-size: calc(calc(var(--vw) * 2200) / 430);
  }
  #qa dt .inner::before {
    left: 0;
    top: calc(calc(var(--vw) * 1000) / 430);
    width: calc(calc(var(--vw) * 2650) / 430);
    height: calc(calc(var(--vw) * 3300) / 430);
    background-image: url("../img/qa_q_sp.png");
    background-size: cover;
  }
  #qa dt .inner::after {
    right: calc(calc(var(--vw) * 1300) / 430);
    height: calc(calc(var(--vw) * 1400) / 430);
  }
  #qa dd .inner {
    padding-top: calc(calc(var(--vw) * 2000) / 430);
    padding-left: calc(calc(var(--vw) * 4000) / 430);
  }
  #qa dd .inner::before {
    left: 0;
    top: calc(calc(var(--vw) * 2000) / 430);
    width: calc(calc(var(--vw) * 2300) / 430);
    height: calc(calc(var(--vw) * 2550) / 430);
    background-image: url("../img/qa_a_sp.png");
    background-size: cover;
  }
}


/* -------------------- .contact -------------------- */
.contact {
  padding-top: 30px;
  padding-bottom: 15px;
  background-image: url("../img/contact_bg.png");
  background-size: cover;
  background-position: center;
}
.contact .inner {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.contact .btn_area {
  max-width: 100%;
  width: 560px;
  text-align: center;
}
.contact .btn_area img {
}
.contact .btn_area a {
  position: relative;
  display: block;
  width: 100%;
  margin-top: 20px;
  padding: 26px;
  background-color: #2F72D1;
  border-radius: 100px;
  box-shadow: 0 13px 0 #004EBC;
  color: #fff;
  font-size: 28px;
  font-weight: bold;
  text-align: center;
}
.contact  .btn_area a::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: calc(calc(var(--vw) * 4000) / 1500);
  display: block;
  width: calc(calc(var(--vw) * 1700) / 1500);
  height: calc(calc(var(--vw) * 1700) / 1500);
  margin-top: auto;
  margin-bottom: auto;
  border-top: calc(calc(var(--vw) * 300) / 1500) solid #fff;
  border-right: calc(calc(var(--vw) * 300) / 1500) solid #fff;
  transform: rotate(45deg);
}
.contact .okigaru {
  padding-right: 20px;
}
.contact .okigaru img {
  max-width: 100%;
}
@media (max-width: 519px) {
  .contact {
    padding-top: 0;
    padding-bottom: calc(calc(var(--vw) * 5000) / 430);
    background-image: url("../img/contact_bg_sp.png");
  }
  .contact .inner {
    display: block;
  }
  .contact .btn_area img {
    max-width: 100%;
    margin-top: calc(calc(var(--vw) * -2500) / 430);
  }
  .contact .btn_area a {
    margin-top: calc(calc(var(--vw) * 2000) / 430);
    padding: calc(calc(var(--vw) * 2000) / 430);
    box-shadow: 0 calc(calc(var(--vw) * 1000) / 430) 0 #004EBC;
    font-size: calc(calc(var(--vw) * 2200) / 430);
  }
  .contact  .btn_area a::before {
    right: calc(calc(var(--vw) * 4000) / 430);
    width: calc(calc(var(--vw) * 1700) / 430);
    height: calc(calc(var(--vw) * 1700) / 430);
    border-top: calc(calc(var(--vw) * 300) / 430) solid #fff;
    border-right: calc(calc(var(--vw) * 300) / 430) solid #fff;
  }
}


/* -------------------- footer -------------------- */
footer {
  padding-top: 40px;
}
footer .inner {
  display: flex;
  justify-content: space-between;
  gap: 30px;
}
footer .f_left {
  text-align: center;
}
footer .f_left img {
  display: block;
  width: 232px;
}
footer .f_left .login {
  display: inline-block;
  width: 210px;
  margin-top: 15px;
  padding: 10px 0;
  background-color: #2F72D1;
  border-radius: 100px;
  color: #fff;
  font-weight: bold;
  text-align: center;
}
footer .f_right {
  display: flex;
  gap: 40px;
  padding-left: 50px;
  border-left: 1px solid #ccc;
}
footer .f_right .gl-edge {
}
footer .f_right .gl-edge img {
}
footer .f_right .link {
  padding-top: 20px;
}
footer .f_right .link li:not(:first-child) {
  margin-top: 10px;
}
footer .f_right .address {
  padding-top: 20px;
}
footer .copy {
  margin-top: 40px;
  text-align: center;
  padding-bottom: 20px;
}
@media (max-width: 519px) {
  footer {
    padding-top: calc(calc(var(--vw) * 4000) / 430);
  }
  footer .inner {
    flex-direction: column;
    align-items: center;
    gap: 0;
  }
  footer .f_left img {
    width: calc(calc(var(--vw) * 23200) / 430);
  }
  footer .f_left .login {
    width: 100%;
    margin-top: 15px;
    padding: 10px 0;
    border-radius: 100px;
    vertical-align: middle;
  }
  footer .f_right {
    display: block;
    width: calc(calc(var(--vw) * 37000) / 430);
    padding: calc(calc(var(--vw) * 2600) / 430) calc(calc(var(--vw) * 5600) / 430) 0;
    margin-top: calc(calc(var(--vw) * 3600) / 430);
    border-left: none;
    border-top: 1px solid #ccc;
  }
  footer .f_right .gl-edge {
  }
  footer .f_right .gl-edge img {
    width: calc(calc(var(--vw) * 23200) / 430);
  }
  footer .f_right .link {
    padding-top: calc(calc(var(--vw) * 2200) / 430);
  }
  footer .f_right .link a {
    font-size: calc(calc(var(--vw) * 1600) / 430);
  }
  footer .f_right .address {
    padding-top: calc(calc(var(--vw) * 1800) / 430);
    font-size: calc(calc(var(--vw) * 1600) / 430);
  }
  footer .copy {
    margin-top: calc(calc(var(--vw) * 4500) / 430);
    padding-bottom: calc(calc(var(--vw) * 1500) / 430);
    font-size: calc(calc(var(--vw) * 1400) / 430);
  }
}


