@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@500;600&family=Noto+Sans+JP:wght@400;500;600;700&family=Noto+Serif+JP:wght@600&display=swap");
/* ------------------------------
    reset
------------------------------ */
html {
  font-size: 62.5%;
  overflow-y: scroll;
}
@media screen and (max-width: 1300px) {
  html {
    font-size: calc(100vw * 10 / 1300);
  }
}
@media screen and (max-width: 767px) {
  html {
    font-size: calc(100vw * 10 / 375);
  }
}

*, *::before, *::after {
  box-sizing: border-box;
}

body, h1, h2, h3, h4, h5, h6, p, address, time,
ul, ol, li, dl, dt, dd,
table, th, td, img, figure, figcaption,
form, input, button, textarea, select {
  margin: 0;
  padding: 0;
  border: none;
  line-height: 100%;
  list-style-type: none;
  font-style: normal;
  font-weight: normal;
  font-family: "メイリオ",Meiryo,"Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","ＭＳ Ｐゴシック",Arial,Verdana,sans-serif;
  word-wrap: break-word;
  overflow-wrap: break-word;
  -webkit-text-size-adjust: 100%;
}

input, button, textarea, select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  border-radius: 0;
  resize: none;
  outline: none;
  background: none;
}

select::-ms-expand {
  display: none;
}

button:hover {
  cursor: pointer;
}

a {
  color: #000;
  text-decoration: none;
  transition: opacity 0.3s ease;
  outline: 1px solid transparent;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
a img {
  outline: 1px solid transparent;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
a:hover {
  opacity: .6;
  cursor: pointer;
}

img, object {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
}

/* ------------------------------
    base
------------------------------ */
body {
  color: #333;
  text-align: left;
  position: relative;
}

section {
  position: relative;
}

main {
  display: block;
  position: relative;
  padding-top: 5.5rem;
}

.wrap {
  width: 100%;
  max-width: 110rem;
  padding: 0;
  margin: 0 auto;
  position: relative;
}

p, th, td, dt, dd, li, input, button, textarea {
  font-size: 1.7rem;
  line-height: calc(30/17);
}
@media screen and (max-width: 767px) {
  p, th, td, dt, dd, li, input, button, textarea {
    font-size: 1.6rem;
  }
}

.flex {
  display: flex;
  justify-content: space-between;
}
.flex.reverse {
  flex-direction: row-reverse;
}

.tal {
  text-align: left;
}

.tar {
  text-align: right;
}

.tac {
  text-align: center;
}

.left {
  float: left;
}

.right {
  float: right;
}

.center {
  display: block;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.fwb {
  font-weight: 700;
}

.ft_oswald {
  font-family: 'Oswald', sans-serif;
}

.fixed {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

.color_red {
  color: #d90000 !important;
}

.color_or1 {
  color: #fa7a4f !important;
}

.color_yel {
  color: #fff3ba !important;
}

.highlight {
  background: linear-gradient(transparent 60%, #ffd701 60%, #ffd701 98%, transparent 98%);
}

.highlight2 {
  background: linear-gradient(transparent 45%, #ffd701 45%, #ffd701 98%, transparent 98%);
}

.udl {
  background: linear-gradient(transparent 88%, #33322e 88%, #33322e 92%, transparent 92%);
}

.mac .udl {
  border-bottom: 1px solid #33322e;
  padding-bottom: .1em;
  background: none;
}

.preload *, .preload *::before, .preload *::after {
  transition: none !important;
}

@media screen and (min-width: 768px) {
  .fade {
    transition: opacity 0.3s ease;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
  }

  .fade img {
    outline: 1px solid transparent;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
  }

  .fade:hover {
    opacity: .6;
    cursor: pointer;
  }

  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
}
@media screen and (max-width: 767px) {
  body {
    min-width: inherit;
  }

  .wrap {
    width: 94%;
    padding: 0;
  }

  main {
    padding-top: 2.4rem;
  }

  input, textarea, select, .select {
    font-size: 16px !important;
  }

  .udl, .mac .udl {
    background: none;
    border-bottom: 1px solid #33322e;
    padding: .05em 0;
  }
}
/* ------------------------------
    header
------------------------------ */
#header {
  top: 0;
  left: 0;
  padding: 0;
  margin: 0;
  z-index: 999;
  position: fixed;
  width: 100%;
}
#header .wrap {
  max-width: inherit;
  width: 100%;
  height: 5.5rem;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #f9f9f9;
  padding-left: 5%;
}
#header .inner {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
#header .logo {
  width: 17.3rem;
  line-height: 1;
}
#header .logo a {
  display: block;
}
#header nav .nav_wrap {
  display: flex;
  align-items: center;
}
#header nav .gnavi {
  display: flex;
  justify-content: right;
}
#header nav .gnavi > li > a {
  display: block;
  font-size: 1.4rem;
  font-family: "Noto Sans JP", sans-serif;
}
#header nav .gnavi > li + li {
  margin-left: 2.7rem;
}
#header nav .btn_dl {
  margin-left: 5.4rem;
}
#header nav .btn_dl a {
  position: relative;
  width: 26.5rem;
  height: 5.5rem;
  font-size: 1.6rem;
  font-weight: 500;
  background: #fa7a4f;
  font-family: "Noto Sans JP", sans-serif;
  color: #fff;
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: .05em;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-right: 1rem;
}
#header nav .btn_dl a::before {
  position: absolute;
  content: "";
  background: url("../img/icn_arrow_dl.png") no-repeat center center/contain;
  width: 0.8rem;
  height: 1.1rem;
  right: 2rem;
  top: 50%;
  transform: translateY(-50%);
}
#header .overlay {
  display: block;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(45, 45, 47, 0.5);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  z-index: 997;
}
#header .overlay.is-active {
  opacity: 1;
  pointer-events: auto;
}

@media screen and (max-width: 767px) {
  #header {
    background-color: transparent;
    width: 100%;
  }
  #header .wrap {
    height: 2.4rem;
    padding-left: 1.8%;
    padding-right: 0;
    margin: 0;
  }
  #header .logo {
    z-index: 999;
    width: inherit;
    flex: 1;
  }
  #header .logo img {
    width: 7.3rem;
  }
  #header .menu-trigger {
    position: relative;
    width: 4rem;
    height: 2.4rem;
    z-index: 999;
    background: #fa7a4f;
  }
  #header .menu-trigger span {
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 50%;
    width: 2.2rem;
    height: 2px;
    background-color: #fff;
  }
  #header .menu-trigger span:nth-of-type(1) {
    top: 25%;
    transform: translateX(-50%);
  }
  #header .menu-trigger span:nth-of-type(2) {
    top: 50%;
    transform: translate(-50%, -50%);
  }
  #header .menu-trigger span:nth-of-type(3) {
    bottom: 25%;
    transform: translateX(-50%);
  }
  #header nav {
    width: 100%;
    opacity: 0;
    padding: 0;
    position: fixed;
    left: 0;
    top: 2.4rem;
    overflow-y: auto;
    max-height: calc(100% - 2.4rem);
    transform: translateX(100%);
    transition: transform .3s, opacity 1s;
    z-index: 998;
  }
  #header nav .nav_wrap {
    background: #fff;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    position: relative;
    margin: 0;
    padding: 2rem 1rem 12.8vw;
    display: block;
  }
  #header nav .nav_wrap .gnavi {
    margin: 0;
    display: block;
  }
  #header nav .nav_wrap .gnavi > li {
    display: block;
    height: auto;
    position: relative;
  }
  #header nav .nav_wrap .gnavi > li > a {
    display: block;
    font-size: 1.6rem;
    line-height: 1;
    padding: 1em 0 1em 1.8em;
    position: relative;
  }
  #header nav .nav_wrap .gnavi > li > a::before {
    position: absolute;
    content: "";
    width: .7rem;
    height: .7rem;
    border-top: solid 1px #fa7a4f;
    border-right: solid 1px #fa7a4f;
    position: absolute;
    left: 1em;
    top: 1.35em;
    transform: rotate(45deg);
  }
  #header nav .nav_wrap .gnavi > li + li {
    margin-left: 0;
  }
  #header nav .btn_dl {
    margin: 2.5rem auto 0;
    text-align: center;
  }
  #header nav .btn_dl a {
    width: 29.5rem;
    height: 6rem;
    font-size: 1.8rem;
    margin: 0 auto;
    padding-right: 1.5rem;
  }
  #header nav .btn_dl a::before {
    right: 2.8rem;
  }
  #header.is-open .menu-trigger span {
    background-color: #fff;
    transform-origin: center center;
  }
  #header.is-open .menu-trigger span:nth-of-type(1) {
    top: 50%;
    transform: translateX(-50%) translateY(-50%) rotate(-30deg);
  }
  #header.is-open .menu-trigger span:nth-of-type(2) {
    opacity: 0;
  }
  #header.is-open .menu-trigger span:nth-of-type(3) {
    top: 50%;
    bottom: auto;
    transform: translateX(-50%) translateY(-50%) rotate(30deg);
  }
  #header.is-open nav {
    opacity: 1;
    transform: translateX(0);
    transition: transform .3s, opacity 0s;
  }
}
/* ------------------------------
    footer
------------------------------ */
#footer {
  background: #ff;
  padding: 3.4rem 0;
}
#footer .logo {
  width: 30.5rem;
  line-height: 1;
  margin: 0 auto 4rem;
}
#footer .copy {
  font-size: 1.8rem;
  letter-spacing: .05em;
  font-family: "Noto Sans JP", sans-serif;
  color: #121212;
  text-align: center;
}

