@charset "UTF-8";
/* header  ----------------------- */
#g-header h1 img {
  -webkit-box-sizing: initial !important;
  box-sizing: initial !important;
  width: auto;
}

/* #path ぱんくず
=========================================== */
.path a {
  text-decoration: underline;
}

@media screen and (min-width: 769px) {
  a {
    color: inherit;
  }
  a:hover {
    color: inherit;
  }
}
/* color  ----------------------- */
/* media　query  ----------------------- */
.pc {
  display: block;
}
@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}
@media screen and (max-width: 768px) {
  .sp {
    display: block;
  }
}

.all_bg {
  border-top-left-radius: 80rem 15rem;
  border-top-right-radius: 80rem 15rem;
  margin-top: -7%;
  margin-left: -100px;
  margin-right: -100px;
  padding-left: 100px;
  padding-right: 100px;
}
.all_bg.about {
  margin-top: 0;
  background: #35187e;
}
.all_bg.case {
  background: #e9f0f5;
}
.all_bg.point {
  background: #fff;
}
.all_bg.price {
  background: #e9f0f5;
}
.all_bg.faq {
  background: #fff;
}
.all_bg.contact {
  background: url(../images/contact_bg.jpg);
  background-size: cover;
}

._cta {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  max-width: 500px;
  width: 100%;
  margin: clamp(2.813rem, 2.143rem + 2.857vw, 5rem) auto 0;
  padding: clamp(0.875rem, 0.76rem + 0.49vw, 1.25rem) 30px clamp(0.875rem, 0.722rem + 0.653vw, 1.375rem);
  color: #fff;
  border-radius: 9999px;
  background-color: #be940c;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
._cta svg {
  position: absolute;
  top: 50%;
  right: 5%;
  width: clamp(0.625rem, 0.357rem + 1.143vw, 1.5rem);
  height: clamp(0.625rem, 0.415rem + 0.898vw, 1.313rem);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  fill: #fff;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
._cta ._text_top {
  position: relative;
  display: inline-block;
  margin-bottom: 5px;
  padding: 0 15px;
  font-size: clamp(0.75rem, 0.635rem + 0.49vw, 1.125rem);
  font-weight: 400;
}
._cta ._text_top::before,
._cta ._text_top::after {
  content: '';
  position: absolute;
  bottom: 0;
  display: block;
  width: 1px;
  height: 85%;
  background-color: #fff;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
._cta ._text_top::before {
  -webkit-transform: rotate(-30deg);
  transform: rotate(-30deg);
  left: 0;
}
._cta ._text_top::after {
  -webkit-transform: rotate(30deg);
  transform: rotate(30deg);
  right: 0;
}
._cta ._text {
  font-weight: 700;
  font-size: clamp(1rem, 0.866rem + 0.571vw, 1.438rem);
  text-align: center;
  line-height: 1.5;
}
._cta:hover {
  color: #35187e;
  background-color: #fff;
}
._cta:hover svg {
  fill: #35187e;
}
._cta:hover ._text_top::before,
._cta:hover ._text_top::after {
  background-color: #35187e;
}

.all_slide {
  width: calc(420px + 50vw);
  margin-top: 78px;
  padding-right: 50px;
}
@media (max-width: 1600px) {
  .all_slide {
    width: 106%;
  }
}
.all_slide .swiper-slide._about {
  width: 420px;
}
@media screen and (max-width: 650px) {
  .all_slide .swiper-slide._about {
    width: 300px;
  }
}
.all_slide .swiper-slide._price {
  width: 420px;
}
@media screen and (max-width: 650px) {
  .all_slide .swiper-slide._price {
    width: 315px;
  }
}

.all_slide_controls {
  margin-top: 35px;
  position: relative;
  text-align: right;
}
.all_slide_controls ._bar {
  background: #fff;
  width: calc(100% - 200px);
  height: 3px;
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
@media screen and (max-width: 650px) {
  .all_slide_controls ._bar {
    width: calc(100% - 120px);
  }
}
.all_slide_controls .swiper-scrollbar-drag {
  background: #35187e;
}
.all_slide_controls button {
  background: #ffffff;
  width: 64px;
  height: 64px;
  position: relative;
  border: 1px #e4e8ee solid;
  border-radius: 50%;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
@media screen and (max-width: 650px) {
  .all_slide_controls button {
    width: 48px;
    height: 48px;
  }
}
.all_slide_controls button svg {
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 20px;
  height: 20px;
}
@media screen and (max-width: 650px) {
  .all_slide_controls button svg {
    width: 7px;
  }
}
.all_slide_controls button path {
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
.all_slide_controls button:hover {
  background: #35187e;
}
.all_slide_controls button:hover path {
  stroke: #fff;
}
.all_slide_controls ._prev svg {
  -webkit-transform: translate(-50%, -50%) rotate(180deg);
  transform: translate(-50%, -50%) rotate(180deg);
}
.all_slide_controls .swiper-button-disabled {
  opacity: 0.5;
}
.all_slide_controls._price_controls {
  margin-top: clamp(1.875rem, 1.301rem + 2.449vw, 3.75rem);
}

#container {
  font-family: 'Noto Sans JP', sans-serif;
}

a {
  text-decoration: none;
}

/* main cta */
.main_cta {
  position: fixed;
  top: 40%;
  right: 0;
  z-index: 10;
}
@media screen and (max-width: 768px) {
  .main_cta {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
  }
  .main_cta.on {
    opacity: 1;
    visibility: visible;
    pointer-events: all;
  }
}

.main_cta_content {
  position: relative;
  display: block;
  width: 100%;
  padding: 0;
  padding-bottom: 40px;
  background-color: #35187e;
  border: none;
  border-radius: 6px 0 0 6px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.main_cta_content p {
  -ms-writing-mode: tb-rl;
  -webkit-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
  font-size: clamp(0.938rem, 0.852rem + 0.364vw, 1.125rem);
  font-weight: 600;
  padding: 32px 16px 24px;
  letter-spacing: 2px;
  color: #fff;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  line-height: 1.8;
}
@media screen and (max-width: 768px) {
  .main_cta_content p {
    line-height: normal;
  }
}
.main_cta_content svg {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  fill: #fff;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.main_cta_content.about {
  background-color: #fff;
}
.main_cta_content.about p {
  color: #35187e;
}
.main_cta_content.about svg {
  fill: #35187e;
}

.main_cta_content svg {
  display: block;
  margin: 0 auto 20px;
  width: 16px;
  height: auto;
}

.main_cta_link {
  display: block;
  width: 68px;
  border-radius: 6px 0 0 6px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 768px) {
  .main_cta_link {
    width: 56px;
  }
}

.main_cta_link:hover .main_cta_content {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  background: #be940c;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  cursor: pointer;
}
.main_cta_link:hover .main_cta_content.about p {
  color: #fff;
}
.main_cta_link:hover .main_cta_content.about svg {
  fill: #fff;
}

/* mv */

#main_bg {
  background-image: image-set(
    url('../images/mv_bg.webp') type('image/webp'),
    url(../images/mv_bg.jpg) type('image/jpeg')
  );
  background-size: cover;
  background-repeat: no-repeat;
  background-position: bottom right;
  background-attachment: fixed;
}

@media screen and (max-width: 768px) {
  #main_bg {
    background: transparent;
  }
}

.main_bg_content {
  background: rgba(255, 255, 255, 0.9);
  width: 640px;
  margin-left: 8%;
  margin-bottom: 200px;
  padding: 60px 70px;
  border-bottom-left-radius: 9px;
  border-bottom-right-radius: 9px;
}
@media screen and (max-width: 1024px) {
  .main_bg_content {
    width: 480px;
    margin-left: 4%;
    margin-bottom: 200px;
    padding: 60px 48px;
  }
}
@media screen and (max-width: 768px) {
  .main_bg_content {
    display: none;
  }
}

.main_bg_content_sp {
  display: none;
}
@media screen and (max-width: 768px) {
  .main_bg_content_sp {
    background-image: image-set(
      url('../images/mv_bg_sp.webp') type('image/webp'),
      url(../images/mv_bg_sp.jpg) type('image/jpeg')
    );
    background-size: cover;
    background-repeat: no-repeat;
    background-position: bottom right;
    display: block;
    padding: 24px 24px 36px;
  }
}

.mv_contracts img {
  display: block;
  width: 70%;
  margin: 0 auto 32px;
}
@media screen and (max-width: 768px) {
  .mv_contracts img {
    width: 50%;
    margin: 0 auto 16px;
  }
}

.mv_title img {
  display: block;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .mv_title img {
    width: 80%;
  }
}
@media screen and (max-width: 650px) {
  .mv_title img {
    width: 100%;
  }
}

.mv_compensation {
  text-align: center;
  background: #e9f0f5;
  padding: 24px 36px;
  border-radius: 8px;
  margin: 60px auto 0;
}
@media screen and (max-width: 768px) {
  .mv_compensation {
    text-align: center;
    padding: 24px;
    margin: 60px 0 0 0;
    width: 40%;
  }
}
@media screen and (max-width: 650px) {
  .mv_compensation {
    text-align: center;
    padding: 12px;
    margin: 24px 0 0 0;
  }
}

.mv_compensation p {
  font-size: clamp(0.75rem, 0.608rem + 0.606vw, 1.063rem);
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .mv_compensation p {
    text-align: left;
    letter-spacing: 0.1em;
  }
}

.mv_compensation_flexbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: 12px;
  gap: 12px;
}
@media screen and (max-width: 768px) {
  .mv_compensation_flexbox {
    display: block;
  }
}

.mv_compensation_whitebox_txt {
  display: block;
  background: #fff;
  width: 100%;
  padding: 12px 56px;
  font-size: clamp(0.75rem, 0.352rem + 1.697vw, 1.625rem);
  font-weight: bold;
  border-radius: 4px;
  color: #35187e;
}
@media screen and (max-width: 1024px) {
  .mv_compensation_whitebox_txt {
    padding: 12px 40px;
  }
}
@media screen and (max-width: 768px) {
  .mv_compensation_whitebox_txt {
    margin-top: 12px;
    padding: 12px;
  }
}
@media screen and (max-width: 650px) {
  .mv_compensation_whitebox_txt {
    padding: 8px;
  }
}

.mv_cta {
  margin: 60px auto 120px;
}
@media screen and (max-width: 768px) {
  .mv_cta {
    margin: 48px auto 32px;
    width: 80%;
  }
}

.mv_cta_link {
  position: relative;
  display: block;
}

.mv_cta_button {
  position: relative;
  z-index: 1;
  background: #35187e;
  border-radius: 500px;
  border: none;
  color: #fff;
  letter-spacing: 1px;
  padding: 20px 30px 20px 60px;
  margin: 0 auto;
  width: 100%;
  display: block;
}
@media screen and (max-width: 1024px) {
  .mv_cta_button {
    padding: 20px 40px 20px 40px;
  }
}
@media screen and (max-width: 768px) {
  .mv_cta_button {
    padding: 16px 16px 16px 30px;
    width: 70%;
    text-align: center;
  }
}
@media screen and (max-width: 650px) {
  .mv_cta_button {
    padding: 14px 16px 14px 16px;
    width: 110%;
    text-align: center;
  }
}

.mv_cta_link:hover .mv_cta_button {
  background: #be940c;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  cursor: pointer;
}

.mv_cta_badge {
  position: absolute;
  z-index: 2;
  top: -40px;
  left: -7%;
  width: 110px;
  height: auto;
  -webkit-filter: drop-shadow(0px 6px 8px rgba(0, 0, 0, 0.16));
  filter: drop-shadow(0px 6px 8px rgba(0, 0, 0, 0.16));
}
@media screen and (max-width: 1024px) {
  .mv_cta_badge {
    position: absolute;
    top: -50px;
    left: -9%;
    width: 90px;
  }
}
@media screen and (max-width: 768px) {
  .mv_cta_badge {
    position: absolute;
    z-index: 2;
    top: -50%;
    left: 10%;
    width: 80px;
    height: auto;
  }
}
@media screen and (max-width: 650px) {
  .mv_cta_badge {
    position: absolute;
    z-index: 2;
    top: -50%;
    left: -9%;
    width: 65px;
    height: auto;
  }
}
.mv_cta_badge img {
  width: 100%;
}

.mv_cta_button_comment {
  position: relative;
  display: inline-block;
  padding: 0 16px;
  font-size: clamp(0.75rem, 0.58rem + 0.727vw, 1.125rem);
}

.mv_cta_button_comment:before {
  position: absolute;
  left: 0;
  bottom: 0;
  content: '';
  width: 2px;
  height: 80%;
  background: #fff;
  border-radius: 3px;
  -webkit-transform: rotate(-25deg);
  transform: rotate(-25deg);
}

.mv_cta_button_comment:after {
  position: absolute;
  content: '';
  right: 0;
  bottom: 0;
  width: 2px;
  height: 80%;
  background: #fff;
  border-radius: 3px;
  -webkit-transform: rotate(25deg);
  transform: rotate(25deg);
}

.mv_cta_button_txt {
  font-weight: bold;
  font-size: clamp(1rem, 0.801rem + 0.848vw, 1.438rem);
  margin-top: 8px;
}

.mv_cta_arrow img {
  position: absolute;
  top: 45%;
  right: 30px;
  width: 24px;
  height: auto;
}
@media screen and (max-width: 1024px) {
  .mv_cta_arrow img {
    right: 20px;
    width: 16px;
    height: auto;
  }
}
@media screen and (max-width: 768px) {
  .mv_cta_arrow img {
    width: 16px;
    height: auto;
  }
}
@media screen and (max-width: 650px) {
  .mv_cta_arrow img {
    width: 12px;
    height: auto;
    right: 10px;
  }
}

.mv_about {
  margin-top: 100px;
}
@media screen and (max-width: 768px) {
  .mv_about {
    margin-top: 0;
  }
}

.mv_about_wrap_sp {
  display: none;
}
@media screen and (max-width: 768px) {
  .mv_about_wrap_sp {
    display: block;
    background: #fff;
    padding: 120px 32px 120px;
  }
}
@media screen and (max-width: 650px) {
  .mv_about_wrap_sp {
    padding: 60px 24px 120px;
  }
}
.mv_about_wrap_sp .youtube_adjust {
  aspect-ratio: 16/9;
}
.mv_about_wrap_sp .youtube_adjust iframe {
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.mv_about_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 10px;
  margin-bottom: 72px;
}
@media screen and (max-width: 650px) {
  .mv_about_title {
    margin-bottom: 44px;
  }
}

.insurance_logo {
  width: 70%;
}

.mv_about_title p {
  font-size: 36px;
  font-weight: bold;
  margin-top: 20px;
}
@media screen and (max-width: 650px) {
  .mv_about_title p {
    font-size: 24px;
  }
}

.mv_about_explan {
  width: 95%;
  margin: 0 auto;
  font-weight: bold;
  font-size: clamp(1.125rem, 0.955rem + 0.727vw, 1.5rem);
  line-height: 1.8;
}
@media screen and (max-width: 650px) {
  .mv_about_explan {
    width: 100%;
  }
}

.txt_gold {
  color: #be940c;
}

.mv_sub_title_adjust {
  text-align: center;
  margin-top: 72px;
  margin-bottom: 24px;
}
@media screen and (max-width: 650px) {
  .mv_sub_title_adjust {
    margin-top: 40px;
    margin-bottom: 24px;
  }
}

.mv_sub_title {
  position: relative;
  display: inline-block;
  font-size: clamp(1.125rem, 0.955rem + 0.727vw, 1.5rem);
  font-weight: bold;
  color: #35187e;
  padding: 0 20px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.mv_sub_title:before {
  position: absolute;
  left: 0;
  bottom: 0;
  content: '';
  width: 2px;
  height: 70%;
  background: #35187e;
  border-radius: 3px;
  -webkit-transform: rotate(-25deg);
  transform: rotate(-25deg);
}
@media screen and (max-width: 768px) {
  .mv_sub_title:before {
    height: 100%;
  }
}

.mv_sub_title:after {
  position: absolute;
  content: '';
  right: 0;
  bottom: 0;
  width: 2px;
  height: 70%;
  background: #35187e;
  border-radius: 3px;
  -webkit-transform: rotate(25deg);
  transform: rotate(25deg);
}
@media screen and (max-width: 768px) {
  .mv_sub_title:after {
    height: 100%;
  }
}

.mv_recommend_box {
  background: #e9f0f5;
  padding: 24px 36px 36px;
  border-radius: 8px;
  margin: 0 auto;
  letter-spacing: 0.6px;
}

.mv_recommend_list {
  font-size: 16px;
  border-bottom: 1px #e3e8eb solid;
  padding: 12px 0;
  line-height: 1.8;
}

.txt_purple_underline {
  font-weight: bold;
  color: #35187e;
  border-bottom: 1px #35187e solid;
}

.mv_recommend_list img {
  width: 20px;
  height: auto;
}

.youtube_adjust {
  border-radius: 8px;
}

small {
  display: block;
  text-align: center;
  font-size: 14px;
  color: #888888;
  margin-top: 16px;
  line-height: 1.6;
}

#main_area {
  overflow: hidden;
}

#side_nav {
  position: fixed;
  top: 100px; /*固定したい位置*/
  margin-top: 150px;
  margin-left: 120px;
  width: 200px;
  padding: 0px 20px 0 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
  z-index: 5;
}
#side_nav.on {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}
@media screen and (max-width: 768px) {
  #side_nav {
    display: none;
  }
}

.side_nav nav ul {
  list-style: none;
  display: block;
}

.side_nav a {
  display: block;
  text-decoration: none;
  color: inherit;
  padding: 10px;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}

.side_nav_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  color: #fff;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  margin-bottom: 24px;
  padding-bottom: 24px;
  font-size: 16px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.pc_menu li a:not(.current) {
  opacity: 0.3;
}

#pcMenu {
  color: #fff;
}
#pcMenu.on .side_nav_link {
  color: #35187e;
  border-bottom: 1px solid #35187e;
}
#pcMenu.on .side_nav_link .side_arrow:before {
  background: #35187e;
}
#pcMenu.on .side_nav_link .side_arrow:after {
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}

