/* ==========================================================================
Foundation
========================================================================== */
/* Reset
----------------------------------------------------------------- */
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
  box-sizing: border-box;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

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

/* Base
	----------------------------------------------------------------- */
html {
  height: 100%;
  color: #FFFFFF;
  background: #E4F5F4;
}
html.is-modal {
  overflow-y: hidden;
}
html.is-room {
  background: #000000;
}

body {
  color: #000000;
  background: #E4F5F4;
  -webkit-text-size-adjust: 100%;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  font-size: 15px;
  letter-spacing: 0.05em;
  line-height: calc(25 / 15);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
@media screen and (max-width: 767px) {
  body {
    min-height: 100vh;
    /* mobile viewport bug fix */
    min-height: -webkit-fill-available;
  }
  .is-sp body {
    min-height: 100dvh;
  }
}
body.is-transition {
  pointer-events: none;
}
.is-room body {
  background: #000000;
}

img {
  vertical-align: bottom;
  backface-visibility: hidden;
}

a {
  color: #000000;
  text-decoration: none;
  cursor: pointer;
  transition: opacity 0.6s;
}
@media screen and (min-width: 768px) {
  a:hover {
    opacity: 0.5;
  }
}

strong, em {
  font-weight: 600;
}

/* ==========================================================================
	Layout
========================================================================== */
.header {
  position: fixed;
  z-index: 100;
}
.header__logo {
  transition: opacity 0.4s;
  opacity: 1;
}
.is-keyvisual .header__logo {
  opacity: 0;
}
@media screen and (min-width: 768px) {
  .header {
    width: 100%;
  }
  .header__inner {
    display: flex;
    justify-content: space-between;
    max-width: 1366px;
    padding: 14px 38px 0 25px;
    margin-inline: auto;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 700;
  }
}
@media screen and (min-width: 768px) and (max-width: 1080px) {
  .header__inner {
    padding: 1.2962962963vw 3.5185185185vw 0 2.3148148148vw;
  }
}
@media screen and (min-width: 768px) {
  .header__inner > nav {
    display: flex;
    align-items: center;
  }
  .header__logo img {
    width: 226px;
    height: 64px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1080px) {
  .header__logo img {
    width: 20.9259259259vw;
    height: 5.9259259259vw;
  }
}
@media screen and (min-width: 768px) {
  .header__navi {
    white-space: nowrap;
    background: #FFFFFF;
    border-radius: 100vmax;
    font-size: 13px;
    letter-spacing: 0.05em;
    line-height: 1;
    height: 52px;
    padding: 0 52px;
    display: flex;
    align-items: center;
    box-shadow: 10px 10px 30px rgba(0, 0, 0, 0.16);
  }
}
@media screen and (min-width: 768px) and (max-width: 1080px) {
  .header__navi {
    font-size: 1.2037037037vw;
    height: 4.8148148148vw;
    padding: 0 4.8148148148vw;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .header__navi li a {
    transition: color 0.4s;
  }
  .header__navi li a:hover {
    color: #54CA84;
    opacity: 1;
    transition: color 0s;
  }
}
@media screen and (min-width: 768px) {
  .header__navi li + li {
    margin-left: 50px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1080px) {
  .header__navi li + li {
    margin-left: 4.6296296296vw;
  }
}
@media screen and (min-width: 768px) {
  .header__contact {
    white-space: nowrap;
    background: linear-gradient(90deg, #54ca84 0%, #91d9d6 100%);
    border-radius: 100vmax;
    box-shadow: 10px 10px 30px rgba(0, 0, 0, 0.16);
    display: flex;
    align-items: center;
    margin-left: 21px;
    height: 52px;
    color: #FFFFFF;
    padding: 0 15.6px 0 28.4px;
    font-size: 13px;
    letter-spacing: 0.05em;
    line-height: 1;
  }
}
@media screen and (min-width: 768px) and (max-width: 1080px) {
  .header__contact {
    margin-left: 1.9444444444vw;
    height: 4.8148148148vw;
    padding: 0 1.4444444444vw 0 2.6296296296vw;
    font-size: 1.2037037037vw;
  }
}
@media screen and (min-width: 768px) {
  .header__contact:after {
    margin-left: 15px;
    content: "";
    width: 21px;
    height: 21px;
    border-radius: 100vmax;
    display: inline-block;
    background: #FFFFFF url("../img/icn-arrow_button.svg") no-repeat center center/cover;
  }
}
@media screen and (min-width: 768px) and (max-width: 1080px) {
  .header__contact:after {
    margin-left: 1.3888888889vw;
    width: 1.9444444444vw;
    height: 1.9444444444vw;
  }
}
@media screen and (min-width: 768px) {
  .header__toggle {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .header {
    width: 100%;
  }
  .header__inner {
    width: 100%;
    display: flex;
    justify-content: space-between;
    max-width: 1366px;
    padding: 2.6666666667vw 2.6666666667vw 0 4.5333333333vw;
  }
  .header__inner > nav {
    position: fixed;
    width: 100%;
    min-height: 100%;
    background: #FFFFFF;
    top: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 100;
    flex-direction: column;
    left: 100%;
    transition: left 0.4s;
  }
  .header__logo {
    position: relative;
    z-index: 101;
    padding-top: 2.4vw;
  }
  .header__logo img {
    width: 34.4vw;
    height: 9.8666666667vw;
  }
  .header__navi {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 700;
    font-size: 4.2666666667vw;
    letter-spacing: 0.05em;
    line-height: 1;
    text-align: center;
  }
  .header__navi li {
    opacity: 0;
    transform: translate(30px, 0);
    transition: opacity 0.4s, transform 0.4s;
  }
  .header__navi li + li {
    margin-top: 10.6666666667vw;
  }
  .header__contact {
    transition: opacity 0.4s, transform 0.4s;
    opacity: 0;
    transform: translate(30px, 0);
    margin-top: 13.3333333333vw;
    white-space: nowrap;
    background: linear-gradient(90deg, #54ca84 0%, #91d9d6 100%);
    border-radius: 100vmax;
    box-shadow: 1.3333333333vw 1.3333333333vw 4vw rgba(0, 0, 0, 0.16);
    display: flex;
    align-items: center;
    height: 17.0666666667vw;
    color: #FFFFFF;
    padding: 0 5.0666666667vw 0 9.3333333333vw;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 700;
    font-size: 4vw;
    letter-spacing: 0.05em;
    line-height: 1;
  }
  .header__contact:after {
    margin-left: 1.9033674963vw;
    content: "";
    width: 21px;
    height: 21px;
    border-radius: 100vmax;
    display: inline-block;
    background: #FFFFFF url("../img/icn-arrow_button.svg") no-repeat center center/cover;
  }
  .header__toggle {
    width: 13.3333333333vw;
    height: 13.3333333333vw;
    background: #FFFFFF;
    box-shadow: 1.3333333333vw 1.3333333333vw 4vw rgba(0, 0, 0, 0.16);
    border-radius: 50%;
    position: relative;
    z-index: 101;
    transition: background-color 0.4s;
  }
  .header__toggle::after, .header__toggle::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: block;
    height: 1px;
    width: 7.4666666667vw;
    background: #E97E6D;
    transition: transform 0.4s, background-color 0.4s, margin-top 0.4s;
  }
  .header__toggle::before {
    margin-top: -0.9333333333vw;
  }
  .header__toggle::after {
    margin-top: 0.9333333333vw;
  }
  .header.is-active .header__inner > nav {
    left: 0;
  }
  .header.is-active .header__toggle {
    background: #E97E6D;
  }
  .header.is-active .header__toggle::before, .header.is-active .header__toggle::after {
    width: 6.0906666667vw;
    margin-top: 0;
  }
  .header.is-active .header__toggle::before {
    background: #FFFFFF;
    transform: translate(-50%, -50%) rotate(215deg);
  }
  .header.is-active .header__toggle::after {
    background: #FFFFFF;
    transform: translate(-50%, -50%) rotate(-215deg);
  }
  .header.is-active .header__navi li,
  .header.is-active .header__contact {
    opacity: 1;
    transform: none;
  }
  .header.is-active .header__navi li:nth-child(1) {
    transition-delay: 0.3s;
  }
  .header.is-active .header__navi li:nth-child(2) {
    transition-delay: 0.3s;
  }
  .header.is-active .header__navi li:nth-child(3) {
    transition-delay: 0.3s;
  }
  .header.is-active .header__navi li:nth-child(4) {
    transition-delay: 0.3s;
  }
  .header.is-active .header__navi li:nth-child(5) {
    transition-delay: 0.3s;
  }
  .header.is-active .header__navi li:nth-child(6) {
    transition-delay: 0.3s;
  }
  .header.is-active .header__contact {
    transition-delay: 0.3s;
  }
}

.wrapper.ext-top {
  background: #E4F5F4 url("../img/bg-keyvisual.svg") no-repeat left top/100% auto;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .wrapper.ext-top {
    background-image: url("../img/bg-keyvisual_sp.svg");
  }
}

.breadcrumb {
  margin-top: 64px;
}
@media screen and (max-width: 767px) {
  .breadcrumb {
    margin-top: 18.6666666667vw;
  }
}

.footer {
  margin-top: 28px;
}
@media screen and (max-width: 767px) {
  .footer {
    margin-top: 7.4666666667vw;
  }
}
.footer__inner {
  display: grid;
  width: 100%;
  max-width: 1506px;
  padding: 0 70px 60px;
  box-sizing: border-box;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .footer__inner {
    padding: 0 4.5333333333vw 10.6666666667vw;
    grid-template-columns: 50% 50%;
  }
}
.footer__logo {
  grid-column: 1;
  grid-row: 1;
}
.footer__logo img {
  width: 100%;
  max-width: 272px;
  height: auto;
  mix-blend-mode: multiply;
}
@media screen and (max-width: 767px) {
  .footer__logo {
    grid-column: 1/span 2;
    grid-row: 1;
    margin-bottom: 16.2666666667vw;
    text-align: center;
  }
  .footer__logo img {
    width: 56.5333333333vw;
    height: auto;
  }
}
.footer__right-area {
  grid-column: 2;
  grid-row: 1/3;
  display: flex;
  justify-content: flex-end;
  gap: 120px;
}
@media screen and (max-width: 767px) {
  .footer__right-area {
    grid-column: 1/span 2;
    grid-row: 2;
    justify-content: center;
    gap: 8vw;
  }
}
.footer__menu {
  display: grid;
  grid-auto-flow: column;
  grid-template-rows: repeat(3, auto);
  grid-auto-columns: 1fr;
  gap: 16px 60px;
}
@media screen and (max-width: 767px) {
  .footer__menu {
    grid-auto-flow: row;
    grid-template-rows: none;
    grid-template-columns: 1fr;
    gap: 6vw;
  }
}
.footer__menu li {
  font-size: 13px;
  line-height: 1em;
}
.footer__menu li a {
  color: #54CA84;
  font-weight: bold;
  text-decoration: underline;
  text-underline-offset: 4px;
}
@media screen and (max-width: 767px) {
  .footer__menu li a {
    font-size: 3.4666666667vw;
    letter-spacing: 0.001em;
    line-height: 1;
  }
}
.footer__navi {
  font-size: 12px;
  letter-spacing: 0.05em;
  line-height: 1;
  display: flex;
  flex-direction: column;
  gap: 17px;
}
@media screen and (max-width: 767px) {
  .footer__navi {
    margin-top: 0;
    font-size: 3.2vw;
    letter-spacing: 0.001em;
    line-height: 1;
    grid-column: 2;
    grid-row: 2;
    flex-direction: column;
    align-items: flex-start;
    align-self: flex-start;
    gap: 6vw;
  }
}
.footer__copy {
  grid-column: 1;
  grid-row: 2;
  font-size: 11px;
  letter-spacing: 0.05em;
  line-height: 1;
  align-self: end;
}
@media screen and (max-width: 767px) {
  .footer__copy {
    margin-top: 12.2666666667vw;
    grid-column: 1/span 2;
    grid-row: 3;
    align-items: flex-start;
    font-size: 7px;
    letter-spacing: 0.001em;
    line-height: 1;
    text-align: center;
  }
}

/* ==========================================================================
	Object
========================================================================== */
/* Component
----------------------------------------------------------------- */
.section {
  width: 100%;
  padding: 0 40px;
}
@media screen and (max-width: 767px) {
  .section {
    padding: 0 4.5333333333vw;
  }
}
.section__inner {
  width: 100%;
  max-width: 1066px;
  margin-inline: auto;
}
.section__title {
  text-align: center;
}
.section__title > h2 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 900;
  font-size: 38px;
  letter-spacing: 0.05em;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .section__title > h2 {
    font-size: 5.8666666667vw;
    letter-spacing: 0em;
    line-height: 1;
  }
}
.section__title > p {
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0em;
  line-height: 1;
  color: #54CA84;
  margin-top: 22px;
}
@media screen and (max-width: 767px) {
  .section__title > p {
    font-size: 3.2vw;
    letter-spacing: 0em;
    line-height: 1;
    margin-top: 2.1333333333vw;
  }
}

.c-page-subtitle {
  font-size: 28px;
  font-weight: bold;
  margin-top: 16px;
  margin-bottom: 40px;
  padding-left: 10px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .c-page-subtitle {
    font-size: 4.4vw;
    margin-top: 3.7vw;
    margin-bottom: -1.5vw;
  }
}
.c-page-subtitle::before {
  content: "";
  width: 8px;
  height: 8px;
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  background: #FA8576;
  border-radius: 50%;
}

.c-news-card {
  background: transparent;
  overflow: hidden;
  transition: all 0.3s ease;
}
.c-news-card:hover .c-news-card__arrow {
  transform: translateX(0);
}
.c-news-card::after {
  content: "";
  width: 100%;
  height: 1px;
  display: block;
  background: #DDDDDD;
}
.c-news-card a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 0 30px;
  text-decoration: none;
  color: inherit;
}
@media screen and (max-width: 767px) {
  .c-news-card a {
    padding: 6.4vw 0;
  }
}
.c-news-card__content {
  flex: 1;
  padding-right: 40px;
}
@media screen and (max-width: 767px) {
  .c-news-card__content {
    padding-right: 5.3333333333vw;
  }
}
.c-news-card__meta {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 2px;
}
@media screen and (max-width: 767px) {
  .c-news-card__meta {
    gap: 3.2vw;
    margin-bottom: 2.6666666667vw;
  }
}
.c-news-card__date {
  color: #333;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.01em;
}
@media screen and (max-width: 767px) {
  .c-news-card__date {
    font-size: 3.4666666667vw;
  }
}
.c-news-card__title {
  font-size: 16px;
  line-height: 1.7;
  font-weight: 500;
  color: #333;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  letter-spacing: -0.01em;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .c-news-card__title {
    font-size: 3.7333333333vw;
  }
}
.c-news-card__arrow {
  flex-shrink: 0;
  width: 27px;
  height: 27px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: translateX(-4px);
  transition: transform 0.3s ease;
}
@media screen and (max-width: 767px) {
  .c-news-card__arrow {
    width: 7.2vw;
    height: 7.2vw;
  }
}
.c-news-card__arrow svg {
  width: 24px;
  height: 24px;
}
@media screen and (max-width: 767px) {
  .c-news-card__arrow svg {
    width: 5.3333333333vw;
    height: 5.3333333333vw;
  }
}

.c-list-vertical {
  display: flex;
  flex-direction: column;
  border-top: 1px solid #DDDDDD;
}
.c-list-vertical--center {
  margin-inline: auto;
}
.c-list-vertical--narrow {
  max-width: 706px;
}
.c-list-vertical--gap-md {
  gap: 24px;
}
@media screen and (max-width: 767px) {
  .c-list-vertical--gap-md {
    gap: 4.2666666667vw;
  }
}

.c-news-card__category {
  padding: 5px 14px 6px;
  background-color: #ffffff;
  color: #54CA84;
  border: 1px solid #54CA84;
  border-radius: 50px;
  font-size: 12px;
  font-weight: bold;
  line-height: 10px;
}
@media screen and (max-width: 767px) {
  .c-news-card__category {
    padding: 1.3333333333vw 3.2vw 1.6vw;
    font-size: 3.2vw;
    line-height: 2.6666666667vw;
  }
}

.breadcrumb {
  padding: 12px 40px;
}
@media screen and (max-width: 767px) {
  .breadcrumb {
    padding: 2.6666666667vw 4.5333333333vw;
  }
}
.breadcrumb__inner {
  max-width: 1066px;
  margin-inline: auto;
}
.breadcrumb__list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}
@media screen and (max-width: 767px) {
  .breadcrumb__list {
    gap: 1.6vw;
  }
}
.breadcrumb__item {
  display: flex;
  align-items: center;
}
.breadcrumb__link {
  font-size: 11px;
  color: #666;
  text-decoration: none;
  transition: color 0.3s ease;
}
@media screen and (max-width: 767px) {
  .breadcrumb__link {
    font-size: 2.9333333333vw;
  }
}
.breadcrumb__link:hover {
  color: #54CA84;
}
.breadcrumb__separator {
  font-size: 11px;
  color: #999;
  margin: 0 4px;
}
@media screen and (max-width: 767px) {
  .breadcrumb__separator {
    font-size: 2.9333333333vw;
    margin: 0 0.8vw;
  }
}

.c-cta-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-inline: auto;
}
.c-cta-box__button {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 800;
  font-size: 26px;
  letter-spacing: 0.05em;
  line-height: 1;
  background: linear-gradient(90deg, #54ca84 0%, #91d9d6 100%);
  border-radius: 100vmax;
  color: #FFFFFF;
  height: 148px;
  width: 660px;
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: -16px;
  box-shadow: 10px 10px 30px #B6BEB9;
  text-decoration: none;
  transition: all 0.6s ease;
}
.c-cta-box__button:hover {
  opacity: 0.5;
}
.c-cta-box__button:after {
  content: "";
  width: 27px;
  height: 27px;
  display: inline-block;
  background: url("../img/icn-arrow_button.svg") no-repeat center center/contain;
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  right: 61px;
}
@media screen and (max-width: 767px) {
  .c-cta-box__button {
    font-size: 4vw;
    letter-spacing: 0.05em;
    line-height: 1;
    height: 18.6666666667vw;
    width: 83.2vw;
    margin-top: -2.1333333333vw;
    box-shadow: 1.3333333333vw 1.3333333333vw 4vw #B6BEB9;
  }
  .c-cta-box__button:after {
    width: 4.8vw;
    height: 4.8vw;
    right: 6.6666666667vw;
  }
}
.banner.ext-contact .c-cta-box p {
  position: relative;
  z-index: 2;
  background: #FFFFFF;
  width: 378px;
  height: 75px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  border-radius: 15px;
  box-shadow: 10px 10px 30px rgba(0, 0, 0, 0.16);
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 800;
  font-size: 19px;
  letter-spacing: 0em;
  line-height: 1;
  white-space: nowrap;
}
.banner.ext-contact .c-cta-box p span {
  font-size: 14px;
  letter-spacing: 0em;
  line-height: 1;
  display: block;
  margin-bottom: 9.4px;
}
@media screen and (max-width: 767px) {
  .banner.ext-contact .c-cta-box p {
    width: 59.2vw;
    height: 11.7333333333vw;
    font-size: 3.4666666667vw;
    letter-spacing: 0em;
    line-height: 1;
  }
  .banner.ext-contact .c-cta-box p span {
    font-size: 2.6666666667vw;
    letter-spacing: 0em;
    line-height: 1;
    margin-bottom: 1.3333333333vw;
  }
}

.c-button-more {
  display: inline-block;
  padding: 2px 57px 7px;
  border: 1px solid #A8A8A8;
  border-radius: 50px;
  background: transparent;
  color: #A8A8A8;
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 18px;
  text-decoration: none;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .c-button-more {
    padding: 2.8vw 15vw;
    font-size: 4.8vw;
    letter-spacing: 0em;
    line-height: 1;
  }
}
.c-button-more:hover {
  background: #7FA0A0;
  color: #fff;
}

.c-sns {
  display: flex;
  align-items: center;
  justify-self: end;
}
@media screen and (max-width: 767px) {
  .c-sns {
    margin: 16vw 0 0 auto;
    align-items: center;
    justify-content: flex-end;
  }
}
.c-sns p {
  font-size: 15px;
  letter-spacing: 0.05em;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .c-sns p {
    margin-right: 2.9333333333vw;
    font-size: 3.2vw;
    letter-spacing: 0.05em;
    line-height: 1;
  }
}
.c-sns ul {
  display: flex;
  align-items: center;
  margin-left: 20px;
}
@media screen and (max-width: 767px) {
  .c-sns ul {
    margin-top: 0;
    margin-left: 0;
  }
}
.c-sns ul li + li {
  margin-left: 17px;
}
@media screen and (max-width: 767px) {
  .c-sns ul li + li {
    margin-left: 2.1333333333vw;
  }
}
@media screen and (max-width: 767px) {
  .c-sns ul li {
    width: 40px;
    height: 40px;
  }
  .c-sns ul li img {
    width: 100%;
    height: auto;
  }
}

.c-card {
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  flex: 1;
}
.c-card a {
  display: block;
  text-decoration: none;
  color: inherit;
}
.c-card__image {
  position: relative;
  padding-top: 52.4%;
  overflow: hidden;
}
.c-card__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-card__content {
  padding: 20px 0 0;
}
@media screen and (max-width: 767px) {
  .c-card__content {
    padding: 4.2666666667vw 0;
  }
}
.c-card__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 15px;
}
@media screen and (max-width: 767px) {
  .c-card__meta {
    gap: 2.1333333333vw;
    margin-bottom: 4vw;
  }
}
.c-card__category {
  padding: 5px 14px 6px;
  display: inline-block;
  background-color: #ffffff;
  color: #54CA84;
  border: 1px solid #54CA84;
  border-radius: 50px;
  font-size: 12px;
  font-weight: bold;
  line-height: 10px;
}
@media screen and (max-width: 767px) {
  .c-card__category {
    padding: 1.3333333333vw 3.2vw 1.6vw;
    font-size: 3.2vw;
    line-height: 2.6666666667vw;
  }
}
.c-card__date {
  color: #666;
  font-size: 13px;
}
@media screen and (max-width: 767px) {
  .c-card__date {
    font-size: 3.2vw;
  }
}
.c-card__title {
  font-weight: bold;
  font-size: 20px;
  line-height: 1.7;
  font-weight: 700;
  color: #333;
  margin-bottom: 17px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .c-card__title {
    font-size: 5.3333333333vw;
    margin-bottom: 4.5333333333vw;
  }
}
.c-card__tags {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .c-card__tags {
    gap: 2.6666666667vw;
  }
}

