/******************************************************************************
 * reset
*******************************************************************************/
html, body {
  width: 100%;
  height: auto;
}

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, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 0;
  margin: 0;
  font-size: 100%;
  letter-spacing: 0.06em;
  vertical-align: baseline;
  background-color: transparent;
  border: 0;
}

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

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

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

a {
  text-decoration: none;
  cursor: pointer;
}

input, select {
  vertical-align: middle;
}

/*******************************************************************************
  site_setting
*******************************************************************************/
.row-fluid [class*=span] {
  float: none;
}

body li {
  margin: 0;
}

a:hover {
  color: #202020;
}

html, body {
  width: 100%;
  height: auto;
}

body {
  --color-base:#000;
  overflow-x: hidden;
  font-family: YakuHanJP, "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  line-height: 1.75;
  color: var(--color-base);
  letter-spacing: 0.06em;
  font-size: calc(28 / 750 * 100vw);
}
@media only screen and (min-width: 768px) {
  body {
    font-size: 18px;
    font-size: calc(18 / 16 * 1rem);
  }
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
  line-height: 1.5;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}
@media only screen and (min-width: 768px) {
  img {
    /* stylelint-disable-next-line value-no-vendor-prefix */
    image-rendering: -webkit-optimize-contrast;
  }
}

a {
  text-decoration: none;
}

em {
  font-style: normal;
}

figure {
  line-height: 0;
}