.arrow {
  position: relative;
  margin-left: 18px;
  margin-right: 0;
  display: inline-block;
  vertical-align: middle;
  text-decoration: none;
  width: 28px;
  height: 28px;
}

.arrow::before,
.arrow::after {
  content: '';
}

.side_arrow::before {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: #f2f2f2;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.side_arrow::after {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8px;
  height: 8px;
  border-top: 2px solid #35187e;
  border-right: 2px solid #35187e;
  -webkit-transform: translate(-50%, -50%) rotate(135deg);
  transform: translate(-50%, -50%) rotate(135deg);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.side_nav_sp {
  display: none;
}
@media screen and (max-width: 768px) {
  .side_nav_sp {
    display: block;
  }
}

.side_nav_sp_accordion {
  margin: 3em auto;
  width: 100%;
  background: #fff;
  border-radius: 3px;
}

.side_nav_sp_toggle {
  display: none;
}

.side_nav_sp_option {
  position: relative;
  margin-bottom: 1em;
}

.side_nav_sp_title,
.side_nav_sp_content {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.side_nav_sp_content {
  padding: 0px 28px;
}
.side_nav_sp_content #side_nav_list {
  margin-top: 16px;
  margin-bottom: 36px;
}
.side_nav_sp_content .side_nav_link {
  padding-bottom: 12px;
  color: #35187e;
  border-bottom: 1px solid rgba(53, 24, 126, 0.3);
}
.side_nav_sp_content .side_nav_link .side_arrow::before {
  background-color: #35187e;
}
.side_nav_sp_content .side_nav_link .side_arrow::after {
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}
.side_nav_sp_content .side_nav_link_adjust {
  line-height: 1.5;
}

.side_nav_sp_title {
  padding: 1em;
  display: block;
  color: #35187e;
  font-weight: bold;
  letter-spacing: 1px;
}

.side_nav_sp_title::after,
.side_nav_sp_title::before {
  content: '';
  position: absolute;
  right: 1.25em;
  top: 1.25em;
  width: 2px;
  height: 0.75em;
  background-color: #35187e;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.side_nav_sp_title::after {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}

.side_nav_sp_content {
  max-height: 0;
  overflow: hidden;
}

.side_nav_sp_toggle:checked + .side_nav_sp_title + .side_nav_sp_content {
  max-height: 500px;
  -webkit-transition: all 1.5s;
  transition: all 1.5s;
}

.side_nav_sp_toggle:checked + .side_nav_sp_title::before {
  -webkit-transform: rotate(90deg) !important;
  transform: rotate(90deg) !important;
}

.main_area_layout {
  padding: 164px 120px 300px 370px;
}
@media screen and (max-width: 768px) {
  .main_area_layout {
    padding: 90px 20px 150px;
  }
}

.section_title_en {
  font-family: 'Lato', sans-serif;
  letter-spacing: 2px;
  margin-bottom: 12px;
}
.section_title_en._white {
  color: #fff;
}
.section_title_en._black {
  color: #222222;
}
.section_title_en._purple {
  color: #35187e;
}

.section_title {
  font-size: clamp(1.75rem, 1.352rem + 1.697vw, 2.625rem);
  font-weight: bold;
  margin-bottom: 72px;
}
@media screen and (max-width: 768px) {
  .section_title {
    margin-bottom: 28px;
  }
}
.section_title._white {
  color: #fff;
}
.section_title._blue {
  color: #35187e;
}

#about_detail_bg {
  background: #fff;
  padding: 5% 7%;
  border-radius: 0 80px 0 0;
  width: 100%;
}
@media screen and (max-width: 768px) {
  #about_detail_bg {
    padding: 22px 20px 52px;
  }
}
@media screen and (max-width: 650px) {
  #about_detail_bg {
    margin-top: 28px;
  }
}