.c-card-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}
@media screen and (max-width: 767px) {
  .c-card-list {
    grid-template-columns: 1fr;
    gap: 11.5vw;
  }
}
.c-card-list--col2 {
  grid-template-columns: repeat(2, 1fr);
  gap: 60px;
}
@media screen and (max-width: 767px) {
  .c-card-list--col2 {
    grid-template-columns: 1fr;
    gap: 11.5vw;
  }
}
.c-card-list--col4 {
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
@media screen and (max-width: 767px) {
  .c-card-list--col4 {
    grid-template-columns: 1fr;
    gap: 5.3333333333vw;
  }
}

.c-left-container {
  grid-column: 1;
  grid-row: 1;
}

.c-sidemenu-container {
  grid-column: 2;
  grid-row: 1;
  height: 100%;
  position: relative;
}
@media screen and (max-width: 767px) {
  .c-sidemenu-container {
    margin-top: 16vw;
  }
}

.c-sidemenu {
  background: #FFFFFF;
}
@media screen and (min-width: 768px) {
  .c-sidemenu {
    border-radius: 15px;
  }
}
@media screen and (max-width: 767px) {
  .c-sidemenu {
    border-radius: 4vw;
  }
}
.c-sidemenu__inner {
  padding: 24px 16px;
}
@media screen and (max-width: 767px) {
  .c-sidemenu__inner {
    padding: 0 4.8vw;
  }
}
.c-sidemenu[data-simplebar] .simplebar-track {
  height: calc(100% - 40px);
  top: 20px;
  background: #CCCCCC;
}
.c-sidemenu[data-simplebar] .simplebar-track.simplebar-vertical {
  width: 2px;
  right: -9px;
}
.c-sidemenu[data-simplebar] .simplebar-scrollbar {
  background: #54CA84;
}
.c-sidemenu__section {
  position: relative;
}
@media screen and (min-width: 768px) {
  .c-sidemenu__section + .c-sidemenu__section {
    border-top: 2px solid #E4F6F4;
    margin-top: 30px;
    padding-top: 30px;
  }
}
@media screen and (max-width: 767px) {
  .c-sidemenu__section {
    margin: 0 auto;
    padding: 6.4vw 0 7.4666666667vw;
  }
  .c-sidemenu__section + .c-sidemenu__section + .c-sidemenu__section {
    border-top: 2px solid #E4F6F4;
  }
}
.c-sidemenu__title {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.001em;
  line-height: 1;
  color: #54CA84;
  margin-bottom: 20px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .c-sidemenu__title {
    font-size: 3.7333333333vw;
    letter-spacing: 0.02em;
    line-height: 1;
    margin-bottom: 4.2666666667vw;
  }
}
.c-sidemenu__category-list {
  max-height: 36px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow: hidden;
  transition: max-height 0.5s;
}
@media screen and (max-width: 767px) {
  .c-sidemenu__category-list {
    gap: 2.6666666667vw;
  }
}
.c-sidemenu__category-list--open {
  max-height: var(--sidemenu-category-list-height);
}
.c-sidemenu__category-item {
  position: relative;
  padding-left: 14px;
}
@media screen and (max-width: 767px) {
  .c-sidemenu__category-item {
    padding-left: 4.2666666667vw;
  }
}
.c-sidemenu__category-item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 4px;
  height: 4px;
  background: #E97E6D;
  border-radius: 50%;
  transform: translateY(-50%);
}
.c-sidemenu__category-item a {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 400;
  font-size: 12px;
  letter-spacing: 0.001em;
  line-height: 1;
  color: #333;
  text-decoration: none;
  transition: color 0.3s ease;
  display: block;
}
@media screen and (max-width: 767px) {
  .c-sidemenu__category-item a {
    font-size: 3.4666666667vw;
    letter-spacing: 0.02em;
    line-height: 1;
  }
}
.c-sidemenu__category-item a:hover {
  color: #54CA84;
}
.c-sidemenu__article-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media screen and (max-width: 767px) {
  .c-sidemenu__article-list {
    gap: 3.2vw;
    margin: 6.4vw 0 0;
  }
}
.c-sidemenu__article-item {
  position: relative;
}
.c-sidemenu__article-link {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  text-decoration: none;
  color: inherit;
  transition: background-color 0.3s ease;
  padding: 8px;
  margin: -8px;
  border-radius: 8px;
}
@media screen and (max-width: 767px) {
  .c-sidemenu__article-link {
    gap: 2.6666666667vw;
    padding: 2.1333333333vw;
    margin: -2.1333333333vw;
  }
}
.c-sidemenu__article-link:hover {
  background-color: rgba(84, 202, 132, 0.05);
}
.c-sidemenu__article-link:hover .c-sidemenu__article-title {
  color: #54CA84;
}
.c-sidemenu__article-thumb {
  flex-shrink: 0;
  width: 59px;
  height: 31px;
  background: #F0F0F0;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .c-sidemenu__article-thumb {
    width: 18.6666666667vw;
    height: 13.8666666667vw;
  }
}
.c-sidemenu__article-thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-sidemenu__article-content {
  flex: 1;
  min-width: 0;
}
.c-sidemenu__article-title {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 400;
  font-size: 10px;
  letter-spacing: 0.001em;
  line-height: calc(16 / 10);
  color: #333;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
  transition: color 0.3s ease;
}
@media screen and (max-width: 767px) {
  .c-sidemenu__article-title {
    font-size: 3.2vw;
    letter-spacing: 0.016em;
    line-height: 1;
  }
}
.c-sidemenu__article-meta {
  margin-top: 4px;
  display: flex;
  align-items: center;
  gap: 8px;
}
@media screen and (max-width: 767px) {
  .c-sidemenu__article-meta {
    margin-top: 0.8vw;
    gap: 1.6vw;
  }
}
.c-sidemenu__article-date {
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.016em;
  line-height: 1;
  color: #999;
}
@media screen and (max-width: 767px) {
  .c-sidemenu__article-date {
    font-size: 2.6666666667vw;
    letter-spacing: 0.014em;
    line-height: 1;
  }
}
.c-sidemenu__tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
@media screen and (max-width: 767px) {
  .c-sidemenu__tag-list {
    gap: 1.6vw;
  }
}
@media screen and (min-width: 768px) {
  .c-sidemenu__tag-list .c-tag {
    padding: 0.4em 1.2em 0.5em;
    font-size: 12px;
  }
}
.c-sidemenu__banner {
  margin-top: 32px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
@media screen and (max-width: 767px) {
  .c-sidemenu__banner {
    margin-top: 0;
    gap: 5.334vw;
  }
}
.c-sidemenu__banner a {
  width: 100%;
}
.c-sidemenu__banner img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-sidemenu .c-sidemenu__button {
  width: 24px;
  height: 24px;
  margin: 22px auto -10px;
  display: none;
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2232%22%20height%3D%2232%22%20viewBox%3D%220%200%2032%2032%22%3E%20%3Cdefs%3E%20%3ClinearGradient%20id%3D%22linear-gradient%22%20y1%3D%220.5%22%20x2%3D%221%22%20y2%3D%220.5%22%20gradientUnits%3D%22objectBoundingBox%22%3E%20%3Cstop%20offset%3D%220%22%20stop-color%3D%22%2359cb8a%22%2F%3E%20%3Cstop%20offset%3D%221%22%20stop-color%3D%22%2395dadb%22%2F%3E%20%3C%2FlinearGradient%3E%20%3C%2Fdefs%3E%20%3Cg%20transform%3D%22translate(-1079%20-449)%22%3E%20%3Ccircle%20cx%3D%2216%22%20cy%3D%2216%22%20r%3D%2216%22%20transform%3D%22translate(1079%20449)%22%20opacity%3D%220.6%22%20fill%3D%22url(%23linear-gradient)%22%2F%3E%20%3Cpath%20d%3D%22M11.6-6.284H7.7V-10.6H4.832v4.318H.918v2.6H4.832V.65H7.7V-3.689H11.6Z%22%20transform%3D%22translate(1088.817%20470.377)%22%20fill%3D%22%23fff%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E");
  background-repeat: no-repeat;
  background-size: contain;
}
.c-sidemenu .c-sidemenu__category-list--open + .c-sidemenu__button {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2232%22%20height%3D%2232%22%20viewBox%3D%220%200%2032%2032%22%3E%20%3Cdefs%3E%20%3ClinearGradient%20id%3D%22linear-gradient%22%20y1%3D%220.5%22%20x2%3D%221%22%20y2%3D%220.5%22%20gradientUnits%3D%22objectBoundingBox%22%3E%20%3Cstop%20offset%3D%220%22%20stop-color%3D%22%2359cb8a%22%2F%3E%20%3Cstop%20offset%3D%221%22%20stop-color%3D%22%2395dadb%22%2F%3E%20%3C%2FlinearGradient%3E%20%3C%2Fdefs%3E%20%3Cg%20transform%3D%22translate(-1079%20-449)%22%3E%20%3Ccircle%20cx%3D%2216%22%20cy%3D%2216%22%20r%3D%2216%22%20transform%3D%22translate(1079%20449)%22%20opacity%3D%220.6%22%20fill%3D%22url(%23linear-gradient)%22%2F%3E%20%3Cpath%20d%3D%22M11.6-6.284H.918v2.6H11.6Z%22%20transform%3D%22translate(1088.817%20470.377)%22%20fill%3D%22%23fff%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E");
}

.l-2column--with-sidemenu {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 240px;
  grid-template-rows: auto;
  gap: 96px;
  align-items: start;
}
@media screen and (max-width: 767px) {
  .l-2column--with-sidemenu {
    display: block;
  }
}

.c-pickup-cards {
  margin-top: 80px;
  padding: 24px 40px 12px;
  background: #FFFFFF;
  border-radius: 15px;
}
@media screen and (max-width: 767px) {
  .c-pickup-cards {
    margin-top: 16.333333vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: 6.4vw 0;
    border-radius: 0;
  }
}
.c-pickup-cards__title {
  text-align: center;
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0.001em;
  line-height: 1;
  color: #52C4C4;
  margin-bottom: 24px;
}
@media screen and (max-width: 767px) {
  .c-pickup-cards__title {
    font-size: 4.8vw;
    letter-spacing: 0.001em;
    line-height: 1;
    margin-bottom: 6.4vw;
  }
}
.c-pickup-cards__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  max-width: 1066px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .c-pickup-cards__list {
    width: calc(192vw + 64px + 64px);
    max-width: none;
    padding: 0 32px;
    gap: 6.4vw;
    overflow-x: hidden;
    overflow-y: hidden;
  }
  .c-pickup-cards__list::-webkit-scrollbar {
    display: none;
    scrollbar-width: none;
  }
}
@media screen and (max-width: 767px) {
  .c-pickup-cards__list .c-card {
    width: 64vw;
  }
}
.c-pickup-cards__list .c-card__meta, .c-pickup-cards__list .c-card__tags {
  display: none;
}
.c-pickup-cards__list .c-card__title {
  font-size: 14px;
  letter-spacing: 0.001em;
  line-height: calc(24 / 14);
}
@media screen and (max-width: 767px) {
  .c-pickup-cards__list .c-card__title {
    font-size: 3.7333333333vw;
    letter-spacing: 0.001em;
    line-height: calc(24 / 14);
    margin-bottom: 0;
  }
}
@media screen and (max-width: 767px) {
  .c-pickup-cards .simplebar-wrapper {
    padding-bottom: 1.5vw;
  }
}
.c-pickup-cards .simplebar-track {
  background: #CCCCCC;
}
.c-pickup-cards .simplebar-track.simplebar-horizontal {
  height: 1px;
}
.c-pickup-cards .simplebar-horizontal {
  width: 50%;
  margin-inline: auto;
}
.c-pickup-cards .simplebar-scrollbar {
  background: #54CA84;
}