@media screen and (max-width: 767px) {
  #footer {
    padding: 2rem 0;
  }
  #footer .logo {
    width: 18rem;
    margin: 0 auto 1.2rem;
  }
  #footer .copy {
    font-size: 1.4rem;
  }
}
/* ------------------------------
    main
------------------------------ */
/* common */
.ttl_sec {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  color: #33322e;
  text-align: center;
  position: relative;
}
.ttl_sec.-line::before {
  position: absolute;
  content: "";
  background: #fa7a4f;
  width: 8.5rem;
  height: 0.7rem;
  bottom: -4rem;
  left: 50%;
  transform: translateX(-50%);
}
.ttl_sec.white {
  color: #fff;
}
.ttl_sec.white.-line::before {
  background: #fff;
}
@media screen and (max-width: 767px) {
  .ttl_sec.-line::before {
    width: 6.5rem;
    height: 0.5rem;
    bottom: -2rem;
  }
}

.cta_img {
  line-height: 1;
  width: 62.2rem;
  margin: 0 auto 4.5rem;
}
.cta_txt {
  color: #e31b1b;
  font-size: 2.4rem;
  font-weight: 700;
  text-align: center;
  line-height: calc(30/24);
  margin-bottom: 0.4rem;
}
@media screen and (max-width: 767px) {
  .cta_img {
    width: 100%;
    margin: 0 auto 4.5rem;
  }
  .cta_txt {
    font-size: 1.5rem;
  }
}

.ctabtn {
  text-align: center;
}
.ctabtn_link {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #1c8a57;
  border-radius: 9999px;
  width: 49.4rem;
  height: 7.6rem;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 3rem;
  font-weight: 500;
  letter-spacing: .04em;
  margin: 0 auto;
  padding-right: 1.6rem;
  padding-bottom: .15em;
}
.ctabtn_link::before {
  position: absolute;
  content: "";
  background: url("../img/icn_arrow_right.png") no-repeat center center/contain;
  width: 1.4rem;
  height: 1.9rem;
  top: 50%;
  transform: translateY(-50%);
  right: 2.9rem;
}
@media screen and (max-width: 767px) {
  .ctabtn_link {
    width: 31rem;
    height: 4.7rem;
    font-size: 1.85rem;
    padding-right: 1rem;
  }
  .ctabtn_link::before {
    width: 0.9rem;
    height: 1.2rem;
    right: 1.6rem;
  }
}

/* sec_mv */
#sec_mv {
  background: url("../img/bg_mv_pc.png") no-repeat center top/100% auto;
  padding-top: 3.2rem;
  padding-bottom: 8.5rem;
}
#sec_mv .ttl {
  margin: 0 auto;
  line-height: 1;
  width: 76.8rem;
}
#sec_mv .cta {
  margin-top: 3.4rem;
}
#sec_mv .movie {
  text-align: center;
}
#sec_mv .movie iframe {
  border: none;
  margin: 7.5rem auto 0;
  width: 79.4rem;
  height: 100%;
  aspect-ratio: 794/434;
}

@media screen and (max-width: 767px) {
  #sec_mv {
    background: url("../img/bg_mv_sp.png") no-repeat center top/100% auto;
    padding-top: 2.6rem;
    padding-bottom: 2.5rem;
  }
  #sec_mv .ttl {
    width: 35.7rem;
  }
  #sec_mv .cta {
    margin-top: 3.3rem;
  }
  #sec_mv .movie iframe {
    margin: 3.5rem auto 0;
    width: 96%;
  }
}
/* sec_lead */
#sec_lead {
  background: #fff;
  padding: 8.5rem 0 10.5rem;
}
#sec_lead .ttl {
  margin: 0 auto 5rem;
}
#sec_lead .ttl .txt01,
#sec_lead .ttl .txt02 {
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.5;
  display: block;
}
#sec_lead .ttl .txt01 {
  font-size: 3.6rem;
  font-weight: 500;
}
#sec_lead .ttl .txt02 {
  font-size: 4.2rem;
  font-weight: 700;
}
#sec_lead .lead_box {
  position: relative;
  padding-bottom: 16.2rem;
}
#sec_lead .lead_box::before {
  position: absolute;
  content: "";
  background: #fa7a4f;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 18.3rem;
  height: 3.2rem;
  bottom: 3rem;
  left: 50%;
  transform: translateX(-50%);
}
#sec_lead .lead_list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  width: 100%;
  gap: 9.6rem 2.3rem;
}
#sec_lead .lead_list li {
  position: relative;
  width: 34.8rem;
  height: auto;
  min-height: 19.4rem;
  border-radius: 10px;
  background: #e7e7e7;
  display: flex;
  align-items: center;
  justify-content: center;
}
#sec_lead .lead_list li:nth-child(1) .txt, #sec_lead .lead_list li:nth-child(5) .txt {
  padding-bottom: 2.4rem;
}
#sec_lead .lead_list .txt {
  font-size: 2.4rem;
  line-height: calc(36/24);
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  line-height: 1.5;
  padding-bottom: 3.2rem;
}
#sec_lead .lead_list .img {
  position: absolute;
  bottom: -7.5rem;
}
#sec_lead .lead_list .img.img01 {
  width: 16.9rem;
  right: -1rem;
}
#sec_lead .lead_list .img.img02 {
  width: 19.1rem;
  right: 1.4rem;
}
#sec_lead .lead_list .img.img03 {
  width: 17.3rem;
  right: 1.4rem;
}
#sec_lead .lead_list .img.img04 {
  width: 16.4rem;
  right: -0.7rem;
  bottom: -5.1rem;
}
#sec_lead .lead_list .img.img05 {
  width: 18.3rem;
  right: -2.5rem;
  bottom: -5.1rem;
}
#sec_lead .lead_btm {
  position: relative;
}
#sec_lead .lead_btm p {
  font-size: 3rem;
  font-family: "Noto Sans JP", sans-serif;
  line-height: calc(48/30);
  font-weight: 500;
}
#sec_lead .lead_btm .notes {
  display: inline-block;
  font-size: 1.4rem;
  color: #33322e;
  line-height: 1;
  font-family: "Noto Sans JP", sans-serif;
  background: #ffd701;
  padding: .2em .3em;
  position: absolute;
  bottom: -2rem;
  right: 27.5rem;
}
#sec_lead .marker {
  background: linear-gradient(transparent 75%, #ffd701 75%, #ffd701 92%, transparent 92%);
}