.about_detail_damage {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 1%;
}

.about_detail_damage img {
  width: 50px;
  height: auto;
}

.about_detail_damage p {
  font-weight: bold;
  font-size: clamp(1.125rem, 1.068rem + 0.242vw, 1.25rem);
  color: #35187e;
}

.about_detail_flexbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 32px;
  margin: 40px 0 30px;
}
@media screen and (max-width: 768px) {
  .about_detail_flexbox {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 24px;
  }
}
@media screen and (max-width: 650px) {
  .about_detail_flexbox {
    display: block;
  }
}

.about_detail_area {
  width: 50%;
}
@media screen and (max-width: 650px) {
  .about_detail_area {
    width: 100%;
    margin-top: 60px;
  }
  .about_detail_area:first-child {
    margin-top: 0;
  }
}

.about_detail_title {
  font-weight: bold;
  color: #be940c;
  font-size: clamp(1.5rem, 1.159rem + 1.455vw, 2.25rem);
  border-bottom: 1px #d3d3d3 solid;
  padding-bottom: 16px;
}
.about_detail_title._mt {
  margin-top: 32px;
}

.about_detail_text {
  margin-top: 18px;
  font-size: clamp(1rem, 0.981rem + 0.082vw, 1.063rem);
  font-weight: 700;
  line-height: 1.7;
}