button {
  padding: 0;
  cursor: pointer;
  background-color: transparent;
  border: none;
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

.object-fit-img-cover {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.ff-english {
  font-family: "Montserrat", sans-serif;
}

.l-wrap {
  padding-right: 5.3333333333vw;
  padding-left: 5.3333333333vw;
}
@media only screen and (min-width: 768px) {
  .l-wrap {
    padding-right: 30px;
    padding-left: 30px;
  }
}

.u-width-800 {
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .u-width-800 {
    width: 100%;
    max-width: 800px;
  }
}

.u-width-1000 {
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .u-width-1000 {
    width: 100%;
    max-width: 1000px;
  }
}

.u-width-1100 {
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .u-width-1100 {
    width: 100%;
    max-width: 1100px;
  }
}

.u-width-1200 {
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .u-width-1200 {
    width: 100%;
    max-width: 1200px;
  }
}
.u-width-1320 {
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .u-width-1320 {
    width: 100%;
    max-width: 1320px;
  }
}
/******************************************************************************
  * link-button
  *******************************************************************************/
.a-link-button-wrap {
  width: 64vw !important;
  height: 12vw !important;
   margin-left: 0 !important;
}
.a-link-button-wrap * {
  height:100%;
}
.a-link-button-wrap .a-link-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  font-weight: 700;
  color: #fff;
  background-color: #f39800;
  border-radius: 100px;
  font-size: calc(26 / 750 * 100vw) !important;
}
.a-link-button-wrap .a-link-button img {
  width: 3.7333333333vw;
  height: 3.7333333333vw;
  margin-left: 2.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .a-link-button-wrap {
    width: 450px !important;
    height: 80px !important;
  }
  .a-link-button-wrap .a-link-button {
    height: 80px;
    margin: 0;
    font-size: 22px !important;;
    font-size: calc(22 / 16 * 1rem) !important;;
  }
  .a-link-button-wrap .a-link-button img {
    width: 21px;
    height: 21px;
    margin-left: 15px;
    -webkit-transform: translateY(0.1em);
            transform: translateY(0.1em);
  }
}
@media (any-hover: hover), (-ms-high-contrast: none) {
  .a-link-button-wrap .a-link-button {
    -webkit-transition: background-color 0.3s ease 0s;
    transition: background-color 0.3s ease 0s;
  }
  .a-link-button-wrap .a-link-button:hover {
    background-color: #f36200 !important;
    opacity: 1 !important;
  }
}

/******************************************************************************
  * heading
  *******************************************************************************/
.a-section-heading {
  text-align: center;
}
.a-section-heading > * {
  display: block;
  font-weight: 700;
}

.a-section-heading_shoulder {
  display: inline;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0.2em 0 0.3em;
  margin: 0 auto;
  line-height: 2.3;
  color: #fc0;
  word-break: keep-all;
  background-image: -webkit-gradient(linear, left top, right top, from(#00693e), to(#00693e));
  background-image: -webkit-linear-gradient(left, #00693e, #00693e);
  background-image: linear-gradient(to right, #00693e, #00693e);
  background-repeat: no-repeat;
  background-position: bottom;
  background-size: 100% 100%;
  font-size: calc(26 / 750 * 100vw);
}
.a-section-heading_shoulder .a-section-heading_shoulder-inner {
  display: inline-block;
  padding: 0 0.9em;
}
@media only screen and (min-width: 768px) {
  .a-section-heading_shoulder {
    padding: 0 0.6em 0.2em;
    line-height: 1.5;
    font-size: 26px;
    font-size: calc(26 / 16 * 1rem);
  }
  .a-section-heading_shoulder .a-section-heading_shoulder-inner {
    display: inline;
    padding: 0;
  }
}

.a-section-heading_main {
  margin-top: 1.3333333333vw;
  line-height: 1.5;
  letter-spacing: 0.03em;
  font-size: calc(48 / 750 * 100vw);
}
@media only screen and (min-width: 768px) {
  .a-section-heading_main.is-keep-all {
  word-break: keep-all;
}
  .a-section-heading_main {
    margin-top: 10px;
    font-size: 46px;
    font-size: calc(46 / 16 * 1rem);
  }
}

/******************************************************************************
  * note
  *******************************************************************************/
.a-note {
  color: #999;
  font-size: calc(22 / 750 * 100vw);
}
@media only screen and (min-width: 768px) {
  .a-note {
    font-size: 14px;
    font-size: calc(14 / 16 * 1rem);
  }
}

.m-text-wrap > * + * {
  margin-top: 4vw;
}
@media only screen and (min-width: 768px) {
  .m-text-wrap > * + *{
    margin-top: 20px;
  }
}

/******************************************************************************
  * header
  *******************************************************************************/
.o-header {
  max-width: 1920px;
  margin: 0 auto;
  background-color: #fff;
}

.o-header-inner {
  width: 100%;
  max-width: 1260px;
  padding: 2.4vw 5.3333333333vw;
  margin:0 auto;
}
@media only screen and (min-width: 768px) {
  .o-header-inner {
    padding: 15px 30px;
  }
}

.o-header-logo {
  width: 52vw;
}
@media only screen and (min-width: 768px) {
  .o-header-logo {
    width: 390px;
  }
}

/******************************************************************************
  * footer
  *******************************************************************************/
.footer-copy {
  padding: 6.6666666667vw;
  line-height: 1.4;
  color: #999;
  text-align: center;
  font-size: calc(16 / 750 * 100vw);
}
@media only screen and (min-width: 768px) {
  .footer-copy {
    padding: 25px 0;
    line-height: 1;
    font-size: 14px;
    font-size: calc(14 / 16 * 1rem);
  }
}



/******************************************************************************
* mv
*******************************************************************************/
.above-the-fold {
  position: relative;
  height: 125.3333333333vw;
  padding: 10.6666666667vw 0 0;
  background: url("https://2179333.fs1.hubspotusercontent-na1.net/hubfs/2179333/lp/signalchain-om/mv_bg_sp.jpg") center 0 no-repeat;
  background-size: 100% auto;
}
@media only screen and (min-width: 768px) {
  .above-the-fold {
    max-width: 1920px;
    height: 660px;
    padding: 0 30px;
    padding-top: 130px;
    margin: 0 auto;
    background-image: url("https://2179333.fs1.hubspotusercontent-na1.net/hubfs/2179333/lp/signalchain-om/mv_bg_pc.jpg");
    background-size: auto auto;
  }
}

.above-the-fold_inner {
  position: relative;
  z-index: 1;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .above-the-fold_inner {
    width: 100%;
    max-width: 1200px;
  }
}

.page-heading {
  font-weight: 700;
  line-height: 1.3;
  color: #fff;
  text-align: center;
  letter-spacing: 0;
  font-size: calc(50 / 750 * 100vw);
}
.page-heading > * {
  display: block;
}
@media only screen and (min-width: 768px) {
  .page-heading {
    line-height: 1.4;
    text-align: left;
    font-size: 50px;
    font-size: calc(50 / 16 * 1rem);
  }
}

.page-heading_shoulder {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 1.3333333333vw 4vw;
  margin: 0 auto;
  line-height: 1;
  color: #fc0;
  border: 2px solid currentcolor;
  font-size: calc(26 / 750 * 100vw);
}
@media only screen and (min-width: 768px) {
  .page-heading_shoulder {
    padding: 12px 30px;
    margin: 0;
    border-width: 2px;
    font-size: 24px;
    font-size: calc(24 / 16 * 1rem);
  }
}

.page-heading_main {
  margin-top: 4vw;
  letter-spacing: 0.02em;
}
@media only screen and (min-width: 768px) {
  .page-heading_main {
    margin-top: 20px;
    text-shadow: 2px 2px 5px black;
  }
}

.above-the-fold .a-link-button {
  margin-top: 5.3333333333vw;
}
@media only screen and (min-width: 768px) {
  .above-the-fold .a-link-button {
    margin-top: 40px;
  }
}

.above-the-fold_img {
  position: absolute;
  right: 0;
  bottom: -8vw;
  left: 0;
  z-index: 0;
  width: 77.3333333333vw !important;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .above-the-fold_img {
    bottom: 0;
    width: 786px !important;
    -webkit-transform: translateX(72%);
            transform: translateX(72%);
  }
}

.p-worries-cell {
  width: 100%;
  padding: 5.3333333333vw 0;
  line-height: 1.5;
  text-align: center;
  border: 1px solid #bfc9ce;
  border-radius: 2.6666666667vw;
  -webkit-box-shadow: 0 3px 0 0 rgb(191, 201, 206);
          box-shadow: 0 3px 0 0 rgb(191, 201, 206);
  font-size: calc(28 / 750 * 100vw);
}
.p-worries-cell em {
  font-weight: 700;
  color: #00693e;
  background-image: -webkit-gradient(linear, left top, right top, from(#ffd633), to(#ffd633));
  background-image: -webkit-linear-gradient(left, #ffd633, #ffd633);
  background-image: linear-gradient(to right, #ffd633, #ffd633);
  background-repeat: no-repeat;
  background-position: bottom;
  background-size: 100% 0.45em;
}
@media only screen and (min-width: 768px) {
  .p-worries-cell {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100%;
    height: 100%;
    padding: 40px 10px;
    border-radius: 20px;
    -webkit-box-shadow: 3px 5px 0 0 rgb(191, 201, 206);
            box-shadow: 3px 5px 0 0 rgb(191, 201, 206);
    font-size: 14px;
    font-size: calc(14 / 16 * 1rem);
  }
}
@media only screen and (min-width: 1350px) {
  .p-worries-cell {
    font-size: 18px;
    font-size: calc(18 / 16 * 1rem);
    width: 380px;
  }
}

.p-worries-illustration {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 0;
  width: 47.2vw;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .p-worries-illustration {
    bottom: 0;
    width: 394px;
  }
}

/******************************************************************************
* worries
*******************************************************************************/
.p-worries {
  position: relative;
  z-index: 0;
  overflow: hidden;
}
.p-worries::before {
  position: absolute;
  top: 100%;
  z-index: 1;
  width: 100%;
  height: 100vh;
  content: "";
  background-color: #f6faeb;
  -webkit-transform: translateX(45%) rotate(-8deg);
          transform: translateX(45%) rotate(-8deg);
  -webkit-transform-origin: center left;
          transform-origin: center left;
}
.p-worries::after {
  position: absolute;
  top: 100%;
  z-index: 2;
  width: 100%;
  height: 100vh;
  content: "";
  background-color: #f6faeb;
  -webkit-transform: translateX(-45%) rotate(8deg);
          transform: translateX(-45%) rotate(8deg);
  -webkit-transform-origin: center right;
          transform-origin: center right;
}

.p-worries .l-inner:nth-child(2) {
  position: relative;
}

.p-worries-list {
  display: -ms-grid;
  display: grid;
  row-gap: 2.6666666667vw;
  width: 74.6666666667vw;
  padding-bottom: 42.6666666667vw;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .p-worries-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    row-gap: 35px;
    -webkit-column-gap: 20px;
       -moz-column-gap: 20px;
            column-gap: 20px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100%;
    padding-bottom: 350px;
  }
  .p-worries-list li {
    width: 30%;
    min-width: 270px;
  }
}
@media only screen and (min-width: 1350px) {
  .p-worries-list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 424px 34px 380px 34px 424px;
    grid-template-columns: 424px 380px 424px;
    -webkit-column-gap: 34px;
       -moz-column-gap: 34px;
            column-gap: 34px;
    padding-bottom: 160px;
  }
  .p-worries-list li:nth-child(1), .p-worries-list li:nth-child(5) {
    width: auto;
  }
  .p-worries-list li:nth-child(1) .p-worries-cell, .p-worries-list li:nth-child(5) .p-worries-cell {
    margin-left: auto;
  }
  .p-worries-list li:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    grid-row: 1/2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-column: 1/2;
  }
  .p-worries-list li:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    grid-row: 1/2;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    grid-column: 2/3;
  }
  .p-worries-list li:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    grid-row: 1/2;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
    grid-column: 3/4;
  }
  .p-worries-list li:nth-child(4) {
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
    grid-row: 2/3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    grid-column: 1/2;
  }
  .p-worries-list li:nth-child(5) {
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
    grid-row: 2/3;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
    grid-column: 3/4;
  }
}

/******************************************************************************
* features
*******************************************************************************/
.p-features {
  position: relative;
  z-index: 1;
  overflow: hidden;
  background-color: #f6faeb;
}

.p-features .a-section-heading_main > * {
  display: block;
}
.p-features .a-section-heading_main .logo-text {
  width: 64.1333333333vw;
  height: 5.3333333333vw;
  margin: 3.3333333333vw auto 0;
}
.p-features .a-section-heading_main .logo-text + * {
  margin-top: 1.3333333333vw;
}
@media only screen and (min-width: 768px) {
  .p-features .a-section-heading_main {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .p-features .a-section-heading_main > * {
    padding: 0 10px;
  }
  .p-features .a-section-heading_main .logo-text {
    width: 455px;
    height: 38px;
    padding: 0;
    margin: 4px 0 0;
  }
  .p-features .a-section-heading_main .logo-text + * {
    margin-top: 0;
  }
}

.p-features-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 100%;
  grid-template-columns: 100%;
  row-gap: 13.3333333333vw;
}
@media only screen and (min-width: 768px) {
  .p-features-list {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    row-gap: 90px;
  }
}

.p-features-box {
  position: relative;
  padding: 13.3333333333vw 2.6666666667vw 5.3333333333vw;
  background-color: #fff;
  border-radius: 2.6666666667vw;
  -webkit-box-shadow: 0 0 20px 0 rgba(0, 105, 62, 0.1);
          box-shadow: 0 0 20px 0 rgba(0, 105, 62, 0.1);
}
@media only screen and (min-width: 768px) {
  .p-features-box {
    padding: 90px 30px 60px;
    border-radius: 20px;
  }
}

.p-features-box_inner {
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .p-features-box_inner {
    width: 100%;
    max-width: 1000px;
  }
}

.p-features-box_heading {
  font-weight: 700;
  text-align: center;
  font-size: calc(36 / 750 * 100vw);
}
@media only screen and (min-width: 768px) {
.p-features-box_heading.is-keep-all {
  word-break: keep-all;
}
}
.p-features-box_heading > * {
  display: block;
}
@media only screen and (min-width: 768px) {
  .p-features-box_heading {
    font-size: 32px;
    font-size: calc(32 / 16 * 1rem);
  }
}

.p-features-box_heading-num {
  position: absolute;
  top: -9.6vw;
  right: 0;
  left: 0;
  width: 16vw;
  height: 19.3333333333vw;
  margin: 0 auto;
  line-height: 1;
}
@media only screen and (min-width: 768px) {
  .p-features-box_heading-num {
    top: -60px;
    width: 108px;
    height: 130px;
  }
}

.p-features-box_heading-main {
  font-size: calc(36 / 750 * 100vw);
  letter-spacing: 0;
}
@media only screen and (min-width: 768px) {
  .p-features-box_heading-main.is-keep-all {
  word-break: keep-all;
}
  .p-features-box_heading-main {
    letter-spacing: 0.06em;
    font-size: 32px;
    font-size: calc(32 / 16 * 1rem);
  }
}

.p-features-box_heading + .m-text-wrap {
  padding: 0 4vw;
}
@media only screen and (min-width: 768px) {
  .p-features-box_heading + .m-text-wrap {
    padding: 0;
  }
}

.p-features-zu {
  overflow: hidden;
}
.p-features-zu + .p-features-zu {
  margin-top: 4vw;
}
@media only screen and (min-width: 768px) {
  .p-features-zu + .p-features-zu {
    margin-top: 20px;
  }
}

.p-features-zu_heading {
  padding: 2.6666666667vw 0;
  font-weight: 700;
  color: #fff;
  text-align: center;
  background-color: #00693e;
  font-size: calc(30 / 750 * 100vw);
}
.p-features-zu_heading em {
  color: #fc0;
}
@media only screen and (min-width: 768px) {
  .p-features-zu_heading {
    padding: 10px 0;
    font-size: 26px;
    font-size: calc(26 / 16 * 1rem);
  }
}

.p-features-zu_inner {
  padding: 0 1.3333333333vw 0 3.3333333333vw;
}
@media only screen and (min-width: 768px) {
  .p-features-zu_inner {
    padding: 20px 15px 0;
    border: 1px solid #00693e;
    border-top: none;
  }
}

.p-features-zu_description {
  position: relative;
  padding-left: 4vw;
  margin-top: 4vw;
  font-weight: 700;
}
.p-features-zu_description::after {
  position: absolute;
  top: 50%;
  left: 0;
  width: 1.0666666667vw;
  height: calc(100% - 0.5em);
  content: "";
  background-color: #aace37;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.p-features-zu_description em {
  color: #00693e;
}
@media only screen and (min-width: 768px) {
  .p-features-zu_description {
    padding-left: 20px;
    margin-top: 0;
    margin-left: 20px;
    font-size: 20px;
    font-size: calc(20 / 16 * 1rem);
  }
  .p-features-zu_description::after {
    width: 5px;
  }
}

.p-features-zu_img {
  width: 84vw;
  padding: 0 0 5.3333333333vw;
  margin: 4vw auto 0;
  overflow-x: scroll;
}
.p-features-zu_img img {
  width: 144vw;
  max-width: none;
}
@media only screen and (min-width: 768px) {
  .p-features-zu_img {
    width: 100%;
    max-width:968px;
    padding: 0 0 35px;
    margin-top: 20px;
    overflow-x: hidden;
  }
  .p-features-zu_img img {
    width: 100%;
  }
}

.p-case-maintenance .p-features-zu_heading {
  color: #172222;
  background-color: #fc0;
}
.p-case-maintenance .p-features-zu_heading em {
  color: #00693e;
}
@media only screen and (min-width: 768px) {
  .p-case-maintenance .p-features-zu_inner {
    border-color: #fc0;
  }
}

/******************************************************************************
* maintenance
*******************************************************************************/
/******************************************************************************
* example
*******************************************************************************/
.p-example {
  background-color: #f6faeb;
}

.p-example-list {
  display: -ms-grid;
  display: grid;
  row-gap: 4vw;
}
@media only screen and (min-width: 768px) {
  .p-example-list {
    row-gap: 30px;
  }
}

.p-example-card {
  position: relative;
  background-color: #fff;
  border-radius: 2.6666666667vw;
  -webkit-box-shadow: 0 0 10px 0 rgba(0, 105, 62, 0.1);
          box-shadow: 0 0 10px 0 rgba(0, 105, 62, 0.1);
}
@media only screen and (min-width: 768px) {
  .p-example-card {
    padding-top: 60px;
    border-radius: 20px;
    -webkit-box-shadow: 0 0 20px 0 rgba(0, 105, 62, 0.1);
            box-shadow: 0 0 20px 0 rgba(0, 105, 62, 0.1);
  }
}

.p-example-card_media {
  padding: 6.6666666667vw 6.6666666667vw 5.3333333333vw;
  margin: 0 auto;
}
.p-example-card_media .is-free-br {
  display: none;
}
@media only screen and (min-width: 768px) {
  .p-example-card_media {
    display: -ms-grid;
    display: grid;
    row-gap: 30px;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding: 0 100px 50px;
  }
}
@media only screen and (min-width: 1100px) {
  .p-example-card_media {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    width: 100%;
    max-width: 1200px;
  }
  .p-example-card_media .is-free-br {
    display: block;
  }
}

.p-example-card_heading {
  padding: 0 0.6666666667vw;
}
.p-example-card_heading > * {
  display: block;
  font-weight: 700;
}
@media only screen and (min-width: 768px) {
  .p-example-card_heading {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    margin-right: 30px;
    padding:0;
  }
}

.p-example-card_heading_shoulder {
  position: relative;
  padding-left: 4vw;
  line-height: 1.5;
  color: #00693e;
  font-size: calc(28 / 750 * 100vw);
}
.p-example-card_heading_shoulder::before {
  position: absolute;
  top: 50%;
  left: 0;
  width: 1.0666666667vw;
  height: calc(100% - 0.5em);
  content: "";
  background-color: currentcolor;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media only screen and (min-width: 768px) {
  .p-example-card_heading_shoulder {
    padding-left: 20px;
    letter-spacing: 0;
    font-size: 18px;
    font-size: calc(18 / 16 * 1rem);
  }
  .p-example-card_heading_shoulder::before {
    width: 4px;
  }
}

.p-example-card_heading_main {
  margin-top: 2.6666666667vw;
  line-height: 1.5;
  letter-spacing: 0.03em;
  font-size: calc(36 / 750 * 100vw);
}
@media only screen and (min-width: 768px) {
  .p-example-card_heading_main {
    margin-top: 15px;
    font-size: 32px;
    font-size: calc(32 / 16 * 1rem);
  }
}

.p-example-card_thum {
  margin-top: 4vw;
}
@media only screen and (min-width: 768px) {
  .p-example-card_thum {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
  }
}
@media only screen and (min-width: 1100px) {
  .p-example-card_thum {
    width: 48%;
  }
}

.p-example-card_bottom {
  position: relative;
  padding: 10vw 6.6666666667vw 10vw 6.6666666667vw;
  margin: 0 auto;
  background-color: #eff3f5;
}
@media only screen and (min-width: 768px) {
  .p-example-card_bottom {
    padding: 60px 120px;
  }
}

.p-example-card_bottom-inner {
  display: -ms-grid;
  display: grid;
  row-gap: 13.3333333333vw;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .p-example-card_bottom-inner {
    row-gap: 60px;
  }
}
@media only screen and (min-width: 1100px) {
  .p-example-card_bottom-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    max-width: 1000px;
  }
}

.p-example-card_bottom-list {
  display: -ms-grid;
  display: grid;
  row-gap: 2.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .p-example-card_bottom-list {
    row-gap: 15px;
  }
}

.p-example-card_bottom-before {
  position: relative;
  padding: 5.3333333333vw 4vw 5.3333333333vw 2.6666vw;
  background-color: #fff;
   border-radius:calc(20/750 * 100vw);
  -webkit-box-shadow: 3px 4px 0 0 rgb(191, 201, 206);
          box-shadow: 3px 4px 0 0 rgb(191, 201, 206);
}
.p-example-card_bottom-before .p-example-card_bottom-list-caption {
  background-color: #9aa5aa;
}
@media only screen and (min-width: 768px) {
  .p-example-card_bottom-before {
    border-radius: 20px;
    padding: 35px 25px 25px;
  }
}
@media only screen and (min-width: 1100px) {
  .p-example-card_bottom-before {
    width: 41.67%;
    margin-right: 38px;
  }
}

.p-example-card_bottom-list-caption {
  position: absolute;
  top: 0;
  left: 5.3333333333vw;
  padding: 1.6vw 2.6666666667vw;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  border-radius: 9999px 9999px 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media only screen and (min-width: 768px) {
  .p-example-card_bottom-list-caption {
    left: 30px;
    padding: 12px 20px;
  }
}

.p-example-card_bottom-arrow {
  position: absolute;
  right: 0;
  bottom: -8vw;
  left: 0;
  width: 4.1333333333vw;
  height: 3.8666666667vw;
  margin: 0 auto;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}
@media only screen and (min-width: 768px) {
  .p-example-card_bottom-arrow {
    bottom: -40px;
    width: 18px;
    height: 20px;
  }
}
@media only screen and (min-width: 1100px) {
  .p-example-card_bottom-arrow {
    top: 50%;
    right: -28px;
    bottom: auto;
    left: auto;
    margin: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}

.p-example-card_bottom-after {
  position: relative;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
 padding: 5.3333333333vw 4vw 5.3333333333vw 2.6666vw;
  background-color: #fff;
   border-radius:calc(20/750 * 100vw);
  -webkit-box-shadow: 3px 4px 0 0 rgb(191, 201, 206);
          box-shadow: 3px 4px 0 0 rgb(191, 201, 206);
}
@media only screen and (min-width: 768px) {
  .p-example-card_bottom-after {
    border-radius: 20px;
    padding: 35px 25px 25px;
  }
}
.p-example-card_bottom-after .p-example-card_bottom-list-caption {
  background-color: #fc0;
}

.p-example-card_bottom-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  letter-spacing: 0;
}
.p-example-card_bottom-item::before {
  margin-right: 0.3em;
  content: "・";
}

.p-example-card_bottom-after .p-example-card_bottom-item::before {
  color: #fc0;
}

.p-example-card_bottom-illustration {
  position: absolute;
  right: 2.4vw;
  bottom: 0;
  width: 16vw;
}
@media only screen and (min-width: 768px) {
  .p-example-card_bottom-illustration {
    right: 10px;
    width: 144px;
  }
}

/******************************************************************************
* support
*******************************************************************************/
.p-support-list {
  display: -ms-grid;
  display: grid;
  row-gap: 4vw;
  margin: 0 -2.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .p-support-list {
    row-gap: 30px;
    margin: 0;
  }
}

.p-support-card {
  padding: 8vw 5.3333333333vw;
  overflow: hidden;
  background: url("/assets/img/support_bg_sp.jpg") no-repeat center center/100% auto;
  border-radius: 2.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .p-support-card {
    padding: 60px;
    background: url("/assets/img/support_bg01_pc.jpg") no-repeat center center;
    border-radius: 20px;
  }
}

.p-support-card > .m-text-wrap .a-text {
  letter-spacing: 0.03em;
}

@media only screen and (min-width: 768px) {
  .p-support-list li:nth-child(2) .p-support-card {
    background-image: url("/assets/img/support_bg02_pc.jpg")/cover;
  }
}

.p-support-card_heading > * {
  display: block;
  text-align: center;
}
.p-support-card_heading svg {
  width: 10.9333333333vw;
  height: 4.5333333333vw;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .p-support-card_heading svg {
    width: 82px;
    height: 34px;
  }
}

.p-support-card_heading-main {
  margin-top: 0.6666666667vw;
  font-weight: 700;
  font-size: calc(36 / 750 * 100vw);
}
@media only screen and (min-width: 768px) {
  .p-support-card_heading-main {
    font-size: 32px;
    font-size: calc(32 / 16 * 1rem);
  }
}

.p-support-card_box {
  padding: 4.6666666667vw 2.6666666667vw 2.6666666667vw;
  margin-top: 5.3333333333vw;
  background-color: #fff;
  -webkit-box-shadow: 5px 8.66px 25px 0 rgba(23, 34, 34, 0.2);
          box-shadow: 5px 8.66px 25px 0 rgba(23, 34, 34, 0.2);
}
@media only screen and (min-width: 768px) {
  .p-support-card_box {
    padding: 40px 50px;
    margin-top: 25px;
  }
}

.p-support-card_box-flow {
  width: 78.6666666667vw;
  padding-bottom: 2.6666666667vw;
  overflow-x: scroll;
}
.p-support-card_box-flow img {
  width: auto;
  max-width: none;
  height: 100px;
}
@media only screen and (min-width: 768px) {
  .p-support-card_box-flow {
    width: auto;
    padding: 0;
    overflow: visible;
  }
  .p-support-card_box-flow img {
    width: 100%;
    height: auto;
  }
}

.p-support-card_box-flow-description {
  padding: 5.3333333333vw 5.3333333333vw 4vw;
  margin-top: 3.3333333333vw;
  background-color: #f5f5f5;
  border-radius: 2.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .p-support-card_box-flow-description {
    padding: 25px 25px 30px 50px;
    margin-top: 25px;
    border-radius: 20px;
  }
}

.p-support-card_box-flow-dt {
  padding-left: 2.6666666667vw;
  font-weight: 700;
  line-height: 1.6;
  border-left: 1.0666666667vw solid #009596;
}
@media only screen and (min-width: 768px) {
  .p-support-card_box-flow-dt {
    padding-left: 15px;
    border-width: 6px;
    font-size: 20px;
    font-size: calc(20 / 16 * 1rem);
  }
}

.p-support-card_box-flow-dd {
  margin-top: 2.6666666667vw;
  font-size: calc(24 / 750 * 100vw);
}
@media only screen and (min-width: 768px) {
  .p-support-card_box-flow-dd {
    margin-top: 10px;
    font-size: 16px;
    font-size: calc(16 / 16 * 1rem);
  }
}

@media only screen and (min-width: 768px) {
  .p-support-media {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media only screen and (min-width: 768px) {
 .p-support-media .m-text-wrap {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  margin-right: 5%;
}
}

.p-support-media_thum {
  margin-top: 8vw;
}
@media only screen and (min-width: 768px) {
  .p-support-media_thum {
    width: 48.3333333333%;
    margin-top: 0;
  }
}

/******************************************************************************
* download
*******************************************************************************/
.p-download {
  background-color: #f5f5f5;
}
.p-download .a-section-heading {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  text-align: center;
}
@media only screen and (min-width: 1040px) {
  .p-download .a-section-heading {
    text-align: left;
  }
}
.p-download .a-section-heading_shoulder {
   display:block;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  width: calc(258/750 * 100vw);
  margin: 0 auto;
  font-size: 10px;
  background-image: none;
}
.p-download .a-section-heading_main {
  margin-top: 2.6666666667vw;
}
.p-download .a-section-heading_main > * {
  display: block;
}
.p-download .a-section-heading_main .a-section-heading_main-inner {
  padding: 0 10px;
}
.p-download .a-section-heading_main img {
  width: 60.1333333333vw;
  padding-bottom: 1.3333333333vw;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .p-download .a-section-heading_shoulder {
    width: 129px;
    margin: 0;
    font-size: 10px;
  }
  .p-download .a-section-heading_main {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 10px;
  }
  .p-download .a-section-heading_main > * {
    padding: 0 10px;
  }
}
@media only screen and (min-width: 768px) and (min-width: 1040px) {
  .p-download .a-section-heading_main {
    margin-top: 0;
  }
}
@media only screen and (min-width: 768px) {
  .p-download .a-section-heading_main img {
    width: 455px;
    height: 38px;
    padding: 0 10px;
    margin: 4px 0 0;
  }
}

.p-download-thum {
  margin: 0 -5.3333333333vw;
}
@media only screen and (min-width: 768px) {
  .p-download-thum {
    max-width: 1030px;
    margin: 0 auto;
  }
}

.p-download_list {
  width: 89.3333333333vw;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) {
  .p-download_list {
    width: auto;
  }
}

.p-download_list dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-weight: 700;
}
.p-download_list dt::before {
  width: 0;
  height: 0;
  margin-right: 2.6666666667vw;
  content: "";
  border-color: transparent transparent transparent #00693e;
  border-style: solid;
  border-width: 5px 0 5px 8px;
  -webkit-transform: translateY(0.5em);
          transform: translateY(0.5em);
}
.p-download_list dt:nth-of-type(2) {
  margin-top: 2.6666666667vw;
}
@media only screen and (min-width: 768px) {
  .p-download_list dt::before {
    margin-right: 10px;
    -webkit-transform: translateY(0.6em);
            transform: translateY(0.6em);
  }
  .p-download_list dt:nth-of-type(2) {
    margin-top: 20px;
  }
}

.p-download_list dd {
  padding-left: 1.5em;
}
@media only screen and (min-width: 768px) {
  .p-download_list dd {
    padding-left: 1em;
  }
}

/* ---------------------------------------------------------
 * display
--------------------------------------------------------- */
.u-d-grid {
  display: -ms-grid;
  display: grid;
}

.u-d-block {
  display: block;
}

.u-d-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.u-d-none {
  display: none;
}

@media only screen and (min-width: 768px) {
  .u-d-grid-md {
    display: -ms-grid;
    display: grid;
  }
  .u-d-block-md {
    display: block;
  }
  .u-d-flex-md {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .u-d-none-md {
    display: none;
  }
}
/* ---------------------------------------------------------
 * other
--------------------------------------------------------- */
/* float
  -------------------------------------------------- */
/* ---------------------------------------------------------
 * spacing
--------------------------------------------------------- */
/* margin
-------------------------------------------------- */
.u-mgt-0-default:not(:root) {
  margin-top: 0;
}

.u-mgt-5:not(:root) {
  margin-top: calc(10 / 750 * 100vw);
}

.u-mgt-10:not(:root) {
  margin-top: calc(20 / 750 * 100vw);
}

.u-mgt-15:not(:root) {
  margin-top: calc(30 / 750 * 100vw);
}

.u-mgt-20:not(:root) {
  margin-top: calc(40 / 750 * 100vw);
}

.u-mgt-25:not(:root) {
  margin-top: calc(50 / 750 * 100vw);
}

.u-mgt-30:not(:root) {
  margin-top: calc(60 / 750 * 100vw);
}

.u-mgt-35:not(:root) {
  margin-top: calc(70 / 750 * 100vw);
}

.u-mgt-40:not(:root) {
  margin-top: calc(80 / 750 * 100vw);
}

.u-mgt-45:not(:root) {
  margin-top: calc(90 / 750 * 100vw);
}

.u-mgt-50:not(:root) {
  margin-top: calc(100 / 750 * 100vw);
}

.u-mgt-55:not(:root) {
  margin-top: calc(110 / 750 * 100vw);
}

.u-mgt-60:not(:root) {
  margin-top: calc(120 / 750 * 100vw);
}

.u-mgt-65:not(:root) {
  margin-top: calc(130 / 750 * 100vw);
}

.u-mgt-70:not(:root) {
  margin-top: calc(140 / 750 * 100vw);
}

.u-mgt-75:not(:root) {
  margin-top: calc(150 / 750 * 100vw);
}

.u-mgt-80:not(:root) {
  margin-top: calc(160 / 750 * 100vw);
}

.u-margin-lr-0:not(:root) {
  margin-right: 0 !important;
  margin-left: 0 !important;
}

.u-margin-lr-auto:not(:root) {
  margin-right: auto !important;
  margin-left: auto !important;
}

@media only screen and (min-width: 768px) {
  .u-mgt-0-md:not(:root) {
    margin-top: 0;
  }
  .u-mgt-5-md:not(:root) {
    margin-top: 5px;
  }
  .u-mgt-10-md:not(:root) {
    margin-top: 10px;
  }
  .u-mgt-15-md:not(:root) {
    margin-top: 15px;
  }
  .u-mgt-20-md:not(:root) {
    margin-top: 20px;
  }
  .u-mgt-25-md:not(:root) {
    margin-top: 25px;
  }
  .u-mgt-30-md:not(:root) {
    margin-top: 30px;
  }
  .u-mgt-35-md:not(:root) {
    margin-top: 35px;
  }
  .u-mgt-40-md:not(:root) {
    margin-top: 40px;
  }
  .u-mgt-45-md:not(:root) {
    margin-top: 45px;
  }
  .u-mgt-50-md:not(:root) {
    margin-top: 50px;
  }
  .u-mgt-55-md:not(:root) {
    margin-top: 55px;
  }
  .u-mgt-60-md:not(:root) {
    margin-top: 60px;
  }
  .u-mgt-65-md:not(:root) {
    margin-top: 65px;
  }
  .u-mgt-70-md:not(:root) {
    margin-top: 70px;
  }
  .u-mgt-75-md:not(:root) {
    margin-top: 75px;
  }
  .u-mgt-80-md:not(:root) {
    margin-top: 80px;
  }
  .u-mgt-85-md:not(:root) {
    margin-top: 85px;
  }
  .u-mgt-90-md:not(:root) {
    margin-top: 90px;
  }
  .u-mgt-95-md:not(:root) {
    margin-top: 95px;
  }
  .u-mgt-100-md:not(:root) {
    margin-top: 100px;
  }
  .u-mgt-105-md:not(:root) {
    margin-top: 105px;
  }
  .u-mgt-110-md:not(:root) {
    margin-top: 110px;
  }
  .u-mgt-115-md:not(:root) {
    margin-top: 115px;
  }
  .u-mgt-120-md:not(:root) {
    margin-top: 120px;
  }
  .u-mgt-125-md:not(:root) {
    margin-top: 125px;
  }
  .u-mgt-130-md:not(:root) {
    margin-top: 130px;
  }
  .u-mgt-135-md:not(:root) {
    margin-top: 135px;
  }
  .u-mgt-140-md:not(:root) {
    margin-top: 140px;
  }
  .u-mgt-145-md:not(:root) {
    margin-top: 145px;
  }
  .u-mgt-150-md:not(:root) {
    margin-top: 150px;
  }
  .u-mgt-155-md:not(:root) {
    margin-top: 155px;
  }
  .u-mgt-160-md:not(:root) {
    margin-top: 160px;
  }
  .u-margin-lr-0-md:not(:root) {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
  .u-margin-lr-auto-md:not(:root) {
    margin-right: auto !important;
    margin-left: auto !important;
  }
}
/* pading
-------------------------------------------------- */
.u-pdt-0:not(:root) {
  padding-top: 0;
}

.u-pdt-5:not(:root) {
  padding-top: calc(10 / 750 * 100vw);
}

.u-pdt-10:not(:root) {
  padding-top: calc(20 / 750 * 100vw);
}

.u-pdt-15:not(:root) {
  padding-top: calc(30 / 750 * 100vw);
}

.u-pdt-20:not(:root) {
  padding-top: calc(40 / 750 * 100vw);
}

.u-pdt-25:not(:root) {
  padding-top: calc(50 / 750 * 100vw);
}

.u-pdt-30:not(:root) {
  padding-top: calc(60 / 750 * 100vw);
}

.u-pdt-35:not(:root) {
  padding-top: calc(70 / 750 * 100vw);
}

.u-pdt-40:not(:root) {
  padding-top: calc(80 / 750 * 100vw);
}

.u-pdt-45:not(:root) {
  padding-top: calc(90 / 750 * 100vw);
}

.u-pdt-50:not(:root) {
  padding-top: calc(100 / 750 * 100vw);
}

.u-pdt-55:not(:root) {
  padding-top: calc(110 / 750 * 100vw);
}

.u-pdt-60:not(:root) {
  padding-top: calc(120 / 750 * 100vw);
}

.u-pdt-65:not(:root) {
  padding-top: calc(130 / 750 * 100vw);
}

.u-pdt-70:not(:root) {
  padding-top: calc(140 / 750 * 100vw);
}

.u-pdt-75:not(:root) {
  padding-top: calc(150 / 750 * 100vw);
}

.u-pdt-80:not(:root) {
  padding-top: calc(160 / 750 * 100vw);
}

.u-pdb-0:not(:root) {
  padding-bottom: 0;
}

.u-pdb-5:not(:root) {
  padding-bottom: calc(10 / 750 * 100vw);
}

.u-pdb-10:not(:root) {
  padding-bottom: calc(20 / 750 * 100vw);
}

.u-pdb-15:not(:root) {
  padding-bottom: calc(30 / 750 * 100vw);
}

.u-pdb-20:not(:root) {
  padding-bottom: calc(40 / 750 * 100vw);
}

.u-pdb-25:not(:root) {
  padding-bottom: calc(50 / 750 * 100vw);
}

.u-pdb-30:not(:root) {
  padding-bottom: calc(60 / 750 * 100vw);
}

.u-pdb-35:not(:root) {
  padding-bottom: calc(70 / 750 * 100vw);
}

.u-pdb-40:not(:root) {
  padding-bottom: calc(80 / 750 * 100vw);
}

.u-pdb-45:not(:root) {
  padding-bottom: calc(90 / 750 * 100vw);
}

.u-pdb-50:not(:root) {
  padding-bottom: calc(100 / 750 * 100vw);
}

.u-pdb-55:not(:root) {
  padding-bottom: calc(110 / 750 * 100vw);
}

.u-pdb-60:not(:root) {
  padding-bottom: calc(120 / 750 * 100vw);
}

.u-pdb-65:not(:root) {
  padding-bottom: calc(130 / 750 * 100vw);
}

.u-pdb-70:not(:root) {
  padding-bottom: calc(140 / 750 * 100vw);
}

.u-pdb-75:not(:root) {
  padding-bottom: calc(150 / 750 * 100vw);
}

.u-pdb-80:not(:root) {
  padding-bottom: calc(160 / 750 * 100vw);
}

@media only screen and (min-width: 768px) {
  .u-pdt-0:not(:root) {
    padding-top: 0;
  }
  .u-pdt-5-md:not(:root) {
    padding-top: 5px;
  }
  .u-pdt-10-md:not(:root) {
    padding-top: 10px;
  }
  .u-pdt-15-md:not(:root) {
    padding-top: 15px;
  }
  .u-pdt-20-md:not(:root) {
    padding-top: 20px;
  }
  .u-pdt-25-md:not(:root) {
    padding-top: 25px;
  }
  .u-pdt-30-md:not(:root) {
    padding-top: 30px;
  }
  .u-pdt-35-md:not(:root) {
    padding-top: 35px;
  }
  .u-pdt-40-md:not(:root) {
    padding-top: 40px;
  }
  .u-pdt-45-md:not(:root) {
    padding-top: 45px;
  }
  .u-pdt-50-md:not(:root) {
    padding-top: 50px;
  }
  .u-pdt-55-md:not(:root) {
    padding-top: 55px;
  }
  .u-pdt-60-md:not(:root) {
    padding-top: 60px;
  }
  .u-pdt-65-md:not(:root) {
    padding-top: 65px;
  }
  .u-pdt-70-md:not(:root) {
    padding-top: 70px;
  }
  .u-pdt-75-md:not(:root) {
    padding-top: 75px;
  }
  .u-pdt-80-md:not(:root) {
    padding-top: 80px;
  }
  .u-pdt-85-md:not(:root) {
    padding-top: 85px;
  }
  .u-pdt-90-md:not(:root) {
    padding-top: 90px;
  }
  .u-pdt-95-md:not(:root) {
    padding-top: 95px;
  }
  .u-pdt-100-md:not(:root) {
    padding-top: 100px;
  }
  .u-pdt-105-md:not(:root) {
    padding-top: 105px;
  }
  .u-pdt-110-md:not(:root) {
    padding-top: 110px;
  }
  .u-pdt-115-md:not(:root) {
    padding-top: 115px;
  }
  .u-pdt-120-md:not(:root) {
    padding-top: 120px;
  }
  .u-pdt-125-md:not(:root) {
    padding-top: 125px;
  }
  .u-pdt-130-md:not(:root) {
    padding-top: 130px;
  }
  .u-pdt-135-md:not(:root) {
    padding-top: 135px;
  }
  .u-pdt-140-md:not(:root) {
    padding-top: 140px;
  }
  .u-pdt-145-md:not(:root) {
    padding-top: 145px;
  }
  .u-pdt-150-md:not(:root) {
    padding-top: 150px;
  }
  .u-pdt-155-md:not(:root) {
    padding-top: 155px;
  }
  .u-pdt-160-md:not(:root) {
    padding-top: 160px;
  }
  .u-pdb-0:not(:root) {
    padding-bottom: 0;
  }
  .u-pdb-5-md:not(:root) {
    padding-bottom: 5px;
  }
  .u-pdb-10-md:not(:root) {
    padding-bottom: 10px;
  }
  .u-pdb-15-md:not(:root) {
    padding-bottom: 15px;
  }
  .u-pdb-20-md:not(:root) {
    padding-bottom: 20px;
  }
  .u-pdb-25-md:not(:root) {
    padding-bottom: 25px;
  }
  .u-pdb-30-md:not(:root) {
    padding-bottom: 30px;
  }
  .u-pdb-35-md:not(:root) {
    padding-bottom: 35px;
  }
  .u-pdb-40-md:not(:root) {
    padding-bottom: 40px;
  }
  .u-pdb-45-md:not(:root) {
    padding-bottom: 45px;
  }
  .u-pdb-50-md:not(:root) {
    padding-bottom: 50px;
  }
  .u-pdb-55-md:not(:root) {
    padding-bottom: 55px;
  }
  .u-pdb-60-md:not(:root) {
    padding-bottom: 60px;
  }
  .u-pdb-65-md:not(:root) {
    padding-bottom: 65px;
  }
  .u-pdb-70-md:not(:root) {
    padding-bottom: 70px;
  }
  .u-pdb-75-md:not(:root) {
    padding-bottom: 75px;
  }
  .u-pdb-80-md:not(:root) {
    padding-bottom: 80px;
  }
  .u-pdb-85-md:not(:root) {
    padding-bottom: 85px;
  }
  .u-pdb-90-md:not(:root) {
    padding-bottom: 90px;
  }
  .u-pdb-95-md:not(:root) {
    padding-bottom: 95px;
  }
  .u-pdb-100-md:not(:root) {
    padding-bottom: 100px;
  }
  .u-pdb-105-md:not(:root) {
    padding-bottom: 105px;
  }
  .u-pdb-110-md:not(:root) {
    padding-bottom: 110px;
  }
  .u-pdb-115-md:not(:root) {
    padding-bottom: 115px;
  }
  .u-pdb-120-md:not(:root) {
    padding-bottom: 120px;
  }
  .u-pdb-125-md:not(:root) {
    padding-bottom: 125px;
  }
  .u-pdb-130-md:not(:root) {
    padding-bottom: 130px;
  }
  .u-pdb-135-md:not(:root) {
    padding-bottom: 135px;
  }
  .u-pdb-140-md:not(:root) {
    padding-bottom: 140px;
  }
  .u-pdb-145-md:not(:root) {
    padding-bottom: 145px;
  }
  .u-pdb-150-md:not(:root) {
    padding-bottom: 150px;
  }
  .u-pdb-155-md:not(:root) {
    padding-bottom: 155px;
  }
  .u-pdb-160-md:not(:root) {
    padding-bottom: 160px;
  }
}
/* ---------------------------------------------------------
 * column
--------------------------------------------------------- */
.u-col-2 {
  width: calc(100 / 2 * 1%);
}

.u-col-3 {
  width: calc(100 / 3 * 1%);
}

.u-col-4 {
  width: calc(100 / 4 * 1%);
}

.u-col-5 {
  width: calc(100 / 5 * 1%);
}

.u-col-6 {
  width: calc(100 / 6 * 1%);
}

@media only screen and (min-width: 768px) {
  .u-col-2-md {
    width: calc(100 / 2 * 1%);
  }
  .u-col-3-md {
    width: calc(100 / 3 * 1%);
  }
  .u-col-4-md {
    width: calc(100 / 4 * 1%);
  }
  .u-col-5-md {
    width: calc(100 / 5 * 1%);
  }
  .u-col-6-md {
    width: calc(100 / 6 * 1%);
  }
}
/* ---------------------------------------------------------
 * text
--------------------------------------------------------- */
/* text-align
-------------------------------------------------- */
.u-text-left:not(:root) {
  text-align: left;
}

.u-text-center:not(:root) {
  text-align: center;
}

.u-text-right:not(:root) {
  text-align: right;
}

@media only screen and (min-width: 768px) {
  .u-text-left-md:not(:root) {
    text-align: left;
  }
  .u-text-center-md:not(:root) {
    text-align: center;
  }
  .u-text-right-md:not(:root) {
    text-align: right;
  }
}
/******************************************************************************
 * utility
*******************************************************************************/

/* ---------------------------------------------------------
 * form
--------------------------------------------------------- */
.p-download-box{
  background-color:#fff !important;
  max-width:1000px;
  margin:0 auto !important;
  border-radius: 2.6666666667vw;
  padding: 25px 20px;
}
@media only screen and (min-width: 768px) {
  .p-download-box{
    border-radius:20px;
    padding: 60px 80px;
  }
}
.hs-submit .actions{
   margin:calc(30/750 * 100vw) auto 0;
  position:relative;
  width:calc(460/750 * 100vw)
}
.hs-submit .actions:after{
  content:"";
  position:absolute;
  background: url('data:image/svg+xml;charset=utf8,%3Csvg%20id%3D%22a%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2221%22%20height%3D%2221%22%20viewBox%3D%220%200%2021%2021%22%3E%3Cpath%20d%3D%22M10.5%2C0C4.7%2C0%2C0%2C4.7%2C0%2C10.5s4.7%2C10.5%2C10.5%2C10.5%2C10.5-4.7%2C10.5-10.5S16.3%2C0%2C10.5%2C0Zm-2.16%2C16.5l-1.84-1.72%2C4.24-3.78-4.24-3.78%2C1.84-1.72%2C6.16%2C5.5-6.16%2C5.5Z%22%20fill%3D%22%23fff%22%20fill-rule%3D%22evenodd%22%2F%3E%3C%2Fsvg%3E') 0 0 no-repeat;
  background-size:100% 100%;
  top:50%;
  transform:translateY(-50%);
  right:0;
  width:calc(25/750 * 100vw);
    height:calc(25/750 * 100vw);
    right:calc(20/750 * 100vw);
}
@media only screen and (min-width: 768px) {
  .hs-submit .actions{
    margin-top:40px;
    width:450px;
  }
   .hs-submit .actions:after{
    width:21px;
    height:21px;
    right:90px;
  }
}

input[type="submit"]{
  padding:0;
  background-color:transparent;
  border:none;
  display:block;
  background-color:#f39800;
  color:#fff;
  font-weight:700;
  letter-spacing:0.06em;
  display:flex;
  align-items:center;
  justify-content:center;
  height:calc(100/750 * 100vw);
  width:100%;
  font-size:calc(26/750 * 100vw);
   box-shadow: 0px 10px 20px 0px rgba(0, 0, 0, 0.1);
}

@media only screen and (min-width: 768px) {
  input[type="submit"]{
    font-size:20px;
    height:70px;
    -webkit-transition: background-color .3s ease 0s;
    transition: background-color .3s ease 0s;
  }
}

@media (-ms-high-contrast:none), (any-hover: hover){
  input[type="submit"]:hover{
    background-color: #f36000;
  }
}


select {
  -webkit-appearance: none;
  appearance: none; /* デフォルトの矢印を非表示 */
   background-color:#fff;
   color:color: var(--color-base);
}
select::-ms-expand {
  display: none; /* デフォルトの矢印を非表示(IE用) */
}

fieldset{
  max-width:none !important;
  width:100%;
}

.input{
  margin-right:0 !important;
}

.hs-input{
  width:100% !important;
}

.hs-form-checkbox,.hs-form-booleancheckbox{
  line-height:1;
}
  .hs-form-checkbox:not(:first-child),.hs-form-booleancheckbox:not(:first-child){
    margin-top:calc(20/750 * 100vw);
  }
@media only screen and (min-width: 768px) {
  .hs-form-checkbox:not(:first-child),.hs-form-booleancheckbox:not(:first-child){
    margin-top:5px;
  }
}

.hs-form-checkbox input,.hs-form-booleancheckbox-display input{
  margin: 0;
  width: auto !important;
}

.form-columns-2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  column-gap:calc(10/750 * 100vw);
}

.form-columns-2 > * {
  width:auto !important;
}

@media only screen and (min-width: 768px) {
  .form-columns-2{
    column-gap:20px;
  }
}

.hs-error-msg{
  color:#f00;
  font-size:calc(24/750 * 100vw);
  font-weight:700;
}

.hs-error-msgs .hs-main-font-element{
  color:#f00;
  font-weight:700;
}

@media only screen and (min-width: 768px) {
  .hs-error-msg{
    font-size:14px;
  }
}

fieldset:has(.hs_input_confirm ){
  margin-top:0 !important;
}
fieldset + fieldset {
  margin-top:calc(30 / 750 * 100vw) !important;
}
@media only screen and (min-width: 768px) {
  fieldset + fieldset {
    margin-top:20px !important;
  }
}
  fieldset label span:first-child{
    font-size:calc(28/750 * 100vw) !important;
  }

@media only screen and (min-width: 768px) {
  fieldset label span:first-child{
    font-size:16px !important;
  }
}
.hs-field-desc{
  color:#999;
  font-size:calc(24/750 * 100vw);
}
@media only screen and (min-width: 768px) {
  .hs-field-desc{
    font-size:14px;
  }
}

.hs-input{
  border:1px solid #999;
  padding:calc(20/750 * 100vw);
  margin-top:calc(10/750 * 100vw);
  border-radius:calc(3/750 * 100vw);
  font-size:calc(26/750 * 100vw);
}
.hs-input::-webkit-input-placeholder{
  color:#999;
}
.hs-input:-moz-placeholder{
  color:#999;
}
.hs-input::-moz-placeholder{
  color:#999;
}
.hs-input:-ms-input-placeholder{
  color:#999;
}

@media only screen and (min-width: 768px) {
  .hs-input{
    padding:15px 10px;
    border-radius:3px;
    margin-top:5px;
    font-size:16px;
  }
}
.hs-form-checkbox input + span,.hs-form-booleancheckbox-display input + span{
     font-size:calc(26/750 * 100vw);
    padding-left:calc(10/750 * 100vw);
  }
@media only screen and (min-width: 768px) {
  .hs-form-checkbox input + span,.hs-form-booleancheckbox-display input + span{
     font-size:16px;
    padding-left:10px;
  }
}
  .inputs-list{
    margin-top:calc(20/750 * 100vw);
  }
@media only screen and (min-width: 768px) {
  .inputs-list{
    margin-top:10px;
  }
}

@media only screen and (min-width: 768px) {
  .hs-richtext p{
    font-size:16px;
  }
}

.hs-fieldtype-select .input{
  position:relative;
}

.hs-fieldtype-select .input:after{
  content: "";
  position:absolute;
  width: 0;
  height: 0;
  top:50%;
  transform: translateY(calc(-50% + 5/750 * 100vw));
  border-style: solid;
  border-width: calc(12/750 * 100vw) calc(8.5/750 * 100vw) 0 calc(8.5/750 * 100vw);
  border-color: #999999 transparent transparent transparent;
  right:calc(20/750 * 100vw);
}

@media only screen and (min-width: 768px) {
  .hs-fieldtype-select .input:after{
    transform: translateY(calc(-50% + 4px));
  right:12px;
  border-width: 8px 6px 0 6px;
}
}
.hs-fieldtype-textarea {
  margin-top:calc(20/750 * 100vw);
}
@media only screen and (min-width: 768px) {
.hs-fieldtype-textarea {
  margin-top:10px;
}
}

.hs-form-required{
  position:relative;
  color: transparent;
}
.hs-form-required:after{
  background-color: #ff0000;
  color: #fff;
  content: "必須";
  font-size: calc(22/750 * 100vw);
  left: -0.6em;
  padding: 0 0.5em 0.3em;
  position: relative;
  top: -0.14em;
  border-radius:calc(6/750 * 100vw);
}
@media only screen and (min-width: 768px) {
  .hs-form-required{
    padding-left:5px;
  }
  .hs-form-required:after{
    font-size:12px;
    border-radius:3px;
  }
}
/* ---------------------------------------------------------
 * footer
--------------------------------------------------------- */
.footer{
 text-align:center;
  padding: calc(35/750 * 100vw) 0;
}
.footer-text{
  line-height:1;
  color:#999999;
    font-size:calc(16/750 * 100vw);
}
@media only screen and (min-width: 768px) {
  .footer{
 padding: 40px 0;
}
  .footer-text{
    font-size:14px;
  }
}