@media screen and (max-width: 767px) {
  #sec_lead {
    padding: 2.5rem 0 5rem;
  }
  #sec_lead .ttl {
    margin: 0 auto 2.5rem;
  }
  #sec_lead .ttl .txt01 {
    font-size: 2rem;
  }
  #sec_lead .ttl .txt02 {
    font-size: 2.3rem;
  }
  #sec_lead .lead_box {
    padding-bottom: 12rem;
  }
  #sec_lead .lead_box::before {
    width: 11rem;
    height: 1.9rem;
    bottom: 3.6rem;
  }
  #sec_lead .lead_list {
    flex-direction: column;
    align-items: center;
    gap: 8rem 0;
  }
  #sec_lead .lead_list li {
    width: 90%;
    min-height: 16rem;
  }
  #sec_lead .lead_list li:nth-child(1) .txt, #sec_lead .lead_list li:nth-child(5) .txt {
    padding-bottom: 2.4rem;
  }
  #sec_lead .lead_list .txt {
    font-size: 2rem;
    padding-bottom: 1.8rem;
  }
  #sec_lead .lead_list .img {
    bottom: -6rem;
    right: -2rem !important;
  }
  #sec_lead .lead_list .img img {
    width: 100%;
  }
  #sec_lead .lead_list .img.img01 {
    width: 13.5rem;
  }
  #sec_lead .lead_list .img.img02 {
    width: 15.2rem;
  }
  #sec_lead .lead_list .img.img03 {
    width: 13.8rem;
  }
  #sec_lead .lead_list .img.img04 {
    width: 13.1rem;
    bottom: -4rem;
  }
  #sec_lead .lead_list .img.img05 {
    width: 14.6rem;
    bottom: -4rem;
  }
  #sec_lead .lead_btm p {
    font-size: 2rem;
  }
  #sec_lead .lead_btm .notes {
    font-size: 1rem;
    padding: .3em .4em;
    right: 0;
  }
}
#sec_about {
  background: #e98d4f;
  padding: 2.6rem 0 6.7rem;
}
#sec_about .ttl_sec {
  font-size: 4.8rem;
  line-height: 1;
}
#sec_about .ttl_sec.ttl01 {
  margin: 0 auto 10rem;
  letter-spacing: -.02em;
}
#sec_about .ttl_sec.ttl02 {
  margin: 0 auto 12rem;
}
#sec_about .ttl_sec.ttl03 {
  line-height: calc(60/48);
  letter-spacing: .075em;
  margin: 0 auto 4rem;
}
#sec_about .ttl_sec.ttl04 {
  letter-spacing: .075em;
}
#sec_about .contents_wrap {
  position: relative;
  max-width: 102.8rem;
  box-shadow: 0 0 4px 2px rgba(102, 102, 102, 0.3);
  background-color: #fff;
  border: 3px solid #fa7a4f;
  margin: auto;
}
#sec_about .contents_wrap::before, #sec_about .contents_wrap::after {
  position: absolute;
  content: "";
  top: 0;
  background: #727171;
  width: 7.8rem;
  height: 7.4rem;
}
#sec_about .contents_wrap::before {
  clip-path: polygon(0 0, 0% 100%, 100% 0);
  left: 0;
}
#sec_about .contents_wrap::after {
  clip-path: polygon(0 0, 100% 100%, 100% 0);
  right: -0.1rem;
}
#sec_about .contents_wrap .bg {
  position: relative;
  padding: 8.8rem 2.6rem 8rem;
}
#sec_about .contents_wrap .bg::before, #sec_about .contents_wrap .bg::after {
  position: absolute;
  content: "";
  bottom: 0;
  background: #727171;
  width: 7.8rem;
  height: 7.4rem;
}
#sec_about .contents_wrap .bg::before {
  clip-path: polygon(0 0, 0% 100%, 100% 100%);
  left: 0;
}
#sec_about .contents_wrap .bg::after {
  clip-path: polygon(100% 0, 0% 100%, 100% 100%);
  right: -0.1rem;
}
#sec_about .txt_box .txt {
  flex: 1;
}
#sec_about .txt_box .txt p + p {
  margin-top: 3rem;
}
#sec_about .txt_box.box01 {
  padding: 0 1rem;
  margin: 0 auto 9.5rem;
  gap: 0 5rem;
}
#sec_about .txt_box.box01 .img {
  width: 43.4rem;
}
#sec_about .txt_box.box02 {
  padding: 0 0 0 2rem;
  margin: 0 auto 9.5rem;
  align-items: center;
  gap: 0 6.5rem;
}
#sec_about .txt_box.box02 .img {
  width: 37.6rem;
}
#sec_about .service {
  margin: 0 auto;
}
#sec_about .service .num_list {
  display: flex;
  width: 100%;
  justify-content: flex-start;
  gap: 0 calc((100% - 22.7rem * 4) / 3);
}
#sec_about .service .num_list li {
  position: relative;
  width: 22.7rem;
  min-height: 37.3rem;
  border: 3px solid #fa7a4f;
  border-radius: 3px;
  padding: 3.4rem 1.8rem 3.2rem;
}
#sec_about .service .num_list li::before, #sec_about .service .num_list li::after {
  position: absolute;
  width: 4.4rem;
  height: 4.4rem;
}
#sec_about .service .num_list li::before {
  color: #fff;
  z-index: 2;
  text-align: center;
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 2.4rem;
  line-height: 1;
  left: 50%;
  transform: translateX(-50%);
  top: -1.4rem;
}
#sec_about .service .num_list li::after {
  content: "";
  background: #fa7a4f;
  border-radius: 50%;
  left: 50%;
  transform: translateX(-50%);
  top: -2.5rem;
}
#sec_about .service .num_list li.list01::before {
  content: "1";
}
#sec_about .service .num_list li.list02::before {
  content: "2";
}
#sec_about .service .num_list li.list03::before {
  content: "3";
}
#sec_about .service .num_list li.list04::before {
  content: "4";
}
#sec_about .service .num_list dt {
  font-size: 3rem;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  text-align: center;
  color: #33322e;
  letter-spacing: .1em;
  line-height: 1;
  margin-bottom: 3.7rem;
}
#sec_about .service .num_list dd .img {
  text-align: center;
  margin-bottom: 1rem;
  width: 19.2rem;
}
#sec_about .service .num_list dd .txt {
  font-size: 1.6rem;
  line-height: calc(24/16);
  letter-spacing: -.08em;
  text-align: justify;
}
#sec_about .service .notes {
  font-size: 1.4rem;
  margin-top: 2em;
  text-align: right;
}
#sec_about .merit {
  position: relative;
  width: 88.3rem;
  background: url("../img/bg_navy.png") repeat;
  padding: 1.8rem 1.8rem;
  margin: 12.2rem auto 12.2rem;
}
#sec_about .merit::before {
  position: absolute;
  content: "";
  background: #fa7a4f;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 18.3rem;
  height: 3.2rem;
  bottom: -6.6rem;
  left: 50%;
  transform: translateX(-50%);
}
#sec_about .merit .inner {
  position: relative;
  background: #fff;
  box-shadow: 0 0 4px 2px rgba(102, 102, 102, 0.3);
  padding: 6.4rem 1rem 5.6rem;
}
#sec_about .merit .inner::before, #sec_about .merit .inner::after {
  position: absolute;
  content: "";
}
#sec_about .merit .inner::before {
  background: url("../img/img_clip.png") no-repeat center center/contain;
  width: 22.6rem;
  height: 7rem;
  left: 50%;
  top: -2.2rem;
  transform: translateX(-50%);
}
#sec_about .merit .inner::after {
  background: url("../img/icn_emblem.png") no-repeat center center/contain;
  width: 5.86rem;
  height: 7.6rem;
  left: 4.8rem;
  top: 3.6rem;
}
#sec_about .merit_ttl {
  position: relative;
  margin-bottom: 6.6rem;
}
#sec_about .merit_ttl::before, #sec_about .merit_ttl::after {
  position: absolute;
  content: "";
  background: #727171;
  width: 77.5rem;
  height: 1px;
  left: 50%;
  transform: translateX(-50%);
}
#sec_about .merit_ttl::before {
  bottom: -1.5rem;
}
#sec_about .merit_ttl::after {
  bottom: -1.9rem;
}
#sec_about .merit_ttl .txt01,
#sec_about .merit_ttl .txt02 {
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.5;
  font-weight: 700;
  display: block;
}
#sec_about .merit_ttl .txt01 {
  font-size: 3.6rem;
}
#sec_about .merit_ttl .txt02 {
  font-size: 4.4rem;
  letter-spacing: -.03em;
}
#sec_about .merit_list {
  margin-bottom: 6.4rem;
  padding-left: 3rem;
}
#sec_about .merit_list li + li {
  margin-top: 4rem;
}
#sec_about .merit_list .list_ttl {
  display: flex;
  align-items: center;
  gap: 0 2.9rem;
  margin-bottom: 1.6rem;
  padding-left: 0.5rem;
}
#sec_about .merit_list .num {
  width: 5.3rem;
}
#sec_about .merit_list .ttltxt {
  font-size: 3.2rem;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  letter-spacing: .075em;
  color: #33322e;
  flex: 1;
  padding-bottom: .2em;
}
#sec_about .foot {
  margin-top: 9.5rem;
}
#sec_about .foot_logo {
  width: 53.4rem;
  line-height: 1;
  margin: 4.2rem auto 5.2rem;
}
#sec_about .foot_txt {
  font-size: 2rem;
  line-height: calc(36/20);
  color: #33322e;
  font-weight: 500;
  font-family: "Noto Sans JP", sans-serif;
  text-align: center;
  margin-bottom: 5.8rem;
}