.about_detail_total_loss {
  width: 60%;
  margin: 0 auto;
}
@media screen and (max-width: 650px) {
  .about_detail_total_loss {
    width: 80%;
  }
}

.about_detail_total_loss img {
  display: block;
  width: 100%;
  margin: 56px auto 0;
}

.about_detail_terms {
  background: #e9f0f5;
  border-radius: 10px;
  padding: 6% 20px;
  margin-top: 56px;
}

.about_detail_terms_title {
  font-weight: bold;
  color: #35187e;
  font-size: 18px;
  margin-bottom: 16px;
}

.about_detail_terms_list:before {
  content: '';
  width: 12px;
  height: 12px;
  display: inline-block;
  background-color: #35187e;
  border-radius: 50%;
  margin-right: 5px;
}

.about_detail_terms_list {
  display: block;
  margin-top: 4px;
  line-height: 1.8;
  padding-left: 1em;
  text-indent: -1em;
}

.about_detail_terms_emphasis {
  font-weight: bold;
  color: #35187e;
  border-bottom: 1px solid #35187e;
}

.modal_content_img {
  display: block;
  width: 100%;
  text-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 36px 0;
}

@media screen and (max-width: 650px) {
  .modal_content_img_sp {
    display: block;
    width: 100%;
    text-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 24px 0;
  }
}

.modal_title {
  font-size: clamp(1.25rem, 1.136rem + 0.485vw, 1.5rem);
  font-weight: bold;
  color: #35187e;
  text-align: center;
}

.annotation {
  text-align: left;
  margin-top: 8px;
}

#about_detail_theft_water_damage {
  margin-top: 80px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 32px;
}
@media screen and (max-width: 768px) {
  #about_detail_theft_water_damage {
    gap: 24px;
  }
}
@media screen and (max-width: 650px) {
  #about_detail_theft_water_damage {
    display: block;
    margin-top: 0;
  }
}

.about_detail_area_one_column {
  width: 100%;
}

.about_detail_txt {
  font-weight: bold;
  margin-top: 32px;
  line-height: 1.8;
}

.modal_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 32px;
  -webkit-box-pack: space-evenly;
  -ms-flex-pack: space-evenly;
  justify-content: space-evenly;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
@media screen and (max-width: 650px) {
  .modal_wrap {
    margin-top: 36px;
  }
}

/* モーダルを開くボタン */
.modal-open {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  font-size: 16px;
  font-weight: bold;
  color: #35187e;
  cursor: pointer;
  background: none;
  border: none;
  margin-top: 12px;
}
@media screen and (max-width: 650px) {
  .modal-open {
    margin-top: 20px;
  }
}
.modal-open img {
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
.modal-open:hover img {
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
}

/* モーダルと背景の指定 */
.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0, 0, 0, 0.5);
  padding: 40px 20px;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  z-index: 200;
}

/* モーダルの擬似要素の指定 */
.modal:before {
  content: '';
  display: inline-block;
  vertical-align: middle;
  height: 100%;
  margin-left: -0.2em;
}

/* クラスが追加された時の指定 */
.modal.is-active {
  opacity: 1;
  visibility: visible;
}

/* モーダル内側の指定 */
.modal-container {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  width: 80%;
}
@media screen and (max-width: 768px) {
  .modal-container {
    width: 90%;
  }
}

/* モーダルを閉じるボタンの指定 */
.modal-close {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  top: -20px;
  right: -20px;
  width: 40px;
  height: 40px;
  color: #fff;
  background: #35187e;
  border-radius: 50%;
  cursor: pointer;
}

/* モーダルのコンテンツ部分の指定 */
.modal-content {
  background: #fff;
  padding: 56px;
  border-radius: 8px;
}
@media screen and (max-width: 768px) {
  .modal-content {
    padding: 56px 20px;
  }
}

