@charset "UTF-8";
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, hr {
  margin: 0;
  padding: 0;
  border: 0;
  font-style: normal;
  font-weight: 400;
  font-size: 100%;
  text-align: left;
  text-decoration: none;
  vertical-align: baseline
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, main, picture {
  display: block
}
html {
  overflow-y: scroll
}
blockquote, q {
  quotes: none
}
blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none
}
input, button, textarea, select {
  -webkit-appearance: none;
  appearance: none;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  outline: none;
  background: none
}
select::-ms-expand {
  display: none
}
ol, ul {
  list-style: none
}
table {
  border-collapse: collapse;
  border-spacing: 0
}
caption, th {
  text-align: left
}
a:focus {
  outline: none
}
a, span, small, strong, em {
  color: inherit;
  font-weight: inherit
}
html {
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -ms-overflow-style: none;
  font-size: .625em;
  /* scrollbar-width: none; */
}
/* html::-webkit-scrollbar {
  display: none
} */
body {
  background-color: var(--color-bg-cream);
  color: var(--color-text-body);
  font: var(--font-size-body)/var(--line-height-body) var(--font-family-body)
}
input, select, option, textarea, button {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: var(--color-text-body);
  font: var(--font-size-body)/var(--line-height-body) var(--font-family-body)
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
  image-rendering: smooth
}
* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box
}
*:after, *:before {
  -webkit-box-sizing: border-box;
  box-sizing: border-box
}
*[role=button], *[type=button], label {
  cursor: pointer
}
my-icon {
  display: block
}
@-webkit-keyframes scroll-hint-appear {
  0% {
    -webkit-transform: translateX(40px);
    transform: translateX(40px);
    opacity: 0
  }
  10% {
    opacity: 1
  }
  50%, 100% {
    -webkit-transform: translateX(-40px);
    transform: translateX(-40px);
    opacity: 0
  }
}
@keyframes scroll-hint-appear {
  0% {
    -webkit-transform: translateX(40px);
    transform: translateX(40px);
    opacity: 0
  }
  10% {
    opacity: 1
  }
  50%, 100% {
    -webkit-transform: translateX(-40px);
    transform: translateX(-40px);
    opacity: 0
  }
}
.scroll-hint.is-right-scrollable {
  background: -o-linear-gradient(right, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
  background: linear-gradient(270deg, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0))
}
.scroll-hint.is-right-scrollable.is-left-scrollable {
  background: -o-linear-gradient(left, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0)), -o-linear-gradient(right, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
  background: linear-gradient(90deg, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0)), linear-gradient(270deg, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0))
}
.scroll-hint.is-left-scrollable {
  background: -o-linear-gradient(left, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
  background: linear-gradient(90deg, rgba(0, 0, 0, .15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0))
}
.scroll-hint-icon {
  -webkit-box-sizing: border-box;
  -webkit-transition: opacity 0.3s;
  -o-transition: opacity 0.3s;
  box-sizing: border-box;
  position: absolute;
  top: calc(50% - 25px);
  left: calc(50% - 60px);
  width: 120px;
  height: 80px;
  padding: 20px 10px 10px 10px;
  border-radius: 5px;
  background: rgba(0, 0, 0, .7);
  text-align: center;
  opacity: 0;
  transition: opacity 0.3s
}
.scroll-hint-icon-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  max-height: 100%;
  pointer-events: none
}
.scroll-hint-text {
  margin-top: 5px;
  color: #FFF;
  font-size: 10px
}
.scroll-hint-icon-wrap.is-active .scroll-hint-icon {
  opacity: .8
}
.scroll-hint-icon:before {
  display: inline-block;
  width: 40px;
  height: 40px;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNS43NyIgaGVpZ2h0PSIzMC41MiIgdmlld0JveD0iMCAwIDI1Ljc3IDMwLjUyIj48dGl0bGU+44Ki44K744OD44OIIDM8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxwYXRoIGQ9Ik0yMS4zMywzMC41Mkg3Ljg1QTEuNTUsMS41NSwwLDAsMSw2LjMsMjlhMTIuNDYsMTIuNDYsMCwwLDAtLjYzLTQuNDIsMjUuMTYsMjUuMTYsMCwwLDAtNC4yNS01bC0uMDYtLjA2QTUsNSwwLDAsMSwwLDE1Ljg2YTMuNjQsMy42NCwwLDAsMSwxLjE3LTIuNjIsMy42MywzLjYzLDAsMCwxLDUuMTQuMDdWMy43N2EzLjc3LDMuNzcsMCwxLDEsNy41NCwwVjguMzNhMy4zNSwzLjM1LDAsMCwxLDEuMjYsMCwzLDMsMCwwLDEsMiwxLjIyLDMuNSwzLjUsMCwwLDEsMi0uMDYsMy4yMSwzLjIxLDAsMCwxLDIsMS41NCwzLjc0LDMuNzQsMCwwLDEsMywuNDdBNC4yMSw0LjIxLDAsMCwxLDI1Ljc0LDE1YzAsLjExLDAsLjI3LDAsLjQ2YTE5LjI2LDE5LjI2LDAsMCwxLS44NCw3Yy0uMTQuMzgtLjM2LjgxLS41NiwxLjIybC0uMTEuMjJjMCwuMDctLjA5LjE0LS4xNC4yMWE3LjEzLDcuMTMsMCwwLDAtMS4xNywyLjE3Yy0uMDYuNTYtLjA2LDIuMTUtLjA1LDIuNzFBMS41NSwxLjU1LDAsMCwxLDIxLjMzLDMwLjUyWk04LjYxLDI4LjIxaDEyYzAtLjcxLDAtMS43MS4wNy0yLjIzYTguNzQsOC43NCwwLDAsMSwxLjU5LTMuMjVsLjA2LS4xMmExMCwxMCwwLDAsMCwuNDYtMSwxNi44LDE2LjgsMCwwLDAsLjctNi4xMmMwLS4yMywwLS40MSwwLS41NGgwYTIsMiwwLDAsMC0uNjQtMS41MiwxLjMzLDEuMzMsMCwwLDAtMS41NS4wOCwxLjEzLDEuMTMsMCwwLDEtMS4xOC4yOCwxLjE1LDEuMTUsMCwwLDEtLjc4LS45NCwxLjI2LDEuMjYsMCwwLDAtLjc1LTEuMTEsMSwxLDAsMCwwLTEuMTEuMjhsLS4xLjFhMS4xNSwxLjE1LDAsMCwxLTEuMTkuMjksMS4xNiwxLjE2LDAsMCwxLS43OC0uOTVjLS4wOS0uNjgtLjIxLS43Ny0uNy0uODdhLjgyLjgyLDAsMCwwLTEsLjQ4LDEuMTYsMS4xNiwwLDAsMS0yLjE2LS41OFYzLjc3YTEuNDYsMS40NiwwLDEsMC0yLjkyLDB2Ny44NWwwLDQuMzNhMS4xNywxLjE3LDAsMCwxLS44MywxLjExLDEuMTUsMS4xNSwwLDAsMS0xLjItLjM1bC0xLS45MWMtLjQ3LS40Mi0uNzMtLjY2LS44NC0uNzdhMS4zNSwxLjM1LDAsMCwwLTItLjEyTDIuNywxNWExLjMyLDEuMzIsMCwwLDAtLjM5LDFBMi41NywyLjU3LDAsMCwwLDMsMTcuODVsMCwwYTI3LjI0LDI3LjI0LDAsMCwxLDQuNyw1LjYyQTEyLjYzLDEyLjYzLDAsMCwxLDguNjEsMjguMjFaTTIzLjIsMjMuMzVaTTYuNTEsMTYuNTlaIiBmaWxsPSIjZmZmIi8+PC9nPjwvZz48L3N2Zz4=);
  background-position: center center;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
  color: #FFF;
  text-align: center;
  vertical-align: middle
}
.scroll-hint-icon:after {
  -webkit-transition-delay: 2.4s;
  -o-transition-delay: 2.4s;
  display: block;
  position: absolute;
  top: 10px;
  left: 50%;
  width: 34px;
  height: 14px;
  margin-left: -20px;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzMy4yOSIgaGVpZ2h0PSIxMi4wMiIgdmlld0JveD0iMCAwIDMzLjI5IDEyLjAyIj48dGl0bGU+44Ki44K744OD44OIIDE8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxsaW5lIHgxPSIxLjg1IiB5MT0iNi4wMSIgeDI9IjEwLjQiIHkyPSI2LjAxIiBmaWxsPSIjZmZmIi8+PHBhdGggZD0iTTEwLjQsNy4xN0gxLjg1YTEuMTYsMS4xNiwwLDEsMSwwLTIuMzFIMTAuNGExLjE2LDEuMTYsMCwxLDEsMCwyLjMxWiIgZmlsbD0iI2ZmZiIvPjxwYXRoIGQ9Ik03LjQsMTJhMS4xNSwxLjE1LDAsMCwxLS43Mi0uMjVsLTYuMjUtNUExLjIsMS4yLDAsMCwxLDAsNS44NywxLjE0LDEuMTQsMCwwLDEsLjQ2LDVMNi43LjIzQTEuMTYsMS4xNiwwLDAsMSw4LjEsMi4wOEwzLDUuOTEsOC4xMiwxMEExLjE2LDEuMTYsMCwwLDEsNy40LDEyWiIgZmlsbD0iI2ZmZiIvPjxsaW5lIHgxPSIzMS40NSIgeTE9IjYuMDEiIHgyPSIyMi44OSIgeTI9IjYuMDEiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNMzEuNDUsNy4xN0gyMi44OWExLjE2LDEuMTYsMCwxLDEsMC0yLjMxaDguNTZhMS4xNiwxLjE2LDAsMCwxLDAsMi4zMVoiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNMjUuOSwxMmExLjE4LDEuMTgsMCwwLDEtLjkxLS40M0ExLjE3LDEuMTcsMCwwLDEsMjUuMTcsMTBsNS4wOS00LjA1TDI1LjIsMi4wOEExLjE2LDEuMTYsMCwwLDEsMjYuNTkuMjNMMzIuODQsNWExLjE2LDEuMTYsMCwwLDEsLjQ1LjkxLDEuMTQsMS4xNCwwLDAsMS0uNDMuOTJsLTYuMjQsNUExLjE3LDEuMTcsMCwwLDEsMjUuOSwxMloiIGZpbGw9IiNmZmYiLz48L2c+PC9nPjwvc3ZnPg==);
  background-repeat: no-repeat;
  content: "";
  opacity: 0;
  transition-delay: 2.4s
}
.scroll-hint-icon-wrap.is-active .scroll-hint-icon:after {
  opacity: 1
}
.scroll-hint-icon-wrap.is-active .scroll-hint-icon:before {
  -webkit-animation: scroll-hint-appear 1.2s linear;
  -webkit-animation-iteration-count: 2;
  animation: scroll-hint-appear 1.2s linear;
  animation-iteration-count: 2
}
.scroll-hint-icon-white {
  -webkit-box-shadow: 0 4px 5px rgba(0, 0, 0, .4);
  background-color: #FFF;
  box-shadow: 0 4px 5px rgba(0, 0, 0, .4)
}
.scroll-hint-icon-white:before {
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNS43NyIgaGVpZ2h0PSIzMC41MiIgdmlld0JveD0iMCAwIDI1Ljc3IDMwLjUyIj48dGl0bGU+44Ki44K744OD44OIIDQ8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxwYXRoIGQ9Ik0yMS4zMywzMC41Mkg3Ljg1QTEuNTUsMS41NSwwLDAsMSw2LjMsMjlhMTIuNDYsMTIuNDYsMCwwLDAtLjYzLTQuNDIsMjUuMTYsMjUuMTYsMCwwLDAtNC4yNS01bC0uMDYtLjA2QTUsNSwwLDAsMSwwLDE1Ljg2YTMuNjQsMy42NCwwLDAsMSwxLjE3LTIuNjIsMy42MywzLjYzLDAsMCwxLDUuMTQuMDdWMy43N2EzLjc3LDMuNzcsMCwxLDEsNy41NCwwVjguMzNhMy4zNSwzLjM1LDAsMCwxLDEuMjYsMCwzLDMsMCwwLDEsMiwxLjIyLDMuNSwzLjUsMCwwLDEsMi0uMDYsMy4yMSwzLjIxLDAsMCwxLDIsMS41NCwzLjc0LDMuNzQsMCwwLDEsMywuNDdBNC4yMSw0LjIxLDAsMCwxLDI1Ljc0LDE1YzAsLjExLDAsLjI3LDAsLjQ2YTE5LjI2LDE5LjI2LDAsMCwxLS44NCw3Yy0uMTQuMzgtLjM2LjgxLS41NiwxLjIybC0uMTEuMjJjMCwuMDctLjA5LjE0LS4xNC4yMWE3LjEzLDcuMTMsMCwwLDAtMS4xNywyLjE3Yy0uMDYuNTYtLjA2LDIuMTUtLjA1LDIuNzFBMS41NSwxLjU1LDAsMCwxLDIxLjMzLDMwLjUyWk04LjYxLDI4LjIxaDEyYzAtLjcxLDAtMS43MS4wNy0yLjIzYTguNzQsOC43NCwwLDAsMSwxLjU5LTMuMjVsLjA2LS4xMmExMCwxMCwwLDAsMCwuNDYtMSwxNi44LDE2LjgsMCwwLDAsLjctNi4xMmMwLS4yMywwLS40MSwwLS41NGgwYTIsMiwwLDAsMC0uNjQtMS41MiwxLjMzLDEuMzMsMCwwLDAtMS41NS4wOCwxLjEzLDEuMTMsMCwwLDEtMS4xOC4yOCwxLjE1LDEuMTUsMCwwLDEtLjc4LS45NCwxLjI2LDEuMjYsMCwwLDAtLjc1LTEuMTEsMSwxLDAsMCwwLTEuMTEuMjhsLS4xLjFhMS4xNSwxLjE1LDAsMCwxLTEuMTkuMjksMS4xNiwxLjE2LDAsMCwxLS43OC0uOTVjLS4wOS0uNjgtLjIxLS43Ny0uNy0uODdhLjgyLjgyLDAsMCwwLTEsLjQ4LDEuMTYsMS4xNiwwLDAsMS0yLjE2LS41OFYzLjc3YTEuNDYsMS40NiwwLDEsMC0yLjkyLDB2Ny44NWwwLDQuMzNhMS4xNywxLjE3LDAsMCwxLS44MywxLjExLDEuMTUsMS4xNSwwLDAsMS0xLjItLjM1bC0xLS45MWMtLjQ3LS40Mi0uNzMtLjY2LS44NC0uNzdhMS4zNSwxLjM1LDAsMCwwLTItLjEyTDIuNywxNWExLjMyLDEuMzIsMCwwLDAtLjM5LDFBMi41NywyLjU3LDAsMCwwLDMsMTcuODVsMCwwYTI3LjI0LDI3LjI0LDAsMCwxLDQuNyw1LjYyQTEyLjYzLDEyLjYzLDAsMCwxLDguNjEsMjguMjFaTTIzLjIsMjMuMzVaTTYuNTEsMTYuNTlaIi8+PC9nPjwvZz48L3N2Zz4=)
}
.scroll-hint-icon-white:after {
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzMy4yOSIgaGVpZ2h0PSIxMi4wMiIgdmlld0JveD0iMCAwIDMzLjI5IDEyLjAyIj48dGl0bGU+44Ki44K744OD44OIIDI8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxsaW5lIHgxPSIxLjg1IiB5MT0iNi4wMSIgeDI9IjEwLjQiIHkyPSI2LjAxIi8+PHBhdGggZD0iTTEwLjQsNy4xN0gxLjg1YTEuMTYsMS4xNiwwLDEsMSwwLTIuMzFIMTAuNGExLjE2LDEuMTYsMCwxLDEsMCwyLjMxWiIvPjxwYXRoIGQ9Ik03LjQsMTJhMS4xNSwxLjE1LDAsMCwxLS43Mi0uMjVsLTYuMjUtNUExLjIsMS4yLDAsMCwxLDAsNS44NywxLjE0LDEuMTQsMCwwLDEsLjQ2LDVMNi43LjIzQTEuMTYsMS4xNiwwLDAsMSw4LjEsMi4wOEwzLDUuOTEsOC4xMiwxMEExLjE2LDEuMTYsMCwwLDEsNy40LDEyWiIvPjxsaW5lIHgxPSIzMS40NSIgeTE9IjYuMDEiIHgyPSIyMi44OSIgeTI9IjYuMDEiLz48cGF0aCBkPSJNMzEuNDUsNy4xN0gyMi44OWExLjE2LDEuMTYsMCwxLDEsMC0yLjMxaDguNTZhMS4xNiwxLjE2LDAsMCwxLDAsMi4zMVoiLz48cGF0aCBkPSJNMjUuOSwxMmExLjE4LDEuMTgsMCwwLDEtLjkxLS40M0ExLjE3LDEuMTcsMCwwLDEsMjUuMTcsMTBsNS4wOS00LjA1TDI1LjIsMi4wOEExLjE2LDEuMTYsMCwwLDEsMjYuNTkuMjNMMzIuODQsNWExLjE2LDEuMTYsMCwwLDEsLjQ1LjkxLDEuMTQsMS4xNCwwLDAsMS0uNDMuOTJsLTYuMjQsNUExLjE3LDEuMTcsMCwwLDEsMjUuOSwxMloiLz48L2c+PC9nPjwvc3ZnPg==)
}
.scroll-hint-icon-white .scroll-hint-text {
  color: #000
}
@font-face {
  font-style: normal;
  font-weight: 400;
  src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA");
  font-family: swiper-icons
}
:root {
  --swiper-theme-color: #007aff
}
.swiper {
  z-index: 1;
  position: relative;
  margin-right: auto;
  margin-left: auto;
  padding: 0;
  overflow: hidden;
  list-style: none
}
.swiper-vertical > .swiper-wrapper {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column
}
.swiper-wrapper {
  -webkit-transition-property: -webkit-transform;
  -o-transition-property: transform;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 1;
  position: relative;
  width: 100%;
  height: 100%;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform
}
.swiper-android .swiper-slide, .swiper-wrapper {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0)
}
.swiper-pointer-events {
  -ms-touch-action: pan-y;
  touch-action: pan-y
}
.swiper-pointer-events.swiper-vertical {
  -ms-touch-action: pan-x;
  touch-action: pan-x
}
.swiper-slide {
  -ms-flex-negative: 0;
  -webkit-transition-property: -webkit-transform;
  -o-transition-property: transform;
  position: relative;
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform
}
.swiper-slide-invisible-blank {
  visibility: hidden
}
.swiper-autoheight, .swiper-autoheight .swiper-slide {
  height: auto
}
.swiper-autoheight .swiper-wrapper {
  -webkit-box-align: start;
  -ms-flex-align: start;
  -webkit-transition-property: height, -webkit-transform;
  -o-transition-property: transform, height;
  align-items: flex-start;
  transition-property: height, -webkit-transform;
  transition-property: transform, height;
  transition-property: transform, height, -webkit-transform
}
.swiper-backface-hidden .swiper-slide {
  -webkit-transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
  backface-visibility: hidden
}
.swiper-3d, .swiper-3d.swiper-css-mode .swiper-wrapper {
  -webkit-perspective: 1200px;
  perspective: 1200px
}
.swiper-3d .swiper-cube-shadow, .swiper-3d .swiper-slide, .swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-bottom, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top, .swiper-3d .swiper-wrapper {
  -webkit-transform-style: preserve-3d;
  transform-style: preserve-3d
}
.swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-bottom, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top {
  z-index: 10;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none
}
.swiper-3d .swiper-slide-shadow {
  background: rgba(0, 0, 0, .15)
}
.swiper-3d .swiper-slide-shadow-left {
  background-image: -webkit-gradient(linear, right top, left top, from(rgba(0, 0, 0, .5)), to(rgba(0, 0, 0, 0)));
  background-image: -o-linear-gradient(right, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to left, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0))
}
.swiper-3d .swiper-slide-shadow-right {
  background-image: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, .5)), to(rgba(0, 0, 0, 0)));
  background-image: -o-linear-gradient(left, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to right, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0))
}
.swiper-3d .swiper-slide-shadow-top {
  background-image: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, .5)), to(rgba(0, 0, 0, 0)));
  background-image: -o-linear-gradient(bottom, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to top, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0))
}
.swiper-3d .swiper-slide-shadow-bottom {
  background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, .5)), to(rgba(0, 0, 0, 0)));
  background-image: -o-linear-gradient(top, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0))
}
.swiper-css-mode > .swiper-wrapper {
  -ms-overflow-style: none;
  overflow: auto;
  scrollbar-width: none
}
.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none
}
.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start
}
.swiper-horizontal.swiper-css-mode > .swiper-wrapper {
  -ms-scroll-snap-type: x mandatory;
  scroll-snap-type: x mandatory
}
.swiper-vertical.swiper-css-mode > .swiper-wrapper {
  -ms-scroll-snap-type: y mandatory;
  scroll-snap-type: y mandatory
}
.swiper-centered > .swiper-wrapper::before {
  -ms-flex-negative: 0;
  -webkit-box-ordinal-group: 10000;
  -ms-flex-order: 9999;
  flex-shrink: 0;
  order: 9999;
  content: ""
}
.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  -webkit-margin-start: var(--swiper-centered-offset-before);
  margin-inline-start: var(--swiper-centered-offset-before)
}
.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
  width: var(--swiper-centered-offset-after);
  height: 100%;
  min-height: 1px
}
.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  -webkit-margin-before: var(--swiper-centered-offset-before);
  margin-block-start: var(--swiper-centered-offset-before)
}
.swiper-centered.swiper-vertical > .swiper-wrapper::before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after)
}
.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always
}
.swiper-virtual .swiper-slide {
  -webkit-backface-visibility: hidden;
  -webkit-transform: translateZ(0);
  transform: translateZ(0)
}
.swiper-virtual.swiper-css-mode .swiper-wrapper::after {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  pointer-events: none
}
.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after {
  width: var(--swiper-virtual-size);
  height: 1px
}
.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after {
  width: 1px;
  height: var(--swiper-virtual-size)
}
:root {
  --swiper-navigation-size: 44px
}
.swiper-button-next, .swiper-button-prev {
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 10;
  position: absolute;
  top: 50%;
  align-items: center;
  justify-content: center;
  width: calc(var(--swiper-navigation-size) / 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(0px - var(--swiper-navigation-size) / 2);
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
  cursor: pointer
}
.swiper-button-next.swiper-button-disabled, .swiper-button-prev.swiper-button-disabled {
  cursor: auto;
  opacity: .35;
  pointer-events: none
}
.swiper-button-next.swiper-button-hidden, .swiper-button-prev.swiper-button-hidden {
  cursor: auto;
  opacity: 0;
  pointer-events: none
}
.swiper-navigation-disabled .swiper-button-next, .swiper-navigation-disabled .swiper-button-prev {
  display: none !important
}
.swiper-button-next:after, .swiper-button-prev:after {
  font-variant: initial;
  font-size: var(--swiper-navigation-size);
  line-height: 1;
  font-family: swiper-icons;
  letter-spacing: 0;
  text-transform: none !important
}
.swiper-button-prev, .swiper-rtl .swiper-button-next {
  right: auto;
  left: 10px
}
.swiper-button-prev:after, .swiper-rtl .swiper-button-next:after {
  content: "prev"
}
.swiper-button-next, .swiper-rtl .swiper-button-prev {
  right: 10px;
  left: auto
}
.swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
  content: "next"
}
.swiper-button-lock {
  display: none
}
.swiper-pagination {
  -webkit-transition: 0.3s opacity;
  -o-transition: 0.3s opacity;
  -webkit-transform: translate3d(0, 0, 0);
  z-index: 10;
  position: absolute;
  transform: translate3d(0, 0, 0);
  text-align: center;
  transition: 0.3s opacity
}
.swiper-pagination.swiper-pagination-hidden {
  opacity: 0
}
.swiper-pagination-disabled > .swiper-pagination, .swiper-pagination.swiper-pagination-disabled {
  display: none !important
}
.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
  bottom: 10px;
  left: 0;
  width: 100%
}
.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transform: scale(.33);
  -ms-transform: scale(.33);
  position: relative;
  transform: scale(.33)
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1)
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1)
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  -webkit-transform: scale(.66);
  -ms-transform: scale(.66);
  transform: scale(.66)
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  -webkit-transform: scale(.33);
  -ms-transform: scale(.33);
  transform: scale(.33)
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  -webkit-transform: scale(.66);
  -ms-transform: scale(.66);
  transform: scale(.66)
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  -webkit-transform: scale(.33);
  -ms-transform: scale(.33);
  transform: scale(.33)
}
.swiper-pagination-bullet {
  display: inline-block;
  width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
  height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
  border-radius: 50%;
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  opacity: var(--swiper-pagination-bullet-inactive-opacity, .2)
}
button.swiper-pagination-bullet {
  -webkit-box-shadow: none;
  -webkit-appearance: none;
  appearance: none;
  margin: 0;
  padding: 0;
  border: none;
  box-shadow: none
}
.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer
}
.swiper-pagination-bullet:only-child {
  display: none !important
}
.swiper-pagination-bullet-active {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  opacity: var(--swiper-pagination-bullet-opacity, 1)
}
.swiper-pagination-vertical.swiper-pagination-bullets, .swiper-vertical > .swiper-pagination-bullets {
  -webkit-transform: translate3d(0, -50%, 0);
  top: 50%;
  right: 10px;
  transform: translate3d(0, -50%, 0)
}
.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
  display: block;
  margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0
}
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  top: 50%;
  width: 8px;
  transform: translateY(-50%)
}
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transition: 0.2s top, 0.2s -webkit-transform;
  -o-transition: 0.2s transform, 0.2s top;
  display: inline-block;
  transition: 0.2s top, 0.2s -webkit-transform;
  transition: 0.2s transform, 0.2s top;
  transition: 0.2s transform, 0.2s top, 0.2s -webkit-transform
}
.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px)
}
.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap
}
.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transition: 0.2s left, 0.2s -webkit-transform;
  -o-transition: 0.2s transform, 0.2s left;
  transition: 0.2s left, 0.2s -webkit-transform;
  transition: 0.2s transform, 0.2s left;
  transition: 0.2s transform, 0.2s left, 0.2s -webkit-transform
}
.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transition: 0.2s right, 0.2s -webkit-transform;
  -o-transition: 0.2s transform, 0.2s right;
  transition: 0.2s right, 0.2s -webkit-transform;
  transition: 0.2s transform, 0.2s right;
  transition: 0.2s transform, 0.2s right, 0.2s -webkit-transform
}
.swiper-pagination-progressbar {
  position: absolute;
  background: rgba(0, 0, 0, .25)
}
.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  -webkit-transform: scale(0);
  -ms-transform: scale(0);
  -webkit-transform-origin: left top;
  -ms-transform-origin: left top;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: scale(0);
  transform-origin: left top;
  background: var(--swiper-pagination-color, var(--swiper-theme-color))
}
.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  -webkit-transform-origin: right top;
  -ms-transform-origin: right top;
  transform-origin: right top
}
.swiper-horizontal > .swiper-pagination-progressbar, .swiper-pagination-progressbar.swiper-pagination-horizontal, .swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite, .swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  top: 0;
  left: 0;
  width: 100%;
  height: 4px
}
.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-vertical, .swiper-vertical > .swiper-pagination-progressbar {
  top: 0;
  left: 0;
  width: 4px;
  height: 100%
}
.swiper-pagination-lock {
  display: none
}
.swiper-scrollbar {
  -ms-touch-action: none;
  position: relative;
  border-radius: 10px;
  background: rgba(0, 0, 0, .1)
}
.swiper-scrollbar-disabled > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-disabled {
  display: none !important
}
.swiper-horizontal > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-horizontal {
  z-index: 50;
  position: absolute;
  bottom: 3px;
  left: 1%;
  width: 98%;
  height: 5px
}
.swiper-scrollbar.swiper-scrollbar-vertical, .swiper-vertical > .swiper-scrollbar {
  z-index: 50;
  position: absolute;
  top: 1%;
  right: 3px;
  width: 5px;
  height: 98%
}
.swiper-scrollbar-drag {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 10px;
  background: rgba(0, 0, 0, .5)
}
.swiper-scrollbar-cursor-drag {
  cursor: move
}
.swiper-scrollbar-lock {
  display: none
}
.swiper-zoom-container {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  text-align: center
}
.swiper-zoom-container > canvas, .swiper-zoom-container > img, .swiper-zoom-container > svg {
  -o-object-fit: contain;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain
}
.swiper-slide-zoomed {
  cursor: move
}
.swiper-lazy-preloader {
  -webkit-transform-origin: 50%;
  -ms-transform-origin: 50%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  z-index: 10;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 42px;
  height: 42px;
  margin-top: -21px;
  margin-left: -21px;
  transform-origin: 50%;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent
}
.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader, .swiper:not(.swiper-watch-progress) .swiper-lazy-preloader {
  -webkit-animation: swiper-preloader-spin 1s infinite linear;
  animation: swiper-preloader-spin 1s infinite linear
}
.swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff
}
.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000
}
@-webkit-keyframes swiper-preloader-spin {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg)
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg)
  }
}
@keyframes swiper-preloader-spin {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg)
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg)
  }
}
.swiper .swiper-notification {
  z-index: -1000;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  pointer-events: none
}
.swiper-free-mode > .swiper-wrapper {
  -webkit-transition-timing-function: ease-out;
  -o-transition-timing-function: ease-out;
  margin: 0 auto;
  transition-timing-function: ease-out
}
.swiper-grid > .swiper-wrapper {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}
.swiper-grid-column > .swiper-wrapper {
  -ms-flex-wrap: wrap;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  flex-wrap: wrap
}
.swiper-fade.swiper-free-mode .swiper-slide {
  -webkit-transition-timing-function: ease-out;
  -o-transition-timing-function: ease-out;
  transition-timing-function: ease-out
}
.swiper-fade .swiper-slide {
  -webkit-transition-property: opacity;
  -o-transition-property: opacity;
  pointer-events: none;
  transition-property: opacity
}
.swiper-fade .swiper-slide .swiper-slide {
  pointer-events: none
}
.swiper-fade .swiper-slide-active, .swiper-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto
}
.swiper-cube {
  overflow: visible
}
.swiper-cube .swiper-slide {
  -webkit-backface-visibility: hidden;
  -webkit-transform-origin: 0 0;
  -ms-transform-origin: 0 0;
  visibility: hidden;
  z-index: 1;
  width: 100%;
  height: 100%;
  transform-origin: 0 0;
  backface-visibility: hidden;
  pointer-events: none
}
.swiper-cube .swiper-slide .swiper-slide {
  pointer-events: none
}
.swiper-cube.swiper-rtl .swiper-slide {
  -webkit-transform-origin: 100% 0;
  -ms-transform-origin: 100% 0;
  transform-origin: 100% 0
}
.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto
}
.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-next, .swiper-cube .swiper-slide-next + .swiper-slide, .swiper-cube .swiper-slide-prev {
  visibility: visible;
  pointer-events: auto
}
.swiper-cube .swiper-slide-shadow-bottom, .swiper-cube .swiper-slide-shadow-left, .swiper-cube .swiper-slide-shadow-right, .swiper-cube .swiper-slide-shadow-top {
  -webkit-backface-visibility: hidden;
  z-index: 0;
  backface-visibility: hidden
}
.swiper-cube .swiper-cube-shadow {
  z-index: 0;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: .6
}
.swiper-cube .swiper-cube-shadow:before {
  -webkit-filter: blur(50px);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: #000;
  content: "";
  filter: blur(50px)
}
.swiper-flip {
  overflow: visible
}
.swiper-flip .swiper-slide {
  -webkit-backface-visibility: hidden;
  z-index: 1;
  backface-visibility: hidden;
  pointer-events: none
}
.swiper-flip .swiper-slide .swiper-slide {
  pointer-events: none
}
.swiper-flip .swiper-slide-active, .swiper-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto
}
.swiper-flip .swiper-slide-shadow-bottom, .swiper-flip .swiper-slide-shadow-left, .swiper-flip .swiper-slide-shadow-right, .swiper-flip .swiper-slide-shadow-top {
  -webkit-backface-visibility: hidden;
  z-index: 0;
  backface-visibility: hidden
}
.swiper-creative .swiper-slide {
  -webkit-backface-visibility: hidden;
  -webkit-transition-property: opacity, height, -webkit-transform;
  -o-transition-property: transform, opacity, height;
  overflow: hidden;
  backface-visibility: hidden;
  transition-property: opacity, height, -webkit-transform;
  transition-property: transform, opacity, height;
  transition-property: transform, opacity, height, -webkit-transform
}
.swiper-cards {
  overflow: visible
}
.swiper-cards .swiper-slide {
  -webkit-transform-origin: center bottom;
  -ms-transform-origin: center bottom;
  -webkit-backface-visibility: hidden;
  overflow: hidden;
  transform-origin: center bottom;
  backface-visibility: hidden
}
.container {
  max-width: calc(var(--container) + var(--gutter) * 2);
  margin-right: auto;
  margin-left: auto;
  padding-right: var(--gutter);
  padding-left: var(--gutter)
}
/* @media (min-width:768px) {
  .hidden--pc {
    display: none
  }
}

@media (max-width:767.98px) {
  .hidden--mobile {
    display: none
  }
} */
.bnr-comingsoon {
  color: var(--color-primary);
  font-family: 'proxima-nova';
  font-weight: 700;
  font-size: 28px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100px;
  margin: 40px auto 60px;
  background: #FFF3E7;
}
.txt-comingsoon {
  color: var(--color-primary);
  font-family: 'proxima-nova';
  font-weight: 700;
  font-size: 21px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 50px;
}
.button-primary {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-shadow: 0 0 15px #FFECC3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 50px;
  overflow: hidden;
  gap: 4px;
  border: 1px solid #fff;
  border-radius: 25px;
  background: var(--gradation-primary) no-repeat center center/100% 100%;
  box-shadow: 0 0 15px #FFECC3
}
.button-primary::before {
  -webkit-transition: 0.3s opacity ease-in-out;
  -o-transition: 0.3s opacity ease-in-out;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--color-primary);
  content: "";
  opacity: 0;
  transition: 0.3s opacity ease-in-out
}
.button-primary[data-color=fill] {
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, .16);
  margin: 0 0 9px;
  background: var(--color-primary);
  box-shadow: 0 3px 6px rgba(0, 0, 0, .16)
}
@media (hover:hover) {
  .button-primary[data-color=fill] {
    -webkit-transition: 0.3s opacity ease-in-out;
    -o-transition: 0.3s opacity ease-in-out;
    transition: 0.3s opacity ease-in-out
  }
  .button-primary[data-color=fill]::before {
    opacity: 0
  }
  .button-primary[data-color=fill]:hover {
    opacity: .6
  }
}
@media (hover:hover) {
  .button-primary:hover::before {
    opacity: 1
  }
}
.button-primary__text {
  z-index: 2;
  position: relative;
  color: #fff;
  font-weight: 700;
  font-size: 16px
}
.button-primary__arrow {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 25px;
  z-index: 1;
  position: relative;
  flex: 0 0 25px;
  width: 25px;
  line-height: 1
}
.button-primary__arrow .fillPath {
  fill: #fff
}
.button-primary[data-size=small] .button-primary__text {
  font-size: 16px
}
@media (min-width:768px) {
  .button-primary {
    height: 60px;
    border-radius: 30px
  }
  .button-primary[data-size=small] {
    height: 50px;
    border-radius: 25px
  }
  .button-primary__text {
    font-size: 18px
  }
}
.button-secondary {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  align-items: center;
  justify-content: center;
  height: 50px;
  gap: 4px;
  border-radius: 25px;
  background: var(--gradation-primary)
}
@media (hover:hover) {
  .button-secondary:hover {
    background: var(--color-primary)
  }
  .button-secondary:hover .button-secondary__text {
    color: #fff
  }
  .button-secondary:hover::before {
    background-color: var(--color-primary)
  }
}
.button-secondary::before {
  -webkit-transition: 0.3s background-color ease-in-out;
  -o-transition: 0.3s background-color ease-in-out;
  z-index: 1;
  position: absolute;
  top: 2px;
  left: 2px;
  width: calc(100% - 4px);
  height: calc(100% - 4px);
  border-radius: 23px;
  background-color: #fff;
  content: "";
  transition: 0.3s background-color ease-in-out
}
.button-secondary__text {
  -webkit-transition: 0.3s color ease-in-out;
  -o-transition: 0.3s color ease-in-out;
  z-index: 2;
  position: relative;
  color: var(--color-primary);
  font-weight: 700;
  font-size: 16px;
  transition: 0.3s color ease-in-out
}
.button-secondary__arrow {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 25px;
  z-index: 2;
  position: relative;
  flex: 0 0 25px;
  width: 25px;
  line-height: 1
}
.button-secondary__arrow .fillPath {
  fill: #fff
}
@media (min-width:768px) {
  .button-secondary {
    height: 60px;
    border-radius: 30px
  }
  .button-secondary::before {
    border-radius: 29px
  }
  .button-secondary__text {
    font-size: 18px
  }
}
@media (hover:hover) {
  .button-image {
    -webkit-transition: 0.3s opacity ease-in-out;
    -o-transition: 0.3s opacity ease-in-out;
    transition: 0.3s opacity ease-in-out
  }
  .button-image:hover {
    opacity: .6
  }
}
.link-text {
  color: var(--color-link);
  text-decoration: underline
}
.link-text:hover {
  text-decoration: none
}
.link-text2 {
  color: var(--color-link)
}
.link-text2:hover {
  text-decoration: underline
}
.link-download {
  display: inline-block;
  padding: 0 17px 0 0;
  background: url(../images/icon-download-thin.svg) no-repeat right center/13px auto;
  color: var(--color-primary);
  font-size: 12px
}
.link-download:hover {
  text-decoration: underline
}
.description_rel {
  /* display: relative; */
}
@media (min-width:768px) {
  .link-download {
    font-size: 14px
  }
}
.text-description {
  font-weight: 300;
  font-size: 14px;
  line-height: 1.85;
  letter-spacing: .02em
}
.text-description > b {
  font-weight: 700;
  color: #FF5F00
}
.text-description--abs {
  position: absolute;
  top: 0px;
  left: 0;
}
@media (min-width:768px) {
  .text-description {
    font-size: 18px;
    line-height: 1.8;
    text-align: center
  }
  .text-description--left {
    text-align: left
  }
}
.h2 {
  font-weight: 700;
  font-size: 24px;
  line-height: 1.55;
  letter-spacing: .04em;
  text-align: center
}
.h2 > span {
  font-weight: inherit;
  font-size: inherit;
  text-align: center
}
.h2 em {
  -webkit-box-shadow: 0 -16px 0 var(--color-marker) inset;
  display: inline;
  box-shadow: 0 -16px 0 var(--color-marker) inset
}
@media (min-width:768px) {
  .h2 {
    font-size: 40px;
    letter-spacing: .1em
  }
  .h2 em {
    -webkit-box-shadow: 0 -24px 0 var(--color-marker) inset;
    box-shadow: 0 -24px 0 var(--color-marker) inset
  }
  .h2 br:not(.sp) {
    display: none;
  }
}
.title-t1__label {
  display: block;
  position: relative;
  padding-left: 60px;
  color: var(--color-secondary);
  font-weight: 700;
  font-size: 14px;
  line-height: 1;
  font-family: var(--font-family-latin)
}
.title-t1__label::before {
  position: absolute;
  top: .5em;
  left: 0;
  width: 50px;
  height: 1px;
  background-color: var(--color-secondary);
  content: ""
}
.title-t1__text {
  display: block;
  margin: 12px 0 0;
  font-weight: 700;
  font-size: 26px;
  line-height: 1.375;
  letter-spacing: .1em
}
@media (min-width:768px) {
  .title-t1__label {
    font-size: 20px
  }
  .title-t1__text {
    margin: 14px 0 0;
    font-size: 44px
  }
}
.title-gradation {
  -webkit-background-clip: text;
  display: inline-block;
  -webkit-text-fill-color: transparent;
  background-image: var(--gradation-primary)
}
.animation-title {
  -webkit-transform: translateX(10px) scale(.99);
  -ms-transform: translateX(10px) scale(.99);
  -webkit-transition-property: opacity, -webkit-transform;
  -o-transition-property: opacity, transform;
  -webkit-transition-duration: 0.8s;
  -o-transition-duration: 0.8s;
  -webkit-transition-timing-function: ease;
  -o-transition-timing-function: ease;
  position: relative;
  transform: translateX(10px) scale(.99);
  opacity: 0;
  transition-duration: 0.8s;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  transition-timing-function: ease
}
.animation-title .title-gradation {
  -webkit-transition-property: background-size;
  -o-transition-property: background-size;
  -webkit-transition-duration: 0.8s;
  -o-transition-duration: 0.8s;
  -webkit-transition-timing-function: ease;
  -o-transition-timing-function: ease;
  background-size: 0% 100%;
  background-repeat: no-repeat;
  transition-duration: 0.8s;
  transition-property: background-size;
  transition-timing-function: ease;
  will-change: background-size
}
.animation-title.is-active {
  -webkit-transform: translateX(0) scale(1);
  -ms-transform: translateX(0) scale(1);
  transform: translateX(0) scale(1);
  opacity: 1
}
.animation-title.is-active .title-gradation {
  background-size: 100% 100%
}
.animation-fadeup, .animation-fadeup--card {
  -webkit-transform: translateY(6px);
  -ms-transform: translateY(6px);
  -webkit-transition-property: opacity, -webkit-transform;
  -o-transition-property: opacity, transform;
  -webkit-transition-duration: 0.6s;
  -o-transition-duration: 0.6s;
  -webkit-transition-timing-function: ease;
  -o-transition-timing-function: ease;
  transform: translateY(6px);
  opacity: 0;
  transition-duration: 0.6s;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  transition-timing-function: ease
}
.animation-fadeup.is-active {
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0);
  opacity: 1
}
.is-active .animation-fadeup--card {
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0);
  opacity: 1
}
.animation-clip {
  -webkit-transform: translateX(10px);
  -ms-transform: translateX(10px);
  -webkit-clip-path: inset(0 100% 0 0);
  -webkit-transition-property: opacity, -webkit-clip-path, -webkit-transform;
  -o-transition-property: clip-path, transform, opacity;
  -webkit-transition-duration: 0.8s;
  -o-transition-duration: 0.8s;
  -webkit-transition-timing-function: ease;
  -o-transition-timing-function: ease;
  display: inline-block;
  transform: translateX(10px);
  clip-path: inset(0 100% 0 0);
  opacity: 0;
  transition-duration: 0.8s;
  transition-property: opacity, -webkit-clip-path, -webkit-transform;
  transition-property: clip-path, transform, opacity;
  transition-property: clip-path, transform, opacity, -webkit-clip-path, -webkit-transform;
  transition-timing-function: ease
}
.animation-clip--wrapper.is-active .animation-clip {
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  -webkit-clip-path: inset(0 0 0 0);
  transform: translateX(0);
  clip-path: inset(0 0 0 0);
  opacity: 1
}
.animation-fadertl {
  -webkit-transform: translateX(20px);
  -ms-transform: translateX(20px);
  -webkit-transition-property: all;
  -o-transition-property: all;
  -webkit-transition-duration: 0.6s;
  -o-transition-duration: 0.6s;
  -webkit-transition-timing-function: ease;
  -o-transition-timing-function: ease;
  -webkit-transition-delay: 0.3s;
  -o-transition-delay: 0.3s;
  width: 100%;
  transform: translateX(20px);
  opacity: 0;
  transition-delay: 0.3s;
  transition-duration: 0.6s;
  transition-property: all;
  transition-timing-function: ease
}
.animation-fadertl.is-active {
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0);
  opacity: 1
}
.site-copy {
  display: none;
  z-index: 4;
  position: absolute;
  left: 0;
  width: 100%;
  padding: 48px 20px 0;
  font-weight: 700;
  font-size: 10px;
  line-height: 0;
  letter-spacing: .1em
}
@media (min-width:768px) {
  .site-copy {
    display: block
  }
}
@media (min-width:1116px) {
  .site-copy {
    padding: 48px 40px 0
  }
}
.header {
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 1999;
  position: fixed;
  top: 0;
  left: 0;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: var(--header-height);
  padding: 0 var(--gutter);
}
.header.is-fixed {
  -webkit-box-shadow: 0 1px 15px rgba(0, 0, 0, .1);
  position: fixed;
  top: 0;
  background-color: #fff;
  box-shadow: 0 1px 15px rgba(0, 0, 0, .1)
}
.header__menu {
  display: none
}
.header__logo, .header__left {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 64px;
  flex: 0 0 64px;
  width: 64px
}
.header__left {
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center
}
.header__right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex
}
.header__menubutton {
  -ms-flex-item-align: center;
  -ms-grid-row-align: center;
  align-self: center;
  line-height: 0
}
@media (min-width:768px) {
  .header {
    -webkit-transition: 0.3s background-color ease, 0.3s -webkit-box-shadow ease;
    -o-transition: 0.3s background-color ease, 0.3s box-shadow ease;
    position: absolute;
    top: 49px;
    background-color: transparent;
    transition: 0.3s background-color ease, 0.3s -webkit-box-shadow ease;
    transition: 0.3s background-color ease, 0.3s box-shadow ease;
    transition: 0.3s background-color ease, 0.3s box-shadow ease, 0.3s -webkit-box-shadow ease
  }
  .header.is-fixed {
    -webkit-box-shadow: 0 1px 15px rgba(0, 0, 0, .1);
    position: fixed;
    top: 0;
    background-color: #fff;
    box-shadow: 0 1px 15px rgba(0, 0, 0, .1)
  }
  .header__left {
    -webkit-box-flex: 0;
    -ms-flex: 0 1 auto;
    flex: 0 1 auto;
    width: auto;
    gap: 30px
  }
  .header__logo {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 100px;
    flex: 0 0 100px;
    width: 100px
  }
  .header__right {
    gap: 10px
  }
}
@media (min-width:768px) {}
@media (min-width:1201px) {
  .header {
    padding: 0 var(--gutter)
  }
  .header__menubutton {
    display: none
  }
  .header__menu {
    display: block;
    margin: 0 0 2px
  }
}
@media (min-width:1250px) {
  .header {
    padding: 0 40px
  }
}
@media (max-width:767.98px) {
  .header__right {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
  }
}
@media (min-width:768px) {
  .wrapper.is-open .header {
    -webkit-box-shadow: 0 1px 15px rgba(0, 0, 0, .1);
    position: fixed;
    top: 0;
    background-color: #fff;
    box-shadow: 0 1px 15px rgba(0, 0, 0, .1)
  }
}
.header-menu {
  -ms-flex-wrap: wrap;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  gap: 5px 15px
}
.header-menu__item {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  line-height: 1.33
}
.header-menu__link {
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .02em
}
@media (hover:hover) {
  .header-menu__link {
    -webkit-transition: 0.3s color ease-in-out;
    -o-transition: 0.3s color ease-in-out;
    transition: 0.3s color ease-in-out
  }
  .header-menu__link:hover {
    color: var(--color-primary)
  }
}
.header-button {
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, .16);
  -webkit-transition: 0.3s background-color ease-in-out, 0.3s color ease-in-out;
  -o-transition: 0.3s background-color ease-in-out, 0.3s color ease-in-out;
  height: 30px;
  gap: 5px;
  border-radius: 15px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, .16);
  transition: 0.3s background-color ease-in-out, 0.3s color ease-in-out
}
.header-button__text {
  font-weight: 700;
  font-size: 13px
}
.header-button__arrow {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 12px;
  flex: 0 0 12px;
  width: 12px;
  line-height: 0
}
.header-button[data-type=download] {
  display: none
}
.header-button[data-type=contact] {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--color-primary);
  background-color: #fff;
  color: var(--color-primary)
}
.header-button[data-type=contact] .header-button__arrow .fillPath {
  fill: var(--color-primary)
}
@media (hover:hover) {
  .header-button[data-type=contact]:hover {
    background-color: var(--color-primary);
    color: #fff
  }
  .header-button[data-type=contact]:hover .header-button__arrow .fillPath {
    fill: #fff
  }
}
.header-button[data-type=contact].is-active {
  background-color: var(--color-primary);
  color: #fff
}
.header-button[data-type=contact].is-active .header-button__arrow .fillPath {
  fill: #fff
}
.header-button[data-type=trial], .header-button[data-type=download] {
  display: none;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--color-primary);
  background-color: #fff;
  color: var(--color-primary)
}
.header-button[data-type=trial] .header-button__arrow .fillPath, .header-button[data-type=download] .header-button__arrow .fillPath {
  fill: var(--color-primary)
}
@media (hover:hover) {
  .header-button[data-type=trial]:hover, .header-button[data-type=download]:hover {
    background-color: var(--color-primary);
    color: #fff
  }
  .header-button[data-type=trial]:hover .header-button__arrow .fillPath, .header-button[data-type=download]:hover .header-button__arrow .fillPath {
    fill: var(--color-primary)
  }
}
.header-button[data-type=trial].is-active, .header-button[data-type=download].is-active {
  background-color: #fff;
  color: var(--color-primary)
}
.header-button[data-type=trial].is-active .header-button__arrow .fillPath, .header-button[data-type=download].is-active .header-button__arrow .fillPath {
  fill: var(--color-primary)
}
@media (min-width:768px) {
  .header-button {
    height: 48px;
    gap: 5px;
    border-radius: 24px
  }
  .header-button[data-type=trial], .header-button[data-type=download] {
    width: 140px;
    display: flex
  }
  .header-button[data-type=contact] {
    width: 140px
  }
  .header-button[data-type=purchase] {
    width: 140px;
  }
  .header-button[data-type=purchase] .header-button__arrow .fillPath {
    fill: #fff
  }
}
.header-button[data-type=purchase] {
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-primary);
  border: 2px solid var(--color-primary);
  color: #fff
}
@media (min-width:768px) and (hover:hover) {
  .header-button[data-type=purchase]:hover {
    background-color: #fff;
    color: var(--color-primary);
  }
  .header-button[data-type=purchase]:hover .header-button__arrow .fillPath {
    fill: var(--color-primary)
  }
}
@media (min-width:768px) {
  .header-button[data-type=purchase].is-active {
    background-color: #fff;
    color: var(--color-primary)
  }
  .header-button[data-type=purchase].is-active .header-button__arrow .fillPath {
    fill: var(--color-primary)
  }
}
@media (min-width:768px) {
  .header-button__arrow {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 18px;
    flex: 0 0 18px;
    width: 20px;
    line-height: 0
  }
  .header-button__arrow .fillPath {
    -webkit-transition: 0.3s fill ease-in-out;
    -o-transition: 0.3s fill ease-in-out;
    transition: 0.3s fill ease-in-out
  }
}
@media (min-width:1024px) {
  .header-button[data-type=trial], .header-button[data-type=contact], .header-button[data-type=download] {
    width: 140px
  }
}
@media (max-width:767.98px) {
  .header-button {
    width: 100px;
    box-shadow: none;
  }
  .header-button[data-type=purchase] {
    margin: 0 10px 0 5px
  }
  .header-button__text {
    font-size: 10px
  }
}
.toggle-menu {
  position: relative;
  width: 20px;
  height: 17px
}
.toggle-menu > i {
  -webkit-transition: 0.3s all ease-in-out;
  -o-transition: 0.3s all ease-in-out;
  position: absolute;
  right: 0;
  width: 100%;
  height: 1px;
  background-color: #222;
  transition: 0.3s all ease-in-out
}
.toggle-menu__bartop {
  top: 0
}
.toggle-menu__barmiddle {
  top: 8px
}
.toggle-menu__barbottom {
  top: 16px
}
.wrapper.is-open .toggle-menu > i {
  top: 8px
}
.wrapper.is-open .toggle-menu__bartop {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg)
}
.wrapper.is-open .toggle-menu__barmiddle {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg)
}
.wrapper.is-open .toggle-menu__barbottom {
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg)
}
@-webkit-keyframes round {
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg)
  }
}
@keyframes round {
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg)
  }
}
@-webkit-keyframes flatObject {
  0% {
    -webkit-transform: translateY(-1.25vw);
    transform: translateY(-1.25vw)
  }
  38% {
    -webkit-transform: translateY(1vw);
    transform: translateY(1vw)
  }
  100% {
    -webkit-transform: translateY(-1.25vw);
    transform: translateY(-1.25vw)
  }
}
@keyframes flatObject {
  0% {
    -webkit-transform: translateY(-1.25vw);
    transform: translateY(-1.25vw)
  }
  38% {
    -webkit-transform: translateY(1vw);
    transform: translateY(1vw)
  }
  100% {
    -webkit-transform: translateY(-1.25vw);
    transform: translateY(-1.25vw)
  }
}
.mv {
  position: relative;
  padding: 90px var(--gutter) 20px;
  background: url(../images/mv_bg_sp.svg) no-repeat left top / 100% auto;
}
.mv__container {
  z-index: 2;
  position: relative;
  max-width: var(--container);
  margin-right: auto;
  margin-left: auto
}
.mv__images {
  display: flex;
  flex-direction: column-reverse;
}
.mv__images figure:nth-of-type(1) {
  margin-top: 20px;
}
.mv__content {
  z-index: 1;
  position: relative;
}
.mv__content .mv__badges {
  display: none
}
.mv__device {
  -webkit-animation-name: flatObject;
  -webkit-animation-duration: 6s;
  -webkit-animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
  animation-duration: 6s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
  animation-name: flatObject
}
.mv__title {
  text-align: center;
  font-size: 20px;
  line-height: 1.4
}
.mv__title-text {
  font-weight: 700
}
.mv__subtitle {
  margin: 10px 0 20px;
  text-align: center;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.375;
  letter-spacing: -0.05em;
}
.mv__subtitle span span {
  color: var(--color-primary);
}
.mv__textbox {
  margin: 20px 0 0
}
.mv__textbox p {
  font-size: 14px;
  font-weight: 500;
}
.mv__textbox p span {
  color: var(--color-primary);
}
@media (min-width:768px) {
  .mv {
    padding: 154px var(--gutter) 70px;
    background: url(../images/mv_bg.svg) no-repeat -60% center /auto 100%;
  }
  .mv__title {
    margin: 0 0 10px;
    text-align: center;
    font-size: 36px;
    font-weight: 700;
    line-height: 1.375
  }
  .mv__title-logo img {
    margin-right: 8px;
    margin-bottom: 8px;
  }
  .mv__title-text {
    letter-spacing: -.01em;
  }
  .mv__subtitle {
    margin: 0 0 20px;
    text-align: center;
    font-size: 20px;
    font-weight: 500;
    line-height: 1.375
  }
  .mv__images {
    display: flex;
    flex-direction: row-reverse;
  }
  .mv__images::after {
    content: "";
    width: calc(200/10.8*1%);
  }
  .mv__images figure:nth-of-type(2) {
    content: "";
    width: calc(680/10.8*1%);
  }
  .mv__images figure:nth-of-type(1) {
    content: "";
    margin-top: 40px;
    width: calc(200/10.8*1%);
  }
  .mv__content {
    max-width: 100%;
    margin: 0 auto
  }
  .mv__textbox {
    margin-top: 10px;
  }
  .mv__textbox p {
    text-align: center;
    font-size: 16px;
    font-weight: 500;
  }
}
@media (min-width:1024px) {
  .mv br.sp {
    display: none;
  }
}
@media (max-width:767.8px) {
  .mv__title-logo img {
    margin-bottom: 4px;
    width: 195px;
  }
}
.cta {
  z-index: 10;
  position: relative;
  background-color: #fff
}
.cta__bg {
  display: none
}
a .cta__license {
  -webkit-transition: 0.3s -webkit-box-shadow ease-in-out;
  -o-transition: 0.3s box-shadow ease-in-out;
  transition: 0.3s -webkit-box-shadow ease-in-out;
  transition: 0.3s box-shadow ease-in-out;
  transition: 0.3s box-shadow ease-in-out, 0.3s -webkit-box-shadow ease-in-out
}
a .cta__license > dd {
  -webkit-transition: 0.3s color ease-in-out;
  -o-transition: 0.3s color ease-in-out;
  transition: 0.3s color ease-in-out
}
@media (hover:hover) {
  a .cta__license:hover {
    -webkit-box-shadow: 0 0 1px rgba(0, 0, 0, .2);
    box-shadow: 0 0 1px rgba(0, 0, 0, .2)
  }
  a .cta__license:hover > dd {
    color: var(--color-primary)
  }
}
.cta__license {
  -webkit-box-shadow: var(--box-shadow);
  height: 73px;
  border-radius: 10px;
  background-color: #fff;
  box-shadow: var(--box-shadow);
  width: 100%;
}
.cta__licenses a {
  width: calc(50% - 2.5px);
}
.cta__licenses a:has(.last) {
  width: 100%;
}
.cta__license dt {
  padding: 11px 0 1px;
  color: var(--color-primary);
  font-weight: 700;
  font-size: 12px;
  font-family: var(--font-family-latin);
  letter-spacing: -.02em;
  text-align: center
}
.cta__license dd {
  font-weight: 700;
  font-size: 12px;
  line-height: 1.35;
  text-align: center
}
.cta__license dd small {
  font-weight: normal;
  font-size: 10px;
}
.cta__title {
  font-weight: 700;
  font-size: 24px;
  line-height: 1.65;
  white-space: nowrap
}
.cta__title b {
  color: var(--color-primary);
  font-weight: 700
}
.cta__textbox {
  margin: 24px 0 0;
  font-size: 14px;
  line-height: 1.75
}
.cta__image {
  z-index: 1;
  position: relative;
  margin: 36px 0 0;
  overflow: hidden;
  text-align: center
}
.cta__image img {
  border-radius: 20px 20px 0 0
}
.cta__licenses {
  display: flex;
  flex-wrap: wrap;
  position: relative;
  margin: -39px 0 0;
  gap: 5px;
  z-index: 10;
}
@media (max-width:1023.8px) {
  .cta__licenses a .cta__license.last {
    width: 100%;
  }
  .cta__licenses a .cta__license.last dt {
    position: relative;
    left: -140px;
  }
  .cta__licenses a .cta__license.last dd {
    gap: 10px;
  }
  .cta__licenses a .cta__license.last dd span + br, .cta__licenses a .cta__license.last dd small + br {
    display: none;
  }
}
@media (max-width:767.8px) {
  .cta__licenses a .cta__license.last dt {
    position: relative;
    left: -60px;
  }
}
@media (min-width:1024px) {
  .cta__licenses {
    -ms-grid-columns: 1fr 1fr;
    display: -ms-grid;
    display: grid;
    z-index: 2;
    position: relative;
    grid-template-columns: 1fr 1fr;
    margin: -39px 0 0;
    gap: 5px
  }
  .cta__license {
    width: auto;
  }
  .cta__licenses .cta__license.last {
    position: relative;
    align-items: center;
    height: 100px;
  }
  .cta__licenses .cta__license.last dt {
    margin-bottom: 40px;
  }
}
@media (min-width:768px) {
  .cta__licenses a {
    /* width: 100%; */
  }
  .cta__licenses a:last-child {
    /* width: 100%; */
  }
  .cta__license dd {
    font-size: 18px
  }
  .cta__license dd small {
    display: inline-block;
    margin-top: 1em;
    padding-left: 1em;
    font-weight: normal;
    font-size: 16px;
  }
  .cta__license dt {
    font-size: 15px;
    line-height: 1.35
  }
  .cta__title {
    font-size: 42px;
    line-height: 1.4
  }
  .cta__textbox {
    margin: 22px 0 0;
    font-size: 16px
  }
}
@media (min-width:1024px) {
  .cta {
    position: relative;
    min-height: 668px;
    padding: 60px 0 0
  }
  .cta__container {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -ms-grid-columns: 600px 305px;
    display: -ms-grid;
    display: grid;
    z-index: 2;
    position: relative;
    grid-template-columns: 600px 305px;
    grid-template-areas: "header license""footer license";
    justify-content: space-between
  }
  .cta__header {
    grid-area: header
  }
  .cta__licenses {
    -ms-grid-columns: 1fr;
    -ms-grid-rows: (80px)[4];
    grid-template-rows: repeat(4, 80px);
    grid-template-columns: 1fr;
    grid-area: license;
    margin: 0;
    padding: 0;
    gap: 20px
  }
  .cta__licenses a {
    width: 100%;
  }
  .cta__license {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    align-items: center;
    height: 80px
  }
  .cta__license dt {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    padding: 0 20px 0 20px;
    text-align: left
  }
  .cta__license dd {
    text-align: left
  }
  .cta__footer {
    -ms-grid-columns: 1fr;
    -ms-grid-rows: (60px)[2];
    display: -ms-grid;
    display: grid;
    grid-template-rows: repeat(2, 60px);
    grid-template-columns: 1fr;
    grid-area: footer;
    max-width: 343px;
    margin: 38px 0 0;
    gap: 20px
  }
  .cta__image {
    display: none
  }
  .cta__bg {
    display: block;
    z-index: 1;
    position: absolute;
    top: 0;
    left: calc(50% - 140px);
    width: calc(50% + 140px);
    min-width: 780px;
    height: 666px;
    overflow: hidden;
    border-radius: 50px 0 0 50px;
    pointer-events: none
  }
  .cta__bg img {
    -o-object-position: left top;
    object-position: left top
  }
}
@media (min-width:1024px) {
  .cta__header {
    -ms-grid-row: 1;
    -ms-grid-column: 1
  }
  .cta__licenses {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 2
  }
  .cta__footer {
    -ms-grid-row: 2;
    -ms-grid-column: 1
  }
}
@media (max-width:1023.98px) {
  .cta__license {
    height: 90px
  }
  .cta__license dt {
    line-height: 1
  }
  .cta__license dd {
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 48px
  }
  .cta__footer {
    -ms-grid-columns: 1fr;
    display: -ms-grid;
    display: grid;
    grid-template-columns: 1fr;
    max-width: 350px;
    margin: 40px auto 0;
    gap: 10px
  }
}
@media (max-width:767.98px) {
  .cta__license {
    height: 73px
  }
  .cta__license dd {
    height: 36px
  }
  .cta__footer {
    max-width: 280px
  }
}
.cta-button {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 50px;
  overflow: hidden;
  gap: 4px;
  border-radius: 25px;
  background: var(--gradation-primary) no-repeat center center/100% 100%
}
.cta-button::before {
  -webkit-transition: 0.3s opacity ease-in-out;
  -o-transition: 0.3s opacity ease-in-out;
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 25px;
  background-color: var(--color-primary);
  content: "";
  opacity: 0;
  transition: 0.3s opacity ease-in-out
}
@media (hover:hover) {
  .cta-button:hover::before {
    opacity: 1
  }
}
.cta-button[data-type=trial] {
  padding: 0 10px 0 0;
  border: 2px solid #fff
}
.cta-button[data-type=download]::after {
  -webkit-transition: 0.3s background-color ease-in-out;
  -o-transition: 0.3s background-color ease-in-out;
  z-index: 1;
  position: absolute;
  top: 2px;
  left: 2px;
  width: calc(100% - 4px);
  height: calc(100% - 4px);
  border-radius: 25px;
  background-color: #fff;
  content: "";
  transition: 0.3s background-color ease-in-out
}
.cta-button[data-type=download] .cta-button__text {
  -webkit-transition: 0.3s color ease-in-out;
  -o-transition: 0.3s color ease-in-out;
  color: var(--color-primary);
  transition: 0.3s color ease-in-out
}
.cta-button[data-type=download] .cta-button__arrow .fillPath {
  fill: var(--color-primary);
  -webkit-transition: 0.3s fill ease-in-out;
  -o-transition: 0.3s fill ease-in-out;
  transition: 0.3s fill ease-in-out
}
@media (hover:hover) {
  .cta-button[data-type=download]:hover::after {
    background-color: var(--color-primary)
  }
  .cta-button[data-type=download]:hover .cta-button__text {
    color: #fff
  }
  .cta-button[data-type=download]:hover .cta-button__arrow .fillPath {
    fill: #fff
  }
}
.cta-button__text {
  z-index: 3;
  position: relative;
  color: #fff;
  font-weight: 700;
  font-size: 16px
}
.cta-button__arrow {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 20px;
  z-index: 3;
  position: absolute;
  right: 12px;
  flex: 0 0 20px;
  width: 20px;
  line-height: 1
}
.cta-button__arrow .fillPath {
  fill: #fff
}
@media (min-width:768px) {
  .cta-button {
    height: 60px;
    border-radius: 30px
  }
  .cta-button::before {
    border-radius: 30px
  }
  .cta-button[data-type=trial] {
    padding: 0 30px 0 0
  }
  .cta-button[data-type=download] {
    padding: 0 20px 0 0
  }
  .cta-button[data-type=download]::after {
    border-radius: 30px
  }
  .cta-button__text {
    font-size: 18px
  }
  .cta-button__arrow {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 25px;
    right: 30px;
    flex: 0 0 25px;
    width: 25px
  }
}
.maker {
  z-index: 2;
  position: relative;
  padding: 24px 0 17px;
  background: #fff;
}
.maker__logos {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 11px 0
}
.maker__logos figure {
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(100% / 3);
}
.maker__logos .logo-spacer {
  width: 100%;
}
@media (min-width:768px) {
  .maker {
    padding: 24px 0 17px;
  }
  .maker__logos {
    gap: 9px 0
  }
  .maker__logos figure {
    width: calc(100% / 5);
  }
  .maker__logos .logo-google img {
    width: 136px
  }
  .maker__logos .logo-amazon img {
    width: 146px
  }
  .maker__logos .logo-microsoft img {
    width: 168px
  }
  .maker__logos .logo-astellas img {
    width: 149px
  }
  .maker__logos .logo-seven img {
    width: 50px
  }
  .maker__logos .logo-epson img {
    width: 133px
  }
  .maker__logos .logo-sompojapan img {
    width: 169px
  }
  .maker__logos .logo-ricoh img {
    width: 142px
  }
  .maker__logos .logo-sourcenext img {
    width: 171px
  }
}
@media (max-width:767.98px) {
  .maker__container {
    -ms-grid-columns: 1fr;
    display: -ms-grid;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas: "title""logos""description"
  }
  .maker__logos {
    grid-area: logos;
    -ms-grid-row: 2;
    -ms-grid-column: 1
  }
  .maker__logos .logo-google img {
    width: 73%
  }
  .maker__logos .logo-amazon img {
    width: 78.3676470588%
  }
  .maker__logos .logo-microsoft img {
    width: 78%
  }
  .maker__logos .logo-astellas img {
    width: 79.9779411765%
  }
  .maker__logos .logo-seven img {
    width: 30%
  }
  .maker__logos .logo-epson img {
    width: 68%
  }
  .maker__logos .logo-sompojapan img {
    width: 80%
  }
  .maker__logos .logo-ricoh img {
    width: 76.2205882353%
  }
  .maker__logos .logo-sourcenext img {
    width: 88%
  }
}
/*About*/
.about {
  padding-block: 20px;
}
.about__text p {
  font-size: 14px;
  font-weight: 500;
}
@media (min-width:768px) {
  .about {
    padding-block: 25px 40px;
  }
  .about__text p {
    text-align: center;
    font-size: 16px;
  }
}
@media (max-width:767.98px) {
  .about__text p br:not(.sp) {
    display: none;
  }
}
/*Reason*/
.reason {
  position: relative;
  padding-block: 60px 40px;
  background-color: #fff
}
.reason::before {
  z-index: 1;
  position: absolute;
  top: 0;
  right: 0;
  width: calc(335/3.75*1%);
  height: 100%;
  background: var(--gradation-secondary);
  content: "";
}
.reason .container {
  position: relative;
  z-index: 1;
}
.reason__title span strong {
  font-weight: inherit;
  color: #CB1F27;
}
.reason__title span span {
  font-weight: inherit;
  color: var(--color-primary);
}
.reason__title span b {
  font-size: calc(50/40*1em);
  font-weight: inherit;
  color: var(--color-primary);
}
.reason__point {
  margin-top: 30px;
}
.reason__point-item {
  counter-increment: mycounter;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  flex-direction: column;
}
.reason__point-item + .reason__point-item {
  margin-top: 30px;
}
.reason__point-item:nth-of-type(odd) {
  flex-direction: column;
}
.reason__point-item::before {
  content: counter(mycounter, decimal-leading-zero);
  width: 100%;
  margin-bottom: 10px;
  font-size: 14px;
  font-weight: 700;
  color: var(--color-primary);
  font-family: 'proxima-nova';
}
.reason__point-item-ph {
  margin-bottom: 30px;
  width: 100%;
}
.reason__point-item-info {
  width: 100%;
}
.reason__point-item-info-title {
  margin-bottom: 20px;
}
.reason__point-item-info-title p {
  font-size: 20px;
  font-weight: 700;
}
.reason__point-item-info-text p {
  font-size: 14px;
}
.reason__point-item-info-text p + p {
  margin-top: 10px;
}
.reason__point-item-info-text p span {
  font-size: 14px;
  font-weight: 700;
  color: var(--color-primary);
}
.reason__point-item-info-remarks {
  margin-top: 20px;
}
.reason__point-item-info-remarks p {
  font-size: 12px;
  color: #707070;
}
.reason__point-item-info-case {
  margin-block: 15px;
  padding: 10px 15px;
  background: #fff;
  border-radius: 5px;
}
.reason__point-item-info-case li {
  position: relative;
  padding-left: 1.25em;
  font-size: 14px;
}
.reason__point-item-info-case li::before {
  position: absolute;
  left: 0;
  content: "・";
  font-size: 14px;
  font-weight: 700;
  color: var(--color-primary);
}
@media (min-width:768px) {
  .reason {
    padding-block: 70px 100px;
  }
  .reason::before {
    width: calc(1100/12.8*1%);
  }
  .reason__point {
    margin-top: 60px;
  }
  .reason__point-item {
    flex-direction: row;
  }
  .reason__point-item + .reason__point-item {
    margin-top: 80px;
  }
  .reason__point-item:nth-of-type(odd) {
    flex-direction: row-reverse;
  }
  .reason__point-item::before {
    width: 100%;
    margin-bottom: 20px;
    font-size: 20px;
  }
  .reason__point-item:nth-of-type(even)::before {
    padding-left: calc(580/10.8*1%);
  }
  .reason__point-item-ph {
    margin-top: 0;
    margin-bottom: 0;
    width: calc(500/10.8*1%);
  }
  .reason__point-item-info {
    width: calc(500/10.8*1%);
  }
  .reason__point-item-info-title {
    margin-bottom: 27px;
  }
  .reason__point-item-info-title p {
    font-size: 30px;
    font-weight: 700;
  }
  .reason__point-item-info-text p {
    font-size: 16px;
  }
  .reason__point-item-info-text p + p {
    margin-top: 10px;
  }
  .reason__point-item-info-text p span {
    font-size: 16px;
    font-weight: 700;
    color: var(--color-primary);
  }
  .reason__point-item-info-remarks {
    margin-top: 30px;
  }
  .reason__point-item-info-remarks p {
    font-size: 14px;
    color: #707070;
  }
  .reason__point-item-info-case {
    margin-block: 15px;
    padding: 20px 25px;
    max-width: 456px;
    background: #fff;
    border-radius: 5px;
  }
  .reason__point-item-info-case li {
    font-size: 14px;
  }
  .reason__point-item-info-case li::before {
    content: "・";
    font-size: 14px;
    font-weight: 700;
    color: var(--color-primary);
  }
}
/*Question*/
.question {
  padding-block: 60px 0;
  background: #fff;
}
.question__container {
  margin: 30px 0 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.question__item {
  flex: 1;
  border-radius: 5px;
  background: #fff;
  box-shadow: var(--box-shadow);
}
.question__item-title {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  width: 100%;
  height: 50px;
  background: var(--color-primary);
  border-radius: 5px 5px 0 0;
}
.question__item-title-icon {}
.question__item-title p {
  font-size: 18px;
  font-weight: 700;
  color: #fff;
}
.question__item-cnt {
  padding: 15px 20px 20px;
  border-radius: 0 0 5px 5px;
}
.question__item-text > p {
  font-size: 14px;
}
.question__item-text > p + p {
  margin-top: 1.75em;
}
.question__item-text--attn {
  margin-block: 20px;
  padding: 16px;
  background: #FFF7F2;
  border-radius: 5px;
}
.question__item-text--attn p {
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  color: var(--color-primary);
}
.question__item-text--row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-block: 30px;
}
.question__item-text--row p {
  padding: 10px;
  width: 100%;
  background: #FFF7F2;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  color: var(--color-primary);
}
@media (min-width:768px) {
  .question {
    padding-block: 100px 0;
  }
  .question h2 br {
    display: none
  }
  .question__container {
    margin: 50px 0 0;
    display: flex;
    flex-direction: row;
    gap: 40px;
  }
  .question__item {
    flex: 1;
  }
  .question__item-title {
    height: 60px;
  }
  .question__item-title p {
    font-size: 20px;
  }
  .question__item-cnt {
    padding: 25px 30px 30px;
  }
  .question__item-text > p {
    font-size: 16px;
  }
  .question__item-text--attn {
    margin-block: 30px;
    padding: 16px;
  }
  .question__item-text--attn p {
    font-size: 18px;
  }
  .question__item-text--row {
    margin-block: 30px;
  }
  .question__item-text--row p {
    padding: 16px;
    width: calc((100% - 4px) / 2);
    background: #FFF7F2;
    font-size: 16px;
  }
}
/*Strength*/
.strength {
  padding-block: 70px 0;
  background-color: #fff
}
.strength__description {
  padding-block: 20px 30px;
}
.strength__description p {
  font-size: 14px;
  font-weight: 500;
}
.strength__description span {
  font-weight: 700;
  color: var(--color-primary);
}
@media (min-width:768px) {
  .strength {
    padding-block: 150px 0;
  }
  .strength__description {
    padding-block: 40px 60px;
  }
  .strength__description p {
    text-align: center;
    font-size: 16px;
  }
}
@media (max-width:767.98px) {
  .strength__description p br:not(.sp) {
    display: none;
  }
}
.strength__container {
  display: flex;
  flex-direction: column-reverse;
  gap: 20px;
}
.strength__spec {
  width: 100%;
}
.strength__spec-catch {
  display: none;
}
.strength__spec-item {}
.strength__spec-item + .strength__spec-item {
  margin-top: 30px;
}
.strength__spec-item-title {
  display: flex;
  gap: 10px;
  margin-bottom: 15px;
}
@media (max-width:767.98px) {
  .strength__spec-item .strength__spec-item-title figure img {
    width: 40px;
  }
}
.strength__spec-item-title p {
  flex: 1;
  font-size: 20px;
  font-weight: 700;
}
.strength__spec-item-remarks {
  margin-bottom: 20px;
}
.strength__spec-item-remarks p {
  font-size: 14px;
}
.strength__spec-item-label {
  display: inline-flex;
  justify-content: center;
  padding: 3px 15px;
  min-width: 190px;
  border-radius: 5px 5px 0 0;
  background: #222222;
}
.strength__spec-item-label p {
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
}
.strength__spec-item-text {
  padding: 10px 15px;
  border-radius: 5px;
  border: 1px solid #D6D6D6;
}
.strength__spec-item-text p {
  font-size: 14px;
}
.strength__spec-item-text p + p {
  margin-top: 10px;
}
.strength__spec-item-text p span {
  font-size: 14px;
  font-weight: 700;
  color: var(--color-primary);
}
.strength__photo {
  width: 100%;
}
@media (min-width:768px) {
  .strength__container {
    display: flex;
    flex-direction: row;
    gap: 80px;
  }
  .strength__spec {
    width: 500px;
  }
  .strength__spec-catch {
    display: block;
    margin-bottom: 48px;
    padding: 8px;
    border-radius: 5px;
    background: #FF5F00;
  }
  .strength__spec-catch p {
    text-align: center;
    font-size: 18px;
    font-weight: 700;
    color: #fff;
  }
  .strength__spec-item {}
  .strength__spec-item + .strength__spec-item {
    margin-top: 70px;
  }
  .strength__spec-item-title {
    margin-bottom: 27px;
  }
  .strength__spec-item-title p {
    font-size: 30px;
  }
  .strength__spec-item-remarks {
    margin-bottom: 30px;
  }
  .strength__spec-item-remarks p {
    font-size: 16px;
  }
  .strength__spec-item-label {
    min-width: 210px;
  }
  .strength__spec-item-label p {
    font-size: 16px;
  }
  .strength__spec-item-text {
    padding: 20px 25px;
  }
  .strength__spec-item-text p {
    font-size: 16px;
  }
  .strength__spec-item-text p + p {
    margin-top: 10px;
  }
  .strength__spec-item-text p span {
    font-size: 16px;
  }
  .strength__photo {
    margin-right: -100px;
    width: 600px;
  }
  .strength__photo picture, .strength__photo img {
    position: sticky;
    top: 0;
  }
}
/*Proposal*/
.proposal {
  padding-block: 50px 0;
  background-color: #fff
}
.proposal__description {
  margin-top: 20px;
}
.proposal__description p {
  text-align: center;
  font-size: 14px;
}
@media (min-width:768px) {
  .proposal {
    padding-block: 150px 0;
  }
  .proposal__description {
    margin-top: 40px;
  }
  .proposal__description p {
    font-size: 16px;
  }
}
@media (max-width:767.98px) {
  .proposal__description p br:not(.sp) {
    display: none;
  }
}
.proposal__case {
  margin-top: 30px;
}
.proposal__case-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.proposal__case-item {
  display: flex;
  flex-direction: column;
  padding: 20px;
  background: #F7F7F8;
  width: 100%;
}
.proposal__case-item-th {
  position: relative;
  margin-bottom: 15px;
  padding: 10px;
  background: #222;
}
.proposal__case-item-th::after {
  content: "懸念";
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: -10px;
  left: -10px;
  width: 44px;
  height: 24px;
  background: #FFE200;
  font-size: 12px;
  font-weight: 700;
}
.proposal__case-item-th p {
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
}
.proposal__case-item-td {
  flex: 1;
  position: relative;
  padding: 20px;
  background: #fff;
}
.proposal__case-item-td::after {
  content: "解決策";
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: -10px;
  left: -10px;
  width: 44px;
  height: 24px;
  background: #FF5F00;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
}
.proposal__case-item-td p {
  font-size: 14px;
}
@media (min-width:768px) {
  .proposal__case {
    margin-top: 50px;
  }
  .proposal__case-row {
    gap: 40px;
  }
  .proposal__case-item {
    width: calc((100% - 40px) / 2);
  }
  .proposal__case-item-th {
    padding: 12px 55px;
  }
  .proposal__case-item-th::after {
    top: -5px;
    left: -5px;
    width: 52px;
    height: 24px;
    font-size: 14px;
  }
  .proposal__case-item-th p {
    font-size: 18px;
  }
  .proposal__case-item-td {
    padding: 25px;
  }
  .proposal__case-item-td::after {
    top: -5px;
    left: -5px;
    width: 52px;
    height: 24px;
    font-size: 14px;
  }
  .proposal__case-item-td p {
    font-size: 14px;
  }
}
@media (max-width:767.98px) {
  .proposal__case-item-th br:not(.sp) {
    display: none;
  }
}
/*Fee*/
.fee {
  padding-block: 50px 70px;
  background-color: #fff
}
.fee__chart {
  margin-block: 30px 40px;
  margin-inline: auto;
  width: 100%;
  max-width: 903px;
  overflow: auto;
}
@media (min-width:768px) {
  .fee {
    padding-block: 150px 100px;
  }
  .fee__chart {
    margin-block: 40px 60px;
  }
}
.fee__table {
  width: 906px;
}
.fee__table-row {
  display: flex;
  gap: 3px;
}
.fee__table-row:not(:first-of-type) {
  margin-top: 3px;
}
.fee__table-item {
  flex: 1;
}
.fee__table-row:nth-of-type(even) .fee__table-item {
  background: #FFF7F2;
}
.fee__table-item-th {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 60px;
  border-radius: 5px 5px 0 0;
  background: #FF5F00;
}
.fee__table-item-th p {
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  font-family: 'proxima-nova', "Noto Sans JP";
}
.fee__table-item-td {
  display: flex;
  align-items: center;
  padding: 0 20px;
  width: 100%;
  height: 60px;
}
.fee__table-item-td p {
  font-size: 20px;
  font-weight: 500;
}
.fee__table-item-td--center p {
  width: 100%;
  text-align: center;
  font-size: 14px;
  font-weight: 400;
}
.fee__table-item-td--center p .num {
  font-size: 24px;
  font-weight: 700;
  color: var(--color-primary);
  font-family: 'proxima-nova', "Noto Sans JP";
}
.fee__table-item-td--center p .text {
  font-size: 16px;
}
@media (min-width:768px) {
  .fee__table {
    width: 100%;
  }
}
.fee__guide {
  margin-inline: auto;
  max-width: 903px;
}
.fee__guide-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.fee__guide-item {
  width: calc((100% - 10px)/2);
  border-radius: 5px;
  box-shadow: var(--box-shadow);
}
.fee__guide-item-th {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 40px;
  background: #FF5F00;
  border-radius: 5px 5px 0 0;
}
.fee__guide-item-th p {
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  font-family: 'proxima-nova';
  letter-spacing: -0.05em;
}
.fee__guide-item-th p small {
  font-size: 12px;
}
.fee__guide-item-td {
  padding: 0 10px 10px;
  border-radius: 0 0 5px 5px;
}
.fee__guide-item-td-anc {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 50px;
  background: #FFF7F2;
}
.fee__guide-item-td-anc p {
  display: flex;
  gap: 8px;
  border-bottom: 1px solid #FF5F00;
  font-size: 14px;
  font-weight: 700;
  color: #FF5F00;
}
.fee__guide-item-td-anc p::after {
  content: "";
  width: 12px;
  aspect-ratio: 1;
  background: url(../images/window_icon.svg) no-repeat center center / contain;
}
@media (min-width:768px) {
  .fee__guide-row {
    display: flex;
    flex-wrap: nowrap;
    gap: 10px;
  }
  .fee__guide-item {
    flex: 1;
    width: auto;
  }
  .fee__guide-item-td-anc {
    height: 60px;
  }
}
/*Comparison*/
.comparison {
  padding: 62px 0 84px;
  background-color: #fff
}
.comparison__chart {
  margin: 40px 0 0
}
.comparison__table {
  display: block;
  width: 100%;
  min-width: 870px;
  overflow: hidden;
  border-radius: 10px
}
.comparison__table th {
  width: 23.3%
}
.comparison__table td {
  position: relative;
  width: 25.5666666667%;
  font-size: 15px
}
.comparison__table thead, .comparison__table tbody {
  display: block
}
.comparison__table tr {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex
}
.comparison__table th, .comparison__table td {
  display: block
}
.comparison__table thead {
  background-color: rgba(var(--color-primary-rgb), .05)
}
.comparison__table thead td {
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  height: 57px;
  color: var(--color-primary);
  font-weight: 700;
  font-size: 14px;
  font-family: var(--font-family-latin);
  text-align: center
}
.comparison__table thead td small {
  display: block;
  font-size: 0.8em;
  line-height: 1;
}
.comparison__table tbody tr {
  min-height: 57px
}
.comparison__table tbody tr:nth-child(odd) {
  background-color: #fff
}
.comparison__table tbody tr:nth-child(even) {
  background-color: var(--color-bg-secondary-light)
}
.comparison__table tbody th {
  -webkit-box-align: center;
  -ms-flex-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  font-weight: 700;
  font-size: 12px;
  line-height: 1.3
}
.comparison__table tbody th.align-top {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start
}
.comparison__table tbody th small {
  font-weight: 400;
  font-size: 10px
}
.comparison__table tbody th b {
  display: block;
  padding-left: 1em;
  color: var(--color-primary);
  font-weight: 700;
  font-size: 10px;
  text-indent: -1em
}
.comparison__table tbody th em {
  display: block;
  margin: 0 0 .8em
}
.comparison__table tbody td {
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center
}
.comparison__table tbody td img {
  display: inline-block;
  line-height: 0;
  vertical-align: bottom
}
.comparison__table tbody td .icon-check {
  width: 20px
}
.comparison__table tbody td .icon-bar {
  width: 12px
}
.comparison__table tbody td .icon-triangle {
  width: 26px
}
.comparison__table tbody .button-primary[data-size=small] .button-primary__text {
  font-size: 12px
}
.comparison__table .price {
  font-size: 10px;
  text-align: center
}
.comparison__table .title {
  padding: 0;
  text-align: center;
  font-size: 12px;
  color: #F68B1F;
}
.comparison__table .soon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 50px;
  text-align: center;
  font-size: 20px;
  font-weight: bold;
  color: #F68B1F;
  letter-spacing: -0.08em;
  font-family: var(--font-family-latin);
}
.comparison__table .price b {
  margin: 0 .15em 0 0;
  font-weight: 600;
  font-size: 17px;
  font-family: var(--font-family-latin)
}
@media (min-width:768px) {
  .comparison {
    padding: 101px 0 121px
  }
  .comparison__chart {
    margin: 50px 0 0
  }
  .comparison__table {
    min-width: 980px;
  }
  .comparison__table th {
    width: 30.5555555556%
  }
  .comparison__table td {
    width: 23.1481481481%
  }
  .comparison__table td::before {
    position: absolute;
    top: 0;
    left: 0;
    width: 2px;
    height: 100%;
    background: -webkit-gradient(linear, left bottom, left top, from(rgba(var(--color-bg-primary-light-rgb), 1)), color-stop(49.9%, rgba(var(--color-bg-primary-light-rgb), 1)), color-stop(50%, rgba(var(--color-bg-primary-light-rgb), 0)), to(rgba(var(--color-bg-primary-light-rgb), 0))) repeat-y left top/2px 10px;
    background: -o-linear-gradient(bottom, rgba(var(--color-bg-primary-light-rgb), 1) 0%, rgba(var(--color-bg-primary-light-rgb), 1) 49.9%, rgba(var(--color-bg-primary-light-rgb), 0) 50%, rgba(var(--color-bg-primary-light-rgb), 0) 100%) repeat-y left top/2px 10px;
    background: linear-gradient(0deg, rgba(var(--color-bg-primary-light-rgb), 1) 0%, rgba(var(--color-bg-primary-light-rgb), 1) 49.9%, rgba(var(--color-bg-primary-light-rgb), 0) 50%, rgba(var(--color-bg-primary-light-rgb), 0) 100%) repeat-y left top/2px 10px;
    content: ""
  }
  .comparison__table thead td {
    height: 80px;
    font-size: 18px;
    letter-spacing: .2px
  }
  .comparison__table tbody tr {
    min-height: 70px
  }
  .comparison__table tbody th {
    padding: 16px 0 12px 40px;
    font-size: 16px
  }
  .comparison__table tbody th small {
    font-size: 14px
  }
  .comparison__table tbody th b {
    font-size: 12px
  }
  .comparison__table tbody th em {
    font-size: 18px
  }
  .comparison__table tbody th.align-top {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    padding-top: 24px
  }
  .comparison__table tbody td .icon-check {
    width: 24px
  }
  .comparison__table tbody td .icon-bar {
    width: 16px
  }
  .comparison__table tbody td .icon-triangle {
    width: 26px
  }
  .comparison__table tbody .button-primary[data-size=small] .button-primary__text {
    font-size: 14px
  }
  .comparison__table .title {
    padding: 0;
    text-align: center;
    font-size: 16px;
    color: #F68B1F;
  }
  .comparison__table .pricebox {
    -webkit-box-flex: 1;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    max-width: 164px;
    padding: 17px 0 29px
  }
  .comparison__table .price {
    padding: 0 0 9px;
    font-size: 13px
  }
  .comparison__table .soon {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 50px;
    text-align: center;
    font-size: 26px;
    font-weight: bold;
    color: #F68B1F;
    letter-spacing: -0.08em;
    font-family: var(--font-family-latin);
  }
}
@media (max-width:767.98px) {
  .comparison__table td::before {
    position: absolute;
    top: 0;
    left: 0;
    width: 2px;
    height: 100%;
    background: -webkit-gradient(linear, left bottom, left top, from(rgba(var(--color-bg-primary-light-rgb), 1)), color-stop(49.9%, rgba(var(--color-bg-primary-light-rgb), 1)), color-stop(50%, rgba(var(--color-bg-primary-light-rgb), 0)), to(rgba(var(--color-bg-primary-light-rgb), 0))) repeat-y left top/2px 10px;
    background: -o-linear-gradient(bottom, rgba(var(--color-bg-primary-light-rgb), 1) 0%, rgba(var(--color-bg-primary-light-rgb), 1) 49.9%, rgba(var(--color-bg-primary-light-rgb), 0) 50%, rgba(var(--color-bg-primary-light-rgb), 0) 100%) repeat-y left top/2px 10px;
    background: linear-gradient(0deg, rgba(var(--color-bg-primary-light-rgb), 1) 0%, rgba(var(--color-bg-primary-light-rgb), 1) 49.9%, rgba(var(--color-bg-primary-light-rgb), 0) 50%, rgba(var(--color-bg-primary-light-rgb), 0) 100%) repeat-y left top/2px 10px;
    content: ""
  }
  .comparison__table td + td::before {
    left: 0
  }
  .comparison__table tbody td {
    padding: 12px 0 12px
  }
  .comparison__table tbody th {
    padding: 12px 0 12px 15px
  }
  .comparison__table tbody th small {
    white-space: nowrap
  }
  .comparison__table tbody th b {
    white-space: nowrap
  }
  .comparison__table .pricebox .button-primary {
    width: 140px;
    height: 40px;
    margin: 5px 0 0
  }
}
/*Case*/
.case {
  position: relative;
  padding-block: 40px 0;
  background-color: #fff;
  z-index: 1;
}
.case::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 80%;
  background-image: var(--gradation-thurdery);
  z-index: -1;
}
.case__cards {
  margin-top: 30px;
}
.case .slick-list {
  overflow: visible !important;
}
.case .slick-track {
  display: flex;
}
.case .slick-slide {
  height: auto !important;
}
.case .slick-next, .case .slick-prev {
  width: 30px;
  height: 30px;
  z-index: 10;
}
.case .slick-next {
  right: -5px;
}
.case .slick-prev {
  left: -5px;
}
.case .slick-next::before, .case .slick-prev::before {
  display: block;
  position: relative;
  content: "";
  background: url(../images/case_arw.svg) no-repeat center center / contain;
  width: 30px;
  height: 30px;
  z-index: 10;
  opacity: 1;
}
.case .slick-next::before {
  transform: scaleX(-1);
}
@media (min-width:768px) {
  .case {
    padding-block: 80px 0;
  }
  .case__cards {
    margin-top: 50px;
  }
  .case .slick-next, .case .slick-prev {
    width: 40px;
    height: 40px;
    z-index: 10;
  }
  .case .slick-next {
    top: -90px;
    transform: initial;
    right: 0;
  }
  .case .slick-prev {
    top: -90px;
    transform: initial;
    left: auto;
    right: 50px;
  }
  .case .slick-next::before, .case .slick-prev::before {
    width: 40px;
    height: 40px;
  }
}
.case-card {
  position: relative;
  margin-inline: 0 15px;
  max-width: 320px;
  border-radius: 5px;
  background-color: #fff;
  box-shadow: var(--box-shadow);
}
.case-card__in {
  z-index: 2;
  position: relative;
  padding: 25px 30px 30px;
  border-radius: 5px;
  background-color: #fff
}
.case-card__name {
  margin-bottom: 5px;
}
.case-card__name p {
  font-size: 18px;
  font-weight: 700;
}
.case-card__data {
  margin-bottom: 20px;
}
.case-card__data p {
  font-size: 12px;
  color: #707070;
}
.case-card__task {
  margin-bottom: 10px;
  padding: 10px 15px 15px;
  border-radius: 5px;
  background: #F6F7F7;
  font-size: 14px;
}
.case-card__task-title {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid #D6D6D5;
  font-weight: 700;
}
.case-card__effect {
  padding: 10px 15px 15px;
  border-radius: 5px;
  background: #FFF7F2;
  font-size: 14px;
  color: #FF5F00;
}
.case-card__effect-title {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid #FFDFCC;
  font-weight: 700;
}
@media (min-width:768px) {
  .case-card {
    margin-right: 30px;
    margin-left: 0;
    max-width: 320px;
  }
  .case-card__in {
    padding: 30px;
  }
  .case-card__name {
    margin-bottom: 5px;
  }
  .case-card__name p {
    font-size: 18px;
  }
  .case-card__data {
    margin-bottom: 20px;
  }
  .case-card__data p {
    font-size: 12px;
  }
  .case-card__task {
    font-size: 14px;
  }
  .case-card__task-title {
    margin-bottom: 10px;
    padding-bottom: 10px;
  }
  .case-card__effect {
    font-size: 14px;
  }
  .case-card__effect-title {
    margin-bottom: 10px;
    padding-bottom: 10px;
  }
}
.voice {
  padding: 70px 0 50px;
  background-color: #fff
}
.voice__cards {
  -ms-grid-columns: 1fr;
  display: -ms-grid;
  display: grid;
  grid-template-columns: 1fr;
  margin: 30px 0 0;
  gap: 20px 0
}
@media (min-width:768px) {
  .voice {
    padding-block: 100px
  }
  .voice__description {
    margin: 34px 0 0
  }
  .voice__cards {
    grid-template-columns: repeat(3, 1fr);
    margin: 50px 0 0;
    gap: 30px;
  }
}
.voice-card {
  -webkit-box-shadow: var(--box-shadow);
  position: relative;
  border-radius: 10px;
  background-color: #fff;
  box-shadow: var(--box-shadow)
}
.voice-card__in {
  z-index: 2;
  position: relative;
  padding: 25px 30px;
  border-radius: 5px;
  background-color: #fff
}
.voice-card__review {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-bottom: 5px;
  line-height: 1;
}
.voice-card__review-star {
  display: flex;
  gap: 2px;
}
.voice-card__review-star-icon {
  position: relative;
  width: 16px;
  aspect-ratio: 33/31;
  background: url(../images/star-frame.png) no-repeat center left /contain;
}
.voice-card__review-star-icon::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 16px;
  aspect-ratio: 33/31;
  background: url(../images/star-icon.png) no-repeat center left /contain;
}
.voice-card__review-star-icon--half::after {
  width: 8px;
  aspect-ratio: 16.5/31;
  background: url(../images/star-icon.png) no-repeat center left /cover;
}
.voice-card__review-star-icon--none::after {
  display: none;
}
.voice-card__review-text {
  font-size: 24px;
  font-family: 'proxima-nova';
  color: var(--color-primary)
}
.voice-card__category {
  z-index: 2;
  position: relative;
  margin-bottom: 20px;
}
.voice-card__category p {
  font-weight: 300;
  font-size: 12px;
  color: #707070;
  line-height: 1.85
}
.voice-card__comma {
  display: block;
  position: relative;
  width: 16px
}
.voice-card__comma--reverse {
  margin: 0 0 0 auto;
  transform: scale(-1);
}
.voice-card__textbox {}
.voice-card__textbox p {
  font-size: 16px;
}
@media (min-width:768px) {
  .voice-card__textbox p {
    font-size: 12px;
    line-height: 1.75
  }
  .voice-card__textbox p {
    font-size: 16px;
    line-height: 1.75
  }
  .voice-card__in {
    padding: 30px
  }
}
/*Faq*/
.faq {
  padding-block: 40px 35px;
  background-image: var(--gradation-thurdery);
}
.faq__main {
  display: -ms-grid;
  display: grid;
  gap: 5px 0
}
.faq__title {
  margin: 0 0 34px
}
@media (min-width:768px) {
  .faq {
    padding-block: 80px 100px;
  }
  .faq__title {
    margin: 0 0 40px
  }
}
.faq-block {
  padding: 20px;
  border-radius: 10px;
  background-color: #fff
}
.faq-block.is-hidden {
  display: none
}
.faq-block.is-hidden.is-ready {
  -webkit-transform: translateY(10px);
  -ms-transform: translateY(10px);
  display: block;
  transform: translateY(10px);
  opacity: 0
}
.faq-block.is-hidden.is-ready.is-view {
  -webkit-transition: 0.3s opacity ease-in-out, 0.3s -webkit-transform ease-in-out;
  -o-transition: 0.3s opacity ease-in-out, 0.3s transform ease-in-out;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0);
  opacity: 1;
  transition: 0.3s opacity ease-in-out, 0.3s -webkit-transform ease-in-out;
  transition: 0.3s opacity ease-in-out, 0.3s transform ease-in-out;
  transition: 0.3s opacity ease-in-out, 0.3s transform ease-in-out, 0.3s -webkit-transform ease-in-out
}
.faq-block__header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  cursor: pointer
}
.faq-block__header.is-open .faq-block__header-toggle::before {
  -webkit-transform: rotate(0deg);
  -ms-transform: rotate(0deg);
  transform: rotate(0deg)
}
.faq-block__header-icon {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 30px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex: 0 0 30px;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 2px;
  background-color: var(--color-primary);
  color: #fff;
  font-weight: 700;
  font-size: 22px;
  font-family: 'proxima-nova', "Noto Sans JP";
}
.faq-block__header-text {
  -webkit-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto;
  padding: 3px 14px 0;
  font-weight: 500;
  font-size: 14px;
  line-height: 1.85
}
.faq-block__header-toggle {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 30px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  flex: 0 0 30px;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background-color: var(--color-primary)
}
.faq-block__header-toggle::before, .faq-block__header-toggle::after {
  position: absolute;
  width: 46.6666666667%;
  height: 2px;
  border-radius: 2px;
  background-color: #fff;
  content: ""
}
.faq-block__header-toggle::before {
  -webkit-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  -webkit-transition: 0.3s -webkit-transform ease-in-out;
  -o-transition: 0.3s transform ease-in-out;
  transform: rotate(90deg);
  transition: 0.3s -webkit-transform ease-in-out;
  transition: 0.3s transform ease-in-out;
  transition: 0.3s transform ease-in-out, 0.3s -webkit-transform ease-in-out
}
.faq-block__body {
  height: 0;
  overflow: hidden
}
.faq-block__in {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 20px 0 0;
  padding: 20px 0 0;
  border-top: 1px solid #D7D6D6;
}
.faq-block__in-icon {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 30px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex: 0 0 30px;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 2px;
  background-color: var(--color-secondary);
  color: #fff;
  font-weight: 700;
  font-size: 22px;
  font-family: var(--font-family-latin)
}
.faq-block__in-text {
  -webkit-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto;
  padding: 3px 45px 0 15px;
  font-size: 12px;
  line-height: 1.65
}
@media (min-width:768px) {
  .faq-block {
    padding: 20px
  }
  .faq-block__header-icon {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 45px;
    flex: 0 0 45px;
    width: 45px;
    height: 45px;
    font-size: 26px
  }
  .faq-block__header-text {
    padding: 8px 20px 0;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.8
  }
  .faq-block__header-toggle {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 35px;
    flex: 0 0 35px;
    width: 35px;
    height: 35px
  }
  .faq-block__in {
    padding: 20px 0 0
  }
  .faq-block__in-icon {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 45px;
    flex: 0 0 45px;
    width: 45px;
    height: 45px;
    font-size: 26px
  }
  .faq-block__in-text {
    padding: 8px 90px 0 20px;
    font-size: 16px;
    line-height: 1.75
  }
}
/*Contact*/
.contact {
  padding-block: 50px;
  background: #fff;
}
.contact__about {
  margin-top: 50px;
}
.contact__about-logo {
  margin-inline: auto;
  max-width: 124px;
}
.contact__about-title {
  margin-top: 40px;
}
.contact__about-title-st {
  text-align: center;
  font-size: 20px;
  font-weight: 700;
}
.contact__about-text {
  margin-top: 30px;
}
.contact__about-text-st {
  text-align: center;
  font-size: 14px;
}
.contact__about-text-st + .contact__about-text-st {
  margin-top: 1.75em;
}
@media (min-width:768px) {
  .contact {
    padding-block: 100px;
  }
  .contact__about {
    margin-top: 100px;
  }
  .contact__about-title-st {
    font-size: 30px;
  }
  .contact__about-text-st {
    font-size: 14px;
  }
  .contact__about-text-st br.sp {
    display: none;
  }
}
/*Footer*/
.footer {
  position: relative;
  padding-block: 50px 20px;
  background-color: #FF5F00;
}
.footer__logo {
  text-align: center
}
.footer__logo img {
  width: 124px
}
.footer__sns {
  margin: 30px 0 0
}
.footer__menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 60px 0 0;
  gap: 5px 0
}
.footer__menu li {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 100%;
  flex: 0 0 100%;
  width: 100%;
  text-align: center
}
.footer__menu a {
  display: block;
  font-weight: 700;
  font-size: 14px;
  color: #fff;
  text-align: center;
}
@media (hover:hover) {
  .footer__menu a {
    -webkit-transition: 0.3s opacity ease-in-out;
    -o-transition: 0.3s opacity ease-in-out;
    transition: 0.3s opacity ease-in-out
  }
  .footer__menu a:hover {
    opacity: 0.7;
  }
}
.footer__copyright {
  display: block;
  margin: 40px 0 0;
  font-size: 10px;
  line-height: 1;
  font-family: var(--font-family-latin);
  text-align: center;
  color: #fff;
}
@media (min-width:768px) {
  .footer {
    padding-block: 80px
  }
  .footer__menu {
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    margin: 35px 0 0;
    gap: 0 31px
  }
  .footer__menu li {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    width: auto
  }
  .footer__copyright {
    margin: 37px 0 0
  }
}
.navigation {
  z-index: 1100;
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  max-width: 375px;
  height: 0;
  overflow: hidden;
  background-color: var(--color-bg-secondary-light)
}
.navigation__tips {
  margin: 8.5px 0 32.5px;
  font-size: 12px;
  text-align: center
}
.navigation__inner {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  padding: calc(45px + var(--header-height)) var(--gutter) 40px;
  gap: 30px
}
.navigation__sns {
  margin: 0 0 30px
}
.navigation__footer {
  width: 100%;
  max-width: 350px;
  margin: 0 auto
}
.navigation__download + .navigation__download, .navigation__campaign {
  margin-top: 10px
}
@media (min-width:768px) {
  .navigation__menu {
    width: 100%;
    max-width: 450px
  }
  .navigation__footer {
    margin: 40px auto 0
  }
}
@media (max-width:767.98px) {
  .navigation__inner {
    -ms-overflow-style: none;
    -webkit-overflow-scrolling: touch;
    height: 100dvh;
    overflow: auto;
    scrollbar-width: none
  }
  .navigation__inner::-webkit-scrollbar {
    display: none
  }
  .navigation__inner .cta-button, .navigation__inner .button-primary {
    height: 60px;
    border-radius: 30px
  }
  .navigation__inner .cta-button__text, .navigation__inner .button-primary__text {
    font-size: 18px
  }
  .navigation__inner .cta-button__arrow, .navigation__inner .button-primary__arrow {
    width: 25px
  }
  .navigation__inner .button-primary__text {
    padding: 0 20px 0 0
  }
  .navigation__inner .button-primary__arrow {
    position: absolute;
    right: 19px
  }
  .navigation__inner .cta-button::before, .navigation__inner .cta-button::after {
    border-radius: 30px
  }
  .navigation__inner .cta-button__text {
    padding: 0 20px 0 0
  }
  .navigation__inner .cta-button__arrow {
    right: 22px
  }
}
.nav-menu {
  -ms-grid-columns: 1fr 1fr;
  display: -ms-grid;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px 0
}
.nav-menu__item {
  -webkit-transition: 0.3s color ease-in-out;
  -o-transition: 0.3s color ease-in-out;
  position: relative;
  padding: 0 0 0 20px;
  font-size: 14px;
  line-height: 1;
  cursor: pointer;
  transition: 0.3s color ease-in-out
}
.nav-menu__item::before {
  -webkit-transition: 0.3s background-color ease-in-out;
  -o-transition: 0.3s background-color ease-in-out;
  position: absolute;
  position: absolute;
  top: calc(50% - 4px);
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--color-text-body);
  content: "";
  transition: 0.3s background-color ease-in-out
}
.nav-menu__item:hover {
  color: var(--color-primary)
}
.nav-menu__item:hover::before {
  background-color: var(--color-primary)
}
.sns-links {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
  gap: 5px
}
.sns-links a {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 40px;
  flex: 0 0 40px;
  width: 40px;
  width: 40px
}
@media (hover:hover) {
  .sns-links a {
    -webkit-transition: 0.3s opacity ease-in-out;
    -o-transition: 0.3s opacity ease-in-out;
    transition: 0.3s opacity ease-in-out
  }
  .sns-links a:hover {
    opacity: .6
  }
}
.pagetop {
  --right: calc(50% - 0.5 * var(--container));
  z-index: 50;
  position: fixed;
  right: max(var(--gutter), var(--right));
  bottom: 30px;
  width: 60px;
  height: 60px;
  opacity: 0;
  pointer-events: none
}
.pagetop.is-view {
  pointer-events: all
}
.pagetop.is-stop {
  position: absolute;
  top: -30px;
  bottom: auto
}
.pagetop__button {
  -webkit-box-shadow: 0 5px 20px rgba(34, 34, 34, .15);
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  box-shadow: 0 5px 20px rgba(34, 34, 34, .15);
  cursor: pointer
}
@media (hover:hover) {
  .pagetop__button {
    -webkit-transition: 0.3s opacity ease-in-out;
    -o-transition: 0.3s opacity ease-in-out;
    transition: 0.3s opacity ease-in-out
  }
  .pagetop__button:hover {
    opacity: .6
  }
}
@media (min-width:768px) {
  .pagetop {
    width: 80px;
    height: 80px
  }
  .pagetop.is-stop {
    top: -40px
  }
}
#download-menu, #trial-menu {
  display: none
}
.float-menu-wrapper {
  z-index: 5;
  position: relative
}
.float-menu-wrapper + .float-menu-wrapper {
  z-index: 4
}
.download-menu {
  -webkit-box-shadow: 0 2px 20px rgba(0, 0, 0, .15);
  position: absolute;
  left: calc(50% - 104px);
  width: 208px;
  height: 0;
  overflow: hidden;
  border-radius: 10px;
  background-color: var(--color-bg-cream);
  box-shadow: 0 2px 20px rgba(0, 0, 0, .15)
}
.download-menu.no-absolute {
  position: static;
  left: auto;
  margin: 10px auto 0
}
.download-menu__link {
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-transition: 0.3s background-color ease-in-out;
  -o-transition: 0.3s background-color ease-in-out;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  padding: 20px;
  gap: 10px;
  transition: 0.3s background-color ease-in-out
}
.download-menu__link + .download-menu__link {
  border-top: 1px dashed #D6D6D6
}
.download-menu__link::before {
  -webkit-transition: 0.3s background-color ease-in-out;
  -o-transition: 0.3s background-color ease-in-out;
  display: block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--color-text-body);
  content: "";
  transition: 0.3s background-color ease-in-out
}
.download-menu__link span {
  -webkit-transition: 0.3s color ease-in-out;
  -o-transition: 0.3s color ease-in-out;
  color: var(--color-text-body);
  font-weight: 700;
  font-size: 14px;
  line-height: 19px;
  transition: 0.3s color ease-in-out
}
.download-menu__link i {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 14px;
  flex: 0 0 14px;
  width: 14px;
  line-height: 0
}
.download-menu__link i path {
  fill: var(--color-text-body);
  -webkit-transition: 0.3s fill ease-in-out;
  -o-transition: 0.3s fill ease-in-out;
  transition: 0.3s fill ease-in-out
}
.download-menu__link:hover {
  background-color: var(--color-primary)
}
.download-menu__link:hover::before {
  background-color: #fff
}
.download-menu__link:hover span {
  color: #fff
}
.download-menu__link:hover i path {
  fill: #fff
}
.trial-menu {
  -webkit-box-shadow: 0 2px 20px rgba(0, 0, 0, .15);
  position: absolute;
  left: calc(50% - 106px);
  width: 212px;
  height: 0;
  overflow: hidden;
  border-radius: 10px;
  background-color: var(--color-bg-cream);
  box-shadow: 0 2px 20px rgba(0, 0, 0, .15);
  z-index: 1110;
}
.trial-menu__link {
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-transition: 0.3s background-color ease-in-out;
  -o-transition: 0.3s background-color ease-in-out;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  padding: 20px 10px;
  gap: 10px;
  transition: 0.3s background-color ease-in-out
}
.trial-menu__link + .trial-menu__link {
  border-top: 1px dashed #D6D6D6
}
.trial-menu__link::before {
  -webkit-transition: 0.3s background-color ease-in-out;
  -o-transition: 0.3s background-color ease-in-out;
  display: block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--color-text-body);
  content: "";
  transition: 0.3s background-color ease-in-out
}
.trial-menu__link span {
  -webkit-transition: 0.3s color ease-in-out;
  -o-transition: 0.3s color ease-in-out;
  color: var(--color-primary);
  font-weight: 700;
  font-size: 14px;
  line-height: 1.5;
  font-family: var(--font-family-latin);
  transition: 0.3s color ease-in-out
}
.trial-menu__link:hover {
  background-color: var(--color-primary)
}
.trial-menu__link:hover::before {
  background-color: #fff
}
.trial-menu__link:hover span {
  color: #fff
}
@media (min-width:768px) {
  .trial-menu {
    left: calc(50% - 127px);
    width: 274px
  }
  .trial-menu__link span {
    font-size: 15px
  }
}
.modal {
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  visibility: hidden;
  z-index: 1200;
  position: fixed;
  top: 0;
  left: 0;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100vh;
  height: 100dvh;
  background-color: rgba(0, 0, 0, .3);
  pointer-events: none
}
.modal.is-open {
  visibility: visible;
  pointer-events: all
}
.modal__close {
  display: block;
  width: 16px;
  height: 16px;
  margin: 0 0 15px auto;
  line-height: 1;
  cursor: pointer
}
@media (hover:hover) {
  .modal__close {
    -webkit-transition: 0.3s opacity ease-in-out;
    -o-transition: 0.3s opacity ease-in-out;
    transition: 0.3s opacity ease-in-out
  }
  .modal__close:hover {
    opacity: .6
  }
}
.modal .download-menu, .modal .trial-menu {
  position: static;
  height: auto
}
@media (min-width:1024px) {
  .modal {
    display: none
  }
}
::-webkit-full-page-media, :future, :root .modal {
  will-change: transform
}
::-webkit-full-page-media, :future, :root .modal * {
  will-change: transform
}
::-webkit-full-page-media, :future, :root .loading {
  will-change: transform
}
::-webkit-full-page-media, :future, :root .loading * {
  will-change: transform
}
/*MENU*/
.menu {
  position: relative;
  padding: 25px 0 30px;
  background: #fff;
}
.menu__cards {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  position: relative;
}
.menu__card {
  position: relative;
  width: calc((100% - 9px) / 2);
}
.menu__card--link-down::after {
  position: absolute;
  bottom: 0;
  left: 50%;
  content: "";
  background: url(../images/icon_link-down.svg);
  width: 11px;
  height: 6px;
  margin-left: -5.5px;
}
.menu__card--link::after {
  position: absolute;
  bottom: 0;
  left: 50%;
  content: "";
  background: url(../images/icon_link.svg);
  width: 9px;
  height: 9px;
  margin-left: -4.5px;
}
.menu__card a {
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
}
.menu__card a:hover {
  opacity: 0.7;
}
.menu__card img {
  height: 40px;
}
.menu__card p {
  margin: 10px 0 16px;
  text-align: center;
  font-size: 12px;
  font-weight: bold;
}
.menu__card p.left {
  text-align: left;
}
.menu__card p b {
  display: inline-block;
  font-weight: inherit;
  color: var(--color-primary);
}
@media (min-width:768px) {
  .menu {
    padding: 25px 0;
  }
  .menu__card a {
    border-right: 1px solid var(--color-primary);
  }
  .menu__card:first-child a {
    border-left: 1px solid var(--color-primary);
  }
  .menu__card p {}
  .menu__card p b {}
}
@media (max-width:767px) {
  .menu__cards {
    gap: 10px 0;
  }
  .menu__card a {
    padding: 15px 0;
    border-radius: 10px;
    box-shadow: var(--box-shadow);
  }
  .menu__card--link-down::after, .menu__card--link::after {
    bottom: 15px
  }
}
@media (max-width:1023.98px) {}
@media (min-width:1024px) {
  .menu__cards {
    flex-wrap: nowrap;
  }
  .menu__card {
    flex: 1;
  }
}
@media (min-width:768px) {
  .hidden--pc {
    display: none
  }
}
@media (max-width:767.98px) {
  .hidden--mobile {
    display: none
  }
}