@media screen and (max-width: 767px) {
  #sec_about {
    padding: 2rem 0 2rem;
  }
  #sec_about .ttl_sec {
    font-size: 2.6rem;
    line-height: 1.4;
  }
  #sec_about .ttl_sec.ttl01 {
    margin-bottom: 5rem;
  }
  #sec_about .ttl_sec.ttl02 {
    margin-bottom: 8rem;
  }
  #sec_about .ttl_sec.ttl03 {
    margin-bottom: 2rem;
  }
  #sec_about .contents_wrap {
    max-width: inherit;
  }
  #sec_about .contents_wrap::before, #sec_about .contents_wrap::after {
    width: 3.9rem;
    height: 3.7rem;
  }
  #sec_about .contents_wrap .bg {
    padding: 3rem 3.5% 5rem;
  }
  #sec_about .contents_wrap .bg::before, #sec_about .contents_wrap .bg::after {
    width: 3.9rem;
    height: 3.7rem;
  }
  #sec_about .txt_box {
    flex-direction: column;
    align-items: center;
  }
  #sec_about .txt_box .txt p + p {
    margin-top: 5%;
  }
  #sec_about .txt_box.box01 {
    padding: 0;
    margin: 0 auto 6rem;
    gap: 5vw 0;
  }
  #sec_about .txt_box.box01 .img {
    width: 86%;
  }
  #sec_about .txt_box.box02 {
    padding: 0;
    margin: 0 auto;
    gap: 5vw 0;
  }
  #sec_about .txt_box.box02 .img {
    width: 72%;
  }
  #sec_about .service .num_list {
    flex-direction: column;
    gap: 9.6vw 0;
  }
  #sec_about .service .num_list li {
    width: 96%;
    min-height: inherit;
    padding: 3.3rem 1.6rem 2rem;
    margin: 0 auto;
  }
  #sec_about .service .num_list li::before, #sec_about .service .num_list li::after {
    width: 4rem;
    height: 4rem;
  }
  #sec_about .service .num_list li::before {
    font-size: 2.2rem;
    top: -1.3rem;
  }
  #sec_about .service .num_list li::after {
    top: -2.3rem;
  }
  #sec_about .service .num_list dt {
    font-size: 2.6rem;
    margin-bottom: 2.2rem;
  }
  #sec_about .service .num_list dd .img {
    text-align: center;
    width: 100%;
    margin: 0 auto;
  }
  #sec_about .service .num_list dd .img img {
    width: 16rem;
  }
  #sec_about .service .num_list dd .txt {
    font-size: 1.6rem;
  }
  #sec_about .service .notes {
    font-size: 1.2rem;
    margin-top: 1em;
  }
  #sec_about .merit {
    width: 104%;
    padding: 3%;
    margin: 5rem -2% 8rem;
  }
  #sec_about .merit::before {
    width: 11rem;
    height: 1.9rem;
    bottom: -5rem;
  }
  #sec_about .merit .inner {
    padding: 5rem 3% 2.5rem;
  }
  #sec_about .merit .inner::before {
    width: 12rem;
    height: 3.7rem;
    top: -1.2rem;
  }
  #sec_about .merit .inner::after {
    width: 3rem;
    height: 3.9rem;
    left: 1.6rem;
    top: 1.2rem;
  }
  #sec_about .merit_ttl {
    margin-bottom: 4rem;
  }
  #sec_about .merit_ttl::before, #sec_about .merit_ttl::after {
    width: 100%;
  }
  #sec_about .merit_ttl .txt01 {
    font-size: 1.8rem;
    margin-bottom: .2em;
  }
  #sec_about .merit_ttl .txt02 {
    font-size: 2.8rem;
    line-height: 1.25;
  }
  #sec_about .merit_list {
    margin-bottom: 3rem;
    padding-left: 0;
  }
  #sec_about .merit_list li + li {
    margin-top: 2.5rem;
  }
  #sec_about .merit_list .list_ttl {
    flex-direction: column;
    gap: 0.5rem 0;
    margin-bottom: 1.6rem;
    padding-left: 0.5rem;
  }
  #sec_about .merit_list .num {
    width: 4rem;
  }
  #sec_about .merit_list .ttltxt {
    font-size: 2.2rem;
    line-height: 1.25;
    text-align: center;
  }
  #sec_about .merit_logo {
    width: 15rem;
    margin: 0 auto;
  }
  #sec_about .foot {
    margin-top: 5rem;
  }
  #sec_about .foot_logo {
    width: 18rem;
    margin: 2rem auto 2rem;
  }
  #sec_about .foot_txt {
    font-size: 1.75rem;
    margin-bottom: 3rem;
  }
}
/* sec_feature */
#sec_feature {
  position: relative;
  background: url("../img/bg_check.png") repeat;
  padding: 7.8rem 0 17rem;
}
#sec_feature::before {
  position: absolute;
  content: "";
  background: #e98d4f;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 38.8rem;
  height: 3.8rem;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
}
#sec_feature .ttl_logo {
  width: 31.5rem;
  line-height: 1;
  margin: 0 auto 4rem;
}
#sec_feature .ttl_sec {
  font-size: 6rem;
  letter-spacing: .05em;
  margin-bottom: 5.5rem;
}
#sec_feature .inner {
  max-width: 98rem;
  margin: 0 auto;
}
#sec_feature .cont01 {
  position: relative;
  padding: 0 2rem 16.2rem;
}
#sec_feature .cont01::before {
  position: absolute;
  content: "";
  background: #fa7a4f;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 18.3rem;
  height: 3.2rem;
  bottom: 5.5rem;
  left: 50%;
  transform: translateX(-50%);
}
#sec_feature .cont01 .item + .item {
  margin-top: 7rem;
}
#sec_feature .cont01 .subttl {
  display: flex;
  align-items: center;
  gap: 0 2.8rem;
  margin-bottom: 4rem;
}
#sec_feature .cont01 .subttl .num {
  width: 7.8rem;
  height: 7.8rem;
  background: #fa7a4f;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 0.5rem 0;
  padding-top: .2em;
}
#sec_feature .cont01 .subttl .num .txt01,
#sec_feature .cont01 .subttl .num .txt02 {
  color: #fff;
  font-weight: 500;
  line-height: 1;
}
#sec_feature .cont01 .subttl .num .txt01 {
  font-size: 2.175rem;
  letter-spacing: .05em;
  font-family: "Noto Sans JP", sans-serif;
}
#sec_feature .cont01 .subttl .num .txt02 {
  font-size: 2.7rem;
  font-family: "Poppins", sans-serif;
}
#sec_feature .cont01 .subttl .ttltxt {
  font-size: 3.6rem;
  line-height: 2;
  color: #33322e;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  letter-spacing: .05em;
}
#sec_feature .cont01 .txt_box {
  align-items: center;
}
#sec_feature .cont01 .txt_box.box01, #sec_feature .cont01 .txt_box.box03 {
  gap: 0 6.2rem;
}
#sec_feature .cont01 .txt_box.box02 {
  gap: 0 4.2rem;
}
#sec_feature .cont01 .txt_box.box04 {
  gap: 0 5rem;
}
#sec_feature .cont01 .txt_box.box05 {
  gap: 0 5.2rem;
}
#sec_feature .cont01 .txt {
  flex: 1;
  font-size: 2.4rem;
  line-height: calc(48/24);
}
#sec_feature .cont01 .img.img01 {
  width: 41.6rem;
}
#sec_feature .cont01 .img.img02 {
  width: 42.1rem;
}
#sec_feature .cont01 .img.img05 {
  width: 42rem;
}
#sec_feature .cont01 .img.img03, #sec_feature .cont01 .img.img04 {
  width: 41.5rem;
}
#sec_feature .cont02 {
  position: relative;
  padding-bottom: 12.5rem;
}
#sec_feature .cont02::before {
  position: absolute;
  content: "";
  background: #fa7a4f;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 18.3rem;
  height: 3.2rem;
  bottom: 6.5rem;
  left: 50%;
  transform: translateX(-50%);
}
#sec_feature .cont02 .box {
  position: relative;
  width: 100%;
  background: #fff;
  border: 5px solid #e98d4f;
  border-radius: 5px;
}
#sec_feature .cont02 .box .support_anchor,
#sec_feature .cont02 .box .fee_anchor {
  position: absolute;
  top: -5rem;
}
#sec_feature .cont02 .box.support {
  padding: 2.5rem 2rem 3.5rem;
}
#sec_feature .cont02 .box.support * {
  font-family: "Noto Sans JP", sans-serif;
}
#sec_feature .cont02 .box.fee {
  padding: 2.5rem 3.5rem 3rem;
  margin-top: 5.5rem;
}
#sec_feature .cont02 .box.fee * {
  font-family: "Noto Sans JP", sans-serif;
}
#sec_feature .cont02 .box_logo {
  line-height: 0;
  margin-bottom: 1.6rem;
}
#sec_feature .cont02 .box_logo img {
  width: 23rem;
}
#sec_feature .cont02 .box_ttl {
  font-size: 5rem;
  line-height: calc(72/50);
  color: #33322e;
  font-weight: 700;
  letter-spacing: .05em;
  margin-bottom: 4.5rem;
}
#sec_feature .cont02 .box .notes {
  font-size: 2.4rem;
  font-weight: 500;
  letter-spacing: .01em;
}
#sec_feature .cont02 .box .support_item {
  justify-content: center;
  gap: 0 calc(100% - 45.4rem * 2);
  margin-bottom: 2.5rem;
}
#sec_feature .cont02 .box .support_item .box_dl {
  position: relative;
  width: 45.4rem;
}
#sec_feature .cont02 .box .support_item .box_dl dt {
  position: relative;
  background: #fa7a4f;
  width: 100%;
  border-radius: 5px;
  height: 5.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 3.6rem;
  font-weight: 500;
  letter-spacing: .1em;
  margin-bottom: 5.5rem;
  padding-left: .4em;
}
#sec_feature .cont02 .box .support_item .box_dl dt::before {
  position: absolute;
  content: "";
  background: #fa7a4f;
  width: 1.8rem;
  height: 2.3rem;
  clip-path: polygon(85% 0, 0 0, 65% 100%);
  bottom: -2.2rem;
  left: 50%;
  transform: translateX(-50%);
}
#sec_feature .cont02 .box .support_item .box_dl .support_list {
  background: #fcf4f2;
  padding: 2rem 2.1rem 2.8rem;
  width: 44rem;
  margin: 0 auto;
}
#sec_feature .cont02 .box .support_item .box_dl .support_list li {
  position: relative;
  font-size: 2.4rem;
  line-height: calc(40/24);
  font-weight: 500;
  color: txt_ttl;
  padding-left: 1.1em;
}
#sec_feature .cont02 .box .support_item .box_dl .support_list li::before {
  position: absolute;
  content: "●";
  color: #e98d4f;
  left: 0;
  top: 0;
}
#sec_feature .cont02 .box .fee_item {
  justify-content: center;
  gap: 0 calc(100% - 44rem * 2);
  margin-bottom: 2.5rem;
}
#sec_feature .cont02 .box .fee_item.full {
  margin-top: 4rem;
  margin-bottom: 2rem;
}
#sec_feature .cont02 .box .fee_item.full .box_dl {
  width: 100%;
}
#sec_feature .cont02 .box .fee_item.full .box_dl > dd {
  padding: 4.5rem 4.8rem 3.5rem;
  min-height: inherit;
  display: block;
}
#sec_feature .cont02 .box .fee_item .box_dl {
  position: relative;
  width: 44rem;
}
#sec_feature .cont02 .box .fee_item .box_dl > dt {
  position: relative;
  background: #fa7a4f;
  width: 26.2rem;
  border-radius: 5px;
  height: 5.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 3.6rem;
  font-weight: 500;
  margin: 0 auto -2.5rem;
}
#sec_feature .cont02 .box .fee_item .box_dl > dt.wide {
  letter-spacing: .02em;
}
#sec_feature .cont02 .box .fee_item .box_dl > dd {
  background: #fcf4f2;
  padding: 2rem 0 1.6rem;
  width: 100%;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  min-height: 21.5rem;
}
#sec_feature .cont02 .box .fee_item .fee_lead {
  font-size: 1.8rem;
  font-weight: 500;
}
#sec_feature .cont02 .box .fee_item .fee_inner {
  align-items: center;
  margin-top: 2.5rem;
}
#sec_feature .cont02 .box .fee_item .fee_list {
  width: 38.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  padding-left: 2.2rem;
}
#sec_feature .cont02 .box .fee_item .fee_list > dt {
  width: calc(100% - 5rem);
}
#sec_feature .cont02 .box .fee_item .fee_list > dt span {
  margin-right: .2em;
}
#sec_feature .cont02 .box .fee_item .fee_list > dd {
  width: 5rem;
}
#sec_feature .cont02 .box .fee_item .fee_total {
  font-size: 4.8rem;
  font-weight: 500;
  color: #33322e;
}
#sec_feature .cont02 .box .img_fee01,
#sec_feature .cont02 .box .img_fee02 {
  width: 26.2rem;
}
#sec_feature .cont03 {
  position: relative;
  padding: 10rem 2rem 0;
}
#sec_feature .cont03 p + p {
  margin-top: 2.8rem;
}
#sec_feature .cont03 .ttl_sec {
  font-size: 5rem;
  letter-spacing: .05em;
  margin-bottom: 9.6rem;
}
#sec_feature .cont03 .txt_box .img08 {
  width: 42rem;
  padding-bottom: 4.8rem;
}
#sec_feature .cont03 .txt_box .txt {
  flex: 1;
}

