@charset "UTF-8";
/**
 * Product Page 専用スタイルシート
 * 完全独立CSS - メインstyle.cssから切り離し
 * 
 * 🎯 目的: productページの完全独立化
 * 📁 出力: assets/css/product.css
 * 🔗 読み込み: page-product.phpでのみ使用
 */
/*** The new CSS reset - version 1.5.1 (last updated 1.3.2022) ***/
@import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap");
body {
  margin: 0;
  padding: 0;
}

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

h1, h2, h3, h4, h5, h6, p {
  margin: 0;
}

a,
button {
  cursor: revert;
  text-decoration: none;
}

ol,
ul,
menu {
  list-style: none;
  padding: 0;
  margin: 0;
}

img {
  width: 100%;
  max-width: 100%;
  height: auto;
}

table {
  border-collapse: collapse;
}

textarea {
  white-space: revert;
}

meter {
  -webkit-appearance: revert;
  appearance: revert;
}

::placeholder {
  color: unset;
}

:where([hidden]) {
  display: none;
}

:where([contenteditable]) {
  -moz-user-modify: read-write;
  -webkit-user-modify: read-write;
  overflow-wrap: break-word;
  -webkit-line-break: after-white-space;
}

:where([draggable=true]) {
  -webkit-user-drag: element;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  font-family: YakuHanJP, "Noto Sans JP", serif;
  color: #3C3C3C;
  overflow-x: hidden;
  touch-action: pan-x pan-y;
}
@media screen and (min-width: 768px) {
  body p {
    font-size: 16px;
    line-height: 2.1875;
    letter-spacing: 0.02em;
    font-weight: 500;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  body p {
    font-size: 0.9756097561vw;
  }
}
@media screen and (max-width: 767px) {
  body p {
    font-size: calc(16 / 375 * 100vw);
    line-height: 1.875;
    letter-spacing: 0.02em;
    font-weight: 500;
  }
}

a {
  color: inherit;
  transition: all 0.3s;
}

.u-en {
  font-family: "Inter", sans-serif;
  position: relative;
}
@media screen and (min-width: 768px) {
  .u-en {
    top: 3px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .u-en {
    top: 0.1829268293vw;
  }
}
@media screen and (max-width: 767px) {
  .u-en {
    top: 1.0666666667vw;
  }
}

.u-color-orange {
  color: #E56E07;
}

.u-arrow {
  position: relative;
}
.u-arrow::after {
  position: absolute;
  content: "";
  display: block;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 98%);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}
@media screen and (min-width: 768px) {
  .u-arrow::after {
    width: 200px;
    height: 77px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .u-arrow::after {
    width: 12.1951219512vw;
    height: 4.6951219512vw;
  }
}
@media screen and (max-width: 767px) {
  .u-arrow::after {
    width: 27.7333333333vw;
    height: 10.4vw;
  }
}

.l-inner {
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .l-inner {
    max-width: 1240px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-inner {
    max-width: 75.6097560976vw;
  }
}
@media screen and (max-width: 767px) {
  .l-inner {
    max-width: 89.3333333333vw;
  }
}

.c-ttl {
  text-align: center;
}
.c-ttl-en {
  color: #E56E07;
  display: block;
}
@media screen and (min-width: 768px) {
  .c-ttl-en {
    font-size: 32px;
    line-height: 1;
    letter-spacing: 0em;
    font-weight: 300;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .c-ttl-en {
    font-size: 1.9512195122vw;
  }
}
@media screen and (max-width: 767px) {
  .c-ttl-en {
    font-size: calc(25 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 300;
  }
}
@media screen and (min-width: 768px) {
  .c-ttl-en {
    margin-bottom: 10px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .c-ttl-en {
    margin-bottom: 0.6097560976vw;
  }
}
@media screen and (max-width: 767px) {
  .c-ttl-en {
    margin-bottom: 1.6vw;
  }
}
.c-ttl-ja {
  display: block;
}
@media screen and (min-width: 768px) {
  .c-ttl-ja {
    font-size: 28px;
    line-height: 1.5;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .c-ttl-ja {
    font-size: 1.7073170732vw;
  }
}
@media screen and (max-width: 767px) {
  .c-ttl-ja {
    font-size: calc(20 / 375 * 100vw);
    line-height: 1.5;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}

.p-kv {
  clip-path: inset(0);
  overflow: hidden;
  position: relative;
}
.p-kv__bg {
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (min-width: 768px) {
  .p-kv__bg {
    background-image: url(../img/bg-kv.jpg);
    padding: 34px 0 260px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-kv__bg {
    padding: 2.0731707317vw 0 15.8536585366vw;
  }
}
@media screen and (max-width: 767px) {
  .p-kv__bg {
    background-image: url(../img/bg-kv-sp.jpg);
    padding: 4.8vw 0 49.3333333333vw;
  }
}
.p-kv__deco {
  position: absolute;
  z-index: 1;
  opacity: 0.8;
  clip-path: circle(0% at 0 100%);
  animation: kvdeco 3s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}
@media screen and (min-width: 768px) {
  .p-kv__deco {
    width: 2400px;
    height: 945px;
    left: -19px;
    top: 70px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-kv__deco {
    width: 146.3414634146vw;
    height: 57.6219512195vw;
    left: -1.1585365854vw;
    top: 4.2682926829vw;
  }
}
@media screen and (max-width: 767px) {
  .p-kv__deco {
    width: 292.5333333333vw;
    height: 235.2vw;
    top: -47.4666666667vw;
    left: -60vw;
  }
}
.p-kv__deco img {
  display: block;
}
.p-kv__logo {
  position: relative;
  z-index: 5;
  margin-left: auto;
  margin-right: auto;
  opacity: 0;
  animation: kvfade 1s ease-in forwards;
  animation-delay: 1.8s;
}
@media screen and (min-width: 768px) {
  .p-kv__logo {
    max-width: 1240px;
    margin-bottom: 215px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-kv__logo {
    max-width: 75.6097560976vw;
    margin-bottom: 13.1097560976vw;
  }
}
@media screen and (max-width: 767px) {
  .p-kv__logo {
    margin-bottom: 32vw;
    padding-left: 5.3333333333vw;
  }
}
.p-kv__logo-img {
  display: block;
}
.p-kv__logo-img img {
  display: block;
}
@media screen and (min-width: 768px) {
  .p-kv__logo-img img {
    width: 174px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-kv__logo-img img {
    width: 10.6097560976vw;
  }
}
@media screen and (max-width: 767px) {
  .p-kv__logo-img img {
    width: 25.3333333333vw;
  }
}
.p-kv__text {
  position: relative;
  z-index: 5;
  margin: 0 auto;
  animation: kvfade 1s ease-in forwards;
  animation-delay: 1.8s;
  opacity: 0;
}
@media screen and (min-width: 768px) {
  .p-kv__text {
    max-width: 1240px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-kv__text {
    max-width: 75.6097560976vw;
  }
}
@media screen and (max-width: 767px) {
  .p-kv__text {
    width: max-content;
  }
}
.p-kv__text-ttl img {
  display: block;
}
@media screen and (min-width: 768px) {
  .p-kv__text-ttl img {
    width: 874px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-kv__text-ttl img {
    width: 53.2926829268vw;
  }
}
@media screen and (max-width: 767px) {
  .p-kv__text-ttl img {
    width: 72.2666666667vw;
  }
}

.p-cta {
  display: flex;
  position: fixed;
  z-index: 100001;
  opacity: 0;
  animation: kvfade 1s ease-in forwards;
  animation-delay: 1.8s;
}
@media screen and (min-width: 768px) {
  .p-cta {
    right: 0;
    bottom: 28px;
    flex-direction: column;
    row-gap: 18px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cta {
    bottom: 1.7073170732vw;
    row-gap: 1.0975609756vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cta {
    flex-direction: row-reverse;
    background-color: rgba(0, 0, 0, 0.8);
    width: 100vw;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 2.6666666667vw 0;
    column-gap: 2.1333333333vw;
    justify-content: center;
  }
}
.p-cta__contact {
  background-color: #FFD800;
  position: relative;
  display: flex;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .p-cta__contact {
    border-top: 3px solid #fff;
    border-bottom: 3px solid #fff;
    border-left: 3px solid #fff;
    border-radius: 10px 0 0 10px;
    width: 266px;
    height: 105px;
    padding-left: 30px;
  }
  .p-cta__contact:hover {
    background-color: #fff;
    border-color: #FFD800;
  }
  .p-cta__contact:hover::after {
    background-image: url(../img/ic-arrow-ye.png);
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cta__contact {
    border-top: 0.1829268293vw solid #fff;
    border-bottom: 0.1829268293vw solid #fff;
    border-left: 0.1829268293vw solid #fff;
    border-radius: 0.6097560976vw 0 0 0.6097560976vw;
    width: 16.2195121951vw;
    height: 6.4024390244vw;
    padding-left: 1.8292682927vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cta__contact {
    width: 53.3333333333vw;
    height: 12vw;
    border-radius: 2.6666666667vw;
    border: 0.5333333333vw solid #fff;
    background-color: #FFD800;
    padding-left: 4.8vw;
  }
}
.p-cta__contact::after {
  position: absolute;
  content: "";
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../img/ic-arrow-bk.png);
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.3s;
}
@media screen and (min-width: 768px) {
  .p-cta__contact::after {
    width: 38px;
    height: 38px;
    right: 54px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cta__contact::after {
    width: 2.3170731707vw;
    height: 2.3170731707vw;
    right: 3.2926829268vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cta__contact::after {
    width: 5.3333333333vw;
    height: 5.3333333333vw;
    right: 4vw;
  }
}
@media screen and (min-width: 768px) {
  .p-cta__contact .txt {
    font-size: 24px;
    line-height: 1.4583333333;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cta__contact .txt {
    font-size: 1.4634146341vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cta__contact .txt {
    font-size: calc(15 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (min-width: 768px) {
  .p-cta__contact .txt {
    width: max-content;
    text-align: center;
  }
}
.p-cta__download {
  display: flex;
  align-items: center;
  background-color: #fff;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-cta__download {
    width: 266px;
    height: 65px;
    border-top: 2px solid #E56E07;
    border-bottom: 2px solid #E56E07;
    border-left: 2px solid #E56E07;
    border-radius: 10px 0 0 10px;
    padding-left: 30px;
  }
  .p-cta__download:hover {
    background-color: #E56E07;
  }
  .p-cta__download:hover::after {
    background-image: url(../img/ic-download-wh.png);
  }
  .p-cta__download:hover .txt {
    color: #fff;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cta__download {
    width: 16.2195121951vw;
    height: 3.9634146341vw;
    border-top: 0.1219512195vw solid #E56E07;
    border-bottom: 0.1219512195vw solid #E56E07;
    border-left: 0.1219512195vw solid #E56E07;
    border-radius: 0.6097560976vw 0 0 0.6097560976vw;
    padding-left: 1.8292682927vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cta__download {
    width: 33.0666666667vw;
    height: 12vw;
    border-radius: 2.6666666667vw;
    border: 0.5333333333vw solid #E56E07;
    padding-left: 4.8vw;
  }
}
.p-cta__download::after {
  position: absolute;
  content: "";
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../img/ic-download-or.png);
  transition: all 0.3s;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 768px) {
  .p-cta__download::after {
    width: 21px;
    height: 24px;
    right: 56px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cta__download::after {
    width: 1.2804878049vw;
    height: 1.4634146341vw;
    right: 3.4146341463vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cta__download::after {
    width: 3.7333333333vw;
    height: 4.2666666667vw;
    right: 5.8666666667vw;
  }
}
.p-cta__download .txt {
  color: #E56E07;
}
@media screen and (min-width: 768px) {
  .p-cta__download .txt {
    font-size: 18px;
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cta__download .txt {
    font-size: 1.0975609756vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cta__download .txt {
    font-size: calc(15 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}

.p-cta02 {
  position: relative;
  z-index: 3;
}
@media screen and (min-width: 768px) {
  .p-cta02 {
    transform: translateY(50%);
  }
}
.p-cta02__bg {
  background-color: #3C3C3C;
}
@media screen and (min-width: 768px) {
  .p-cta02__bg {
    box-shadow: 5px 5px 30px rgba(0, 0, 0, 0.4);
    width: 85.15625%;
    border-radius: 0 125px 125px 0;
    padding: 80px 0;
  }
}
@media (min-width: 768px) and (max-width: 1700px) {
  .p-cta02__bg {
    width: 97.5609756098vw;
    border-radius: 0 7.6219512195vw 7.6219512195vw 0;
    padding: 4.8780487805vw 0;
  }
}
@media screen and (max-width: 767px) {
  .p-cta02__bg {
    padding: 12.2666666667vw 0;
  }
}
.p-cta02__inner {
  display: flex;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .p-cta02__inner {
    margin-left: calc((100vw - 636px) / 2);
    column-gap: 48px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cta02__inner {
    column-gap: 2.9268292683vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cta02__inner {
    flex-direction: column;
    row-gap: 4.2666666667vw;
    align-items: center;
  }
}
.p-cta02__text {
  color: #fff;
  width: max-content;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-cta02__text {
    font-size: 25px;
    line-height: 1.68;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cta02__text {
    font-size: 1.5243902439vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cta02__text {
    font-size: calc(20 / 375 * 100vw);
    line-height: 1.7;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
.p-cta02__btn {
  position: relative;
  display: flex;
  align-items: center;
  background: linear-gradient(to right, #e56e07 0%, #ffc400 100%);
  box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.16);
  color: #fff;
}
@media screen and (min-width: 768px) {
  .p-cta02__btn {
    font-size: 29px;
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cta02__btn {
    font-size: 1.7682926829vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cta02__btn {
    font-size: calc(19 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
@media screen and (min-width: 768px) {
  .p-cta02__btn {
    width: 520px;
    height: 90px;
    border-radius: 45px;
    padding-left: 52px;
  }
  .p-cta02__btn:hover {
    opacity: 0.7;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cta02__btn {
    width: 31.7073170732vw;
    height: 5.487804878vw;
    border-radius: 2.743902439vw;
    padding-left: 3.1707317073vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cta02__btn {
    width: 76.5333333333vw;
    height: 14.6666666667vw;
    border-radius: 7.3333333333vw;
    padding-left: 8.5333333333vw;
  }
}
.p-cta02__btn::after {
  position: absolute;
  content: "";
  display: block;
  top: 50%;
  transform: translateY(-50%);
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../img/ic-arrow-or.png);
}
@media screen and (min-width: 768px) {
  .p-cta02__btn::after {
    width: 49px;
    height: 49px;
    right: 37px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cta02__btn::after {
    width: 2.987804878vw;
    height: 2.987804878vw;
    right: 2.256097561vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cta02__btn::after {
    width: 8.2666666667vw;
    height: 8.2666666667vw;
    right: 3.4666666667vw;
  }
}

.p-worries {
  position: relative;
  z-index: 3;
}
@media screen and (min-width: 768px) {
  .p-worries {
    padding: 80px 0 100px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-worries {
    padding-bottom: 4.8780487805vw 0 6.0975609756vw;
  }
}
@media screen and (max-width: 767px) {
  .p-worries {
    padding: 9.6vw 0 14.4vw;
  }
}
.p-worries::after {
  background-color: #fff;
}
.p-worries__wrap {
  display: flex;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-worries__wrap {
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 45px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-worries__wrap {
    margin-bottom: 2.743902439vw;
  }
}
@media screen and (max-width: 767px) {
  .p-worries__wrap {
    flex-direction: column;
    margin-bottom: 5.3333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .p-worries__text {
    width: 675px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-worries__text {
    width: 41.1585365854vw;
  }
}
@media screen and (min-width: 768px) {
  .p-worries__text-ttl {
    font-size: 37px;
    line-height: 1.5945945946;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-worries__text-ttl {
    font-size: 2.256097561vw;
  }
}
@media screen and (max-width: 767px) {
  .p-worries__text-ttl {
    font-size: calc(24 / 375 * 100vw);
    line-height: 1.5833333333;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (min-width: 768px) {
  .p-worries__text-ttl {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-worries__text-ttl {
    margin-bottom: 1.2195121951vw;
  }
}
@media screen and (max-width: 767px) {
  .p-worries__text-ttl {
    text-align: center;
    margin-bottom: 53.3333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .p-worries__text-txt {
    font-size: 18px;
    line-height: 2;
    letter-spacing: 0.02em;
    font-weight: 500;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-worries__text-txt {
    font-size: 1.0975609756vw;
  }
}
@media screen and (min-width: 768px) {
  .p-worries__img {
    width: 432px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-worries__img {
    width: 26.3414634146vw;
  }
}
@media screen and (max-width: 767px) {
  .p-worries__img {
    position: absolute;
    z-index: 1;
    left: 50%;
    transform: translateX(-50%);
    top: 28vw;
    width: 78.6666666667vw;
  }
}
.p-worries__list {
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-worries__list {
    justify-content: space-between;
  }
}
@media screen and (max-width: 767px) {
  .p-worries__list {
    flex-direction: column;
    align-items: center;
    row-gap: 6.6666666667vw;
  }
}
.p-worries__list-item {
  text-align: center;
  background-color: #EFEFEF;
}
@media screen and (min-width: 768px) {
  .p-worries__list-item {
    box-shadow: 5px 5px 20px rgba(0, 0, 0, 0.16);
    border-radius: 20px;
    padding-top: 24px;
    width: 390px;
    height: 300px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-worries__list-item {
    border-radius: 1.2195121951vw;
    padding-top: 1.4634146341vw;
    width: 23.7804878049vw;
    height: 18.2926829268vw;
  }
}
@media screen and (max-width: 767px) {
  .p-worries__list-item {
    box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.16);
    width: 88.5333333333vw;
    height: 61.3333333333vw;
    border-radius: 5.3333333333vw;
    padding-top: 6.4vw;
  }
}
@media screen and (min-width: 768px) {
  .p-worries__list-item.item01 img {
    width: 179px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-worries__list-item.item01 img {
    width: 10.9146341463vw;
  }
}
@media screen and (max-width: 767px) {
  .p-worries__list-item.item01 img {
    width: 40.5333333333vw;
  }
}
@media screen and (max-width: 767px) {
  .p-worries__list-item.item01 .txt {
    margin-bottom: 2.6666666667vw;
  }
}
@media screen and (min-width: 768px) {
  .p-worries__list-item.item02 img {
    width: 305px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-worries__list-item.item02 img {
    width: 18.5975609756vw;
  }
}
@media screen and (max-width: 767px) {
  .p-worries__list-item.item02 img {
    width: 64.8vw;
  }
}
@media screen and (min-width: 768px) {
  .p-worries__list-item.item03 img {
    width: 295px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-worries__list-item.item03 img {
    width: 17.987804878vw;
  }
}
@media screen and (max-width: 767px) {
  .p-worries__list-item.item03 img {
    width: 64vw;
  }
}
@media screen and (min-width: 768px) {
  .p-worries__list-item .txt {
    font-size: 20px;
    line-height: 1.6;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-worries__list-item .txt {
    font-size: 1.2195121951vw;
  }
}
@media screen and (max-width: 767px) {
  .p-worries__list-item .txt {
    font-size: calc(16 / 375 * 100vw);
    line-height: 1.625;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
@media screen and (min-width: 768px) {
  .p-worries__list-item .txt {
    margin-bottom: 24px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-worries__list-item .txt {
    margin-bottom: 1.4634146341vw;
  }
}
@media screen and (max-width: 767px) {
  .p-worries__list-item .txt {
    margin-bottom: 5.3333333333vw;
  }
}

.p-cost {
  position: relative;
  z-index: 2;
}
.p-cost__bg {
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-cost__bg {
    padding: 140px 0 85px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__bg {
    padding: 8.5365853659vw 0 5.1829268293vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__bg {
    padding: 17.6vw 0 10.6666666667vw;
  }
}
.p-cost__bg::after {
  position: absolute;
  content: "";
  display: block;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  background-position: bottom center;
  top: 0;
  left: 0;
  right: 0;
}
@media screen and (min-width: 768px) {
  .p-cost__bg::after {
    background-image: url(../img/bg-cost.png);
    height: calc(100% + 70px);
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__bg::after {
    height: calc(100% + 4.2682926829vw);
  }
}
@media screen and (max-width: 767px) {
  .p-cost__bg::after {
    background-image: url(../img/bg-cost-sp.png);
    height: calc(100% + 10.4vw);
  }
}
.p-cost .l-inner {
  position: relative;
  z-index: 3;
}
.p-cost__lead {
  text-align: center;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .p-cost__lead {
    font-size: 39px;
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__lead {
    font-size: 2.3780487805vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__lead {
    font-size: calc(24 / 375 * 100vw);
    line-height: 1.75;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (min-width: 768px) {
  .p-cost__lead {
    margin-bottom: 36px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__lead {
    margin-bottom: 2.1951219512vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__lead {
    margin-bottom: 6.4vw;
  }
}
.p-cost__lead-dot {
  display: inline-flex;
}
.p-cost__lead-dot span {
  position: relative;
}
.p-cost__lead-dot span::after {
  position: absolute;
  content: "";
  display: block;
  background-color: #FFD800;
  left: 50%;
  transform: translate(-50%, -100%);
  border-radius: 50%;
}
@media screen and (min-width: 768px) {
  .p-cost__lead-dot span::after {
    width: 8px;
    height: 8px;
    top: -4px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__lead-dot span::after {
    width: 0.487804878vw;
    height: 0.487804878vw;
    top: -0.243902439vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__lead-dot span::after {
    width: 1.3333333333vw;
    height: 1.3333333333vw;
    top: 1.0666666667vw;
  }
}
.p-cost__note {
  color: #D8D8D8;
}
@media screen and (min-width: 768px) {
  .p-cost__note {
    font-size: 15px;
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 400;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__note {
    font-size: 0.9146341463vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__note {
    font-size: calc(15 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 400;
  }
}
@media screen and (min-width: 768px) {
  .p-cost__note {
    margin-bottom: 12px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__note {
    margin-bottom: 0.7317073171vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__note {
    text-align: center;
    margin-bottom: 3.2vw;
  }
}
.p-cost__wrap {
  background-color: #D8D8D8;
  position: relative;
  overflow: hidden;
  display: flex;
  justify-content: space-between;
}
@media screen and (min-width: 768px) {
  .p-cost__wrap {
    box-shadow: 5px 5px 20px rgba(0, 0, 0, 0.2);
    height: 152px;
    border-radius: 20px;
    margin-bottom: 32px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__wrap {
    height: 9.2682926829vw;
    border-radius: 1.2195121951vw;
    margin-bottom: 1.9512195122vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__wrap {
    box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.8);
    width: 88.5333333333vw;
    height: 45.3333333333vw;
    border-radius: 2.6666666667vw;
    margin-bottom: 8vw;
  }
}
.p-cost__wrap::before, .p-cost__wrap::after {
  position: absolute;
  content: "";
  z-index: 1;
  display: block;
  background-color: #fff;
  height: 100%;
  top: 0;
}
@media screen and (min-width: 768px) {
  .p-cost__wrap::before, .p-cost__wrap::after {
    width: 5.5px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__wrap::before, .p-cost__wrap::after {
    width: 0.3353658537vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__wrap::before, .p-cost__wrap::after {
    width: 0.5333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .p-cost__wrap::before {
    left: 410px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__wrap::before {
    left: 25vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__wrap::before {
    left: 29.3333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .p-cost__wrap::after {
    right: 410px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__wrap::after {
    right: 25vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__wrap::after {
    right: 29.3333333333vw;
  }
}
.p-cost__item {
  background-color: #FFD800;
  transition: all 1.5s;
  width: 0;
}
.p-cost__item.is-FadeIn02 {
  width: 100%;
}
.p-cost__add {
  text-align: center;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .p-cost__add {
    font-size: 30px;
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__add {
    font-size: 1.8292682927vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__add {
    font-size: calc(20 / 375 * 100vw);
    line-height: 1.75;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (min-width: 768px) {
  .p-cost__add {
    margin-bottom: 46px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__add {
    margin-bottom: 2.8048780488vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__add {
    margin-bottom: 5.3333333333vw;
  }
}
.p-cost__list {
  display: flex;
  justify-content: center;
}
@media screen and (min-width: 768px) {
  .p-cost__list {
    column-gap: 45px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__list {
    column-gap: 2.743902439vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__list {
    column-gap: 4.5333333333vw;
    row-gap: 4vw;
    flex-wrap: wrap;
  }
}
.p-cost__list-item {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: 50%;
  background-color: #FFD800;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-cost__list-item {
    width: 246px;
    height: 246px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__list-item {
    width: 15vw;
    height: 15vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__list-item {
    width: 40.5333333333vw;
    height: 40.5333333333vw;
  }
}
.p-cost__list-item::after {
  position: absolute;
  content: "";
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../img/ic-exclamation.png);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .p-cost__list-item::after {
    width: 83px;
    height: 145px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__list-item::after {
    width: 5.0609756098vw;
    height: 8.8414634146vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__list-item::after {
    width: 13.6vw;
    height: 24vw;
  }
}
.p-cost__list-item .txt {
  position: relative;
  z-index: 3;
}
@media screen and (min-width: 768px) {
  .p-cost__list-item .txt {
    font-size: 25px;
    line-height: 1.44;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-cost__list-item .txt {
    font-size: 1.5243902439vw;
  }
}
@media screen and (max-width: 767px) {
  .p-cost__list-item .txt {
    font-size: calc(15 / 375 * 100vw);
    line-height: 1.6;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}

.p-revolution::after {
  background-color: #1D1D1D;
}
.p-revolution__bg {
  position: relative;
  background-color: #1D1D1D;
  clip-path: inset(0);
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-revolution__bg {
    padding: 120px 0 130px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__bg {
    padding: 7.3170731707vw 0 7.9268292683vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__bg {
    padding: 19.2vw 0 20vw;
  }
}
.p-revolution__bg::after {
  position: absolute;
  content: "";
  display: block;
  z-index: 1;
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (min-width: 768px) {
  .p-revolution__bg::after {
    width: 2077px;
    height: 995px;
    top: -30px;
    left: 30px;
    background-image: url(../img/dc-revolution.png);
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__bg::after {
    width: 126.6463414634vw;
    height: 60.6707317073vw;
    top: -1.8292682927vw;
    left: 1.8292682927vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__bg::after {
    background-image: url(../img/dc-revolution-sp.png);
    width: 366.6666666667vw;
    height: 257.0666666667vw;
    top: -65.6vw;
    left: -65.6vw;
  }
}
.p-revolution .l-inner {
  position: relative;
  z-index: 3;
}
.p-revolution__list {
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-revolution__list {
    justify-content: center;
    column-gap: 90px;
    margin-bottom: 60px;
    padding-left: 30px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__list {
    column-gap: 5.487804878vw;
    margin-bottom: 3.6585365854vw;
    padding-left: 1.8292682927vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__list {
    margin-bottom: 8.5333333333vw;
    flex-direction: column;
    row-gap: 3.2vw;
    align-items: center;
  }
}
.p-revolution__list-item {
  position: relative;
  color: #aaa;
}
@media screen and (min-width: 768px) {
  .p-revolution__list-item {
    font-size: 28px;
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__list-item {
    font-size: 1.7073170732vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__list-item {
    font-size: calc(18 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (min-width: 768px) {
  .p-revolution__list-item {
    padding: 0 38px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__list-item {
    padding: 0 2.3170731707vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__list-item {
    padding: 0 4.5333333333vw;
  }
}
.p-revolution__list-item::before, .p-revolution__list-item::after {
  position: absolute;
  content: "";
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../img/ic-quotation.png);
  top: 0;
}
@media screen and (min-width: 768px) {
  .p-revolution__list-item::before, .p-revolution__list-item::after {
    width: 28px;
    height: 24px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__list-item::before, .p-revolution__list-item::after {
    width: 1.7073170732vw;
    height: 1.4634146341vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__list-item::before, .p-revolution__list-item::after {
    width: 3.2vw;
    height: 2.9333333333vw;
  }
}
.p-revolution__list-item::before {
  left: 0;
}
.p-revolution__list-item::after {
  right: 0;
  transform: rotate(180deg);
}
@media screen and (min-width: 768px) {
  .p-revolution__ttl {
    margin-bottom: 76px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__ttl {
    margin-bottom: 4.6341463415vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__ttl {
    margin-bottom: 10.6666666667vw;
  }
}
.p-revolution__ttl img {
  display: block;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .p-revolution__ttl img {
    width: 957px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__ttl img {
    width: 58.3536585366vw;
  }
}
.p-revolution__text {
  text-align: center;
  color: #aaa;
}
@media screen and (min-width: 768px) {
  .p-revolution__text {
    font-size: 25px;
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 600;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__text {
    font-size: 1.5243902439vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__text {
    font-size: calc(15 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 600;
  }
}
@media screen and (min-width: 768px) {
  .p-revolution__text {
    margin-bottom: 24px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__text {
    margin-bottom: 1.4634146341vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__text {
    margin-bottom: 4.8vw;
  }
}
.p-revolution__wrap {
  background-color: #D8D8D8;
  position: relative;
  overflow: hidden;
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-revolution__wrap {
    box-shadow: 5px 5px 20px rgba(0, 0, 0, 0.2);
    height: 152px;
    border-radius: 20px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__wrap {
    height: 9.2682926829vw;
    border-radius: 1.2195121951vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__wrap {
    box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.8);
    width: 88.5333333333vw;
    height: 45.3333333333vw;
    border-radius: 2.6666666667vw;
  }
}
.p-revolution__wrap::before, .p-revolution__wrap::after {
  position: absolute;
  content: "";
  z-index: 1;
  display: block;
  background-color: #fff;
  height: 100%;
  top: 0;
}
@media screen and (min-width: 768px) {
  .p-revolution__wrap::before, .p-revolution__wrap::after {
    width: 5.5px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__wrap::before, .p-revolution__wrap::after {
    width: 0.3353658537vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__wrap::before, .p-revolution__wrap::after {
    width: 0.5333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .p-revolution__wrap::before {
    left: 410px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__wrap::before {
    left: 25vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__wrap::before {
    left: 29.3333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .p-revolution__wrap::after {
    right: 410px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__wrap::after {
    right: 25vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__wrap::after {
    right: 29.3333333333vw;
  }
}
.p-revolution__count {
  position: absolute;
  z-index: 5;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .p-revolution__count-item {
    font-size: 28px;
    line-height: 1.25;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__count-item {
    font-size: 1.7073170732vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__count-item {
    font-size: calc(18 / 375 * 100vw);
    line-height: 1.7222222222;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (min-width: 768px) {
  .p-revolution__count-item {
    display: inline-block;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__count-item {
    display: block;
  }
}
@media screen and (min-width: 768px) {
  .p-revolution__count-item:first-of-type {
    position: relative;
    margin-right: 70px;
  }
  .p-revolution__count-item:first-of-type::after {
    position: absolute;
    content: "";
    display: block;
    background-color: #3C3C3C;
    width: 2px;
    height: 80px;
    right: -40px;
    top: 53%;
    transform: translateY(-50%) rotate(18deg);
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__count-item:first-of-type {
    margin-right: 4.2682926829vw;
  }
  .p-revolution__count-item:first-of-type::after {
    height: 4.8780487805vw;
    right: -2.4390243902vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__count-item:first-of-type {
    margin-bottom: 2.1333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .p-revolution__count-item:first-of-type .u-en {
    width: 82px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__count-item:first-of-type .u-en {
    width: 5vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__count-item:first-of-type .u-en {
    width: 14.6666666667vw;
  }
}
@media screen and (min-width: 768px) {
  .p-revolution__count-item:nth-of-type(2) .u-en {
    width: 147px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__count-item:nth-of-type(2) .u-en {
    width: 8.9634146341vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__count-item:nth-of-type(2) .u-en {
    width: 25.0666666667vw;
  }
}
.p-revolution__count-item .u-en {
  display: inline-block;
}
@media screen and (min-width: 768px) {
  .p-revolution__count-item .u-en {
    font-size: 100px;
    line-height: 1;
    letter-spacing: 0em;
    font-weight: 700;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__count-item .u-en {
    font-size: 6.0975609756vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__count-item .u-en {
    font-size: calc(60 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0em;
    font-weight: 700;
  }
}
@media screen and (min-width: 768px) {
  .p-revolution__count-item .u-en {
    padding: 0 12px 0 8px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__count-item .u-en {
    padding: 0 0.7317073171vw 0 0.487804878vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__count-item .u-en {
    padding: 0 3.2vw 0 1.6vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__count-item .large {
    font-size: calc(25 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
.p-revolution__item {
  background-color: #E56E07;
  width: 0;
  transition: all 0.5s;
}
@media screen and (min-width: 768px) {
  .p-revolution__item.is-FadeIn02 {
    width: 410px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-revolution__item.is-FadeIn02 {
    width: 25vw;
  }
}
@media screen and (max-width: 767px) {
  .p-revolution__item.is-FadeIn02 {
    width: 29.3333333333vw;
  }
}

.p-flow {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .p-flow {
    padding: 110px 0 75px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow {
    padding: 6.7073170732vw 0 4.5731707317vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow {
    padding: 20.5333333333vw 0 14.9333333333vw;
  }
}
.p-flow::after {
  background-color: #fff;
}
@media screen and (min-width: 768px) {
  .p-flow .c-ttl {
    margin-bottom: 16px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow .c-ttl {
    margin-bottom: 0.9756097561vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow .c-ttl {
    margin-bottom: 4.2666666667vw;
  }
}
.p-flow .c-ttl-sub {
  display: block;
}
@media screen and (min-width: 768px) {
  .p-flow .c-ttl-sub {
    font-size: 39px;
    line-height: 1.5;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow .c-ttl-sub {
    font-size: 2.3780487805vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow .c-ttl-sub {
    font-size: calc(18 / 375 * 100vw);
    line-height: 1.7777777778;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
.p-flow .c-ttl-main {
  display: block;
}
@media screen and (min-width: 768px) {
  .p-flow .c-ttl-main {
    font-size: 55px;
    line-height: 1.5;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow .c-ttl-main {
    font-size: 3.3536585366vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow .c-ttl-main {
    font-size: calc(34 / 375 * 100vw);
    line-height: 1.5;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (min-width: 768px) {
  .p-flow .c-ttl-main .u-en {
    font-size: 81px;
    line-height: 1.0185185185;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow .c-ttl-main .u-en {
    font-size: 4.9390243902vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow .c-ttl-main .u-en {
    font-size: calc(51 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0em;
    font-weight: 700;
  }
}
@media screen and (min-width: 768px) {
  .p-flow .c-ttl-main .u-en {
    padding: 0 8px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow .c-ttl-main .u-en {
    padding: 0 0.487804878vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow .c-ttl-main .u-en {
    padding: 0 1.6vw;
  }
}
@media screen and (min-width: 768px) {
  .p-flow__text {
    font-size: 16px;
    line-height: 1.875;
    letter-spacing: 0.02em;
    font-weight: 500;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow__text {
    font-size: 0.9756097561vw;
  }
}
@media screen and (min-width: 768px) {
  .p-flow__text {
    text-align: center;
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow__text {
    margin-bottom: 2.4390243902vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow__text {
    margin-bottom: 8.5333333333vw;
  }
}
.p-flow__wrap {
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-flow__wrap {
    flex-direction: column;
    row-gap: 45px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow__wrap {
    row-gap: 2.743902439vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow__wrap {
    justify-content: space-between;
  }
}
.p-flow__list {
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-flow__list {
    justify-content: space-between;
  }
}
@media screen and (max-width: 767px) {
  .p-flow__list {
    flex-direction: column;
    row-gap: 3.7333333333vw;
  }
}
.p-flow__list-item {
  display: flex;
  justify-content: center;
  text-align: center;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .p-flow__list-item {
    font-size: 22px;
    line-height: 1.3636363636;
    letter-spacing: 0.03em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow__list-item {
    font-size: 1.3414634146vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow__list-item {
    font-size: calc(18 / 375 * 100vw);
    line-height: 1.6666666667;
    letter-spacing: 0.03em;
    font-weight: 800;
  }
}
@media screen and (min-width: 768px) {
  .p-flow__list-item {
    align-items: center;
    padding-right: 20px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow__list-item {
    padding-right: 1.2195121951vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow__list-item {
    padding-top: 4.8vw;
  }
}
@media screen and (min-width: 768px) {
  .p-flow__list-item:not(:last-of-type) {
    clip-path: polygon(80% 0, 100% 50%, 80% 100%, 0 100%, 0 0);
  }
}
@media screen and (max-width: 767px) {
  .p-flow__list-item:not(:last-of-type) {
    clip-path: polygon(100% 0, 100% 80%, 50% 100%, 0 80%, 0 0);
  }
}
@media screen and (min-width: 768px) {
  .p-flow__list-item {
    box-shadow: 5px 5px 20px rgba(0, 0, 0, 0.2);
    width: 190px;
    height: 260px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow__list-item {
    width: 11.5853658537vw;
    height: 15.8536585366vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow__list-item {
    box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.2);
    width: 69.3333333333vw;
    height: 21.3333333333vw;
  }
}
.p-flow__list-item.item01 {
  background-color: #FFC400;
}
.p-flow__list-item.item02 {
  background-color: #FBB601;
}
.p-flow__list-item.item03 {
  background-color: #F29A03;
}
.p-flow__list-item.item04 {
  background-color: #EF9004;
}
.p-flow__list-item.item05 {
  background-color: #EA8005;
}
.p-flow__list-item.item06 {
  background-color: #E56E07;
}
@media screen and (min-width: 768px) {
  .p-flow__list-item.item06 {
    padding-right: 0;
  }
}
@media screen and (max-width: 767px) {
  .p-flow__list-item.item06 {
    padding-top: 0;
    align-items: center;
  }
}
.p-flow__arrow {
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-flow__arrow {
    width: 15.7333333333vw;
  }
}
.p-flow__arrow-txt {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .p-flow__arrow-txt {
    font-size: 30px;
    line-height: 2.3333333333;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow__arrow-txt {
    font-size: 1.8292682927vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow__arrow-txt {
    font-size: calc(19 / 375 * 100vw);
    line-height: 1.1052631579;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (min-width: 768px) {
  .p-flow__arrow-txt {
    left: 50%;
  }
}
@media screen and (max-width: 767px) {
  .p-flow__arrow-txt {
    left: 48%;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    text-orientation: upright;
  }
}
@media screen and (min-width: 768px) {
  .p-flow__arrow-txt .u-en {
    font-size: 81px;
    line-height: 0;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow__arrow-txt .u-en {
    font-size: 4.9390243902vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow__arrow-txt .u-en {
    font-size: calc(48 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0em;
    font-weight: 700;
  }
}
@media screen and (min-width: 768px) {
  .p-flow__arrow-txt .u-en {
    padding: 0 8px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow__arrow-txt .u-en {
    padding: 0 0.487804878vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow__arrow-txt .u-en {
    margin-bottom: -1.3333333333vw;
    left: -0.2666666667vw;
  }
}
@media screen and (min-width: 768px) {
  .p-flow__arrow-txt .large {
    font-size: 55px;
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-flow__arrow-txt .large {
    font-size: 3.3536585366vw;
  }
}
@media screen and (max-width: 767px) {
  .p-flow__arrow-txt .large {
    font-size: calc(24 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}

.p-reason__bg {
  background-color: #EFEFEF;
}
@media screen and (min-width: 768px) {
  .p-reason__bg {
    padding: 130px 0;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__bg {
    padding: 7.9268292683vw 0;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__bg {
    padding: 26.1333333333vw 0 12vw;
  }
}
.p-reason__ttl {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .p-reason__ttl {
    padding-left: 275px;
    margin-bottom: 90px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__ttl {
    padding-left: 16.7682926829vw;
    margin-bottom: 5.487804878vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__ttl {
    margin-bottom: 14.9333333333vw;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-left: 2.6666666667vw;
  }
}
.p-reason__ttl::after {
  position: absolute;
  content: "";
  z-index: -1;
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../img/bg-reason.png);
}
@media screen and (min-width: 768px) {
  .p-reason__ttl::after {
    width: 712px;
    height: 390px;
    top: -42px;
    right: -215px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__ttl::after {
    width: 43.4146341463vw;
    height: 23.7804878049vw;
    top: -2.5609756098vw;
    right: -13.1097560976vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__ttl::after {
    width: 73.6vw;
    height: 40vw;
    top: -7.4666666667vw;
    left: 11.4666666667vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__ttl img {
    width: 792px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__ttl img {
    width: 48.2926829268vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__ttl img {
    max-width: none;
    width: 100vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item:not(:last-of-type) {
    position: relative;
    padding-bottom: 100px;
    margin-bottom: 100px;
  }
  .p-reason__item:not(:last-of-type)::after {
    position: absolute;
    content: "";
    display: block;
    width: 100vw;
    height: 1px;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    background-color: #fff;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item:not(:last-of-type) {
    padding-bottom: 6.0975609756vw;
    margin-bottom: 6.0975609756vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item:not(:last-of-type) {
    margin-bottom: 14.4vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item.item01 .p-reason__item-text .subttl {
    top: 2.6666666667vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item.item01 .p-reason__item-text .subttl::before {
    transform: rotate(3deg);
    background-image: url(../img/dc-reason01.png);
    width: 356px;
    height: 111px;
    left: -54px;
    top: -50px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item.item01 .p-reason__item-text .subttl::before {
    width: 21.7073170732vw;
    height: 6.7682926829vw;
    left: -3.2926829268vw;
    top: -3.0487804878vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item.item01 .p-reason__item-text .txt {
    width: 532px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item.item01 .p-reason__item-text .txt {
    width: 32.4390243902vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item.item01 .p-reason__item-img img {
    width: 641px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item.item01 .p-reason__item-img img {
    width: 39.0853658537vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item.item02 .p-reason__item-text .subttl::before {
    transform: rotate(3deg);
    background-image: url(../img/dc-reason02.png);
    width: 485px;
    height: 75px;
    left: -40px;
    top: -20px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item.item02 .p-reason__item-text .subttl::before {
    width: 29.5731707317vw;
    height: 4.5731707317vw;
    left: -2.4390243902vw;
    top: -1.2195121951vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item.item02 .p-reason__btn {
    width: 88.5333333333vw;
    height: 14.6666666667vw;
    margin-top: 7.7333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item.item03 .p-reason__item-text .subttl::before {
    transform: rotate(2deg);
    background-image: url(../img/dc-reason03.png);
    width: 458px;
    height: 98px;
    left: -28px;
    top: -30px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item.item03 .p-reason__item-text .subttl::before {
    width: 27.9268292683vw;
    height: 5.9756097561vw;
    left: -1.7073170732vw;
    top: -1.8292682927vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item.item02 .p-reason__item-text .txt, .p-reason__item.item03 .p-reason__item-text .txt {
    width: 484px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item.item02 .p-reason__item-text .txt, .p-reason__item.item03 .p-reason__item-text .txt {
    width: 29.512195122vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item.item02 .p-reason__item-text .subttl, .p-reason__item.item03 .p-reason__item-text .subttl {
    top: 1.3333333333vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item.item02 .p-reason__item-text .subttl::before, .p-reason__item.item03 .p-reason__item-text .subttl::before {
    top: -8.5333333333vw;
  }
}
.p-reason__item-wrap {
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-reason__item-wrap {
    justify-content: space-between;
    align-items: flex-start;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-wrap {
    flex-direction: column;
    row-gap: 5.3333333333vw;
  }
}
.p-reason__item-text {
  position: relative;
}
.p-reason__item-text .num {
  display: block;
  width: auto;
  position: absolute;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .p-reason__item-text .num {
    height: 178px;
    top: 0;
    left: -50px;
    transform: translateX(-110%);
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-text .num {
    left: -3.0487804878vw;
    height: 10.8536585366vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-text .num {
    height: 13.3333333333vw;
    top: 0;
    left: 0;
  }
}
.p-reason__item-text .subttl {
  position: relative;
  z-index: 1;
  display: inline-block;
  transform: rotate(-3deg);
  color: #fff;
  font-family: YakuHanJP, "Noto Serif JP", serif;
}
@media screen and (min-width: 768px) {
  .p-reason__item-text .subttl {
    font-size: 18px;
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 900;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-text .subttl {
    font-size: 1.0975609756vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-text .subttl {
    font-size: calc(13 / 375 * 100vw);
    line-height: 1.3846153846;
    letter-spacing: 0.02em;
    font-weight: 900;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-text .subttl {
    margin-left: 13.3333333333vw;
    padding-left: 12.2666666667vw;
  }
}
.p-reason__item-text .subttl::before {
  position: absolute;
  content: "";
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-reason__item-text .subttl::before {
    transform: rotate(3deg);
    background-image: url(../img/dc-reason01.png);
    width: 81.0666666667vw;
    height: 25.0666666667vw;
    left: 0;
    top: -10.6666666667vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item-text .ttl {
    font-size: 38px;
    line-height: 1.5263157895;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-text .ttl {
    font-size: 2.3170731707vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-text .ttl {
    font-size: calc(24 / 375 * 100vw);
    line-height: 1.5833333333;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item-text .ttl {
    margin-top: 48px;
    margin-bottom: 12px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-text .ttl {
    margin-top: 2.9268292683vw;
    margin-bottom: 0.7317073171vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-text .ttl {
    text-align: center;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    margin-top: 10.6666666667vw;
    margin-bottom: 5.3333333333vw;
  }
}
.p-reason__item-text .txt .u-color-orange {
  font-weight: 700;
}
.p-reason__item-img img {
  display: block;
}
@media screen and (min-width: 768px) {
  .p-reason__item-img img {
    box-shadow: 5px 5px 20px rgba(0, 0, 0, 0.2);
    border-radius: 10px;
    width: 592px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-img img {
    border-radius: 0.6097560976vw;
    width: 36.0975609756vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-img img {
    box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.2);
    border-radius: 2.6666666667vw;
  }
}
.p-reason__item-flow {
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow {
    justify-content: space-between;
    margin-top: 40px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow {
    margin-top: 2.4390243902vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow {
    flex-direction: column;
    row-gap: 12.8vw;
    margin-top: 12.8vw;
  }
}
.p-reason__item-flow .step01,
.p-reason__item-flow .step02 {
  position: relative;
}
.p-reason__item-flow .step01::after,
.p-reason__item-flow .step02::after {
  position: absolute;
  content: "";
  display: block;
  background-color: #aaa;
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step01::after,
  .p-reason__item-flow .step02::after {
    clip-path: polygon(0 0, 100% 50%, 0 100%);
    width: 27px;
    height: 49px;
    right: -27px;
    top: 50%;
    transform: translate(100%, -50%);
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step01::after,
  .p-reason__item-flow .step02::after {
    width: 1.6463414634vw;
    height: 2.987804878vw;
    right: -1.6463414634vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step01::after,
  .p-reason__item-flow .step02::after {
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    width: 10.4vw;
    height: 5.8666666667vw;
    left: 50%;
    transform: translate(-50%, 100%);
    bottom: -3.2vw;
  }
}
.p-reason__item-flow .step01 {
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step01 {
    flex-direction: column;
    row-gap: 19px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step01 {
    row-gap: 1.1585365854vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step01 {
    justify-content: space-between;
  }
}
.p-reason__item-flow .step01-item {
  display: flex;
  align-items: center;
  background-color: #fff;
  border: 1px solid #d8d8d8;
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step01-item {
    width: 205px;
    height: 80px;
    border-radius: 10px;
    padding: 0 27px 0 19px;
    justify-content: space-between;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step01-item {
    width: 12.5vw;
    height: 4.8780487805vw;
    border-radius: 0.6097560976vw;
    padding: 0 1.6463414634vw 0 1.1585365854vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step01-item {
    width: 43.2vw;
    height: 25.3333333333vw;
    border-radius: 2.6666666667vw;
    flex-direction: column;
    justify-content: center;
    row-gap: 4vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step01-item .txt {
    font-size: 20px;
    line-height: 1;
    letter-spacing: 0em;
    font-weight: 700;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step01-item .txt {
    font-size: 1.2195121951vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step01-item .txt {
    font-size: calc(15 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0em;
    font-weight: 700;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step01-item.btob img {
    width: 84px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step01-item.btob img {
    width: 5.1219512195vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step01-item.btob img {
    width: 22.4vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step01-item.btoc img {
    width: 78px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step01-item.btoc img {
    width: 4.756097561vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step01-item.btoc img {
    width: 20.8vw;
  }
}
.p-reason__item-flow .step02 {
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step02 {
    column-gap: 20px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step02 {
    column-gap: 1.2195121951vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step02 {
    justify-content: space-between;
  }
}
.p-reason__item-flow .step02-item {
  background-color: #fff;
  border: 1px solid #D8D8D8;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step02-item {
    width: 200px;
    height: 180px;
    border-radius: 10px;
    padding-top: 16px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step02-item {
    width: 12.1951219512vw;
    height: 10.9756097561vw;
    border-radius: 0.6097560976vw;
    padding-top: 0.9756097561vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step02-item {
    width: 28.2666666667vw;
    height: 40vw;
    border-radius: 2.6666666667vw;
    display: flex;
    flex-direction: column-reverse;
    align-items: center;
    justify-content: flex-end;
    padding-top: 5.3333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step02-item .txt {
    font-size: 18px;
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step02-item .txt {
    font-size: 1.0975609756vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step02-item .txt {
    font-size: calc(14 / 375 * 100vw);
    line-height: 1.4285714286;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
.p-reason__item-flow .step02-item img {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step02-item.item01 img {
    width: 162px;
    margin-top: 15px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step02-item.item01 img {
    width: 9.8780487805vw;
    margin-top: 0.9146341463vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step02-item.item01 img {
    width: 19.4666666667vw;
    margin-bottom: 4.8vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step02-item.item02 img {
    width: 98px;
    margin-top: 18px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step02-item.item02 img {
    width: 5.9756097561vw;
    margin-top: 1.0975609756vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step02-item.item02 img {
    width: 12.5333333333vw;
    margin-bottom: 4.2666666667vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step02-item.item03 img {
    width: 161px;
    margin-top: 12px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step02-item.item03 img {
    width: 9.8170731707vw;
    margin-top: 0.7317073171vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step02-item.item03 img {
    width: 21.3333333333vw;
    margin-bottom: 2.1333333333vw;
  }
}
.p-reason__item-flow .step03 {
  background-color: #E56E07;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step03 {
    width: 245px;
    height: 181px;
    border-radius: 10px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step03 {
    width: 14.9390243902vw;
    height: 11.0365853659vw;
    border-radius: 0.6097560976vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step03 {
    width: 100%;
    height: 32vw;
    border-radius: 2.6666666667vw;
  }
}
.p-reason__item-flow .step03-txt {
  color: #fff;
}
@media screen and (min-width: 768px) {
  .p-reason__item-flow .step03-txt {
    font-size: 19px;
    line-height: 1.6315789474;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-flow .step03-txt {
    font-size: 1.1585365854vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-flow .step03-txt {
    font-size: calc(16 / 375 * 100vw);
    line-height: 1.75;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
.p-reason__item-present {
  position: relative;
  background-color: #fff;
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-reason__item-present {
    box-shadow: 5px 5px 20px rgba(0, 0, 0, 0.16);
    align-items: flex-start;
    column-gap: 70px;
    border-radius: 20px;
    padding: 48px 64px;
    margin-top: 70px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-present {
    column-gap: 4.2682926829vw;
    border-radius: 1.2195121951vw;
    padding: 2.9268292683vw 3.9024390244vw;
    margin-top: 4.2682926829vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-present {
    box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.16);
    padding: 8.5333333333vw 5.3333333333vw;
    margin-top: 14.9333333333vw;
    border-radius: 5.3333333333vw;
    flex-direction: column;
    row-gap: 5.3333333333vw;
  }
}
.p-reason__item-present .ttl {
  position: absolute;
  z-index: 1;
  top: 0;
}
@media screen and (min-width: 768px) {
  .p-reason__item-present .ttl {
    font-size: 35px;
    line-height: 1;
    letter-spacing: 0em;
    font-weight: 700;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-present .ttl {
    font-size: 2.1341463415vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-present .ttl {
    font-size: calc(27 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0em;
    font-weight: 700;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item-present .ttl {
    transform: translateY(-50%);
    left: 34px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-present .ttl {
    left: 2.0731707317vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-present .ttl {
    left: 50%;
    transform: translate(-50%, -50%);
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item-present .text-ttl {
    font-size: 29px;
    line-height: 1.6206896552;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-present .text-ttl {
    font-size: 1.7682926829vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-present .text-ttl {
    font-size: calc(24 / 375 * 100vw);
    line-height: 1.5833333333;
    letter-spacing: 0.02em;
    font-weight: 800;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item-present .text-ttl {
    margin-bottom: 16px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-present .text-ttl {
    margin-bottom: 0.9756097561vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-present .text-ttl {
    text-align: center;
    margin-bottom: 3.2vw;
  }
}
@media screen and (min-width: 768px) {
  .p-reason__item-present .text-txt {
    width: 575px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-present .text-txt {
    width: 35.0609756098vw;
  }
}
.p-reason__item-present .img img {
  display: block;
}
@media screen and (min-width: 768px) {
  .p-reason__item-present .img img {
    width: 416px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__item-present .img img {
    width: 25.3658536585vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-present .img img {
    width: 74.1333333333vw;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__item-present .p-reason__btn {
    width: 76.5333333333vw;
    height: 14.6666666667vw;
    margin-top: 4.5333333333vw;
  }
}
.p-reason__btn {
  display: flex;
  align-items: center;
  position: relative;
  background-color: #E56E07;
  overflow: hidden;
  box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.16);
}
@media screen and (min-width: 768px) {
  .p-reason__btn {
    width: 338px;
    height: 60px;
    border-radius: 30px;
    margin-top: 20px;
    padding-left: 34px;
  }
  .p-reason__btn:hover::before {
    opacity: 0;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__btn {
    width: 20.6097560976vw;
    height: 3.6585365854vw;
    border-radius: 1.8292682927vw;
    margin-top: 1.2195121951vw;
    padding-left: 2.0731707317vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__btn {
    border-radius: 7.3333333333vw;
    padding-left: 8.5333333333vw;
  }
}
.p-reason__btn::before, .p-reason__btn::after {
  position: absolute;
  content: "";
  display: block;
  transition: all 0.3s;
}
.p-reason__btn::before {
  background: linear-gradient(to right, #e56e07 0%, #ffc400 100%);
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  right: 0;
}
.p-reason__btn::after {
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../img/ic-arrow-or.png);
  top: 50%;
  transform: translateY(-50%) rotate(-90deg);
}
@media screen and (min-width: 768px) {
  .p-reason__btn::after {
    width: 32px;
    height: 32px;
    right: 24px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__btn::after {
    width: 1.9512195122vw;
    height: 1.9512195122vw;
    right: 1.4634146341vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__btn::after {
    width: 8.5333333333vw;
    height: 8.5333333333vw;
    right: 3.7333333333vw;
  }
}
.p-reason__btn span {
  position: relative;
  z-index: 5;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .p-reason__btn span {
    font-size: 20px;
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-reason__btn span {
    font-size: 1.2195121951vw;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__btn span {
    font-size: calc(19 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}

@media screen and (min-width: 768px) {
  .p-clients {
    padding-top: 100px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-clients {
    padding-top: 6.0975609756vw;
  }
}
@media screen and (max-width: 767px) {
  .p-clients {
    padding: 10.1333333333vw 0 14.6666666667vw;
    border-bottom: 1px solid #D8D8D8;
  }
}
@media screen and (min-width: 768px) {
  .p-clients .c-ttl {
    margin-bottom: 10px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-clients .c-ttl {
    margin-bottom: 0.6097560976vw;
  }
}
@media screen and (max-width: 767px) {
  .p-clients .c-ttl {
    margin-bottom: 1.6vw;
  }
}
.p-clients__text {
  text-align: center;
  color: #aaa;
}
@media screen and (min-width: 768px) {
  .p-clients__text {
    font-size: 12px;
    line-height: 1.5;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-clients__text {
    font-size: 0.7317073171vw;
  }
}
@media screen and (max-width: 767px) {
  .p-clients__text {
    font-size: calc(12 / 375 * 100vw);
    line-height: 1.5;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}
@media screen and (min-width: 768px) {
  .p-clients__text {
    margin-bottom: 54px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-clients__text {
    margin-bottom: 3.2926829268vw;
  }
}
@media screen and (max-width: 767px) {
  .p-clients__text {
    margin-bottom: 7.4666666667vw;
  }
}
.p-clients__slider-item {
  display: flex;
}
.p-clients__slider-item img {
  flex-shrink: 0;
  max-width: none;
}
@media screen and (min-width: 768px) {
  .p-clients__slider-item.toleft {
    margin-bottom: 32px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-clients__slider-item.toleft {
    margin-bottom: 1.9512195122vw;
  }
}
.p-clients__slider-item.toleft img {
  animation: scroll-left 28s infinite linear 0.5s both;
}
@media screen and (min-width: 768px) {
  .p-clients__slider-item.toleft img {
    width: 1739px;
    padding-right: 10px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-clients__slider-item.toleft img {
    width: 106.0365853659vw;
    padding-right: 0.6097560976vw;
  }
}
.p-clients__slider-item.toright img {
  animation: scroll-right 24s infinite linear 0.5s both;
}
@media screen and (min-width: 768px) {
  .p-clients__slider-item.toright img {
    width: 1549px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-clients__slider-item.toright img {
    width: 94.4512195122vw;
  }
}
.p-clients__img img {
  display: block;
  margin: 0 auto;
  width: 83.2vw;
}

@media screen and (min-width: 768px) {
  .p-media {
    padding-top: 130px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-media {
    padding-top: 7.9268292683vw;
  }
}
@media screen and (max-width: 767px) {
  .p-media {
    padding: 14.1333333333vw 0;
  }
}
@media screen and (min-width: 768px) {
  .p-media .c-ttl {
    margin-bottom: 56px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-media .c-ttl {
    margin-bottom: 3.4146341463vw;
  }
}
@media screen and (max-width: 767px) {
  .p-media .c-ttl {
    margin-bottom: 7.4666666667vw;
  }
}
.p-media__list {
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-media__list {
    justify-content: center;
    column-gap: 67px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-media__list {
    column-gap: 4.0853658537vw;
  }
}
@media screen and (max-width: 767px) {
  .p-media__list {
    flex-direction: column;
    align-items: center;
    row-gap: 5.3333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .p-media__list-item {
    width: 260px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-media__list-item {
    width: 15.8536585366vw;
  }
}
@media screen and (max-width: 767px) {
  .p-media__list-item {
    width: 68vw;
  }
}
.p-media__list-item img {
  display: block;
}

.p-faq__bg {
  background-color: #EFEFEF;
}
@media screen and (min-width: 768px) {
  .p-faq__bg {
    padding: 240px 0 136px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-faq__bg {
    padding: 14.6341463415vw 0 8.2926829268vw;
  }
}
@media screen and (max-width: 767px) {
  .p-faq__bg {
    padding: 13.3333333333vw 0 8.5333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .p-faq .c-ttl {
    margin-bottom: 70px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-faq .c-ttl {
    margin-bottom: 4.2682926829vw;
  }
}
@media screen and (max-width: 767px) {
  .p-faq .c-ttl {
    margin-bottom: 8.5333333333vw;
  }
}
.p-faq__item {
  background-color: #FFFFFF;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
}
@media screen and (min-width: 768px) {
  .p-faq__item:not(:last-of-type) {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-faq__item:not(:last-of-type) {
    margin-bottom: 1.2195121951vw;
  }
}
@media screen and (max-width: 767px) {
  .p-faq__item:not(:last-of-type) {
    margin-bottom: 6.6666666667vw;
  }
}
.p-faq__item-head {
  cursor: pointer;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-faq__item-head {
    padding: 38px 42px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-faq__item-head {
    padding: 2.3170731707vw 2.5609756098vw;
  }
}
@media screen and (max-width: 767px) {
  .p-faq__item-head {
    padding: 8.5333333333vw 10.6666666667vw 8.5333333333vw 5.8666666667vw;
  }
}
@media screen and (min-width: 768px) {
  .p-faq__item-head .txt {
    font-size: 22px;
    line-height: 1.5;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-faq__item-head .txt {
    font-size: 1.3414634146vw;
  }
}
@media screen and (max-width: 767px) {
  .p-faq__item-head .txt {
    font-size: calc(16 / 375 * 100vw);
    line-height: 2;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
.p-faq__item-head.is-open .icon::after {
  height: 0;
}
.p-faq__item-head .icon {
  display: inline-block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 768px) {
  .p-faq__item-head .icon {
    width: 25px;
    height: 25px;
    right: 50px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-faq__item-head .icon {
    width: 1.5243902439vw;
    height: 1.5243902439vw;
    right: 3.0487804878vw;
  }
}
@media screen and (max-width: 767px) {
  .p-faq__item-head .icon {
    width: 4.8vw;
    height: 4.8vw;
    right: 6.4vw;
  }
}
.p-faq__item-head .icon::before, .p-faq__item-head .icon::after {
  position: absolute;
  content: "";
  display: block;
  background-color: #3C3C3C;
  transition: all 0.3s;
}
.p-faq__item-head .icon::before {
  width: 100%;
  height: 2px;
  top: 50%;
  transform: translateY(-50%);
}
.p-faq__item-head .icon::after {
  width: 2px;
  height: 100%;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.p-faq__item-body {
  background-color: #E6E6E6;
}
@media screen and (min-width: 768px) {
  .p-faq__item-body {
    padding: 36px 46px 45px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-faq__item-body {
    padding: 2.1951219512vw 2.8048780488vw 2.743902439vw;
  }
}
@media screen and (max-width: 767px) {
  .p-faq__item-body {
    padding: 5.3333333333vw 5.3333333333vw 5.3333333333vw 6.1333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .p-faq__item-body .txt {
    font-size: 20px;
    line-height: 1.5;
    letter-spacing: 0.02em;
    font-weight: 500;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-faq__item-body .txt {
    font-size: 1.2195121951vw;
  }
}
@media screen and (max-width: 767px) {
  .p-faq__item-body .txt {
    font-size: calc(15 / 375 * 100vw);
    line-height: 1.6;
    letter-spacing: 0.02em;
    font-weight: 500;
  }
}

@media screen and (min-width: 768px) {
  .p-contact {
    padding: 124px 0;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact {
    padding-bottom: 7.5609756098vw 0;
  }
}
@media screen and (max-width: 767px) {
  .p-contact {
    padding: 10.6666666667vw 0;
  }
}
@media screen and (min-width: 768px) {
  .p-contact .c-ttl {
    margin-bottom: 36px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact .c-ttl {
    margin-bottom: 2.1951219512vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact .c-ttl {
    margin-bottom: 3.2vw;
  }
}
.p-contact__text {
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-contact__text {
    font-size: 15px;
    line-height: 2.1333333333;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__text {
    font-size: 0.9146341463vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__text {
    font-size: calc(13 / 375 * 100vw);
    line-height: 2;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__text {
    margin-bottom: 70px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__text {
    margin-bottom: 4.2682926829vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__text {
    margin-bottom: 10.1333333333vw;
  }
}
.p-contact__form {
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .p-contact__form {
    max-width: 905px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form {
    max-width: 55.1829268293vw;
  }
}
.p-contact__form.comfirm .p-contact__form-item .ttl {
  padding-top: 0;
}
.p-contact__form-item {
  display: flex;
  align-items: flex-start;
}
@media screen and (min-width: 768px) {
  .p-contact__form-item {
    justify-content: space-between;
    margin-bottom: 16px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-item {
    margin-bottom: 0.9756097561vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-item {
    margin-bottom: 6.4vw;
    flex-direction: column;
    row-gap: 2.1333333333vw;
  }
}
.p-contact__form-item .ttl {
  display: flex;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .p-contact__form-item .ttl {
    font-size: 16px;
    line-height: 1.5;
    letter-spacing: 0.03em;
    font-weight: 500;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-item .ttl {
    font-size: 0.9756097561vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-item .ttl {
    font-size: calc(13 / 375 * 100vw);
    line-height: 1.5384615385;
    letter-spacing: 0.03em;
    font-weight: 700;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__form-item .ttl {
    column-gap: 16px;
    padding-top: 16px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-item .ttl {
    column-gap: 0.9756097561vw;
    padding-top: 0.9756097561vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-item .ttl {
    flex-direction: row-reverse;
    column-gap: 2.1333333333vw;
  }
}
.p-contact__form-item .ttl .required {
  background-color: #D8D8D8;
}
@media screen and (min-width: 768px) {
  .p-contact__form-item .ttl .required {
    font-size: 10px;
    line-height: 1.5;
    letter-spacing: 0.03em;
    font-weight: 500;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-item .ttl .required {
    font-size: 0.6097560976vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-item .ttl .required {
    font-size: calc(10 / 375 * 100vw);
    line-height: 1.5;
    letter-spacing: 0.03em;
    font-weight: 500;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__form-item .ttl .required {
    border-radius: 16px;
    padding: 3px 12px 4px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-item .ttl .required {
    border-radius: 0.9756097561vw;
    padding: 0.1829268293vw 0.7317073171vw 0.243902439vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-item .ttl .required {
    border-radius: 4.2666666667vw;
    padding: 0.8vw 3.2vw 1.0666666667vw;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__form-item > .cf7msm-ro {
    width: 637px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-item > .cf7msm-ro {
    width: 38.8414634146vw;
  }
}
.p-contact__form-item input,
.p-contact__form-item textarea {
  background-color: #fff;
  border: 1px solid #707070;
  font-family: inherit;
}
@media screen and (min-width: 768px) {
  .p-contact__form-item input,
  .p-contact__form-item textarea {
    font-size: 15px;
    line-height: 1.6666666667;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-item input,
  .p-contact__form-item textarea {
    font-size: 0.9146341463vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-item input,
  .p-contact__form-item textarea {
    font-size: calc(14 / 375 * 100vw);
    line-height: 1.7857142857;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__form-item input,
  .p-contact__form-item textarea {
    width: 637px;
    border-radius: 5px;
    padding: 12px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-item input,
  .p-contact__form-item textarea {
    width: 38.8414634146vw;
    border-radius: 0.3048780488vw;
    padding: 0.7317073171vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-item input,
  .p-contact__form-item textarea {
    width: 100%;
    border-radius: 1.3333333333vw;
    padding: 3.2vw;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__form-item input {
    height: 44px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-item input {
    height: 2.6829268293vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-item input {
    height: 11.7333333333vw;
  }
}
.p-contact__form-item textarea {
  resize: vertical;
}
@media screen and (min-width: 768px) {
  .p-contact__form-item textarea {
    height: 250px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-item textarea {
    height: 15.243902439vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-item textarea {
    height: 58.9333333333vw;
  }
}
.p-contact__form-item ::placeholder {
  color: #ccc;
}
.p-contact__form-link {
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-contact__form-link {
    font-size: 15px;
    line-height: 1;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-link {
    font-size: 0.9146341463vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-link {
    font-size: calc(13 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__form-link {
    margin: 54px 0 36px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-link {
    margin: 3.2926829268vw 0 2.1951219512vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-link {
    margin: 10.6666666667vw 0 7.4666666667vw;
  }
}
.p-contact__form-link a {
  text-decoration: underline;
}
.p-contact__form-policy {
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-contact__form-policy {
    font-size: 15px;
    line-height: 1;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-policy {
    font-size: 0.9146341463vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-policy {
    font-size: calc(13 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__form-policy {
    margin-bottom: 48px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-policy {
    margin-bottom: 2.9268292683vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-policy {
    margin-bottom: 11.7333333333vw;
  }
}
.p-contact__form-btnwrap {
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-contact__form-btnwrap {
    justify-content: center;
    column-gap: 48px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-btnwrap {
    column-gap: 2.9268292683vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-btnwrap {
    flex-direction: column;
    align-items: center;
    row-gap: 2.6666666667vw;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__form-btnwrap.mt {
    margin-top: 40px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-btnwrap.mt {
    margin-top: 2.4390243902vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-btnwrap.mt {
    margin-top: 8vw;
  }
}
.p-contact__form-btn {
  display: flex;
  position: relative;
}
.p-contact__form-btn::after {
  position: absolute;
  content: "";
  pointer-events: none;
  background-repeat: no-repeat;
  background-size: contain;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 768px) {
  .p-contact__form-btn::after {
    width: 11px;
    height: 16px;
    right: 24px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-btn::after {
    width: 0.6707317073vw;
    height: 0.9756097561vw;
    right: 1.4634146341vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-btn::after {
    width: 2.9333333333vw;
    height: 4.2666666667vw;
    right: 6.4vw;
  }
}
.p-contact__form-btn input {
  display: flex;
  align-items: center;
  text-align: left;
  background-color: transparent;
  font-family: inherit;
  border: 1px solid #3C3C3C;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .p-contact__form-btn input {
    font-size: 16px;
    line-height: 1;
    letter-spacing: 0.03em;
    font-weight: 500;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-btn input {
    font-size: 0.9756097561vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-btn input {
    font-size: calc(16 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.03em;
    font-weight: 500;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__form-btn input {
    padding-left: 25px;
    width: 347px;
    height: 50px;
    border-radius: 25px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-btn input {
    padding-left: 1.5243902439vw;
    width: 21.1585365854vw;
    height: 3.0487804878vw;
    border-radius: 1.5243902439vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-btn input {
    width: 89.3333333333vw;
    height: 13.3333333333vw;
    padding-left: 6.6666666667vw;
    border-radius: 6.6666666667vw;
  }
}
.p-contact__form-btn.submit::after {
  background-image: url(../img/ic-submitarrow-gr.png);
}
.p-contact__form-btn.submit input {
  background-color: #fff;
  color: #3C3C3C;
}
@media screen and (min-width: 768px) {
  .p-contact__form-btn .wpcf7-not-valid-tip {
    font-size: 16px;
    line-height: 1;
    letter-spacing: 0.03em;
    font-weight: 500;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__form-btn .wpcf7-not-valid-tip {
    font-size: 0.9756097561vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__form-btn .wpcf7-not-valid-tip {
    font-size: calc(16 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.03em;
    font-weight: 500;
  }
}
.p-contact__form-btn .wpcf7-spinner {
  position: absolute;
  right: 0;
  transform: translateX(100%);
  margin: 0;
}
.p-contact__download {
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-contact__download {
    align-items: flex-start;
    justify-content: space-between;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__download {
    flex-direction: column;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__download-text {
    width: 550px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__download-text {
    width: 33.5365853659vw;
  }
}
.p-contact__download-text .logo {
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-contact__download-text .logo {
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__download-text .logo {
    margin-bottom: 1.8292682927vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__download-text .logo {
    margin-bottom: 5.3333333333vw;
  }
}
.p-contact__download-text .logo-note {
  color: #aaa;
}
@media screen and (min-width: 768px) {
  .p-contact__download-text .logo-note {
    font-size: 12px;
    line-height: 1.5;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__download-text .logo-note {
    font-size: 0.7317073171vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__download-text .logo-note {
    font-size: calc(12 / 375 * 100vw);
    line-height: 1.5;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__download-text .logo-note {
    margin: 4px 0 16px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__download-text .logo-note {
    margin: 0.243902439vw 0 0.9756097561vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__download-text .logo-note {
    margin: 1.0666666667vw 0 4.2666666667vw;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__download-text .logo img {
    width: 80%;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__download-text .img,
  .p-contact__download-text .text {
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__download-text .img,
  .p-contact__download-text .text {
    margin-bottom: 1.8292682927vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__download-text .img,
  .p-contact__download-text .text {
    margin-bottom: 5.3333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__download .p-contact__form {
    width: 600px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__download .p-contact__form {
    width: 36.5853658537vw;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__download .p-contact__form .img,
  .p-contact__download .p-contact__form .text {
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__download .p-contact__form .img,
  .p-contact__download .p-contact__form .text {
    margin-bottom: 1.8292682927vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__download .p-contact__form .img,
  .p-contact__download .p-contact__form .text {
    margin-bottom: 5.3333333333vw;
  }
}
.p-contact__download .p-contact__form .list {
  border: 2px solid #E56E07;
}
@media screen and (min-width: 768px) {
  .p-contact__download .p-contact__form .list {
    padding: 30px;
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__download .p-contact__form .list {
    padding: 1.8292682927vw;
    margin-bottom: 1.8292682927vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__download .p-contact__form .list {
    padding: 5.3333333333vw;
    margin-bottom: 5.3333333333vw;
  }
}
.p-contact__download .p-contact__form .list li {
  position: relative;
  padding-left: 1.7em;
}
@media screen and (min-width: 768px) {
  .p-contact__download .p-contact__form .list li {
    font-size: 16px;
    line-height: 2.1875;
    letter-spacing: 0.02em;
    font-weight: 500;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__download .p-contact__form .list li {
    font-size: 0.9756097561vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__download .p-contact__form .list li {
    font-size: calc(16 / 375 * 100vw);
    line-height: 1.875;
    letter-spacing: 0.02em;
    font-weight: 500;
  }
}
.p-contact__download .p-contact__form .list li::before {
  content: "";
  display: block;
  position: absolute;
  width: 0.9em;
  height: 0.6em;
  border-left: 2px solid #E56E07;
  border-bottom: 2px solid #E56E07;
  top: 0.5em;
  left: 0;
  transform: rotate(-45deg);
}
@media screen and (min-width: 768px) {
  .p-contact__download .p-contact__form-item {
    flex-direction: column;
    row-gap: 12px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .p-contact__download .p-contact__form-item {
    row-gap: 0.7317073171vw;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__download .p-contact__form-item .ttl {
    padding-top: 0;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__download .p-contact__form-item .wpcf7-form-control-wrap {
    display: block;
    max-width: 100%;
  }
}
.p-contact__download .p-contact__form-item .wpcf7-form-control-wrap input {
  max-width: 100%;
}

@media screen and (min-width: 768px) {
  .l-download .p-contact {
    padding-top: 80px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-download .p-contact {
    padding-top: 4.8780487805vw;
  }
}

@media screen and (min-width: 768px) {
  .l-footer a:hover {
    opacity: 0.7;
  }
}
.l-footer__bg {
  background-color: #3C3C3C;
}
@media screen and (min-width: 768px) {
  .l-footer__bg {
    padding: 62px 0 32px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__bg {
    padding: 3.7804878049vw 0 1.9512195122vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__bg {
    padding: 12.8vw 0 24vw;
  }
}
.l-footer__inner {
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .l-footer__inner {
    width: 1145px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__inner {
    width: 69.8170731707vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__inner {
    width: 78.6666666667vw;
  }
}
.l-footer__wrap {
  display: flex;
}
@media screen and (min-width: 768px) {
  .l-footer__wrap {
    column-gap: 92px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__wrap {
    column-gap: 5.6097560976vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__wrap {
    flex-direction: column;
    row-gap: 10.1333333333vw;
  }
}
.l-footer__logo img {
  display: block;
}
@media screen and (min-width: 768px) {
  .l-footer__logo img {
    width: 171px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__logo img {
    width: 10.4268292683vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__logo img {
    width: 45.3333333333vw;
  }
}
.l-footer__nav-list {
  display: flex;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  .l-footer__nav-list {
    row-gap: 24px;
    max-width: 505px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__nav-list {
    row-gap: 1.4634146341vw;
    max-width: 30.7926829268vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__nav-list {
    row-gap: 6.4vw;
  }
}
@media screen and (min-width: 768px) {
  .l-footer__nav-list li:nth-of-type(2n) {
    width: 52%;
  }
}
@media screen and (min-width: 768px) {
  .l-footer__nav-list li:nth-of-type(2n) .u-en {
    width: 120px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__nav-list li:nth-of-type(2n) .u-en {
    width: 7.3170731707vw;
  }
}
@media screen and (min-width: 768px) {
  .l-footer__nav-list li:nth-of-type(2n+1) {
    width: 48%;
  }
}
@media screen and (min-width: 768px) {
  .l-footer__nav-list li:nth-of-type(2n+1) .u-en {
    width: 86px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__nav-list li:nth-of-type(2n+1) .u-en {
    width: 5.243902439vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__nav-list li:nth-of-type(1) {
    order: 0;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__nav-list li:nth-of-type(2) {
    order: 3;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__nav-list li:nth-of-type(3) {
    order: 2;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__nav-list li:nth-of-type(4) {
    order: 4;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__nav-list li:nth-of-type(5) {
    order: 1;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__nav-list li:nth-of-type(6) {
    order: 5;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__nav-list li {
    width: 100%;
  }
}
.l-footer__nav-list li a {
  display: flex;
  align-items: center;
}
.l-footer__nav-list li a .u-en {
  color: #aaa;
}
@media screen and (min-width: 768px) {
  .l-footer__nav-list li a .u-en {
    font-size: 13px;
    line-height: 1;
    letter-spacing: 0em;
    font-weight: 300;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__nav-list li a .u-en {
    font-size: 0.7926829268vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__nav-list li a .u-en {
    font-size: calc(13 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0em;
    font-weight: 300;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__nav-list li a .u-en {
    width: 37.3333333333vw;
  }
}
.l-footer__nav-list li a .u-ja {
  color: #fff;
}
@media screen and (min-width: 768px) {
  .l-footer__nav-list li a .u-ja {
    font-size: 13px;
    line-height: 1;
    letter-spacing: 0.03em;
    font-weight: 500;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__nav-list li a .u-ja {
    font-size: 0.7926829268vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__nav-list li a .u-ja {
    font-size: calc(13 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.03em;
    font-weight: 500;
  }
}
.l-footer__contact a {
  display: flex;
  align-items: center;
  background-color: #E56E07;
  color: #fff;
  position: relative;
}
@media screen and (min-width: 768px) {
  .l-footer__contact a {
    font-size: 16px;
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__contact a {
    font-size: 0.9756097561vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__contact a {
    font-size: calc(16 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 700;
  }
}
@media screen and (min-width: 768px) {
  .l-footer__contact a {
    width: 213px;
    height: 43px;
    padding-left: 16px;
    border-radius: 24px;
    padding-bottom: 2px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__contact a {
    width: 12.987804878vw;
    height: 2.6219512195vw;
    padding-left: 0.9756097561vw;
    border-radius: 1.4634146341vw;
    padding-bottom: 0.1219512195vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__contact a {
    width: 76.2666666667vw;
    height: 11.4666666667vw;
    padding-left: 4.5333333333vw;
    border-radius: 6.4vw;
    padding-bottom: 0.5333333333vw;
  }
}
.l-footer__contact a::after {
  position: absolute;
  content: "";
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../img/ic-arrow-wh.png);
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 768px) {
  .l-footer__contact a::after {
    right: 16px;
    width: 13px;
    height: 13px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__contact a::after {
    right: 0.9756097561vw;
    width: 0.7926829268vw;
    height: 0.7926829268vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__contact a::after {
    right: 4.2666666667vw;
    width: 3.4666666667vw;
    height: 3.4666666667vw;
  }
}
@media screen and (min-width: 768px) {
  .l-footer__corporate {
    margin-top: -30px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__corporate {
    margin-top: -1.8292682927vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__corporate {
    margin-top: 4.8vw;
  }
}
.l-footer__corporate-address {
  color: #aaa;
}
@media screen and (min-width: 768px) {
  .l-footer__corporate-address {
    font-size: 12px;
    line-height: 1.9166666667;
    letter-spacing: 0.03em;
    font-weight: 500;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__corporate-address {
    font-size: 0.7317073171vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__corporate-address {
    font-size: calc(12 / 375 * 100vw);
    line-height: 1.9166666667;
    letter-spacing: 0.03em;
    font-weight: 500;
  }
}
@media screen and (min-width: 768px) {
  .l-footer__corporate-address {
    margin-bottom: 16px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__corporate-address {
    margin-bottom: 0.9756097561vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__corporate-address {
    margin-bottom: 4.2666666667vw;
  }
}
.l-footer__corporate-link {
  display: flex;
  align-items: center;
  position: relative;
  border: 1px solid #fff;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .l-footer__corporate-link {
    font-size: 13px;
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 600;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__corporate-link {
    font-size: 0.7926829268vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__corporate-link {
    font-size: calc(13 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0.02em;
    font-weight: 600;
  }
}
@media screen and (min-width: 768px) {
  .l-footer__corporate-link {
    width: 205px;
    height: 35px;
    border-radius: 24px;
    padding-left: 17px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__corporate-link {
    width: 12.5vw;
    height: 2.1341463415vw;
    border-radius: 1.4634146341vw;
    padding-left: 1.0365853659vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__corporate-link {
    width: 54.6666666667vw;
    height: 9.3333333333vw;
    border-radius: 6.4vw;
    padding-left: 4.5333333333vw;
  }
}
.l-footer__corporate-link::after {
  position: absolute;
  content: "";
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../img/ic-external-wh.png);
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 768px) {
  .l-footer__corporate-link::after {
    width: 14px;
    height: 14px;
    right: 18px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__corporate-link::after {
    width: 0.8536585366vw;
    height: 0.8536585366vw;
    right: 1.0975609756vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__corporate-link::after {
    width: 3.7333333333vw;
    height: 3.7333333333vw;
    right: 4.8vw;
  }
}
.l-footer__copy {
  display: block;
  text-align: center;
  color: #AAAAAA;
}
@media screen and (min-width: 768px) {
  .l-footer__copy {
    font-size: 10px;
    line-height: 1;
    letter-spacing: 0em;
    font-weight: 400;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__copy {
    font-size: 0.6097560976vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__copy {
    font-size: calc(10 / 375 * 100vw);
    line-height: 1;
    letter-spacing: 0em;
    font-weight: 400;
  }
}
@media screen and (min-width: 768px) {
  .l-footer__copy {
    margin-top: 15px;
  }
}
@media screen and (max-width: 1640px) and (min-width: 768px) {
  .l-footer__copy {
    margin-top: 0.9146341463vw;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__copy {
    margin-top: 9.6vw;
  }
}

.js-accordion-body {
  display: none;
}

@media screen and (max-width: 767px) {
  .is-pc {
    display: none !important;
  }
}

@media screen and (min-width: 768px) {
  .is-sp {
    display: none !important;
  }
}

@keyframes kvdeco {
  0% {
    clip-path: circle(0% at 0 100%);
  }
  100% {
    clip-path: circle(150% at 50% 50%);
  }
}
@keyframes kvfade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes scroll-left {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}
@keyframes scroll-right {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(0);
  }
}
[data-module=FadeIn] {
  opacity: 0;
  transform: translate3d(0, 100px, 0);
  transition-timing-function: ease-out;
  transition-property: opacity, transform;
  transition-duration: 0.6s;
}

[data-module=FadeIn].is-FadeIn {
  opacity: 1;
  transform: translateZ(0);
}

/*# sourceMappingURL=product.css.map */