.c-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .c-pagination {
    gap: 2.1333333333vw;
    margin-top: 16.333333vw;
    font-size: 3.2vw;
    letter-spacing: 0.001em;
    line-height: 1;
  }
}
.c-pagination__item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 12px;
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.04em;
  line-height: 1;
  color: #333333;
  text-decoration: none;
  border-radius: 50%;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .c-pagination__item {
    min-width: 6.9333333333vw;
    height: 6.9333333333vw;
    padding: 0 1.6vw;
    font-size: 3.7333333333vw;
    letter-spacing: 0.032em;
    line-height: 1;
  }
}
.c-pagination__item:hover:not(.c-pagination__item--current) {
  background: rgba(82, 196, 196, 0.1);
}
.c-pagination__item--current {
  background: linear-gradient(90deg, #59cb8a 0%, #95dadb 100%);
  color: #FFFFFF;
  pointer-events: none;
}
.c-pagination__item--prev, .c-pagination__item--next, .c-pagination__item--first, .c-pagination__item--last {
  position: relative;
  padding: 0;
  width: 40px;
}
@media screen and (max-width: 767px) {
  .c-pagination__item--prev, .c-pagination__item--next, .c-pagination__item--first, .c-pagination__item--last {
    width: 8.5333333333vw;
  }
}
.c-pagination__item--prev::before, .c-pagination__item--next::before, .c-pagination__item--first::before, .c-pagination__item--last::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 10px;
  background: url("../img/icn-pagination-arrow.svg") no-repeat center/contain;
}
@media screen and (max-width: 767px) {
  .c-pagination__item--prev::before, .c-pagination__item--next::before, .c-pagination__item--first::before, .c-pagination__item--last::before {
    width: 1.3333333333vw;
    height: 2.1333333333vw;
  }
}
.c-pagination__item--prev::before {
  transform: rotate(180deg);
}
.c-pagination__item--first::before, .c-pagination__item--last::before {
  width: 12px;
  background: url("../img/icn-pagination-double-arrow.svg") no-repeat center/contain;
}
@media screen and (max-width: 767px) {
  .c-pagination__item--first::before, .c-pagination__item--last::before {
    width: 2.6666666667vw;
  }
}
.c-pagination__item--first::before {
  transform: rotate(180deg);
}
.c-pagination__item--dots {
  pointer-events: none;
  color: #999999;
  min-width: auto;
  padding: 0 4px;
}
@media screen and (max-width: 767px) {
  .c-pagination__item--dots {
    padding: 0 0.5333333333vw;
  }
}
.c-pagination__item:disabled, .c-pagination__item--disabled {
  opacity: 0.4;
  pointer-events: none;
  cursor: not-allowed;
}