@media screen and (max-width: 767px) {
  #sec_feature {
    padding: 4rem 0 2.5rem;
  }
  #sec_feature::before {
    width: 20rem;
    height: 2rem;
  }
  #sec_feature .ttl_logo {
    width: 16rem;
    margin: 0 auto 2rem;
  }
  #sec_feature .ttl_sec {
    font-size: 3.2rem;
    margin-bottom: 5rem;
  }
  #sec_feature .inner {
    max-width: inherit;
  }
  #sec_feature .cont01 {
    padding: 0 0 7.2rem;
  }
  #sec_feature .cont01::before {
    width: 11rem;
    height: 1.9rem;
    bottom: 2.4rem;
  }
  #sec_feature .cont01 .item + .item {
    margin-top: 4rem;
  }
  #sec_feature .cont01 .subttl {
    flex-direction: column;
    align-items: center;
    gap: 1rem 0;
    margin-bottom: 2.5rem;
  }
  #sec_feature .cont01 .subttl .num {
    width: 5.2rem;
    height: 5.2rem;
    gap: 0.5rem 0;
  }
  #sec_feature .cont01 .subttl .num .txt01 {
    font-size: 1.4rem;
  }
  #sec_feature .cont01 .subttl .num .txt02 {
    font-size: 1.9rem;
  }
  #sec_feature .cont01 .subttl .ttltxt {
    font-size: 2.2rem;
    line-height: 1.25;
    text-align: center;
  }
  #sec_feature .cont01 .txt_box {
    flex-direction: column;
    gap: 5vw 0 !important;
  }
  #sec_feature .cont01 .txt {
    font-size: 1.8rem;
    line-height: 1.5;
  }
  #sec_feature .cont01 .img {
    width: 86% !important;
    margin: 0 auto;
    text-align: center;
  }
  #sec_feature .cont02 {
    padding-bottom: 8rem;
  }
  #sec_feature .cont02::before {
    width: 11rem;
    height: 1.9rem;
    bottom: 3rem;
  }
  #sec_feature .cont02 .box {
    border-width: 3px;
  }
  #sec_feature .cont02 .box .support_anchor,
  #sec_feature .cont02 .box .fee_anchor {
    position: absolute;
    top: -2rem;
  }
  #sec_feature .cont02 .box.support {
    padding: 2.5rem 3%;
  }
  #sec_feature .cont02 .box.fee {
    padding: 2.5rem 3%;
    margin-top: 3.5rem;
  }
  #sec_feature .cont02 .box.fee .box_ttl {
    font-size: 2.4rem;
  }
  #sec_feature .cont02 .box_logo {
    margin-bottom: 1rem;
  }
  #sec_feature .cont02 .box_logo img {
    width: 16rem;
  }
  #sec_feature .cont02 .box_ttl {
    font-size: 3.2rem;
    line-height: 1.25;
    margin-bottom: 2.5rem;
  }
  #sec_feature .cont02 .box .notes {
    font-size: 1.7rem;
  }
  #sec_feature .cont02 .box .support_item {
    flex-direction: column;
    align-items: center;
    gap: 7vw 0;
    margin-bottom: 2.5rem;
  }
  #sec_feature .cont02 .box .support_item .box_dl {
    width: 100%;
  }
  #sec_feature .cont02 .box .support_item .box_dl dt {
    height: auto;
    width: 85%;
    padding: 1.5% 0;
    font-size: 2rem;
    margin: 0 auto 2.4rem;
  }
  #sec_feature .cont02 .box .support_item .box_dl dt::before {
    width: 1.5rem;
    height: 1.9rem;
    bottom: -1.8rem;
  }
  #sec_feature .cont02 .box .support_item .box_dl .support_list {
    padding: 5%;
    width: 100%;
  }
  #sec_feature .cont02 .box .support_item .box_dl .support_list li {
    font-size: 1.7rem;
  }
  #sec_feature .cont02 .box .fee_item {
    flex-direction: column;
    align-items: center;
    gap: 7vw 0;
    margin-bottom: 2.5rem;
  }
  #sec_feature .cont02 .box .fee_item.full {
    margin-top: 0;
    margin-bottom: 2rem;
  }
  #sec_feature .cont02 .box .fee_item.full .box_dl {
    width: 100%;
  }
  #sec_feature .cont02 .box .fee_item.full .box_dl > dd {
    padding: 4.5rem 4.8rem 3.5rem;
    min-height: inherit;
    display: block;
  }
  #sec_feature .cont02 .box .fee_item .box_dl {
    width: 100%;
  }
  #sec_feature .cont02 .box .fee_item .box_dl > dt {
    height: auto;
    width: 85%;
    padding: 1.5% 0;
    font-size: 2rem;
    margin: 0 auto -2.5rem;
  }
  #sec_feature .cont02 .box .fee_item .box_dl > dd {
    background: #fcf4f2;
    width: 100%;
    min-height: inherit;
  }
  #sec_feature .cont02 .box .fee_item .box_dl:nth-child(1) > dd {
    padding: 4.2rem 0 1.6rem;
  }
  #sec_feature .cont02 .box .fee_item .box_dl:nth-child(2) > dd {
    padding: 2.6rem 0 1.6rem;
  }
  #sec_feature .cont02 .box .fee_item .fee_lead {
    font-size: 1.6rem;
  }
  #sec_feature .cont02 .box .fee_item .fee_inner {
    margin-top: 2rem;
    flex-direction: column;
    align-items: center;
  }
  #sec_feature .cont02 .box .fee_item .fee_list {
    width: 100%;
    padding: 0 5%;
    margin: 0 auto 1rem;
  }
  #sec_feature .cont02 .box .fee_item .fee_total {
    font-size: 2.6rem;
    text-align: right;
    padding-right: 6%;
    width: 100%;
  }
  #sec_feature .cont02 .box .img_fee01,
  #sec_feature .cont02 .box .img_fee02 {
    width: 20rem;
    margin: 0 auto;
    text-align: center;
  }
  #sec_feature .cont03 {
    position: relative;
    padding: 5rem 0 0;
  }
  #sec_feature .cont03 p + p {
    margin-top: 5%;
  }
  #sec_feature .cont03 .ttl_sec {
    font-size: 3.1rem;
    margin-bottom: 2.5rem;
    line-height: 1.25;
  }
  #sec_feature .cont03 .txt_box {
    flex-direction: column;
    align-items: center;
    gap: 0;
  }
  #sec_feature .cont03 .txt_box .img08 {
    width: 80%;
    padding-bottom: 2.5rem;
    margin: 0 auto;
    text-align: center;
  }
}
/* sec_flow */
#sec_flow {
  background: #fa7a4f;
  padding: 3.8rem 0 6.3rem;
  margin-bottom: 7rem;
}
#sec_flow .inner {
  max-width: 97.5rem;
  margin: 0 auto;
}
#sec_flow .ttl_sec {
  margin-bottom: 8.4rem;
  font-size: 4.8rem;
  letter-spacing: -.03em;
}
#sec_flow .item {
  position: relative;
  width: 100%;
  background: #fff;
  border-radius: 5px;
  padding: 0.9rem 2.6rem;
  display: flex;
  gap: 0 2.2rem;
}
#sec_flow .item::before {
  position: absolute;
  content: "";
  width: 1.9rem;
  left: 50%;
  transform: translateX(-50%);
}
#sec_flow .item.item01::before {
  background: url("../img/icn_arrow_down02.png") no-repeat center center/contain;
  height: 2.8rem;
  bottom: -4rem;
}
#sec_flow .item.item02::before {
  background: url("../img/icn_arrow_down01.png") no-repeat center center/contain;
  height: 1.4rem;
  bottom: -3rem;
}
#sec_flow .item + .item {
  margin-top: 5.2rem;
}
#sec_flow .item .step {
  color: #fa7a4f;
  font-size: 2.4rem;
  font-weight: 700;
  font-family: "Poppins", sans-serif;
  letter-spacing: -.03em;
  padding-top: .01em;
}
#sec_flow .item dl {
  flex: 1;
}
#sec_flow .item dt {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: 2.4rem;
  letter-spacing: .075em;
  color: #33322e;
}
#sec_flow .item dd {
  color: #121212;
}