/* モーダルのコンテンツ部分のテキストの指定 */
.modal-content p {
  margin: 1em 0;
  line-height: 1.8;
  text-align: left;
}

.modal_open_btn {
  width: 24px;
  height: 24px;
}

body.is-noscroll {
  overflow: hidden;
}

#about_terms_wrap {
  background: #e9f0f5;
  padding: 7% 5%;
  border-radius: 9px;
  margin-top: 80px;
}
@media screen and (max-width: 650px) {
  #about_terms_wrap {
    padding: 52px 20px;
  }
}

.about_terms_title_layout {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 1%;
}
@media screen and (max-width: 650px) {
  .about_terms_title_layout {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
}

.about_terms_title {
  font-size: clamp(1.125rem, 0.926rem + 0.848vw, 1.563rem);
  margin-bottom: 40px;
  z-index: 5;
  color: #35187e;
}
@media screen and (max-width: 650px) {
  .about_terms_title {
    margin-bottom: 32px;
    line-height: 1.8;
  }
}

.about_terms_icon {
  width: 180px;
  height: 94px;
  z-index: 4;
  margin-top: -20px;
  margin-right: -20px;
}
@media screen and (max-width: 1024px) {
  .about_terms_icon {
    width: 123px;
    height: 64px;
  }
}
@media screen and (max-width: 768px) {
  .about_terms_icon {
    width: 123px;
    height: 64px;
  }
}
@media screen and (max-width: 650px) {
  .about_terms_icon {
    width: 103px;
    height: 53px;
    margin-top: -40px;
    margin-right: -10px;
    margin-left: auto;
  }
}

.about_terms_detail_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 650px) {
  .about_terms_detail_wrap {
    display: block;
  }
}

.about_terms_detail_box {
  width: 100%;
}

.about_terms_detail_box + div {
  border-left: 1px solid #d3d3d3;
  margin-left: 32px;
}
@media screen and (max-width: 650px) {
  .about_terms_detail_box + div {
    border-left: none;
    margin-left: 0;
  }
}

.about_terms_detail_box + div {
  padding-left: 32px;
}
@media screen and (max-width: 650px) {
  .about_terms_detail_box + div {
    padding-left: 0;
  }
}

.about_terms_detail_list {
  margin-bottom: 24px;
  line-height: 1.6;
}
@media screen and (max-width: 650px) {
  .about_terms_detail_list {
    width: 95%;
    margin: 0 auto 16px;
    border-bottom: 1px #d3d3d3 solid;
    padding-bottom: 16px;
    text-indent: -2em;
    padding-left: 2em;
  }
}

.about_terms_detail_list img {
  width: 20px;
  height: auto;
}
@media screen and (max-width: 650px) {
  .about_terms_detail_list img {
    margin-right: 0.5em;
  }
}

.txt_annotation {
  margin-top: 32px;
  text-align: left;
  line-height: 1.8;
}

#case img {
  width: 100%;
}
#case .section_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  #case .section_title {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
}
#case .section_title:after {
  content: '-保険金額100万円の場合-';
  margin-left: 26px;
  font-size: clamp(0.938rem, 0.88rem + 0.245vw, 1.125rem);
  font-weight: 400;
  color: #222222;
}
@media screen and (max-width: 768px) {
  #case .section_title:after {
    margin-top: 10px;
    margin-left: 0;
  }
}
#case ._ex_text {
  margin-top: clamp(1.5rem, 1.309rem + 0.816vw, 2.125rem);
  font-size: 16px;
  line-height: 2;
}
#case ._coverage {
  margin-top: clamp(1.313rem, 1.179rem + 0.571vw, 1.75rem);
  font-size: clamp(0.938rem, 0.918rem + 0.082vw, 1rem);
  font-weight: 700;
  line-height: 2;
}
#case ._coverage span {
  color: #be940c;
}
#case ._note {
  margin-top: clamp(1.063rem, 0.929rem + 0.571vw, 1.5rem);
  font-size: 14px;
  color: #888888;
  line-height: 1.5;
}
#case ._scroll {
  position: relative;
}
#case ._scroll::before {
  content: '';
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  background-image: url(../images/point_scroll.png);
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
  width: 180px;
  height: 124px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
#case ._scroll.on::before {
  opacity: 1;
  visibility: visible;
}

#point .point_content {
  position: relative;
  margin-top: clamp(2rem, 1.694rem + 1.306vw, 3rem);
  margin-left: 40px;
  padding: 7%;
  border: 2px solid #35187e;
  border-radius: 6px;
}
@media screen and (max-width: 768px) {
  #point .point_content {
    margin-left: 28px;
    padding: 30px 5% 30px 10%;
  }
}
#point ._number {
  position: absolute;
  top: 30px;
  left: -40px;
  display: -ms-grid;
  display: grid;
  place-items: center;
  width: 80px;
  height: 80px;
  border-radius: 100%;
  background-color: #35187e;
}
@media screen and (max-width: 768px) {
  #point ._number {
    top: 23px;
    left: -28px;
    width: 56px;
    height: 56px;
  }
}
#point ._number p {
  font-size: clamp(0.375rem, 0.279rem + 0.408vw, 0.688rem);
  font-family: 'Lato', sans-serif;
  font-weight: 700;
  color: #fff;
  text-align: center;
}
#point ._number p span {
  font-size: clamp(1.563rem, 1.429rem + 0.571vw, 2rem);
  line-height: 1;
}
#point ._box {
  margin-top: 46px;
}
#point ._title {
  font-size: clamp(1.063rem, 0.929rem + 0.571vw, 1.5rem);
  font-weight: 700;
  color: #35187e;
  line-height: 1.5;
}
#point ._title span {
  color: #be940c;
}
#point ._lead {
  margin-top: 13px;
  line-height: 1.75;
}
#point ._note {
  margin-top: 20px;
  font-size: 14px;
  color: #888888;
  line-height: 1.5;
}
@media screen and (max-width: 650px) {
  #point ._note {
    margin-top: 10px;
  }
}
#point ._image {
  position: relative;
  margin-top: 25px;
}
@media screen and (max-width: 650px) {
  #point ._image {
    overflow: scroll;
  }
}
#point ._image::before {
  content: '';
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  background-image: url(../images/point_scroll.png);
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
  width: 180px;
  height: 124px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