.c-button-link {
  min-width: 160px;
  padding: 5px 16px 7px;
  display: inline-block;
  background: linear-gradient(90deg, #59cb8a 0%, #95dadb 100%);
  color: #fff;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  border-radius: 16px;
}
@media screen and (max-width: 767px) {
  .c-button-link {
    min-width: 42.6666666667vw;
    padding: 2.4vw 3.7333333333vw 2.9333333333vw;
    font-size: 3.7333333333vw;
    letter-spacing: 0.001em;
    line-height: 1;
    border-radius: 99px;
  }
}
.c-button-link-wrapper {
  margin: 40px 0;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .c-button-link-wrapper {
    margin: 18vw 0;
  }
}
.c-button-link--arrow {
  width: 100%;
  padding: 11px 56px 12px 27px;
  position: relative;
  font-size: 12px;
  font-weight: 800;
  border-radius: 27px;
}
@media screen and (max-width: 767px) {
  .c-button-link--arrow {
    padding: 5.3333333333vw 13.6vw 5.6vw 6.9333333333vw;
    font-size: 4vw;
    letter-spacing: 0.001em;
    line-height: 1;
  }
}
.c-button-link--arrow::after {
  content: "";
  width: 19px;
  height: 19px;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2219%22%20height%3D%2219%22%20viewBox%3D%220%200%2019%2019%22%3E%20%3Cg%20transform%3D%22translate(-0.449%20-0.265)%22%3E%20%3Ccircle%20cx%3D%229.5%22%20cy%3D%229.5%22%20r%3D%229.5%22%20transform%3D%22translate(0.449%200.265)%22%20fill%3D%22%23fff%22%2F%3E%20%3Cpath%20d%3D%22M454.134%2C532.761l2.566%2C2.887-2.566%2C2.887%22%20transform%3D%22translate(-444.866%20-525.825)%22%20fill%3D%22none%22%20stroke%3D%22%2390d8d4%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E");
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .c-button-link--arrow::after {
    width: 5.0666666667vw;
    height: 5.0666666667vw;
    right: 6.9333333333vw;
  }
}

.c-contact {
  max-width: 540px;
  margin: 0 auto 75px;
  padding: 24px 32px 28px;
  background: #F1FAF9;
  border-radius: 16px;
}
@media screen and (max-width: 767px) {
  .c-contact {
    max-width: none;
    margin: 16vw auto;
    padding: 6.4vw 3vw 8.8vw;
  }
}
.c-contact__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .c-contact__inner {
    flex-direction: column;
    text-align: center;
  }
}
.c-contact__content {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
@media screen and (max-width: 767px) {
  .c-contact__content {
    flex-direction: column;
    align-items: flex-start;
    gap: 4.4vw;
  }
}
.c-contact__title {
  margin: 0;
  color: #59cb8a;
  font-size: 18px;
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .c-contact__title {
    font-size: 4.8vw;
    letter-spacing: 0.001em;
    line-height: 1;
  }
}
.c-contact__text {
  margin: 0;
  color: #000000;
  font-size: 11px;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .c-contact__text {
    font-size: 3.2vw;
    letter-spacing: 0.0015em;
    line-height: 1;
  }
}
.c-contact__button {
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .c-contact__button {
    width: 100%;
    margin-top: 6.4vw;
  }
}
.c-contact .c-button-link--arrow {
  border-radius: 99px;
}

.c-tag-area {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  align-items: center;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .c-tag-area {
    gap: 2.6666666667vw;
    margin-bottom: 8.5333333333vw;
  }
}

.c-tag {
  display: inline-block;
  padding: 0.5em 1.4em 0.6em;
  background: #F1FAF9;
  color: #000000;
  border-radius: 50px;
  font-weight: 500;
  font-size: 10px;
  text-decoration: none;
  transition: all 0.3s ease;
}
.c-tag::before {
  content: "#";
  color: #FA8576;
  margin-right: 2px;
}
@media screen and (max-width: 767px) {
  .c-tag {
    padding: 1.4vw 3.5vw;
    font-size: 2.6666666667vw;
  }
}
.c-tag--hover:hover {
  background: #54CA84;
  color: #FFFFFF;
}
.c-tag--hover:hover::before {
  color: #FFFFFF;
}

/* Project
----------------------------------------------------------------- */
.keyvisual {
  width: 100%;
  position: relative;
  z-index: 2;
  overflow: visible;
  margin-top: 90px;
}
.keyvisual__logo, .keyvisual__lead, .keyvisual__title, .keyvisual__text, .keyvisual__comment {
  opacity: 0;
  transform: translate(0, 40px);
  transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 1.2s cubic-bezier(0.33, 1, 0.68, 1);
}
@media screen and (max-width: 767px) {
  .keyvisual__logo, .keyvisual__lead, .keyvisual__title, .keyvisual__text, .keyvisual__comment {
    transform: translate(-10.6666666667vw, 0);
  }
}
.keyvisual__image {
  opacity: 0;
  transform: translate(40px, 0);
  transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 1.2s cubic-bezier(0.33, 1, 0.68, 1);
}
@media screen and (max-width: 767px) {
  .keyvisual__image {
    transform: translate(0, -10.6666666667vw);
  }
}
.keyvisual.is-animated .keyvisual__logo,
.keyvisual.is-animated .keyvisual__lead,
.keyvisual.is-animated .keyvisual__title,
.keyvisual.is-animated .keyvisual__text,
.keyvisual.is-animated .keyvisual__comment,
.keyvisual.is-animated .keyvisual__image {
  opacity: 1;
  transform: none;
}
@media screen and (min-width: 768px) {
  .keyvisual__logo, .keyvisual__lead, .keyvisual__title, .keyvisual__text, .keyvisual__comment {
    transition-delay: 0.6s;
  }
  .keyvisual__image {
    transition-delay: 0.3s;
    pointer-events: none;
  }
}
@media screen and (max-width: 767px) {
  .keyvisual__image {
    transition-delay: 0.3s;
    pointer-events: none;
  }
  .keyvisual__logo, .keyvisual__lead, .keyvisual__title, .keyvisual__text, .keyvisual__comment {
    transition-delay: 0.5s;
  }
}
@media screen and (min-width: 1367px) {
  .keyvisual__inner {
    max-width: 1066px;
    width: 100%;
    height: 0;
    padding-top: min(49.1947291362%, 672px);
    margin-inline: auto;
    position: relative;
  }
  .keyvisual__logo {
    position: absolute;
    width: 33.8649155722%;
    top: 12px;
    left: -0.3752345216%;
  }
  .keyvisual__logo img {
    width: 100%;
    height: auto;
  }
  .keyvisual__lead {
    position: absolute;
    top: 21.4285714286%;
    left: 0;
  }
  .keyvisual__lead span {
    display: flex;
    align-items: center;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
    font-size: 28px;
    letter-spacing: 0em;
    line-height: 1;
    white-space: nowrap;
    color: #54CA84;
  }
  .keyvisual__lead span img {
    margin-left: 2px;
    height: auto;
  }
  .keyvisual__lead span:first-child img {
    width: 134px;
  }
  .keyvisual__lead span:last-child {
    margin-top: 8px;
  }
  .keyvisual__lead span:last-child img {
    width: 145px;
  }
  .keyvisual__title {
    position: absolute;
    top: 34.6726190476%;
    left: -0.5628517824%;
  }
  .keyvisual__title span {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 900;
    font-size: 46px;
    letter-spacing: 0em;
    line-height: 1;
    color: #54CA84;
  }
  .keyvisual__title span:nth-child(1) {
    font-family: "Work Sans", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 700;
    font-size: 59px;
    letter-spacing: 0em;
    line-height: 1;
  }
  .keyvisual__title span:nth-child(3) {
    display: block;
  }
  .keyvisual__text {
    position: absolute;
    top: 57.1428571429%;
    left: 0;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
    font-size: 22px;
    letter-spacing: 0em;
    line-height: calc(37 / 22);
  }
  .keyvisual__text strong {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
  }
  .keyvisual__comment {
    position: absolute;
    top: 75.5952380952%;
    left: 0;
    border-radius: 15px;
    background: rgba(255, 255, 255, 0.6);
    padding: 20px 36px 20px 30px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .keyvisual__comment ul {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
    font-size: 16px;
    letter-spacing: 0em;
    line-height: 1;
    color: #54CA84;
  }
  .keyvisual__comment ul li::before {
    content: "- ";
  }
  .keyvisual__comment ul li + li {
    margin-top: 7px;
  }
  .keyvisual__comment p {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0em;
    line-height: 1;
    margin-left: 34px;
  }
  .keyvisual__comment p strong {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 800;
    font-size: 17px;
    letter-spacing: 0em;
    line-height: 1;
    margin: 8.3px 0 11px;
    display: block;
    position: relative;
  }
  .keyvisual__comment p strong:before {
    content: "";
    width: 100%;
    height: 6px;
    position: absolute;
    bottom: -3px;
    background: #54CA84;
    z-index: 1;
  }
  .keyvisual__comment p strong span {
    position: relative;
    z-index: 2;
  }
  .keyvisual__image {
    position: absolute;
    top: -90px;
    left: 50%;
    margin-left: -683px;
    width: 1715px;
    height: auto;
  }
}
@media screen and (max-width: 1366px) {
  .keyvisual__inner {
    width: 100%;
    height: 0;
    padding-top: 49.1947291362vw;
    margin-inline: auto;
    position: relative;
  }
  .keyvisual__logo {
    position: absolute;
    top: 0.878477306vw;
    left: 10.541727672vw;
  }
  .keyvisual__logo img {
    width: 26.4275256223vw;
    height: auto;
  }
  .keyvisual__lead {
    position: absolute;
    top: 10.0292825769vw;
    left: 10.9077598829vw;
  }
  .keyvisual__lead span {
    display: flex;
    align-items: center;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
    font-size: 2.0497803807vw;
    letter-spacing: 0em;
    line-height: 1;
    white-space: nowrap;
    color: #54CA84;
  }
  .keyvisual__lead span img {
    margin-left: 0.1464128843vw;
    height: auto;
  }
  .keyvisual__lead span:first-child img {
    width: 9.8096632504vw;
  }
  .keyvisual__lead span:last-child {
    margin-top: 0.5856515373vw;
  }
  .keyvisual__lead span:last-child img {
    width: 10.6149341142vw;
  }
  .keyvisual__title {
    position: absolute;
    top: 16.5446559297vw;
    left: 10.7613469985vw;
  }
  .keyvisual__title span {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 900;
    font-size: 3.3674963397vw;
    letter-spacing: 0em;
    line-height: 1;
    color: #54CA84;
  }
  .keyvisual__title span:nth-child(1) {
    font-family: "Work Sans", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 700;
    font-size: 4.3191800878vw;
    letter-spacing: 0em;
    line-height: 1;
  }
  .keyvisual__title span:nth-child(3) {
    display: block;
  }
  .keyvisual__text {
    position: absolute;
    top: 27.5988286969vw;
    left: 10.980966325vw;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
    font-size: 1.5373352855vw;
    letter-spacing: 0em;
    line-height: calc(35 / 21);
  }
  .keyvisual__text strong {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
  }
  .keyvisual__comment {
    position: absolute;
    top: 37.1888726208vw;
    left: 10.980966325vw;
    border-radius: 15px;
    background: rgba(255, 255, 255, 0.6);
    padding: 1.4641288433vw 2.635431918vw 1.4641288433vw 2.196193265vw;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .keyvisual__comment ul {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
    font-size: 1.1713030747vw;
    letter-spacing: 0em;
    line-height: 1;
    color: #54CA84;
  }
  .keyvisual__comment ul li::before {
    content: "- ";
  }
  .keyvisual__comment ul li + li {
    margin-top: 0.5124450952vw;
  }
  .keyvisual__comment p {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
    font-size: 0.9516837482vw;
    letter-spacing: 0em;
    line-height: 1;
    margin-left: 2.4890190337vw;
  }
  .keyvisual__comment p strong {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 800;
    font-size: 1.2445095168vw;
    letter-spacing: 0em;
    line-height: 1;
    margin: 0.60761347vw 0 0.8052708638vw;
    display: block;
    position: relative;
  }
  .keyvisual__comment p strong:before {
    content: "";
    width: 100%;
    height: 0.439238653vw;
    position: absolute;
    bottom: -0.2196193265vw;
    background: #54CA84;
    z-index: 1;
  }
  .keyvisual__comment p strong span {
    position: relative;
    z-index: 2;
  }
  .keyvisual__image {
    position: absolute;
    top: -90px;
    left: 0;
    width: 125.5490483163vw;
    height: auto;
  }
}
@media screen and (max-width: 767px) {
  .keyvisual {
    margin-top: 0;
  }
  .keyvisual__inner {
    width: 100%;
    height: 0;
    padding-top: 177.8666666667vw;
    margin-inline: auto;
    position: relative;
  }
  .keyvisual__logo {
    position: absolute;
    top: 84.5333333333vw;
    left: 6.4vw;
  }
  .keyvisual__logo img {
    width: 53.6vw;
    height: auto;
  }
  .keyvisual__lead {
    position: absolute;
    top: 103.9013333333vw;
    left: 7.816vw;
    display: flex;
    align-items: center;
  }
  .keyvisual__lead span {
    display: flex;
    align-items: center;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
    font-size: 4.2666666667vw;
    letter-spacing: 0em;
    line-height: 1;
    white-space: nowrap;
    color: #54CA84;
  }
  .keyvisual__lead span img {
    margin-left: 1.0666666667vw;
    height: auto;
  }
  .keyvisual__lead span:first-child img {
    width: 22.088vw;
  }
  .keyvisual__lead span:last-child {
    margin-left: 1.8666666667vw;
  }
  .keyvisual__lead span:last-child img {
    width: 23.9146666667vw;
  }
  .keyvisual__title {
    position: absolute;
    top: 112.92vw;
    left: 7.832vw;
  }
  .keyvisual__title span {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 900;
    font-size: 8vw;
    letter-spacing: 0em;
    line-height: 1;
    color: #54CA84;
  }
  .keyvisual__title span:nth-child(1) {
    font-family: "Work Sans", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 700;
    font-size: 9.3333333333vw;
    letter-spacing: 0em;
    line-height: 1;
  }
  .keyvisual__title span:nth-child(3) {
    display: block;
  }
  .keyvisual__text {
    position: absolute;
    top: 133.5413333333vw;
    left: 7.7333333333vw;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
    font-size: 3.4666666667vw;
    letter-spacing: 0em;
    line-height: calc(20 / 13);
  }
  .keyvisual__text strong {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
  }
  .keyvisual__comment {
    position: absolute;
    top: 142.1333333333vw;
    left: 7.4666666667vw;
    border-radius: 15px;
    background: rgba(255, 255, 255, 0.6);
    padding: 4.8vw 7.7333333333vw 5.8666666667vw 6.6666666667vw;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .keyvisual__comment ul {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
    font-size: 3.7333333333vw;
    letter-spacing: 0em;
    line-height: 1;
    color: #54CA84;
  }
  .keyvisual__comment ul li::before {
    content: "- ";
  }
  .keyvisual__comment ul li + li {
    margin-top: 2.1333333333vw;
  }
  .keyvisual__comment p {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 600;
    font-size: 2.9333333333vw;
    letter-spacing: 0em;
    line-height: 1;
    margin-left: 5.3333333333vw;
  }
  .keyvisual__comment p strong {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 800;
    font-size: 3.7333333333vw;
    letter-spacing: 0em;
    line-height: 1;
    margin: 2.4266666667vw 0 3.52vw;
    display: block;
    position: relative;
  }
  .keyvisual__comment p strong:before {
    content: "";
    width: 100%;
    height: 1.6vw;
    position: absolute;
    bottom: -0.8vw;
    background: #54CA84;
    z-index: 1;
  }
  .keyvisual__comment p strong span {
    position: relative;
    z-index: 2;
  }
  .keyvisual__image {
    position: absolute;
    top: 0;
    left: 0;
    margin-left: 0;
    width: 100vw;
    height: auto;
  }
}

@media screen and (max-width: 767px) {
  .banner {
    padding: 0;
  }
}
@media screen and (max-width: 1366px) {
  .banner .section__inner {
    max-width: 78.0380673499vw;
  }
}
@media screen and (max-width: 767px) {
  .banner .section__inner {
    max-width: 82.192vw;
  }
}
@media screen and (max-width: 767px) {
  .banner.ext-campaign {
    max-width: 82.192vw;
    margin-inline: auto;
  }
}
.banner.ext-campaign img {
  width: 100%;
  height: auto;
}
.banner.ext-campaign a {
  box-shadow: 10px 10px 30px rgba(0, 0, 0, 0.16);
  transform: translateZ(0);
  position: relative;
  display: block;
  background: #FFFFFF;
  border-radius: 22px;
  padding: 40px 220px 49px 83px;
}
@media screen and (max-width: 1366px) {
  .banner.ext-campaign a {
    border-radius: 1.6105417277vw;
    padding: 2.9282576867vw 16.1054172767vw 3.5871156662vw 6.0761346999vw;
  }
}
@media screen and (max-width: 767px) {
  .banner.ext-campaign a {
    box-shadow: 1.3333333333vw 1.3333333333vw 4vw rgba(0, 0, 0, 0.16);
    border-radius: 2.6666666667vw;
    padding: 9.3333333333vw 21.0666666667vw 9.3333333333vw 9.3333333333vw;
  }
}
.banner.ext-campaign a::after {
  content: "";
  display: block;
  background: url("../img/icn-arrow_campaign_large.svg") no-repeat center center/cover;
  width: 15px;
  height: 30px;
  position: absolute;
  right: 61.9px;
  top: 50%;
  transform: translate(0, -50%);
}
@media screen and (max-width: 1366px) {
  .banner.ext-campaign a::after {
    width: 1.0980966325vw;
    height: 2.196193265vw;
    right: 4.5314787701vw;
  }
}
@media screen and (max-width: 767px) {
  .banner.ext-campaign a::after {
    width: 1.5626666667vw;
    height: 3.1226666667vw;
    right: 5.0133333333vw;
  }
}
.banner.ext-campaign a::before {
  content: "";
  display: block;
  position: absolute;
  right: 137px;
  top: 23px;
  width: 2px;
  height: calc(100% - 46px);
  background: #E6E6E6;
}
@media screen and (max-width: 1366px) {
  .banner.ext-campaign a::before {
    right: 10.0292825769vw;
    top: 1.6837481698vw;
    height: calc(100% - 3.3674963397vw);
  }
}
@media screen and (max-width: 767px) {
  .banner.ext-campaign a::before {
    right: 11.84vw;
    top: 5.3333333333vw;
    height: calc(100% - 10.6666666667vw);
  }
}
.banner.ext-campaign a > span,
.banner.ext-campaign a > div, .banner.ext-campaign a::before, .banner.ext-campaign a:after {
  transition: opacity 0.4s;
}
.banner.ext-campaign a:hover > span,
.banner.ext-campaign a:hover > div, .banner.ext-campaign a:hover::before, .banner.ext-campaign a:hover:after {
  opacity: 0.5;
}
.banner.ext-campaign .banner__special {
  background: #E97E6D;
  color: #FFFFFF;
  border-radius: 100vmax;
  text-align: center;
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0em;
  line-height: 1;
  padding: 0 18px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translate(-50%, 0);
  z-index: 1;
  white-space: nowrap;
}
@media screen and (max-width: 1366px) {
  .banner.ext-campaign .banner__special {
    font-size: 1.317715959vw;
    letter-spacing: 0em;
    line-height: 1;
    padding: 0 1.317715959vw;
    height: 2.9282576867vw;
    top: -1.4641288433vw;
  }
}
@media screen and (max-width: 767px) {
  .banner.ext-campaign .banner__special {
    font-size: 3.2vw;
    letter-spacing: 0em;
    line-height: 1;
    padding: 0 3.7333333333vw;
    height: 8vw;
    top: -4vw;
  }
}
.banner.ext-campaign .banner__lead {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 600;
  font-size: 35px;
  letter-spacing: 0em;
  line-height: calc(48 / 35);
  text-align: center;
}
.banner.ext-campaign .banner__lead em {
  color: #E97E6D;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 900;
  font-size: 35px;
  letter-spacing: 0em;
  line-height: calc(48 / 35);
}
.banner.ext-campaign .banner__lead strong {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 900;
}
@media screen and (max-width: 1366px) {
  .banner.ext-campaign .banner__lead {
    font-size: 2.5622254758vw;
    letter-spacing: 0em;
    line-height: calc(48 / 35);
  }
  .banner.ext-campaign .banner__lead em {
    font-size: 2.5622254758vw;
    letter-spacing: 0em;
    line-height: calc(48 / 35);
  }
}
@media screen and (max-width: 767px) {
  .banner.ext-campaign .banner__lead {
    font-size: 5.0666666667vw;
    letter-spacing: 0em;
    line-height: calc(27.8 / 19);
    text-align: left;
  }
  .banner.ext-campaign .banner__lead em {
    font-size: 5.0666666667vw;
    letter-spacing: 0em;
    line-height: calc(27.8 / 19);
  }
}
.banner.ext-campaign .banner__detail {
  display: flex;
  align-items: center;
  margin-top: 15.8px;
}
@media screen and (max-width: 1366px) {
  .banner.ext-campaign .banner__detail {
    margin-top: 1.1566617862vw;
  }
}
@media screen and (max-width: 767px) {
  .banner.ext-campaign .banner__detail {
    margin-top: 3.3866666667vw;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
  }
}
.banner.ext-campaign .banner__detail p {
  display: flex;
  align-items: center;
  white-space: nowrap;
}
.banner.ext-campaign .banner__detail p.ext-price {
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.05em;
  line-height: 1;
}
.banner.ext-campaign .banner__detail p.ext-price + .ext-price {
  margin-left: 30px;
}
.banner.ext-campaign .banner__detail p.ext-price .ext-label {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.05em;
  line-height: 1;
  color: #54CA84;
  border: 1px solid #54CA84;
  padding: 7px 7.5px;
  display: inline-block;
  margin-right: 10px;
}
.banner.ext-campaign .banner__detail p.ext-price img {
  width: 5.32px;
  height: auto;
  margin: 0 7px;
  flex-grow: 0;
  flex-shrink: 0;
}
.banner.ext-campaign .banner__detail p.ext-price strong {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 800;
  font-size: 22px;
  letter-spacing: 0.05em;
  line-height: 1;
  color: #E97E6D;
  margin-top: -4px;
}
.banner.ext-campaign .banner__detail p.ext-price em {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0em;
  line-height: 1;
  color: #54CA84;
  margin-right: 4.5px;
}
@media screen and (max-width: 1366px) {
  .banner.ext-campaign .banner__detail p.ext-price {
    font-size: 1.317715959vw;
    letter-spacing: 0.05em;
    line-height: 1;
  }
  .banner.ext-campaign .banner__detail p.ext-price + .ext-price {
    margin-left: 2.196193265vw;
  }
  .banner.ext-campaign .banner__detail p.ext-price .ext-label {
    font-size: 0.8052708638vw;
    letter-spacing: 0.05em;
    line-height: 1;
    padding: 0.5124450952vw 0.5490483163vw;
    margin-right: 0.7320644217vw;
  }
  .banner.ext-campaign .banner__detail p.ext-price img {
    width: 0.3894582723vw;
    margin: 0 0.5124450952vw;
  }
  .banner.ext-campaign .banner__detail p.ext-price strong {
    font-size: 1.6105417277vw;
    letter-spacing: 0.05em;
    line-height: 1;
    margin-top: -0.2928257687vw;
  }
  .banner.ext-campaign .banner__detail p.ext-price em {
    font-size: 0.878477306vw;
    letter-spacing: 0em;
    line-height: 1;
    margin-right: 0.3294289898vw;
  }
}
@media screen and (max-width: 767px) {
  .banner.ext-campaign .banner__detail p.ext-price {
    font-size: 3.7333333333vw;
    letter-spacing: 0.05em;
    line-height: 1;
  }
  .banner.ext-campaign .banner__detail p.ext-price + .ext-price {
    margin-left: 0;
    margin-top: 1.3333333333vw;
  }
  .banner.ext-campaign .banner__detail p.ext-price .ext-label {
    font-size: 2.4vw;
    letter-spacing: 0.05em;
    line-height: 1;
    padding: 1.6vw 1.6vw;
    margin-right: 1.8133333333vw;
  }
  .banner.ext-campaign .banner__detail p.ext-price span:not(.ext-label) {
    width: 20.2666666667vw;
  }
  .banner.ext-campaign .banner__detail p.ext-price img {
    width: 1.208vw;
    margin: 0 1.3333333333vw;
  }
  .banner.ext-campaign .banner__detail p.ext-price strong {
    font-size: 4.8vw;
    letter-spacing: 0.05em;
    line-height: 1;
    margin-top: -1.0666666667vw;
  }
  .banner.ext-campaign .banner__detail p.ext-price em {
    font-size: 2.4vw;
    letter-spacing: 0em;
    line-height: 1;
    margin-right: 1.2vw;
  }
}
.banner.ext-campaign .banner__detail p:not(.ext-price) {
  display: inline-block;
  margin-left: 28.6px;
  color: #FFFFFF;
  background: #54CA84;
  padding: 10px 14px;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.05em;
  line-height: 1;
}
@media screen and (max-width: 1366px) {
  .banner.ext-campaign .banner__detail p:not(.ext-price) {
    margin-left: 2.093704246vw;
    padding: 0.7320644217vw 1.0248901903vw;
    font-size: 0.9516837482vw;
    letter-spacing: 0.05em;
    line-height: 1;
  }
}
@media screen and (max-width: 767px) {
  .banner.ext-campaign .banner__detail p:not(.ext-price) {
    margin-left: 0;
    margin-top: 3.04vw;
    padding: 1.8666666667vw 0;
    width: 100%;
    text-align: center;
    font-size: 2.4vw;
    letter-spacing: 0.05em;
    line-height: 1;
  }
}
.keyvisual + .banner.ext-campaign {
  margin-top: 158px;
}
@media screen and (max-width: 767px) {
  .keyvisual + .banner.ext-campaign {
    margin-top: 24vw;
  }
}
.price + .banner.ext-campaign {
  margin-top: 105px;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .price + .banner.ext-campaign {
    margin-top: 20.64vw;
  }
}
.banner.ext-contact {
  text-align: center;
  position: relative;
  z-index: 2;
}
.banner.ext-contact p {
  position: relative;
  z-index: 2;
  background: #FFFFFF;
  width: 378px;
  height: 75px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  border-radius: 15px;
  box-shadow: 10px 10px 30px rgba(0, 0, 0, 0.16);
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 800;
  font-size: 19px;
  letter-spacing: 0em;
  line-height: 1;
  white-space: nowrap;
}
.banner.ext-contact p span {
  font-size: 14px;
  letter-spacing: 0em;
  line-height: 1;
  display: block;
  margin-bottom: 9.4px;
}
@media screen and (max-width: 767px) {
  .banner.ext-contact p {
    width: 59.2vw;
    height: 11.7333333333vw;
    font-size: 3.4666666667vw;
    letter-spacing: 0em;
    line-height: 1;
  }
  .banner.ext-contact p span {
    font-size: 2.6666666667vw;
    letter-spacing: 0em;
    line-height: 1;
    margin-bottom: 1.3333333333vw;
  }
}
.feature + .banner.ext-contact {
  margin-top: 78.5px;
}
@media screen and (max-width: 767px) {
  .feature + .banner.ext-contact {
    margin-top: 10.6666666667vw;
  }
}
.price + .banner.ext-contact, .recommend + .banner.ext-contact {
  margin-top: 96px;
}
@media screen and (max-width: 767px) {
  .price + .banner.ext-contact, .recommend + .banner.ext-contact {
    margin-top: 18.1333333333vw;
  }
}
.company + .banner.ext-contact {
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .company + .banner.ext-contact {
    margin-top: 14.6666666667vw;
  }
}
.banner__box {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-inline: auto;
}
.banner__button {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 800;
  font-size: 26px;
  letter-spacing: 0.05em;
  line-height: 1;
  background: linear-gradient(90deg, #54ca84 0%, #91d9d6 100%);
  border-radius: 100vmax;
  color: #FFFFFF;
  height: 148px;
  width: 660px;
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: -16px;
  box-shadow: 10px 10px 30px #B6BEB9;
}
.banner__button:after {
  content: "";
  width: 27px;
  height: 27px;
  display: inline-block;
  background: url("../img/icn-arrow_button.svg") no-repeat center center/contain;
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  right: 61px;
}
@media screen and (max-width: 767px) {
  .banner__button {
    font-size: 4vw;
    letter-spacing: 0.05em;
    line-height: 1;
    height: 18.6666666667vw;
    width: 83.2vw;
    margin-top: -2.1333333333vw;
    box-shadow: 1.3333333333vw 1.3333333333vw 4vw #B6BEB9;
  }
  .banner__button:after {
    content: "";
    width: 4.8vw;
    height: 4.8vw;
    right: 6.6666666667vw;
  }
}

.worries {
  position: relative;
  z-index: 1;
  margin-top: 204.5px;
}
.worries:before {
  pointer-events: none;
  content: "";
  display: block;
  position: absolute;
  width: 100vw;
  height: 701px;
  top: -142.5px;
  left: 50%;
  transform: translate(-50%, 0);
  background: url(../img/bg-about.png) no-repeat center top/100% 100%;
}
@media screen and (max-width: 767px) {
  .worries:before {
    width: 100vw;
    height: 160.2666666667vw;
    top: -28.1866666667vw;
    background: url(../img/bg-about_sp.svg) no-repeat center top/cover;
  }
}
@media screen and (max-width: 767px) {
  .worries {
    margin-top: 10.0533333333vw;
    padding: 0;
  }
}
.worries .section__title {
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .worries .section__title img {
    width: 100%;
    height: auto;
  }
}
.worries .section__title h2 {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .worries .section__title {
    width: 100%;
    text-align: center;
  }
  .worries .section__title img {
    width: 69.0666666667vw;
    height: auto;
  }
  .worries .section__title p {
    margin-top: 3.7066666667vw;
  }
}
.worries .section__inner {
  position: relative;
}
@media screen and (min-width: 768px) {
  .worries__list {
    margin-top: 4.3557833089vw;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (max-width: 767px) {
  .worries__list {
    margin-top: 8.72vw;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .worries__list li img {
    width: 100%;
    height: auto;
  }
  .worries__list li:nth-child(1) {
    width: 45.1228893058%;
    order: 1;
    margin-left: 9.6622889306%;
    margin-right: auto;
  }
  .worries__list li:nth-child(2) {
    width: 38.5515947467%;
    order: 3;
    margin-left: 10.3658536585%;
    margin-right: auto;
    margin-top: -4.9048316252vw;
  }
  .worries__list li:nth-child(3) {
    width: 41.1744840525%;
    order: 2;
    margin-left: auto;
    margin-right: 4.4559099437%;
    margin-top: -2.4158125915vw;
  }
}
@media screen and (max-width: 767px) {
  .worries__list li img {
    width: 100%;
    height: auto;
  }
  .worries__list li:nth-child(1) {
    width: 87.8133333333vw;
    align-self: flex-end;
    margin-right: 0.4533333333vw;
  }
  .worries__list li:nth-child(2) {
    width: 79.1973333333vw;
    margin-top: 4.4533333333vw;
    align-self: flex-start;
    margin-left: 1.336vw;
  }
  .worries__list li:nth-child(3) {
    width: 86.8613333333vw;
    margin-top: 2.9333333333vw;
    align-self: flex-end;
    margin-right: 6.56vw;
  }
  .worries__list li:nth-child(4) {
    width: 78.1333333333vw;
    margin-top: -0.5333333333vw;
    align-self: flex-start;
    margin-left: 6.56vw;
  }
}

.about {
  max-width: 1066px;
  margin: 96.1px auto 0;
  padding: 64px 108px 85px 110px;
  box-sizing: border-box;
  position: relative;
  z-index: 2;
  overflow: visible;
  background: #FFFFFF;
  border-radius: min(189px, 13.8360175695vw);
}
@media screen and (max-width: 1086px) {
  .about {
    width: calc(100% - 2.9282576867vw);
    margin-left: 1.4641288433vw;
    margin-right: 1.4641288433vw;
    padding-left: 8.0527086384vw;
    padding-right: 7.906295754vw;
  }
}
@media screen and (max-width: 767px) {
  .about {
    width: calc(100% - 5.3333333333vw);
    margin: 14.0533333333vw 2.6666666667vw 0;
    padding: 11.7333333333vw 2.6666666667vw 12.5333333333vw;
    border-radius: 25.3333333333vw;
  }
  .worries.ext-alt + .about {
    margin-top: 40.5333333333vw;
  }
}
.about .section__inner {
  display: grid;
}
@media screen and (max-width: 1066px) {
  .about .section__inner {
    display: flex;
    align-items: center;
    flex-direction: column;
  }
}
.about__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  position: relative;
  z-index: 1;
  grid-row: 1;
  grid-column: 1/span 2;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 600;
  font-size: 39px;
  letter-spacing: 0.008em;
  line-height: 1;
}
@media screen and (max-width: 900px) {
  .about__title {
    font-size: 40px;
    letter-spacing: 0.05em;
    line-height: 1;
  }
}
@media screen and (max-width: 767px) {
  .about__title {
    font-size: 5.6vw;
    letter-spacing: 0em;
    line-height: 1;
  }
}
.about__title span {
  display: flex;
  align-items: center;
  white-space: nowrap;
}
.about__title span + span {
  margin-top: 3px;
}
@media screen and (max-width: 767px) {
  .about__title span + span {
    margin-top: 1.7866666667vw;
  }
}
.about__title strong {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 900;
}
.about__title img {
  width: 294px;
  height: auto;
  margin-right: 4px;
}
@media screen and (max-width: 900px) {
  .about__title img {
    margin-right: 11px;
  }
}
@media screen and (max-width: 767px) {
  .about__title img {
    width: 36.5333333333vw;
    margin-right: 2.5333333333vw;
  }
}
.about__text {
  margin-top: 52px;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 600;
  font-size: 17px;
  letter-spacing: 0.05em;
  line-height: calc(33 / 17);
  grid-column: 1/span 2;
  grid-row: 2;
  position: relative;
  display: flex;
  justify-content: center;
  padding-right: 0;
}
.about__text span {
  display: block;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .about__text {
    margin-top: 5.4933333333vw;
    font-size: 3.4666666667vw;
    letter-spacing: 0em;
    line-height: calc(23 / 13);
    padding-right: 0;
  }
  .about__text span {
    text-align: center;
  }
}
.about__button {
  margin-top: 52px;
  grid-column: 2;
  grid-row: 2;
  display: flex;
  align-items: center;
  position: relative;
}
@media screen and (max-width: 767px) {
  .about__button {
    margin-top: 5.8666666667vw;
  }
}
.about__button a {
  margin-top: auto;
  margin-left: auto;
  background: #54CA84;
  color: #FFFFFF;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 24px 0 34px;
  border-radius: 100vmax;
  height: 68px;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 20px;
  letter-spacing: 0.05em;
  line-height: 1;
  box-shadow: 10px 10px 30px rgba(0, 0, 0, 0.16);
}
.about__button a strong {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  font-size: 25px;
  letter-spacing: 0.04em;
  line-height: 1;
  margin-right: 5px;
}
.about__button a:after {
  content: "";
  display: inline-block;
  width: 29.48px;
  height: 29.48px;
  background: url("../img/icn-arrow_about.svg") no-repeat center center/contain;
  margin-left: 28.5px;
}
@media screen and (max-width: 767px) {
  .about__button a {
    padding: 0 4.48vw 0 4.8266666667vw;
    height: 10.9333333333vw;
    font-size: 3.2vw;
    letter-spacing: 0.05em;
    line-height: 1;
    box-shadow: 1.3333333333vw 1.3333333333vw 4vw rgba(0, 0, 0, 0.16);
  }
  .about__button a strong {
    margin-right: 1.0133333333vw;
    font-size: 4vw;
    letter-spacing: 0.05em;
    line-height: 1;
  }
  .about__button a:after {
    width: 6.7946666667vw;
    height: 6.7946666667vw;
    margin-left: 4.9333333333vw;
  }
}

.feature {
  margin-top: 125px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .feature {
    margin-top: 21.3333333333vw;
  }
}
.feature .section__title h2 {
  display: flex;
  align-items: center;
  justify-content: center;
}
.feature .section__title h2 img {
  width: 265px;
  height: auto;
  margin-right: 10px;
}
@media screen and (max-width: 767px) {
  .feature .section__title h2 img {
    width: 36.5333333333vw;
    margin-right: 1.0666666667vw;
  }
}
.feature .section__title p {
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  .feature .section__title p {
    margin-top: 1.0666666667vw;
  }
}
.feature__lead {
  font-size: 15px;
  letter-spacing: 0.05em;
  line-height: calc(27 / 15);
  margin-inline: auto;
  margin-top: 39px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .feature__lead {
    margin-top: 5.0666666667vw;
    font-size: 3.4666666667vw;
    letter-spacing: 0em;
    line-height: calc(23 / 13);
    text-align: left;
  }
  .feature__lead br {
    display: none;
  }
}
.feature__section {
  background: #FFFFFF;
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .feature__section {
    margin-top: 10.6666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .feature__lead + .feature__section {
    margin-top: 16vw;
  }
}
.feature__section > h3 {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 800;
  font-size: 27px;
  letter-spacing: 0.05em;
  line-height: calc(41 / 27);
  padding: 18.8px 18.8px 20.2px;
  color: #FFFFFF;
  background: linear-gradient(90deg, #24c465 0%, #66d9db 78.82%, #fff 110%);
}
@media screen and (max-width: 767px) {
  .feature__section > h3 {
    font-size: 4.8vw;
    letter-spacing: 0.05em;
    line-height: calc(25 / 18);
    padding: 2.4vw 4.5333333333vw 3.4666666667vw;
    background: url("../img/bg-function_headline_sp.png") no-repeat left top/cover;
  }
}
.feature__section > h3 span:first-child {
  flex-shrink: 0;
  flex-grow: 0;
  width: 41px;
  height: 41px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid #FFFFFF;
  border-radius: 50%;
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0em;
  line-height: 1;
  margin-right: 20px;
}
@media screen and (max-width: 767px) {
  .feature__section > h3 span:first-child {
    width: 8.2666666667vw;
    height: 8.2666666667vw;
    font-size: 3.2vw;
    letter-spacing: 0em;
    line-height: 1;
    margin-right: 2.6666666667vw;
  }
}
.feature__section > div {
  padding: 50px 6.3789868668%;
}
.feature__section > div p {
  font-size: 15px;
  letter-spacing: 0.05em;
  line-height: calc(25 / 15);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .feature__section > div {
    padding: 6.88vw 5.3333333333vw 7.7333333333vw;
    overflow: hidden;
  }
  .feature__section > div p {
    font-size: 3.2vw;
    letter-spacing: 0em;
    line-height: calc(20 / 12);
    text-align: left;
  }
}
@media screen and (min-width: 768px) {
  .feature__section.ext-01 .swiper, .feature__section.ext-02 .swiper, .feature__section.ext-03 .swiper {
    overflow: visible;
  }
  .feature__section.ext-01 .swiper-slide img, .feature__section.ext-02 .swiper-slide img, .feature__section.ext-03 .swiper-slide img {
    width: 100%;
    height: auto;
  }
  .feature__section.ext-01 .swiper-button-next, .feature__section.ext-01 .swiper-button-prev, .feature__section.ext-02 .swiper-button-next, .feature__section.ext-02 .swiper-button-prev, .feature__section.ext-03 .swiper-button-next, .feature__section.ext-03 .swiper-button-prev {
    display: none;
  }
  .feature__section.ext-01 .swiper-pagination-bullet, .feature__section.ext-02 .swiper-pagination-bullet, .feature__section.ext-03 .swiper-pagination-bullet {
    display: none;
  }
  .feature__section.ext-01 .swiper-wrapper, .feature__section.ext-02 .swiper-wrapper, .feature__section.ext-03 .swiper-wrapper {
    display: flex;
  }
}
@media screen and (max-width: 767px) {
  .feature__section.ext-01 .swiper, .feature__section.ext-02 .swiper, .feature__section.ext-03 .swiper, .feature__section.ext-04 .swiper {
    overflow: visible;
    width: 100%;
    position: relative;
  }
  .feature__section.ext-01 .swiper::before, .feature__section.ext-01 .swiper::after, .feature__section.ext-02 .swiper::before, .feature__section.ext-02 .swiper::after, .feature__section.ext-03 .swiper::before, .feature__section.ext-03 .swiper::after, .feature__section.ext-04 .swiper::before, .feature__section.ext-04 .swiper::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: -5.3333333333vw;
    width: 2.1333333333vw;
    height: 100%;
    background: #FFFFFF;
    z-index: 4;
  }
  .feature__section.ext-01 .swiper::after, .feature__section.ext-02 .swiper::after, .feature__section.ext-03 .swiper::after, .feature__section.ext-04 .swiper::after {
    left: auto;
    right: -5.3333333333vw;
  }
  .feature__section.ext-01 .swiper-wrapper, .feature__section.ext-02 .swiper-wrapper, .feature__section.ext-03 .swiper-wrapper, .feature__section.ext-04 .swiper-wrapper {
    margin-inline: auto;
  }
  .feature__section.ext-01 .swiper-slide, .feature__section.ext-02 .swiper-slide, .feature__section.ext-03 .swiper-slide, .feature__section.ext-04 .swiper-slide {
    padding: 0 3.7333333333vw 2.1333333333vw;
  }
  .feature__section.ext-01 .swiper-slide img, .feature__section.ext-02 .swiper-slide img, .feature__section.ext-03 .swiper-slide img, .feature__section.ext-04 .swiper-slide img {
    width: 100%;
    height: auto;
  }
  .feature__section.ext-01 .swiper-pagination, .feature__section.ext-02 .swiper-pagination, .feature__section.ext-03 .swiper-pagination, .feature__section.ext-04 .swiper-pagination {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    padding: 0 4vw;
    bottom: 0;
  }
  .feature__section.ext-01 .swiper-pagination-bullet, .feature__section.ext-02 .swiper-pagination-bullet, .feature__section.ext-03 .swiper-pagination-bullet, .feature__section.ext-04 .swiper-pagination-bullet {
    flex-shrink: 1;
    flex-grow: 0;
    height: 2px;
    padding: 0;
    margin: 0;
    background-color: #CCCCCC;
    width: 8.8vw;
    opacity: 1;
    border-radius: 0;
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  .feature__section.ext-01 .swiper-pagination-bullet, .feature__section.ext-02 .swiper-pagination-bullet, .feature__section.ext-03 .swiper-pagination-bullet, .feature__section.ext-04 .swiper-pagination-bullet {
    height: 1px;
  }
}
@media screen and (max-width: 767px) {
  .feature__section.ext-01 .swiper-pagination-bullet + .swiper-pagination-bullet, .feature__section.ext-02 .swiper-pagination-bullet + .swiper-pagination-bullet, .feature__section.ext-03 .swiper-pagination-bullet + .swiper-pagination-bullet, .feature__section.ext-04 .swiper-pagination-bullet + .swiper-pagination-bullet {
    margin-left: 0.8vw;
  }
  .feature__section.ext-01 .swiper-pagination-bullet-active, .feature__section.ext-02 .swiper-pagination-bullet-active, .feature__section.ext-03 .swiper-pagination-bullet-active, .feature__section.ext-04 .swiper-pagination-bullet-active {
    background-color: #54CA84;
  }
  .feature__section.ext-01 .swiper-button-next, .feature__section.ext-01 .swiper-button-prev, .feature__section.ext-02 .swiper-button-next, .feature__section.ext-02 .swiper-button-prev, .feature__section.ext-03 .swiper-button-next, .feature__section.ext-03 .swiper-button-prev, .feature__section.ext-04 .swiper-button-next, .feature__section.ext-04 .swiper-button-prev {
    width: 6.1013333333vw;
    height: 0;
    padding-top: 19.8533333333vw;
    background: url("../img/icn-arrow_carousel_sp.svg") no-repeat center center/contain;
    transform: translate(0, -50%);
    margin: auto;
    right: 0;
  }
  .feature__section.ext-01 .swiper-button-next:after, .feature__section.ext-01 .swiper-button-prev:after, .feature__section.ext-02 .swiper-button-next:after, .feature__section.ext-02 .swiper-button-prev:after, .feature__section.ext-03 .swiper-button-next:after, .feature__section.ext-03 .swiper-button-prev:after, .feature__section.ext-04 .swiper-button-next:after, .feature__section.ext-04 .swiper-button-prev:after {
    display: none;
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  .feature__section.ext-01 .swiper-button-next, .feature__section.ext-01 .swiper-button-prev, .feature__section.ext-02 .swiper-button-next, .feature__section.ext-02 .swiper-button-prev, .feature__section.ext-03 .swiper-button-next, .feature__section.ext-03 .swiper-button-prev, .feature__section.ext-04 .swiper-button-next, .feature__section.ext-04 .swiper-button-prev {
    right: -2.9333333333vw;
  }
}
@media screen and (max-width: 767px) {
  .feature__section.ext-01 .swiper-button-prev, .feature__section.ext-02 .swiper-button-prev, .feature__section.ext-03 .swiper-button-prev, .feature__section.ext-04 .swiper-button-prev {
    transform: translate(0, -50%) scale(-1, 1);
    left: 0;
    right: auto;
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  .feature__section.ext-01 .swiper-button-prev, .feature__section.ext-02 .swiper-button-prev, .feature__section.ext-03 .swiper-button-prev, .feature__section.ext-04 .swiper-button-prev {
    left: -2.9333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .feature__section.ext-01 .swiper-slide {
    width: 32.9032258065%;
  }
  .feature__section.ext-01 .swiper-slide:nth-child(2) {
    margin-top: 104px;
    margin-left: -10.5376344086%;
  }
  .feature__section.ext-01 .swiper-slide:nth-child(3) {
    margin-left: -10.4301075269%;
  }
  .feature__section.ext-01 .swiper-slide:nth-child(4) {
    margin-top: 104px;
    margin-left: -10.4301075269%;
  }
}
.feature__section.ext-01 p {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .feature__section.ext-01 p {
    margin-top: 3.7866666667vw;
  }
}
@media screen and (min-width: 768px) {
  .feature__section.ext-02 .swiper-wrapper {
    justify-content: center;
  }
  .feature__section.ext-02 .swiper-slide {
    width: 42.5806451613%;
  }
  .feature__section.ext-02 .swiper-slide:nth-child(2) {
    margin-left: 2.688172043%;
  }
}
.feature__section.ext-02 > div p {
  width: 100%;
  max-width: 818px;
  margin: 30px auto 0;
}
@media screen and (max-width: 767px) {
  .feature__section.ext-02 > div p {
    margin-top: 3.7866666667vw;
  }
}
@media screen and (min-width: 768px) {
  .feature__section.ext-03 .swiper-wrapper {
    justify-content: center;
  }
  .feature__section.ext-03 .swiper-slide {
    width: 42.5806451613%;
  }
  .feature__section.ext-03 .swiper-slide:nth-child(2) {
    margin-left: 2.688172043%;
  }
}
.feature__section.ext-03 > div p {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .feature__section.ext-03 > div p {
    margin-top: 3.7866666667vw;
  }
}
@media screen and (max-width: 767px) {
  .feature__section.ext-04 > div {
    padding: 6.88vw 5.3333333333vw 7.7333333333vw;
    overflow: hidden;
  }
}
@media screen and (min-width: 768px) {
  .feature__section.ext-04 > div .swiper {
    width: 88.8956989247%;
  }
  .feature__section.ext-04 > div .swiper-wrapper {
    margin-inline: auto;
  }
  .feature__section.ext-04 > div .swiper-slide {
    padding: 0 8.3333333333% 12px;
  }
  .feature__section.ext-04 > div .swiper-slide img {
    width: 100%;
    height: auto;
  }
  .feature__section.ext-04 > div .swiper-pagination {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    padding: 0 8.1673280423%;
    bottom: 0;
  }
  .feature__section.ext-04 > div .swiper-pagination-bullet {
    flex-grow: 1;
    flex-shrink: 1;
    height: 2px;
    padding: 0;
    margin: 0;
    background-color: #CCCCCC;
    opacity: 1;
    border-radius: 0;
  }
}
@media screen and (min-width: 768px) and (max-width: 767px) {
  .feature__section.ext-04 > div .swiper-pagination-bullet {
    height: 1px;
  }
}
@media screen and (min-width: 768px) {
  .feature__section.ext-04 > div .swiper-pagination-bullet + .swiper-pagination-bullet {
    margin-left: 7px;
    opacity: 1;
  }
  .feature__section.ext-04 > div .swiper-pagination-bullet-active {
    background-color: #54CA84;
  }
  .feature__section.ext-04 > div .swiper-button-next, .feature__section.ext-04 > div .swiper-button-prev {
    width: 6.8783068783%;
    height: 0;
    padding-top: 22.3822751323%;
    background: url("../img/icn-arrow_carousel.svg") no-repeat center center/contain;
    transform: translate(0, -50%);
    margin: auto;
    right: 0;
  }
  .feature__section.ext-04 > div .swiper-button-next:after, .feature__section.ext-04 > div .swiper-button-prev:after {
    display: none;
  }
  .feature__section.ext-04 > div .swiper-button-prev {
    transform: translate(0, -50%) scale(-1, 1);
    left: 0;
    right: auto;
  }
}
.feature__section.ext-04 > div p {
  width: 75.576344086%;
  margin-top: 29.6px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .feature__section.ext-04 > div p {
    width: 100%;
    padding: 0;
    margin-top: 4vw;
  }
}
.feature__section.ext-05 > div {
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .feature__section.ext-05 > div {
    flex-direction: column;
  }
}
.feature__section.ext-05 > div img {
  width: 25.5387096774%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .feature__section.ext-05 > div img {
    width: 49.1733333333vw;
  }
}
.feature__section.ext-05 > div p {
  width: 53.3333333333%;
  margin-left: 3.4731182796%;
}
@media screen and (max-width: 767px) {
  .feature__section.ext-05 > div p {
    width: 100%;
    margin-left: 0;
    margin-top: 4.4vw;
  }
}

.flow {
  margin-top: 130px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .flow {
    margin-top: 22.333333vw;
  }
}
.flow:before {
  pointer-events: none;
  content: "";
  display: block;
  position: absolute;
  width: 100vw;
  height: 896px;
  top: -191px;
  left: 50%;
  transform: translate(-50%, 0);
  background: url("../img/bg-flow.png") no-repeat center top/100% 100%;
}
@media screen and (max-width: 767px) {
  .flow:before {
    height: 275.2vw;
    top: -28vw;
    background: url("../img/bg-flow_sp.svg") no-repeat center top/100% 100%;
  }
}
.flow > .section__inner {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .flow .section__title img {
    width: 30.4vw;
    height: auto;
  }
}
.flow__lead {
  margin-top: 25px;
  font-size: 15px;
  letter-spacing: 0.05em;
  line-height: calc(25 / 15);
  text-align: center;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .flow__lead {
    margin-top: 4.5333333333vw;
    font-size: 3.4666666667vw;
    letter-spacing: 0em;
    line-height: calc(23 / 13);
    text-align: center;
  }
}
.flow__lead strong {
  color: #E97E6D;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 800;
  font-size: 20px;
  letter-spacing: 0.05em;
  line-height: calc(25 / 20);
  margin: 0 2px;
}
.flow__list {
  display: flex;
  justify-content: space-between;
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .flow__list {
    flex-direction: column;
    align-items: flex-start;
    margin-top: 6.6666666667vw;
  }
}
.flow__list > div {
  text-align: center;
  flex-grow: 1;
  flex-shrink: 1;
  width: 25%;
}
@media screen and (max-width: 767px) {
  .flow__list > div {
    width: 100%;
    display: flex;
    align-items: center;
  }
  .flow__list > div + div {
    margin-top: 10.6666666667vw;
  }
}
.flow__list > div > div:first-child {
  position: relative;
  flex-shrink: 0;
  flex-grow: 0;
}
.flow__list > div > div:first-child img {
  max-width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .flow__list > div > div:first-child img {
    width: 25.3333333333vw;
    height: 25.3333333333vw;
  }
}
.flow__list > div > div:first-child:after {
  content: "";
  width: 13px;
  height: 22px;
  background: url("../img/icn-arrow_flow.svg") no-repeat center center/contain;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translate(50%, -50%);
}
@media screen and (max-width: 767px) {
  .flow__list > div > div:first-child:after {
    width: 2.9333333333vw;
    height: 4.5333333333vw;
    background: url("../img/icn-arrow_flow.svg") no-repeat center center/cover;
    right: auto;
    left: 50%;
    top: 100%;
    transform: translate(-50%, -50%) rotate(90deg);
    margin-top: 4.56vw;
  }
}
@media screen and (max-width: 767px) {
  .flow__list > div > div:last-child {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    margin-left: 4.8vw;
  }
}
.flow__list > div h3 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  margin-top: 15px;
  font-size: 20px;
  letter-spacing: 0.05em;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .flow__list > div h3 {
    margin-top: 0;
    font-size: 4vw;
    letter-spacing: 0.05em;
    line-height: 1;
  }
}
.flow__list > div p {
  margin-top: 11px;
  font-size: 15px;
  letter-spacing: 0.05em;
  line-height: calc(25 / 15);
  padding: 0 5px;
}
@media screen and (max-width: 767px) {
  .flow__list > div p {
    margin-top: 1.3333333333vw;
    font-size: 3.4666666667vw;
    letter-spacing: 0.05em;
    line-height: calc(21 / 13);
    padding: 0;
  }
}
.flow__list > div:last-child > div:first-child::after {
  display: none;
}

.flow + .banner {
  margin-top: 289px;
}
@media screen and (max-width: 767px) {
  .flow + .banner {
    margin-top: 60.5333333333vw;
  }
}

.column {
  margin-top: 130px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .column {
    margin-top: 22.4vw;
  }
}
.column .section__title h2 {
  display: flex;
  align-items: center;
  justify-content: center;
}
.column .section__title h2 img {
  width: 265px;
  height: auto;
  margin-right: 10px;
}
@media screen and (max-width: 767px) {
  .column .section__title h2 img {
    width: 36.5333333333vw;
    margin-right: 1.0666666667vw;
  }
}
.column__list {
  margin-top: 45px;
}
@media screen and (max-width: 767px) {
  .column__list {
    margin-top: 10.6666666667vw;
  }
}
.column__section {
  margin-top: 120px;
}
@media screen and (max-width: 767px) {
  .column__section {
    margin-top: 21.3333333333vw;
  }
}
.column__more {
  text-align: center;
  margin-top: 38px;
}
@media screen and (max-width: 767px) {
  .column__more {
    margin-top: 11.5vw;
  }
}

.price {
  position: relative;
  z-index: 2;
  margin-top: 282px;
}
@media screen and (max-width: 767px) {
  .price {
    margin-top: 39.4666666667vw;
  }
}
.price__column {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  max-width: 706px;
  margin: 44px auto 0;
}
@media screen and (max-width: 767px) {
  .price__column {
    margin: 8vw auto 0;
    flex-direction: column;
  }
}
.price__box {
  background: #FFFFFF;
  border-radius: 15px;
  width: 47.5920679887%;
  padding: 14px 0 27px;
}
@media screen and (max-width: 767px) {
  .price__box {
    width: 100%;
    border-radius: 4vw;
    padding: 4.2666666667vw 0 7.2vw;
  }
}
@media screen and (max-width: 767px) {
  .price__box.ext-light {
    margin-top: 2.6666666667vw;
  }
}
.price__box.ext-light h3 img {
  width: 141px;
}
@media screen and (max-width: 767px) {
  .price__box.ext-light h3 img {
    width: 40.8vw;
  }
}
.price__box.ext-light > p em {
  background: #3BC4C0;
}
.price__box.ext-light > p strong {
  color: #3BC4C0;
}
.price__box.ext-light > p span {
  color: #3BC4C0;
}
.price__box > h3 {
  text-align: center;
}
.price__box > h3 img {
  width: 159px;
  height: auto;
}
@media screen and (max-width: 767px) {
  .price__box > h3 img {
    width: 44.2666666667vw;
  }
}
.price__box > p {
  display: grid;
  align-items: center;
  max-width: 233px;
  margin: 30px auto 0;
}
@media screen and (max-width: 767px) {
  .price__box > p {
    max-width: 62.1333333333vw;
    margin: 3.7333333333vw auto 0;
  }
}
.price__box > p + p {
  margin-top: 13.5px;
  padding-top: 12.5px;
  border-top: 1px solid #D0D0D0;
}
@media screen and (max-width: 767px) {
  .price__box > p + p {
    margin-top: 3.6vw;
    padding-top: 3.3333333333vw;
  }
}
.price__box > p em {
  grid-row: 1;
  grid-column: 1;
  background: #54CA84;
  color: #FFFFFF;
  border-radius: 6px;
  width: 55px;
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0em;
  line-height: 1;
  margin-right: 13px;
}
@media screen and (max-width: 767px) {
  .price__box > p em {
    border-radius: 1.3333333333vw;
    width: 14.6666666667vw;
    height: 5.8666666667vw;
    font-size: 2.9333333333vw;
    letter-spacing: 0em;
    line-height: 1;
    margin-right: 3.4666666667vw;
  }
}
.price__box > p strong {
  grid-row: 1;
  grid-column: 2;
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 30px;
  letter-spacing: 0.02em;
  line-height: 1;
  color: #54CA84;
  display: flex;
  align-items: center;
}
.price__box > p strong span {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 20px;
  letter-spacing: 0em;
  line-height: 1;
  margin-left: 3px;
}
@media screen and (max-width: 767px) {
  .price__box > p strong {
    font-size: 8vw;
    letter-spacing: 0.02em;
    line-height: 1;
  }
  .price__box > p strong span {
    font-size: 5.3333333333vw;
    letter-spacing: 0em;
    line-height: 1;
    margin-left: 0.8vw;
  }
}
.price__box > p span {
  grid-row: 2;
  grid-column: 2;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.02em;
  line-height: 1;
  color: #54CA84;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.price__box > p span span {
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.02em;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .price__box > p span {
    font-size: 2.9333333333vw;
    letter-spacing: 0.02em;
    line-height: 1;
  }
  .price__box > p span span {
    font-size: 3.4666666667vw;
    letter-spacing: 0.02em;
    line-height: 1;
  }
}

.function {
  margin-top: 133px;
}
@media screen and (max-width: 767px) {
  .function {
    margin-top: 21.3333333333vw;
  }
}
.function + .banner {
  margin-top: 39px;
}
@media screen and (max-width: 767px) {
  .function + .banner {
    margin-top: 2.6666666667vw;
  }
}
.function__viewport {
  position: relative;
}
@media screen and (max-width: 767px) {
  .function__viewport {
    width: calc(100% + 9.0666666667vw);
    overflow-x: auto;
    margin-right: -4.5333333333vw;
    margin-left: -4.5333333333vw;
  }
  .function__viewport::-webkit-scrollbar {
    display: none;
    scrollbar-width: none;
  }
  .function__viewport .simplebar-wrapper {
    padding-bottom: 2.9333333333vw;
  }
  .function__viewport .simplebar-track {
    width: 39.2vw;
    right: 4.5333333333vw;
    background: #CCCCCC;
  }
  .function__viewport .simplebar-track.simplebar-horizontal {
    height: 1px;
    left: auto;
  }
  .function__viewport .simplebar-scrollbar {
    background: #54CA84;
  }
}
.function__table {
  margin-top: 72px;
  border-radius: 0 0 0 15px;
}
@media screen and (min-width: 768px) {
  .function__table {
    overflow: hidden;
    position: relative;
  }
}
@media screen and (max-width: 767px) {
  .function__table {
    width: 117.0666666667vw;
    margin-top: 7.2vw;
    margin-left: 4.5333333333vw;
    margin-right: 4.5333333333vw;
    border-radius: 0 0 0 4vw;
  }
}
.function__table sup {
  vertical-align: super;
  font-size: 8px;
  letter-spacing: 0.05em;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .function__table sup {
    font-size: 2.1333333333vw;
    letter-spacing: 0.05em;
    line-height: 1;
  }
}
.function__table th,
.function__table td {
  padding: 7px 10px;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.05em;
  line-height: 1;
  position: relative;
  box-sizing: border-box;
}
@media screen and (max-width: 767px) {
  .function__table th,
  .function__table td {
    padding: 1.3333333333vw 2.6666666667vw;
    font-size: 3.2vw;
    letter-spacing: 0.05em;
    line-height: calc(16 / 12);
  }
}
.function__table th {
  text-align: left;
  white-space: nowrap;
  background: #F1FAF9;
  color: #54CA84;
}
.function__table th.ext-child {
  color: #000000;
}
.function__table th.ext-child span {
  display: block;
  white-space: wrap;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 300;
  font-size: 10px;
  letter-spacing: 0em;
  line-height: calc(12 / 10);
  margin-top: 4px;
}
@media screen and (max-width: 767px) {
  .function__table th.ext-child span {
    font-size: 2.4vw;
    letter-spacing: 0em;
    line-height: calc(12 / 9);
    margin-top: 0vw;
  }
}
.function__table thead th {
  background: #FFFFFF;
  border-radius: 15px 15px 0 0;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .function__table thead th {
    border-radius: 4vw vSp(15) 0 0;
  }
}
.function__table thead th:first-child {
  visibility: hidden;
}
@media screen and (max-width: 767px) {
  .function__table thead th:first-child {
    visibility: visible;
    background: #E4F5F4;
    position: sticky;
    left: 4.5333333333vw;
    border-radius: 0;
    z-index: 3;
  }
}
.function__table thead th:nth-child(2):after {
  content: "";
  width: 15px;
  height: 15px;
  background: url("../img/img-function_round.svg") no-repeat left top/cover;
  display: block;
  position: absolute;
  right: 0;
  top: 0;
  transform: scale(-1, 1);
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .function__table thead th:nth-child(2):after {
    width: 4vw;
    height: 4vw;
  }
}
.function__table thead th:last-child {
  border-left: 15px solid #E4F5F4;
}
@media screen and (max-width: 767px) {
  .function__table thead th:last-child {
    border-left: 2.6666666667vw solid #E4F5F4;
    border-right: 2.6666666667vw solid #E4F5F4;
  }
}
@media screen and (max-width: 767px) {
  .function__table thead th:last-child:before {
    content: "";
    width: 15px;
    height: 15px;
    background: url("../img/img-function_round.svg") no-repeat left top/cover;
    display: block;
    position: absolute;
    transform: rotate(90deg);
    right: 0;
    top: 0;
    width: 4vw;
    height: 4vw;
    z-index: 1;
  }
}
.function__table thead th:last-child:after {
  content: "";
  width: 15px;
  height: 15px;
  background: url("../img/img-function_round.svg") no-repeat left top/cover;
  display: block;
  position: absolute;
  left: 0;
  top: 0;
}
@media screen and (max-width: 767px) {
  .function__table thead th:last-child:after {
    width: 4vw;
    height: 4vw;
  }
}
.function__table thead th img {
  max-width: 138px;
  height: auto;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .function__table thead th img {
    max-width: 25.6vw;
  }
}
.function__table thead th.ext-light img {
  max-width: 120px;
}
@media screen and (max-width: 767px) {
  .function__table thead th.ext-light img {
    max-width: 22.4vw;
  }
}
.function__table tbody tr:first-child th:first-child {
  border-radius: 15px 0 0 0;
}
@media screen and (max-width: 767px) {
  .function__table tbody tr:first-child th:first-child {
    border-radius: 4vw 0 0 0;
  }
}
.function__table tbody tr:first-child th, .function__table tbody tr:first-child td {
  padding-top: 10px;
}
@media screen and (max-width: 767px) {
  .function__table tbody tr:first-child th, .function__table tbody tr:first-child td {
    padding-top: 2.6666666667vw;
  }
}
.function__table tbody tr:first-child th::before, .function__table tbody tr:first-child td::before {
  display: none;
}
.function__table tbody tr:last-child th, .function__table tbody tr:last-child td {
  padding-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .function__table tbody tr:last-child th, .function__table tbody tr:last-child td {
    padding-bottom: 2.6666666667vw;
  }
}
.function__table tbody th::before, .function__table tbody td::before {
  content: "";
  display: block;
  position: absolute;
  height: 1px;
  width: calc(100% - 30px);
  top: 0;
  background: #ededed;
}
@media screen and (max-width: 767px) {
  .function__table tbody th::before, .function__table tbody td::before {
    width: calc(100% - 5.3333333333vw);
  }
}
@media screen and (max-width: 767px) {
  .function__table tbody th, .function__table tbody td {
    z-index: 1;
  }
}
@media screen and (max-width: 767px) {
  .function__table tbody th[colspan], .function__table tbody th[rowspan], .function__table tbody th.ext-child, .function__table tbody td[colspan], .function__table tbody td[rowspan], .function__table tbody td.ext-child {
    position: sticky;
    left: 4.5333333333vw;
    z-index: 2;
  }
}
@media screen and (max-width: 767px) {
  .function__table tbody th.ext-child, .function__table tbody td.ext-child {
    left: 15.2vw;
    z-index: 2;
  }
}
@media screen and (max-width: 767px) {
  .function__table tbody th.ext-sp_round, .function__table tbody td.ext-sp_round {
    background: #F1FAF9 url("../img/bg-function_table.svg") no-repeat left bottom/4vw 4vw;
  }
}
@media screen and (max-width: 767px) {
  .function__table tbody th:last-child, .function__table tbody td:last-child {
    border-right: 2.6666666667vw solid #E4F5F4;
  }
}
.function__table tbody th[colspan] {
  width: 45.8724202627%;
}
@media screen and (max-width: 767px) {
  .function__table tbody th[colspan] {
    width: 44.8vw;
  }
}
.function__table tbody th[rowspan] {
  padding-right: 38px;
}
@media screen and (max-width: 767px) {
  .function__table tbody th[rowspan] {
    padding-right: 4.5333333333vw;
    width: 7.7333333333vw;
  }
  .function__table tbody th[rowspan]:after {
    content: "";
    display: block;
    width: 3.2vw;
    height: 0;
  }
}
.function__table tbody th:first-child {
  padding-left: 15px;
}
@media screen and (max-width: 767px) {
  .function__table tbody th:first-child {
    padding-left: 2.6666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .function__table tbody th:not(.ext-child) span {
    display: block;
    text-orientation: upright;
    writing-mode: vertical-lr;
    position: absolute;
    top: 2.1333333333vw;
  }
}
.function__table tbody th.ext-child {
  padding-left: 0;
  width: 36.4915572233%;
}
@media screen and (max-width: 767px) {
  .function__table tbody th.ext-child {
    width: 40vw;
    padding-right: 0;
  }
}
.function__table tbody th.ext-child::before {
  width: calc(100% - 15px);
}
@media screen and (max-width: 767px) {
  .function__table tbody th.ext-child::before {
    width: calc(100% - 2.6666666667vw);
    left: 0;
  }
}
.function__table tbody th + .ext-child::before {
  width: 100%;
  left: -15px;
}
@media screen and (max-width: 767px) {
  .function__table tbody th + .ext-child::before {
    width: calc(100% + 1.8666666667vw);
    left: -4.5333333333vw;
  }
}
.function__table tbody td {
  text-align: center;
  background: #FFFFFF;
  width: 24.9530956848%;
  box-sizing: border-box;
  vertical-align: middle;
}
.function__table tbody td + td {
  border-left: 15px solid #F1FAF9;
}
@media screen and (max-width: 767px) {
  .function__table tbody td {
    width: 32vw;
  }
  .function__table tbody td + td {
    border-left: 2.6666666667vw solid #F1FAF9;
  }
}
@media screen and (max-width: 767px) {
  .function__table tbody td img {
    width: 2.6666666667vw;
    height: 2.6666666667vw;
  }
}
.function__note {
  margin-top: 10px;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 300;
  font-size: 10px;
  letter-spacing: 0.03em;
  line-height: calc(15 / 10);
}
@media screen and (max-width: 767px) {
  .function__note {
    margin-top: 4vw;
    font-size: 2.6666666667vw;
    letter-spacing: 0.03em;
    line-height: calc(15 / 10);
  }
}
.function__option {
  margin: 95px auto 0;
  max-width: 706px;
}
@media screen and (max-width: 767px) {
  .function__option {
    margin: 13.3333333333vw auto 0;
  }
}
.function__option h3 {
  text-align: center;
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0em;
  line-height: 1;
  color: #54CA84;
}
@media screen and (max-width: 767px) {
  .function__option h3 {
    font-size: 4.8vw;
    letter-spacing: 0em;
    line-height: 1;
  }
}
.function__option table {
  margin-top: 28.2px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .function__option table {
    margin-top: 6.4vw;
  }
}
.function__option table th, .function__option table td {
  position: relative;
  text-align: left;
  padding: 30px 0;
}
@media screen and (max-width: 767px) {
  .function__option table th, .function__option table td {
    padding: 8vw 0;
  }
}
.function__option table th::before, .function__option table td::before {
  content: "";
  display: block;
  position: absolute;
  height: 1px;
  width: 100%;
  top: 0;
  background: #ddd;
}
.function__option table th {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 900;
  font-size: 15px;
  letter-spacing: 0.05em;
  line-height: calc(21 / 15);
  color: #54CA84;
}
.function__option table th span {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  color: #000000;
  display: block;
  margin-top: 6px;
  font-size: 13px;
  letter-spacing: 0em;
  line-height: calc(19 / 13);
}
@media screen and (max-width: 767px) {
  .function__option table th {
    font-size: 4vw;
    letter-spacing: 0.05em;
    line-height: calc(21 / 15);
  }
  .function__option table th span {
    margin-top: 1.6vw;
    font-size: 3.4666666667vw;
    letter-spacing: 0em;
    line-height: calc(21 / 13);
  }
}
.function__option table td {
  color: #54CA84;
  border-left: 20.5px solid transparent;
  white-space: nowrap;
  vertical-align: middle;
}
@media screen and (max-width: 767px) {
  .function__option table td {
    border-left: 2.7466666667vw solid transparent;
  }
}
.function__option table td > strong {
  display: block;
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 20px;
  letter-spacing: 0.05em;
  line-height: calc(24 / 20);
}
.function__option table td > strong span {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0em;
  line-height: calc(24 / 16);
  margin-left: 1px;
}
@media screen and (max-width: 767px) {
  .function__option table td > strong {
    font-size: 5.3333333333vw;
    letter-spacing: 0.05em;
    line-height: calc(24 / 20);
  }
  .function__option table td > strong span {
    font-size: 4.2666666667vw;
    letter-spacing: 0em;
    line-height: calc(24 / 16);
    margin-left: 0.2666666667vw;
  }
}
.function__option table td > span {
  display: block;
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.02em;
  line-height: calc(15 / 13);
  margin-top: 3px;
}
.function__option table td > span span {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.02em;
  line-height: calc(15 / 11);
  margin-right: 3px;
}
@media screen and (max-width: 767px) {
  .function__option table td > span {
    font-size: 3.4666666667vw;
    letter-spacing: 0.02em;
    line-height: calc(15 / 13);
    margin-top: 0.8vw;
  }
  .function__option table td > span span {
    font-size: 2.9333333333vw;
    letter-spacing: 0.02em;
    line-height: calc(15 / 11);
    margin-right: 0.8vw;
  }
}
.function__option table tr:last-child th, .function__option table tr:last-child td {
  position: relative;
  text-align: left;
  padding: 30px 0;
}
@media screen and (max-width: 767px) {
  .function__option table tr:last-child th, .function__option table tr:last-child td {
    padding: 8vw 0;
  }
}
.function__option table tr:last-child th::after, .function__option table tr:last-child td::after {
  content: "";
  display: block;
  position: absolute;
  height: 1px;
  width: 100%;
  bottom: 0;
  background: #ddd;
}
.function__option p {
  margin-top: 78px;
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  font-size: 15px;
  letter-spacing: 0.05em;
  line-height: calc(25 / 15);
}
@media screen and (max-width: 767px) {
  .function__option p {
    margin-top: 13.44vw;
    font-size: 3.4666666667vw;
    letter-spacing: 0.05em;
    line-height: calc(20 / 13);
  }
}

.news {
  margin-top: 130px;
}
.news__list {
  max-width: 706px;
  display: flex;
  flex-direction: column;
  margin: 30px auto 0;
}
@media screen and (max-width: 767px) {
  .news__list {
    gap: 4.2666666667vw;
    margin-top: 10.6666666667vw;
  }
}
.news__more {
  margin-top: 40px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .news__more {
    margin-top: 8.5333333333vw;
  }
}

.recommend {
  margin-top: 130px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .recommend {
    margin-top: 19.2vw;
  }
}
.recommend:before {
  pointer-events: none;
  content: "";
  display: block;
  position: absolute;
  width: 100vw;
  height: 961px;
  top: -340px;
  left: 50%;
  transform: translate(-50%, 0);
  background: url("../img/bg-recommend.png") no-repeat center top/100% 100%;
}
@media screen and (max-width: 767px) {
  .recommend:before {
    height: 284vw;
    top: -134.9333333333vw;
    background: url("../img/bg-recommend_sp.svg") no-repeat center top/100% 100%;
  }
}
.recommend__box {
  width: 100%;
  background: #FFFFFF;
  position: relative;
  padding: 60px 64px 60px 70px;
  display: grid;
  grid-template-columns: 22.7687366167% 72.982869379%;
  grid-gap: 0px 4.1006423983%;
}
@media screen and (max-width: 767px) {
  .recommend__box {
    padding: 8.5333333333vw 4.2666666667vw 5.6vw;
    grid-gap: 0px 3.4666666667vw;
    grid-template-columns: 27.7333333333vw 48.8vw;
  }
}
.recommend__box h2 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 800;
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: 1;
  height: 37px;
  background: #54CA84;
  color: #FFFFFF;
  border-radius: 100vmax;
  padding: 0 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: -20px;
  left: -30px;
}
@media screen and (max-width: 767px) {
  .recommend__box h2 {
    font-size: 3.2vw;
    letter-spacing: 0.05em;
    line-height: 1;
    height: 8.2666666667vw;
    top: -4.2666666667vw;
    left: -1.8666666667vw;
    padding: 0 3.4666666667vw;
  }
}
.recommend__image {
  grid-row: 1/span 3;
  grid-column: 1;
}
.recommend__image img {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .recommend__image {
    grid-row: 1/span 2;
    grid-column: 1;
  }
}
.recommend__company {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  font-size: 15px;
  letter-spacing: 0.05em;
  line-height: 1;
  grid-row: 1;
  grid-column: 2;
}
@media screen and (max-width: 767px) {
  .recommend__company {
    box-sizing: border-box;
    grid-row: 1;
    grid-column: 2;
    font-size: 3.2vw;
    letter-spacing: 0em;
    line-height: calc(19 / 12);
    height: 16.2666666667vw;
    display: flex;
    align-items: end;
    padding-bottom: 1.6vw;
  }
}
.recommend__name {
  margin-top: 17px;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  font-size: 19px;
  letter-spacing: 0.05em;
  line-height: 1;
  grid-row: 2;
  grid-column: 2;
}
@media screen and (max-width: 767px) {
  .recommend__name {
    box-sizing: border-box;
    grid-row: 2;
    grid-column: 2;
    margin-top: 0;
    font-size: 4.5333333333vw;
    letter-spacing: 0.05em;
    line-height: 1;
    height: 16.2666666667vw;
    padding-top: 1.6vw;
  }
}
.recommend__name span {
  display: flex;
  align-items: end;
}
@media screen and (max-width: 767px) {
  .recommend__name span {
    display: flex;
    align-items: end;
  }
}
.recommend__name strong {
  margin-right: 4px;
  font-size: 27px;
  letter-spacing: 0.05em;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .recommend__name strong {
    margin-right: 0.8vw;
    font-size: 5.3333333333vw;
    letter-spacing: 0.05em;
    line-height: 1;
  }
}
.recommend__name img {
  margin-left: 8px;
  margin-bottom: -2px;
}
@media screen and (max-width: 767px) {
  .recommend__name img {
    margin-left: 1.6vw;
    margin-bottom: -0.5333333333vw;
    width: 12.2666666667vw;
    height: auto;
  }
}
.recommend__comment {
  grid-row: 3;
  grid-column: 2;
  margin-top: 25px;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 300;
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: calc(26 / 16);
}
@media screen and (max-width: 767px) {
  .recommend__comment {
    margin-top: 4vw;
    grid-row: 3;
    grid-column: 1/span 2;
    font-size: 3.4666666667vw;
    letter-spacing: 0em;
    line-height: calc(21 / 13);
  }
}

.aboutisee {
  margin-top: 183px;
}
@media screen and (max-width: 1186px) {
  .aboutisee {
    padding-left: 2.6981450253vw;
    padding-right: 2.6981450253vw;
  }
}
@media screen and (max-width: 767px) {
  .aboutisee {
    margin-top: 26.6666666667vw;
  }
}
.aboutisee .section__inner {
  display: flex;
  flex-direction: column;
  max-width: 1106px;
}
.aboutisee__lead {
  background: #F0FFFD;
  border-radius: min(50px, 4.215851602vw);
  padding: min(45px, 3.7942664418vw) min(56.8px, 4.7892074199vw) min(184.5px, 15.5564924115vw) min(58.5px, 4.9325463744vw);
  width: min(566.29px, 47.7478920742vw);
  box-sizing: border-box;
  position: relative;
}
@media screen and (max-width: 767px) {
  .aboutisee__lead {
    border-radius: 0 13.3333333333vw 13.3333333333vw 0;
    padding: 4.8vw 9.44vw 26.4266666667vw 4.5333333333vw;
    width: 95.2vw;
    margin-left: -4.5333333333vw;
  }
}
.aboutisee__lead > h3 {
  display: flex;
  align-items: center;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 600;
  font-size: min(26px, 2.1922428331vw);
  line-height: min(46px, 3.8785834739vw);
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .aboutisee__lead > h3 {
    font-size: 4.5333333333vw;
    letter-spacing: 0em;
    line-height: calc(31 / 17);
  }
}
.aboutisee__lead > h3 span {
  display: flex;
  align-items: center;
}
.aboutisee__lead > h3 span:first-child img {
  width: min(131px, 11.0455311973vw);
  height: auto;
  margin: 0 min(9px, 0.7588532884vw) 0 min(6px, 0.5059021922vw);
}
@media screen and (max-width: 767px) {
  .aboutisee__lead > h3 span:first-child img {
    width: 25.8106666667vw;
    margin: 0 2.0266666667vw 0 0.9333333333vw;
  }
}
.aboutisee__lead > h3 span:last-child img {
  width: min(142px, 11.9730185497vw);
  height: auto;
  margin: 0 0 0 min(4px, 0.3372681282vw);
}
@media screen and (max-width: 767px) {
  .aboutisee__lead > h3 span:last-child img {
    width: 28.1893333333vw;
    margin: 0 0 0 0.9333333333vw;
  }
}
.aboutisee__lead > p {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 900;
  font-size: min(31px, 2.6138279933vw);
  letter-spacing: 0.02em;
  line-height: min(44px, 3.7099494098vw);
  margin-top: min(16px, 1.3490725126vw);
}
@media screen and (max-width: 767px) {
  .aboutisee__lead > p {
    margin-top: 3.3866666667vw;
    font-size: 5.3333333333vw;
    letter-spacing: 0.02em;
    line-height: calc(28 / 20);
  }
}
.aboutisee__lead > p span {
  display: flex;
  flex-direction: column;
  position: relative;
  white-space: nowrap;
}
.aboutisee__lead > p span::after {
  content: "";
  width: 100%;
  height: min(6.52px, 0.5497470489vw);
  background: url("../img/img-aboutisee_lead_03.svg") no-repeat left top/100% 100%;
  margin-top: 1px;
}
@media screen and (max-width: 767px) {
  .aboutisee__lead > p span::after {
    height: 1.296vw;
  }
}
.aboutisee__lead > p span + span {
  margin-top: 8.7px;
}
.aboutisee__lead > p span + span::after {
  background-image: url("../img/img-aboutisee_lead_04.svg");
}
.aboutisee__lead > img {
  position: absolute;
  max-width: min(452px, 38.1112984823vw);
  width: 100%;
  height: auto;
  left: -3.5px;
  top: min(198.1px, 16.7032040472vw);
}
@media screen and (max-width: 767px) {
  .aboutisee__lead > img {
    max-width: 64.056vw;
    left: -3.8933333333vw;
    top: 35.2vw;
  }
}
.aboutisee__box {
  background: #FFFFFF;
  border-radius: min(50px, 4.215851602vw);
  padding: min(45px, 3.7942664418vw) min(45px, 3.7942664418vw) min(34.6px, 2.9173693086vw) min(45px, 3.7942664418vw);
  width: min(589px, 49.6627318718vw);
  box-sizing: border-box;
  position: relative;
  align-self: flex-end;
  margin-top: max(-304px, -25.6323777403vw);
}
@media screen and (min-width: 768px) {
  .aboutisee__box {
    transition-delay: 0.2s !important;
  }
}
@media screen and (max-width: 767px) {
  .aboutisee__box {
    width: 95.2vw;
    margin-top: 15.4933333333vw;
    margin-right: -4.5333333333vw;
    padding: 8vw 4.5333333333vw 6.5066666667vw 8.96vw;
    border-radius: 13.3333333333vw 0 0 13.3333333333vw;
  }
}
.aboutisee__box p {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 600;
  font-size: min(17px, 1.4333895447vw);
  line-height: min(28px, 2.3608768971vw);
}
@media screen and (max-width: 767px) {
  .aboutisee__box p {
    font-size: 3.4666666667vw;
    letter-spacing: 0em;
    line-height: calc(23 / 13);
  }
}
.aboutisee__box img {
  margin-top: min(15.3px, 1.2900505902vw);
  width: min(241.71px, 20.3802698145vw);
  height: auto;
}
@media screen and (max-width: 767px) {
  .aboutisee__box img {
    margin-top: 5.432vw;
    width: 52.768vw;
  }
}

.company {
  margin-top: 268px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .company {
    margin-top: 32.3733333333vw;
  }
}
.company:before {
  pointer-events: none;
  content: "";
  display: block;
  position: absolute;
  width: 100vw;
  height: 1911px;
  top: -195px;
  left: 50%;
  transform: translate(-50%, 0);
  background: url("../img/bg-company.png") no-repeat center top/100% 100%;
}
@media screen and (max-width: 767px) {
  .company:before {
    height: 581.5573333333vw;
    top: -26.5333333333vw;
    background: url("../img/bg-company_sp.svg") no-repeat center top/100% 100%;
  }
}
.company .section__title {
  position: relative;
}
.company .section__title > h2 {
  font-size: 38px;
  letter-spacing: 0.05em;
  line-height: calc(50 / 38);
}
@media screen and (max-width: 767px) {
  .company .section__title > h2 {
    font-size: 5.8666666667vw;
    letter-spacing: 0.05em;
    line-height: calc(28 / 22);
  }
}
.company .section__title > p {
  margin-top: 21px;
}
@media screen and (max-width: 767px) {
  .company .section__title > p {
    margin-top: 4vw;
  }
}
@media screen and (max-width: 767px) {
  .company .section__title img {
    width: 77.4213333333vw;
    height: auto;
  }
}
.company__lead {
  margin-top: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
.company__lead img {
  width: 28.4240150094%;
  height: auto;
}
.company__lead p {
  margin-left: 2.7204502814%;
  font-size: 15px;
  letter-spacing: 0.05em;
  line-height: calc(25 / 15);
}
@media screen and (max-width: 767px) {
  .company__lead {
    flex-direction: column;
    margin-top: 15.4666666667vw;
  }
  .company__lead img {
    width: 62.936vw;
    height: auto;
    align-self: flex-end;
    margin-right: 11.2vw;
  }
  .company__lead p {
    margin-left: 0;
    margin-top: 8.0533333333vw;
    text-align: center;
    font-size: 3.4666666667vw;
    letter-spacing: 0em;
    line-height: calc(23 / 13);
  }
}
.company__list {
  margin-top: 75px;
}
@media screen and (max-width: 767px) {
  .company__list {
    margin-top: 10.6666666667vw;
  }
}
.company__list li {
  position: relative;
  background: rgba(255, 255, 255, 0.5);
  border-radius: 10px;
  display: grid;
  padding: 34px 28px 34px 0;
  grid-template-columns: 216px 146px auto;
}
.company__list li + li {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .company__list li {
    border-radius: 2.6666666667vw;
    padding: 6.6666666667vw 4.2666666667vw 5.3333333333vw;
    grid-template-columns: 34.4vw 41.8666666667vw;
    grid-template-rows: auto auto 1fr auto;
    grid-gap: 0 5.3333333333vw;
  }
  .company__list li + li {
    margin-top: 5.3333333333vw;
  }
  .company__list li:nth-child(2) .company__link {
    font-size: 2.9333333333vw;
    letter-spacing: 0em;
    line-height: 1;
  }
}
.company__logo {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  flex-grow: 0;
  grid-column: 1;
  grid-row: 1/span 3;
}
@media screen and (max-width: 767px) {
  .company__logo {
    grid-column: 2;
    grid-row: 1;
    justify-content: start;
    height: 8.7253333333vw;
  }
}
.company__logo img {
  height: auto;
}
@media screen and (min-width: 768px) {
  .company__logo img {
    margin-top: 65px;
  }
}
.company__logo.ext-helios img {
  width: 38.4259259259%;
}
@media screen and (max-width: 767px) {
  .company__logo.ext-helios img {
    width: 14.3786666667vw;
  }
}
.company__logo.ext-heads img {
  width: 60.6481481481%;
}
@media screen and (max-width: 767px) {
  .company__logo.ext-heads img {
    width: 22.8373333333vw;
  }
}
.company__logo.ext-to img {
  width: 38.4259259259%;
}
@media screen and (max-width: 767px) {
  .company__logo.ext-to img {
    width: 14.3813333333vw;
  }
}
.company__photo {
  grid-column: 2;
  grid-row: 1/span 3;
  display: flex;
  align-items: flex-start;
}
.company__photo img {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .company__photo {
    grid-column: 1;
    grid-row: 1/span 3;
    align-items: flex-start;
  }
}
.company__division {
  grid-column: 3;
  grid-row: 1;
  margin-left: 20px;
  color: #838282;
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.05em;
  line-height: calc(17 / 12);
}
@media screen and (max-width: 767px) {
  .company__division {
    margin-top: 2.7466666667vw;
    grid-row: 2;
    grid-column: 2;
    margin-left: 0;
    font-size: 3.2vw;
    letter-spacing: 0.05em;
    line-height: calc(17 / 12);
  }
}
.company__name {
  grid-column: 3;
  grid-row: 2;
  margin-left: 20px;
  margin-top: 6px;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: calc(20 / 14);
}
@media screen and (max-width: 767px) {
  .company__name {
    margin-top: 1.0666666667vw;
    margin-left: 0;
    grid-column: 2;
    grid-row: 3;
    font-size: 3.7333333333vw;
    letter-spacing: 0.05em;
    line-height: calc(20 / 14);
  }
}
.company__comment {
  grid-column: 3;
  grid-row: 3;
  margin-left: 20px;
  margin-top: 6px;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.015em;
  line-height: calc(23 / 13);
}
@media screen and (max-width: 850px) {
  .company__comment {
    margin-top: 70px;
  }
}
@media screen and (max-width: 767px) {
  .company__comment {
    grid-column: 1/span 2;
    grid-row: 4;
    margin-left: 0;
    margin-top: 6.6666666667vw;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 500;
    font-size: 3.4666666667vw;
    letter-spacing: 0.015em;
    line-height: calc(22 / 13);
  }
}
.company__link {
  position: absolute;
  right: 37px;
  top: 30px;
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.05em;
  line-height: 1;
  height: 26px;
  padding: 0 13px;
  background: #FFFFFF;
  border-radius: 1000vmax;
  display: flex;
  align-items: center;
}
.company__link:hover {
  opacity: 1;
  color: #54CA84;
}
.company__link:hover:after {
  background: url("../img/icn-arrow_link_green.svg") no-repeat center/contain;
}
.company__link:after {
  content: "";
  display: inline-block;
  width: 3px;
  height: 6px;
  background: url("../img/icn-arrow_link.svg") no-repeat center center/contain;
  margin-left: 15.5px;
}
@media screen and (max-width: 850px) {
  .company__link {
    top: 100px;
    right: auto;
    left: 382px;
  }
}
@media screen and (max-width: 767px) {
  .company__link {
    font-size: 2.9333333333vw;
    letter-spacing: 0.05em;
    line-height: 1;
    right: auto;
    left: 44vw;
    top: 43.6533333333vw;
    height: 5.944vw;
    padding: 0 2.6666666667vw;
  }
  .company__link::after {
    width: 0.8vw;
    height: 1.6vw;
    margin-left: 4vw;
  }
}

.terms {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  padding-top: 222px;
}
@media screen and (max-width: 767px) {
  .terms {
    padding-top: 32vw;
  }
}
.terms .section__inner {
  max-width: 800px;
}
@media screen and (max-width: 767px) {
  .terms .section__inner {
    max-width: 100%;
  }
}
.terms .section__inner > h1 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 30px;
  letter-spacing: 0.05em;
  line-height: calc(50 / 30);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .terms .section__inner > h1 {
    font-size: 5.8666666667vw;
    letter-spacing: 0.05em;
    line-height: calc(50 / 22);
  }
}
.terms .section__inner > h1 + * {
  margin-top: 102px;
}
@media screen and (max-width: 767px) {
  .terms .section__inner > h1 + * {
    margin-top: 70px;
  }
}
.terms .section__inner > p {
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: calc(22 / 14);
}
@media screen and (max-width: 767px) {
  .terms .section__inner > p {
    font-size: 3.4666666667vw;
    letter-spacing: 0.05em;
    line-height: calc(18 / 13);
  }
}
.terms .section__inner > p a {
  text-decoration: underline;
}
.terms .section__inner > h2 {
  margin-top: 70px;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0em;
  line-height: calc(30 / 18);
}
@media screen and (max-width: 767px) {
  .terms .section__inner > h2 {
    margin-top: 13.3333333333vw;
    font-size: 4vw;
    letter-spacing: 0em;
    line-height: calc(30 / 15);
  }
}
.terms .section__inner > h2 + * {
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .terms .section__inner > h2 + * {
    margin-top: 5.3333333333vw;
  }
}
.terms .section__inner > ol {
  margin-top: 20px;
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: calc(22 / 14);
}
@media screen and (max-width: 767px) {
  .terms .section__inner > ol {
    margin-top: 5.3333333333vw;
    font-size: 3.4666666667vw;
    letter-spacing: 0.05em;
    line-height: calc(18 / 13);
  }
}
.terms .section__inner > ol li {
  list-style-type: decimal;
  padding-left: 10px;
  margin-left: calc(0.5em + 10px);
}
@media screen and (max-width: 767px) {
  .terms .section__inner > ol li {
    margin-left: calc(0.5em + 2.6666666667vw);
  }
}
.terms .section__inner > ol li + li {
  margin-top: 1em;
}
.terms .section__inner > ol.ext-child {
  margin-top: 10px;
  margin-left: 45px;
}
@media screen and (max-width: 767px) {
  .terms .section__inner > ol.ext-child {
    margin-top: 2.6666666667vw;
    margin-left: 9.3333333333vw;
  }
}
.terms .section__inner > ol.ext-child li {
  margin-top: 0;
  list-style-type: none;
  counter-increment: cnt;
}
.terms .section__inner > ol.ext-child li:before {
  display: inline-block;
  width: 2em;
  margin-left: -2em;
  content: "(" counter(cnt) ") ";
}
.terms .section__inner > div {
  margin-top: 150px;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .terms .section__inner > div {
    margin-top: 26.6666666667vw;
  }
}
.terms .section__inner > div h2 {
  font-size: 18px;
  letter-spacing: 0em;
  line-height: calc(30 / 18);
}
@media screen and (max-width: 767px) {
  .terms .section__inner > div h2 {
    font-size: 4vw;
    letter-spacing: 0.05em;
    line-height: calc(18 / 15);
  }
}
.terms .section__inner > div p {
  margin-top: 24px;
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: calc(22 / 14);
}
@media screen and (max-width: 767px) {
  .terms .section__inner > div p {
    margin-top: 2.6666666667vw;
    font-size: 3.4666666667vw;
    letter-spacing: 0.05em;
    line-height: calc(18 / 13);
  }
}

/* Utility
----------------------------------------------------------------- */
@media screen and (min-width: 768px) {
  .u-sp_only {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .u-pc_only {
    display: none !important;
  }
}
.is-disable {
  opacity: 0.3 !important;
  pointer-events: none !important;
}
.is-disable a {
  pointer-events: none !important;
}

.u-breakctrl {
  display: inline-block;
}

.js-lazy {
  opacity: 1;
  transition: opacity 0.4s;
}
.js-lazy[src^="/asset/img/dummy"] {
  opacity: 0;
}

.js-hoverimg {
  display: block;
}
.js-hoverimg img:not(.js-inview), .js-hoverimg img.js-inview.is-animated {
  transition: clip-path 0.6s cubic-bezier(0.75, 0.01, 0.31, 1), opacity 0.6s, transform 0.8s, filter 0.8s;
}
.js-hoverimg img.js-invew.ext-image {
  transition: clip-path 0.6s cubic-bezier(0.75, 0.01, 0.31, 1), opacity 0.6s, transform 0.8s, filter 0.8s;
}
.is-pc .js-hoverimg:hover {
  opacity: 1 !important;
}
.is-pc .js-hoverimg:hover img:not(.js-inview), .is-pc .js-hoverimg:hover img.js-inview.is-animated {
  transform: scale(1.1);
}
.is-pc .js-hoverimg.is-active img {
  transform: scale(1.2);
  filter: blur(10px);
  opacity: 0;
}

.js-inview.ext-float {
  opacity: 0;
  transform: translateY(40px) translateZ(0);
  transition: transform 1s cubic-bezier(0.33, 1, 0.68, 1), opacity 1.2s cubic-bezier(0.33, 1, 0.68, 1);
}
.js-inview.ext-float.is-animated {
  opacity: 1;
  transform: none;
}
.js-inview.ext-bounce {
  opacity: 0;
  transform: translateY(40px) translateZ(0);
  transition: transform 0.4s cubic-bezier(0.12, 0.74, 0.61, 1.5) 0.1s, opacity 0.2s linear 0s;
}
.js-inview.ext-bounce.is-animated {
  opacity: 1;
  transform: none;
}

/* Animations */
@keyframes scroll {
  0% {
    transform: translate(0, -50%);
  }
  25% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(0, 0);
  }
}
@keyframes rotate {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(359deg);
  }
}
@keyframes grow {
  0% {
    filter: none;
    transform: none;
    transform-origin: center center;
    animation-timing-function: ease-in-out;
  }
  50% {
    opacity: 0.9;
    filter: brightness(1.2);
    transform: scale(1.05);
    transform-origin: center center;
    animation-timing-function: ease-in-out;
  }
  100% {
    filter: none;
    transform: none;
    transform-origin: center center;
  }
}/*# sourceMappingURL=base.css.map */