@media screen and (max-width: 767px) {
  #sec_flow {
    padding: 2.5rem 0 3.5rem;
    margin-bottom: 3.5rem;
  }
  #sec_flow .inner {
    max-width: inherit;
  }
  #sec_flow .ttl_sec {
    margin-bottom: 4rem;
    font-size: 3.2rem;
    line-height: 1.25;
  }
  #sec_flow .item {
    padding: 1rem 1.8rem;
    flex-direction: column;
    gap: 0;
  }
  #sec_flow .item.item01::before {
    bottom: -3.5rem;
  }
  #sec_flow .item.item02::before {
    bottom: -2.9rem;
  }
  #sec_flow .item + .item {
    margin-top: 4rem;
  }
  #sec_flow .item .step {
    font-size: 2rem;
  }
  #sec_flow .item dt {
    font-size: 2rem;
    line-height: 1.25;
    margin-bottom: 0.8rem;
  }
}
/* sec_faq */
#sec_faq {
  background: #fff;
  padding: 4.5rem 0 5rem;
  margin-top: 5rem;
}
#sec_faq .inner {
  max-width: 93.5rem;
  margin: 0 auto;
}
#sec_faq .ttl_sec {
  margin-bottom: 7.5rem;
  font-size: 4.8rem;
  letter-spacing: -.03em;
}
#sec_faq .faq_item {
  padding: 1.8rem 0;
  border-bottom: 1px solid #33322e;
}
#sec_faq .faq_item dt {
  display: flex;
  gap: 0 2.5rem;
  position: relative;
  padding-right: 9.5rem;
  cursor: pointer;
  transition: .3s ease;
}
@media print and (any-hover: hover), screen and (any-hover: hover) and (min-width: 768px) {
  #sec_faq .faq_item dt:hover {
    opacity: .7;
  }
}
#sec_faq .faq_item dt .icn_q {
  width: 3.8rem;
}
#sec_faq .faq_item dt .txt {
  font-size: 2rem;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  color: #33322e;
  letter-spacing: -.03em;
  width: calc(100% - 3.8rem);
}
#sec_faq .faq_item dt.is-open .ico:before {
  transform: rotate(-45deg);
}
#sec_faq .faq_item dt .ico {
  position: absolute;
  right: 7.4rem;
  top: 0.8em;
}
#sec_faq .faq_item dt .ico::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 0.8rem;
  height: 0.8rem;
  border-top: solid 2px #33322e;
  border-right: solid 2px #33322e;
  transform: rotate(135deg);
  transition: all .4s;
}
#sec_faq .faq_item dd {
  padding: 2rem 9.5rem 0 0;
}