#point ._image.on::before {
  opacity: 1;
  visibility: visible;
}
#point ._image img {
  width: 100%;
  max-width: inherit;
}
@media screen and (max-width: 650px) {
  #point ._image img {
    width: 500px;
  }
}
#point ._sub_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: 26px;
  font-size: 20px;
  color: #35187e;
}
@media screen and (max-width: 650px) {
  #point ._sub_title {
    font-size: 18px;
  }
}
#point ._sub_title::before {
  content: '';
  background-image: url(../images/point_sub_title_icon.png);
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
  width: 41px;
  height: 31px;
  margin-right: 5px;
}
#point ._ex_image {
  margin-top: 32px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 36px 1fr 36px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
}
@media screen and (max-width: 768px) {
  #point ._ex_image {
    -ms-grid-columns: 1fr 10px 1fr;
    grid-template-columns: repeat(2, 1fr);
    row-gap: 20px;
    -webkit-column-gap: 10px;
    -moz-column-gap: 10px;
    column-gap: 10px;
  }
}
#point ._ex_image figure {
  margin: 0;
}
#point ._ex_image img {
  width: 100%;
  border: 1px solid #d3d3d3;
  border-radius: 4px;
  overflow: hidden;
}
#point ._ex_image figcaption {
  margin-top: 12px;
  font-weight: 700;
  text-align: center;
  color: #35187e;
}
@media screen and (max-width: 768px) {
  #point ._ex_image figcaption {
    margin-top: 8px;
  }
}
#point .modal-open {
  width: 100%;
  margin-top: 46px;
  text-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  #point .modal-container {
    width: 100%;
  }
}
#point .modal-content {
  padding: 0;
}
#point .modal-content img {
  width: 100%;
  border-radius: 8px;
}
#point .modal::before {
  content: none;
}
@media screen and (max-width: 650px) {
  #point .modal_link_txt {
    text-align: left;
  }
}
#point ._pattern {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 26px 1fr 26px 1fr;
  grid-template-columns: repeat(3, 1fr);
  row-gap: 24px;
  -webkit-column-gap: 26px;
  -moz-column-gap: 26px;
  column-gap: 26px;
  margin-top: 12px;
}
@media screen and (max-width: 650px) {
  #point ._pattern {
    -ms-grid-columns: (1fr) [1];
    grid-template-columns: repeat(1, 1fr);
    row-gap: 16px;
  }
}
#point ._pattern img {
  width: 100%;
}

#price .section_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  #price .section_title {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
  #price .section_title::after {
    margin-top: 10px;
    margin-left: 0 !important;
  }
}
#price .section_title:after {
  content: '※一括払・分割払をお選びいただけます。';
  margin-left: 26px;
  font-size: 14px;
  font-weight: 400;
  color: #888888;
}
#price ._price {
  border: 2px solid #35187e;
  border-radius: 8px;
  overflow: hidden;
}
#price ._image_container {
  padding: clamp(1.563rem, 1.18rem + 1.633vw, 2.813rem) clamp(1.25rem, 1.059rem + 0.816vw, 1.875rem) 16px;
  background-color: #fff;
}
#price ._image_container ._image {
  width: 54%;
  margin: 0 auto;
}
#price ._image_container ._image img {
  width: 100%;
}
#price ._image_container ._bottom {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}
#price ._image_container ._model {
  font-size: 28px;
  font-family: 'Lato', sans-serif;
  font-weight: 700;
  color: #35187e;
}
#price ._image_container ._model span {
  display: block;
  font-size: 16px;
  font-family: 'Noto Sans JP', sans-serif;
}
#price ._image_container ._ex_price {
  font-size: 16px;
}
#price ._image_container ._ex_price span {
  display: block;
  font-size: 12px;
}
#price ._price_list {
  padding: clamp(1.063rem, 0.948rem + 0.49vw, 1.438rem) clamp(1.25rem, 1.02rem + 0.98vw, 2rem);
  background-color: #35187e;
  color: #fff;
}
#price ._price_list ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: clamp(0.5rem, 0.423rem + 0.327vw, 0.75rem) 0;
}
#price ._price_list ul li:not(:last-child) {
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
}
#price ._price_list ul li:first-child {
  padding-top: 0;
}
#price ._price_list ul li:last-child {
  padding-bottom: 0;
}
#price ._price_list ._case p {
  font-size: 15px;
  font-weight: 700;
  line-height: 1.5;
}
#price ._price_list ._fee {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
#price ._price_list ._fee ._gold {
  font-family: 'Lato', sans-serif;
  font-size: clamp(2rem, 1.847rem + 0.653vw, 2.5rem);
  font-weight: 700;
  color: #be940c;
}
#price ._price_list ._fee ._payment {
  margin-left: 10px;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.1em;
}
#price ._price_list ._fee ._payment span {
  display: block;
  margin-bottom: 2px;
  padding: 3px 4px;
  font-size: 9px;
  font-weight: 700;
  color: #35187e;
  border-radius: 9999px;
  background-color: #fff;
  text-align: center;
}

#faq ._faq_container {
  margin-top: clamp(2rem, 1.847rem + 0.653vw, 2.5rem);
  padding: clamp(1.188rem, 0.862rem + 1.388vw, 2.25rem) clamp(1rem, 0.407rem + 2.531vw, 2.938rem)
    clamp(1.188rem, 0.862rem + 1.388vw, 2.25rem) clamp(1.25rem, 0.714rem + 2.286vw, 3rem);
  background-color: #e9f0f5;
  border-radius: 8px;
}
#faq .acd-label {
  position: relative;
  cursor: pointer;
}
#faq .acd-label::before,
#faq .acd-label::after {
  content: '';
  position: absolute;
  right: 0;
  top: 18px;
  width: 18px;
  height: 4px;
  background-color: #35187e;
  border-radius: 10px;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
#faq .acd-label::after {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}
#faq .acd-label.active::after {
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}
#faq .acd-label p {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 90%;
  font-size: clamp(1.063rem, 1.005rem + 0.245vw, 1.25rem);
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.03em;
}
#faq .acd-label p::before {
  content: 'Q.';
  margin-right: 10px;
  font-size: 24px;
  font-family: 'Lato', sans-serif;
  font-weight: 700;
  color: #35187e;
  line-height: 1.4;
}
#faq .acd-content {
  display: none;
  margin-top: 28px;
}
#faq .acd-content ._answer_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#faq .acd-content ._answer_wrapper::before {
  content: 'A.';
  margin-right: 10px;
  font-size: 24px;
  font-family: 'Lato', sans-serif;
  font-weight: 700;
  color: #35187e;
  line-height: 1.4;
}
#faq .acd-content ._inner {
  width: 90%;
}
#faq .acd-content ._answer {
  line-height: 1.75;
}
#faq ._available_cards {
  display: -ms-grid;
  display: grid;
  place-items: center;
  margin-top: 20px;
  padding: 20px;
  background-color: #fff;
  border-radius: 4px;
}
#faq ._available_cards p {
  text-align: center;
}
#faq ._available_cards p span {
  display: inline-block;
}
#faq ._available_cards ._card_image {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 25px;
  margin-top: 16px;
}
#faq ._available_cards ._card_image img {
  min-width: 56px;
  width: 10%;
}
#faq ._note {
  margin-top: 20px;
  font-size: 14px;
  color: #888888;
  line-height: 1.8;
}
#faq ._tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 26px;
  margin-top: 20px;
  padding: clamp(1rem, 0.923rem + 0.327vw, 1.25rem);
  background-color: #fff;
  border-radius: 4px;
}
@media (max-width: 1400px) {
  #faq ._tel {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
#faq ._tel a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-family: 'Lato', sans-serif;
  font-weight: 700;
  font-size: clamp(1.625rem, 1.548rem + 0.327vw, 1.875rem);
  color: #35187e;
}
#faq ._tel a::before {
  content: '';
  background-image: url(../images/all_tel_icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
  width: 30px;
  height: 30px;
  margin-right: 10px;
}
#faq ._tel ._text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding-left: 26px;
  color: #888888;
  line-height: 1.8;
  border-left: 1px solid #e3e8eb;
}
@media (max-width: 1400px) {
  #faq ._tel ._text {
    display: block;
    padding-left: 0;
    border-left: none;
  }
}
#faq ._tel ._text ._inline_block {
  display: inline-block;
}
#faq ._tel ._text ._under_line {
  border-bottom: 1px solid #35187e;
}
#faq ._tel ._text ._text_blue {
  margin-bottom: 16px;
  color: #35187e;
}
#faq ._sms table {
  margin-top: 30px;
  width: 100%;
}
#faq ._sms ._head {
  padding: 20px;
  color: #fff;
  font-weight: 700;
  background-color: #35187e;
  text-align: center;
}
#faq ._sms ._w40 {
  width: 40%;
}
#faq ._sms ._bg_blue {
  background-color: #f8fbfc;
  font-weight: 700;
}
#faq ._sms ._bg_white {
  background-color: #fff;
}
#faq ._sms table,
#faq ._sms td,
#faq ._sms th {
  border: 1px solid #d3d3d3;
  border-collapse: collapse;
}
#faq ._sms td,
#faq ._sms th {
  padding: clamp(0.625rem, 0.434rem + 0.816vw, 1.25rem);
  height: 25px;
}
#faq ._sms td {
  line-height: 1.75;
  font-size: clamp(0.875rem, 0.837rem + 0.163vw, 1rem);
}
#faq ._sms td span {
  display: inline-block;
}
#faq ._sms td ._note {
  margin-top: 10px;
  font-size: 14px;
  color: #888888;
  line-height: 1.8;
  letter-spacing: 0.03em;
}
#faq ._sms th {
  background: #f0e6cc;
}
#faq ._another_question {
  margin-top: 50px;
  text-align: center;
}
#faq ._another_question a {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  color: #35187e;
  text-decoration: underline;
}
#faq ._another_question a::after {
  content: '';
  background-image: url(../images/faq_another_question.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 20px;
  height: 20px;
  display: inline-block;
  margin-left: 5px;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
#faq ._another_question a:hover::after {
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
}

.detail_information {
  padding: clamp(3.625rem, 3.319rem + 1.306vw, 4.625rem) 20px;
  background-color: #fff;
}
.detail_information h2 {
  font-size: clamp(1.25rem, 1.097rem + 0.653vw, 1.75rem);
  color: #35187e;
  text-align: center;
}
.detail_information ._pdf_wrapper {
  margin-top: clamp(1.375rem, 0.992rem + 1.633vw, 2.625rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: clamp(1rem, 0.541rem + 1.959vw, 2.5rem);
}
.detail_information ._pdf_wrapper a {
  position: relative;
  display: block;
  width: 100%;
  max-width: 360px;
  padding: 24px 20px;
  border-radius: 9999px;
  color: #fff;
  text-align: center;
}
.detail_information ._pdf_wrapper a::after {
  content: '';
  position: absolute;
  right: 20px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background-image: url(../images/all_pdf_icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
  width: 22px;
  height: 30px;
}
.detail_information ._juyo {
  background-color: #cc0319;
}
.detail_information ._shiori {
  background-color: #2e54a3;
}
.detail_information ._attention {
  width: 85%;
  margin: 48px auto;
  padding: clamp(1.75rem, 1.482rem + 1.143vw, 2.625rem) clamp(1.25rem, -0.242rem + 6.367vw, 6.125rem);
  background-color: #e9f0f5;
  border-radius: 10px;
}
@media screen and (max-width: 768px) {
  .detail_information ._attention {
    width: 100%;
  }
}
.detail_information ._attention ._title {
  margin-bottom: 10px;
  font-weight: 700;
}
.detail_information ._attention p {
  line-height: 1.8;
}
.detail_information ._attention ._note {
  font-size: 14px;
  color: #888888;
}
.detail_information ._number {
  font-size: 14px;
  color: #888888;
  text-align: right;
}

#contact .main_area_layout {
  padding-bottom: 100px;
}

.contact_whitebox {
  background: #fff;
  display: block;
  padding: 5%;
  border-radius: 9px;
  margin-bottom: 48px;
}
@media screen and (max-width: 650px) {
  .contact_whitebox {
    margin-bottom: 30px;
    padding: 8% 5%;
  }
}
.contact_whitebox.small_box {
  width: 50%;
}
@media screen and (max-width: 1024px) {
  .contact_whitebox.small_box {
    width: 100%;
  }
}
@media screen and (max-width: 1024px) {
  .contact_whitebox.whitebox_last {
    margin-bottom: 0;
  }
}

.contact_subtitle_big {
  font-size: clamp(1.063rem, 0.864rem + 0.848vw, 1.5rem);
  text-align: center;
  margin-bottom: 18px;
  font-weight: bold;
}
@media screen and (max-width: 1024px) {
  .contact_subtitle_big {
    font-size: clamp(1.063rem, 0.977rem + 0.364vw, 1.25rem);
  }
}

.contact_whitebox img {
  display: block;
  width: 38px;
  height: 38px;
}
@media screen and (max-width: 650px) {
  .contact_whitebox img {
    width: 32px;
    height: 32px;
  }
}

.contact_tel_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 8px;
}

.contact_tel_link p {
  font-size: clamp(2.063rem, 1.864rem + 0.848vw, 2.5rem);
  font-weight: bold;
  color: #35187e;
}

.contact_guide {
  color: #35187e;
  text-align: center;
  margin: 30px auto 20px;
}

.contact_whitebox_flexbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 3%;
}
@media screen and (max-width: 1024px) {
  .contact_whitebox_flexbox {
    display: block;
  }
}

.contact_subtitle_small {
  font-size: clamp(1.063rem, 0.977rem + 0.364vw, 1.25rem);
  text-align: center;
  margin-bottom: 18px;
  font-weight: bold;
}