@media screen and (max-width: 767px) {
  #sec_faq {
    padding: 2.5rem 0 3.5rem;
    margin-top: 2.5rem;
  }
  #sec_faq .inner {
    max-width: inherit;
    padding: 0 0.5rem;
  }
  #sec_faq .ttl_sec {
    margin-bottom: 3.5rem;
    font-size: 3.2rem;
  }
  #sec_faq .faq_item {
    padding: 1.8rem 0;
  }
  #sec_faq .faq_item dt {
    gap: 0 1.2rem;
    padding-right: 2.5rem;
  }
  #sec_faq .faq_item dt .icn_q {
    width: 3rem;
  }
  #sec_faq .faq_item dt .icn_q img {
    width: 100%;
  }
  #sec_faq .faq_item dt .txt {
    font-size: 1.7rem;
    width: calc(100% - 3rem);
  }
  #sec_faq .faq_item dt .ico {
    right: 2rem;
    top: 0.6em;
  }
  #sec_faq .faq_item dt .ico::before {
    width: 0.8rem;
    height: 0.8rem;
  }
  #sec_faq .faq_item dd {
    padding: 1.5rem 1rem 0 1rem;
  }
}
/* sec_company */
#sec_company {
  background: #fff;
  padding: 4.5rem 0 12.3rem;
}
#sec_company .inner {
  max-width: 93.5rem;
  margin: 0 auto;
}
#sec_company .ttl_sec {
  margin-bottom: 9.5rem;
  font-size: 4.8rem;
  letter-spacing: -.03em;
}
#sec_company .company_tbl {
  border-collapse: collapse;
  width: 100%;
  border: 1px solid #333;
}
#sec_company .company_tbl th, #sec_company .company_tbl td {
  letter-spacing: .075em;
  line-height: calc(24/17);
  padding-top: 1.4rem;
  padding-bottom: 1.2rem;
  border-bottom: 1px solid #333;
}
#sec_company .company_tbl th {
  font-size: 1.8rem;
  font-weight: 700;
  width: 21rem;
  background: #fcf4f2;
  padding-left: 4rem;
}
#sec_company .company_tbl td {
  font-size: 1.7rem;
  width: calc(100% - 21rem);
  background: #fff;
  padding-left: 2.8rem;
  padding-right: 2.8rem;
}
#sec_company .movie {
  text-align: center;
}
#sec_company .movie iframe {
  border: none;
  margin: 7.5rem auto 0;
  width: 79.4rem;
  height: 100%;
  aspect-ratio: 794/434;
}

@media screen and (max-width: 767px) {
  #sec_company {
    background: #fff;
    padding: 2.5rem 0 3.5rem;
  }
  #sec_company .inner {
    max-width: inherit;
    padding: 0 0.5rem;
  }
  #sec_company .ttl_sec {
    margin-bottom: 5rem;
    font-size: 3.2rem;
  }
  #sec_company .company_tbl th, #sec_company .company_tbl td {
    padding-top: 1.4rem;
    padding-bottom: 1.2rem;
  }
  #sec_company .company_tbl th {
    font-size: 1.5rem;
    width: 30%;
    padding-left: 3%;
    padding-right: 3%;
  }
  #sec_company .company_tbl td {
    font-size: 1.5rem;
    width: 70%;
    padding-left: 3%;
    padding-right: 3%;
  }
  #sec_company .movie iframe {
    margin: 3.5rem auto 0;
    width: 100%;
  }
}
/* sec_form */
#sec_form {
  background: #fa7a4f;
  padding: 7rem 0 9.5rem;
}
#sec_form .inner {
  max-width: 97.5rem;
  margin: 0 auto;
}
#sec_form .ttl_sec {
  margin-bottom: 8.4rem;
  font-size: 6rem;
}
#sec_form .contents_wrap {
  position: relative;
  max-width: 102.8rem;
  box-shadow: 0 0 4px 2px rgba(102, 102, 102, 0.3);
  background-color: #fff;
  border: 3px solid #fa7a4f;
  margin: auto;
  padding: 8.4rem 4rem 7.4rem;
}
#sec_form .txt_box {
  align-items: center;
  justify-content: space-between;
}
#sec_form .txt_box .img {
  width: 40.4rem;
}
#sec_form .txt_box .txt {
  width: 50.7rem;
  padding-bottom: 2rem;
}
#sec_form .txt_box .logo {
  width: 37.9rem;
  line-height: 1;
  margin: 0 0 0 4rem;
}
#sec_form .txt_box .price {
  width: 100%;
  margin: 4rem auto 2.2rem;
  line-height: 1;
}
#sec_form .txt_box .cta_txt {
  font-size: 2rem;
}
#sec_form .form_box {
  padding: 4rem 0 6.5rem;
}
#sec_form .form_box .notes {
  font-size: 1.8rem;
  font-family: "Noto Sans JP", sans-serif;
  color: #33322e;
  font-weight: 500;
}
#sec_form .form_cont {
  width: 100%;
  margin: 7rem auto 5.5rem;
}
#sec_form .form_cont iframe {
  border: none;
  border-style: inherit;
  width: 100%;
  height: 1460px;
}
@media screen and (max-width: 767px) {
  #sec_form .form_cont {
    margin-top: 5%;
  }
  #sec_form .form_cont iframe {
    height: 435vw;
  }
}
#sec_form .form_list {
  margin: 2rem auto 6rem;
  padding: 0 0 0 4rem;
}
#sec_form .form_list li {
  position: relative;
  font-size: 2.12rem;
  color: #33322e;
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: .075em;
  line-height: calc(36/21.2);
  font-weight: 500;
  padding-left: 1.2em;
}
#sec_form .form_list li::before {
  position: absolute;
  content: "●";
  color: #fa7a4f;
  left: 0;
  top: 0;
}
#sec_form .policy_ttl {
  font-size: 2.4rem;
  line-height: calc(36/24);
  color: #121212;
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: .05em;
  font-weight: 700;
}
#sec_form .policy_wrap {
  max-width: 75rem;
  width: 100%;
  height: 14.5rem;
  padding: 2rem;
  overflow: hidden;
  margin: 3rem auto 0;
  background: #fff;
  border: 1px solid #ccc;
}
#sec_form .policy_wrap p, #sec_form .policy_wrap a, #sec_form .policy_wrap dt, #sec_form .policy_wrap dd, #sec_form .policy_wrap li {
  font-size: 1.2rem !important;
  line-height: 1.4;
  word-break: break-all;
}
#sec_form .policy_wrap dl {
  margin-top: 2rem;
}
#sec_form .policy_wrap dt {
  font-weight: 700;
  margin-bottom: 0.5em;
}
#sec_form .policy_wrap p + p, #sec_form .policy_wrap li + li, #sec_form .policy_wrap p + ol {
  margin-top: 1rem;
}
#sec_form .policy_wrap ol > li > ol {
  margin-top: 1rem;
}
#sec_form .policy_wrap ol li {
  list-style-type: decimal;
  margin-left: 1.5em;
}
#sec_form .policy_inner {
  overflow: hidden;
  overflow-y: scroll;
  height: 100%;
  padding-right: .5rem;
}

@media screen and (max-width: 767px) {
  #sec_form {
    padding: 2.5rem 0;
  }
  #sec_form .inner {
    max-width: inherit;
    padding: 0 0.5rem;
  }
  #sec_form .ttl_sec {
    margin-bottom: 5rem;
    font-size: 3.2rem;
    line-height: 1.25;
  }
  #sec_form .contents_wrap {
    max-width: inherit;
    padding: 3rem 3.5% 3.5rem;
  }
  #sec_form .txt_box {
    flex-direction: column;
    align-items: center;
    gap: 1rem 0;
  }
  #sec_form .txt_box .img {
    width: 86%;
    margin: 0 auto 2.5%;
    text-align: center;
  }
  #sec_form .txt_box .txt {
    width: 100%;
    padding: 0;
    margin: 0 auto;
  }
  #sec_form .txt_box .logo {
    width: 24rem;
    margin: 0 auto;
  }
  #sec_form .txt_box .price {
    width: 100%;
    margin: 2.5rem auto 2rem;
  }
  #sec_form .txt_box .cta_txt {
    font-size: 1.6rem;
    white-space: nowrap;
  }
  #sec_form .form_box {
    padding: 2.5rem 0 3.5rem;
  }
  #sec_form .form_box .notes {
    font-size: 1.6rem;
  }
  #sec_form .form_cont {
    width: 100%;
    margin: 2.5rem auto;
  }
  #sec_form .form_list {
    margin: 1.5rem auto 3rem;
    padding: 0;
  }
  #sec_form .form_list li {
    font-size: 1.5rem;
  }
  #sec_form .policy_ttl {
    font-size: 1.6rem;
  }
  #sec_form .policy_wrap {
    max-width: inherit;
    height: 12rem;
    padding: 1rem;
    margin: 1.5rem auto 0;
  }
  #sec_form .policy_wrap p, #sec_form .policy_wrap a, #sec_form .policy_wrap dt, #sec_form .policy_wrap dd, #sec_form .policy_wrap li {
    font-size: 1.2rem !important;
  }
  #sec_form .policy_inner {
    padding-right: 1rem;
  }
}
/* sec_mv_thanks */
#sec_mv_thanks {
  background: url("../img/bg_mv_thanks_pc.png") no-repeat center top/cover;
  padding-top: 6.4rem;
  padding-bottom: 6.2rem;
}
#sec_mv_thanks .ttl {
  margin: 0 auto;
  line-height: 1;
  width: 76.3rem;
}
#sec_mv_thanks .txt {
  font-size: 1.8rem;
  font-weight: 500;
  font-family: "Noto Sans JP", sans-serif;
  color: #33322e;
  line-height: 2;
  margin: 6rem auto 0;
}

@media screen and (max-width: 767px) {
  #sec_mv_thanks {
    background: url("../img/bg_mv_sp.png") no-repeat center top/100% auto;
    padding-top: 8%;
    padding-bottom: 5%;
  }
  #sec_mv_thanks .ttl {
    width: 100%;
  }
  #sec_mv_thanks .txt {
    font-size: 1.5rem;
    line-height: 1.75;
    margin: 5% auto 0;
  }
}
/* sec_form_thanks */
.sec_form_thanks {
  background: #fa7a4f;
  padding: 3.6rem 0 6rem;
}
.sec_form_thanks .contents_wrap {
  position: relative;
  max-width: 102.8rem;
  box-shadow: 0 0 4px 2px rgba(102, 102, 102, 0.3);
  background-color: #fff;
  border: 3px solid #fa7a4f;
  margin: auto;
  padding: 5rem 3.5rem 8.8rem;
}
.sec_form_thanks .contents_wrap .txt {
  font-size: 2rem;
  font-weight: 700;
}
.sec_form_thanks iframe {
  width: 100%;
  height: 100%;
  border: none;
}

@media screen and (max-width: 767px) {
  .sec_form_thanks {
    padding: 2.5rem 0;
  }
  .sec_form_thanks .contents_wrap {
    max-width: inherit;
    padding: 3rem 3.5% 3.5rem;
  }
  .sec_form_thanks .contents_wrap .txt {
    font-size: 1.6rem;
  }
}
/* ------------------------------
*  fixbtn
------------------------------ */
.fixbtn {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  text-align: center;
  padding: 10px 0;
  max-width: 100%;
  z-index: 10;
}

@media screen and (max-width: 767px) {
  .fixbtn {
    padding: 3% 0;
  }
  .fixbtn .btn {
    width: 100%;
    margin: auto;
  }
}
/* ------------------------------
    responsive
------------------------------ */
@media screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}
/* ------------------------------
    clearfix
------------------------------ */
.cf {
  zoom: 1;
}
.cf::after {
  content: " ";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
  overflow: hidden;
  /* 隙間対応 */
  font-size: 0.1em;
  /* 隙間対応 */
  line-height: 0;
  /* 隙間対応 */
}