.p-water-disaster {
  margin-top: 100px;
  padding: 36px 0 80px;
  border-radius: 9px;
  background-color: #fff;
  letter-spacing: 0.03em;
}
@media screen and (max-width: 650px) {
  .p-water-disaster {
    margin-top: 60px;
    padding: 20px 0 64px;
  }
}
.p-water-disaster img {
  width: 100%;
}
.p-water-disaster .c-block {
  display: inline-block;
}
@media screen and (max-width: 650px) {
  .p-water-disaster .c-block {
    display: inline;
  }
}
.p-water-disaster .c-sp_only {
  display: none;
}
@media screen and (max-width: 650px) {
  .p-water-disaster .c-sp_only {
    display: block;
  }
}

.p-water-disaster__inner {
  padding: 0 7%;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__inner {
    padding: 0 20px;
  }
}

.p-water-disaster__title {
  padding: 40px 7% 0;
  text-align: center;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__title {
    padding: 40px 20px 0;
  }
}
.p-water-disaster__title .--inner {
  padding-bottom: clamp(0.625rem, 0.319rem + 1.306vw, 1.625rem);
  border-bottom: 1px solid #d3d3d3;
}

.p-water-disaster__mainTitle {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  position: relative;
  font-weight: bold;
  text-align: center;
}
.p-water-disaster__mainTitle .--top {
  position: relative;
  display: inline-block;
  font-size: clamp(1.125rem, 1.01rem + 0.49vw, 1.5rem);
  color: #cc0319;
  line-height: 1.5;
  letter-spacing: 0.03em;
}
.p-water-disaster__mainTitle .--top::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -7px;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  display: block;
  width: 42%;
  height: 7px;
  background-image: url(../images/water_disaster_titlewave.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.p-water-disaster__mainTitle .--top .--large {
  font-size: 30px;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__mainTitle .--top .--large {
    font-size: 26px;
  }
}
.p-water-disaster__mainTitle .--bottom {
  margin-top: 10px;
  font-size: clamp(1.5rem, 1.347rem + 0.653vw, 2rem);
  line-height: 1.8;
}

.p-water-disaster__titleBubble {
  position: absolute;
  top: -20%;
  left: -34%;
  width: 33%;
}
@media (max-width: 1100px) {
  .p-water-disaster__titleBubble {
    top: -60%;
    left: -2%;
    width: 30%;
  }
}

.p-water-disaster__lead {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: clamp(1.563rem, 1.467rem + 0.408vw, 1.875rem);
  margin-top: clamp(2rem, 1.847rem + 0.653vw, 2.5rem);
  padding: 0 7%;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__lead {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: 0 20px;
  }
}

.p-water-disaster__leadTitle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: 12px;
  width: 45%;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__leadTitle {
    width: 100%;
  }
}
.p-water-disaster__leadTitle .--image {
  width: 4%;
  margin-top: 0.8em;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__leadTitle .--image {
    margin-top: 0.4em;
  }
}
.p-water-disaster__leadTitle .--text {
  width: 96%;
  font-size: clamp(1.125rem, 1.01rem + 0.49vw, 1.5rem);
  font-weight: bold;
  line-height: 1.8;
}
.p-water-disaster__leadTitle .--text .--red {
  color: #cc0319;
  border-bottom: 3px solid #cc0319;
}

.p-water-disaster__leadText {
  width: 55%;
  font-size: 15px;
  line-height: 1.8;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__leadText {
    width: 100%;
  }
}
.p-water-disaster__leadText .--note {
  margin-top: 5px;
  color: #888888;
}

.p-water-disaster-graph {
  margin-top: clamp(2rem, 1.847rem + 0.653vw, 2.5rem);
  padding: 0 7%;
}
@media screen and (max-width: 650px) {
  .p-water-disaster-graph {
    padding: 0;
  }
}
.p-water-disaster-graph img {
  border-radius: 16px;
}
@media screen and (max-width: 650px) {
  .p-water-disaster-graph img {
    border-radius: 0;
  }
}

.p-water-disaster-graph__note {
  margin-top: 8px;
  padding: 0 20px;
  text-align: right;
}
@media screen and (max-width: 650px) {
  .p-water-disaster-graph__note {
    text-align: left;
  }
}
.p-water-disaster-graph__note p {
  font-size: 14px;
  color: #888888;
  line-height: 1.8;
}
@media screen and (max-width: 650px) {
  .p-water-disaster-graph__note p {
    font-size: 13px;
  }
}

.p-water-disaster-anxiety {
  margin-top: 24px;
  padding: 0 7%;
}
@media screen and (max-width: 650px) {
  .p-water-disaster-anxiety {
    margin-top: 50px;
    padding: 0 20px;
  }
}

.p-water-disaster__raise {
  margin: 68px 7% 0;
  padding: 50px 7%;
  background-image: url(../images/water_disaster_raise.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__raise {
    margin: 20px 0 0;
    padding: 20px;
  }
}
.p-water-disaster__raise p {
  font-size: 22px;
  font-weight: 700;
  text-align: center;
  color: #2e54a3;
  line-height: 1.5;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__raise p {
    font-size: 16px;
  }
}

.p-water-disaster__suggestion {
  width: 100%;
  margin-top: 32px;
  padding: 0 7%;
  text-align: center;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__suggestion {
    padding: 0 20px;
  }
}
.p-water-disaster__suggestion .--image {
  max-width: 290px;
  margin: 0 auto;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__suggestion .--image {
    max-width: 250px;
  }
}

.p-water-disaster__message {
  margin-top: 42px;
  padding: 0 7%;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__message {
    margin-top: 14px;
  }
}
.p-water-disaster__message p {
  font-size: 20px;
  line-height: 1.6;
  text-align: center;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__message p {
    font-size: 18px;
  }
}
.p-water-disaster__message p .--inlineBlock {
  display: inline-block;
}
.p-water-disaster__message p .--blue {
  font-size: 24px;
  font-weight: 700;
  color: #2e54a3;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__message p .--blue {
    font-size: 22px;
  }
}

.p-water-disaster__cta {
  margin-top: 24px;
  padding: 0 7%;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__cta {
    margin-top: 16px;
    padding: 0 20px;
  }
}
.p-water-disaster__cta a {
  margin-top: 0;
}
.p-water-disaster__cta a:hover {
  color: #fff;
  background-color: #35187e;
}
.p-water-disaster__cta a:hover svg {
  fill: #fff;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__cta a {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    padding: 24px;
  }
}
.p-water-disaster__cta .--note {
  margin-top: 16px;
  font-size: 15px;
  color: #222222;
  text-align: center;
  line-height: 1.8;
}
@media screen and (max-width: 650px) {
  .p-water-disaster__cta .--note {
    margin-top: 12px;
  }
}
.campaign_banner {
  display: block;
  width: 640px;
  margin-left: 8%;
}
.campaign_banner img {
  display: block;
  width: 100%;
}
@media screen and (max-width: 650px) {
  .campaign_banner {
    width: 100%;
    margin-left: 0;
  }
}