@media (min-width: 769px) and (max-width: 1421px) {

/* -------------------------------------------------- */
/* header */

.header {
  padding-block: 2.1vw 4.21vw;
}
.header-logo {
  font-size: 2.53vw;
  margin-bottom: 4.92vw;
}
.header-logo img {
  width: 10.5vw;
}
.header-title {
  font-size: 4vw;
  margin-bottom: 2.1vw;
}
.header-content p {
  font-size: 1.68vw;
}
.header-list li {
  height: 15.68vw;
  margin-right: 1.4vw;
  width: 15.68vw;
}
.header-list li::before {
  height: 14.76vw;
  width: 14.76vw;
}
.header-list p {
  font-size: 1.96vw;
}
.header-list strong {
  font-size: 3.86vw;
}
.header-list .en {
  font-size: 3.86vw;
}

/* form */

.form {
  margin-top: 2.39vw;
  padding: 3.16vw 2.46vw;
}
.form-title {
  border-left-width: .28vw;
  font-size: 2.18vw;
  margin-bottom: .7vw;
}
.form-title span {
  font-size: 1.75vw;
}
.form p {
  font-size: 1.33vw;
  margin-bottom: 1.68vw;
}
.form small {
  display: block;
  font-size: .98vw;
}
.form-item {
  margin-bottom: 1.05vw;
}
.form-item label {
  font-size: 1.33vw;
}
.form-item span {
  font-size: 1.26vw;
}
.form-item input[type='text'],
.form-item input[type='email'] {
  border-radius: .35vw;
  font-size: 1.33vw;
}
.form-item input::placeholder {
  color: #a4a4a4;
}
.form-content p {
  font-size: .91vw;
  margin-block: 1.4vw;
}
.form-button input[type='submit'] {
  background-position: center right 1.4vw;
  background-size: .7vw auto;
  font-size: 1.68vw;
}

}

@media (min-width: 769px) and (max-width: 1337px) {

/* -------------------------------------------------- */
/* global */

section {
  padding-block: 7.47vw;
}
h2 {
  font-size: 3.36vw;
}
h2 strong {
  font-size: 3.88vw;
}
p {
  font-size: 1.49vw;
}

/* component */

.button a,
.button input[type='submit'] {
  background-position: center right 1.49vw;
  background-size: .74vw auto;
  font-size: 1.79vw;
}
.button span {
  border-radius: .52vw;
  font-size: 1.49vw;
}

/* general */

.general .header-body {
  height: 5.23vw;
}
.general .header-logo img {
  width: 11.65vw;
}

/* -------------------------------------------------- */
/* report */

.report-head strong {
  font-size: 5.97vw;
}
.report-head span {
  font-size: 2.54vw;
  height: 9.19vw;
  right: -9.19vw;
  width: 9.19vw;
}

/* cta */

.cta {
  padding-top: 3.73vw;
}
.cta .report-image {
  margin-top: 2.98vw;
}
.cta .report-content {
  margin-left: 3.73vw;
}
.cta .report-head span {
  right: -4.59vw;
}

/* -------------------------------------------------- */
/* market */

.market-head {
  margin-bottom: 2.24vw;
}
.market-head strong {
  border-bottom-width: .22vw;
}

/* -------------------------------------------------- */
/* slider */

.slider {
  padding-block: 3.73vw;
}
.slider-head {
  margin-bottom: 2.24vw;
}
.slider-head strong.en {
  font-size: 5.23vw;
}
.slider-head span {
  font-size: 1.79vw;
}

/* -------------------------------------------------- */
/* result */

.result {
  padding-top: 3.73vw;
}
.result-list {
  margin-bottom: 3.73vw;
}
.result-list li {
  margin-bottom: 2.24vw;
  padding: 2.98vw 3.73vw 25px;
}
.result-title {
  font-size: 2.24vw;
}
.result-tags {
  margin-bottom: 1.12vw;
}
.result-tags span {
  font-size: 1.04vw;
}
.result-name {
  font-size: 1.79vw;
}
.result-desc {
  padding: .74vw 2.98vw .74vw 7.47vw;
}
.result-desc::before {
  border-width: 1.34vw;
  left: 3.36vw;
}
.result-capt {
  font-size: 1.79vw;
}
.result-desc p {
  font-size: 1.49vw;
}

/* -------------------------------------------------- */
/* graph */

.graph-head span {
  margin-bottom: 1.12vw;
}
.graph-image img {
  margin-bottom: 2.24vw;
}
.graph-image p {
  font-size: .89vw;
}
.graph-arrow {
  margin-block: 2.54vw;
}
.graph-foot {
  font-size: 2.91vw;
}
.graph-foot strong {
  font-size: 3.28vw;
}

/* -------------------------------------------------- */
/* feature */

.feature {
  background-size: 38.11vw auto;
}
.feature-text {
  margin-bottom: 7.47vw;
}
.feature-slide {
  margin-bottom: 5.23vw;
}
.feature-slide img {
  margin: .44vw;
  width: calc(100% / 7 - .88vw);
}
.feature-item {
  margin-bottom: 5.23vw;
}
.feature-item:last-child {
  margin-bottom: 2.98vw;
}
.feature-num {
  font-size: 1.86vw;
}
.feature-num span {
  font-size: 9.94vw;
}
.feature-title {
  font-size: 3.36vw;
}
.feature-title strong {
  font-size: 4.63vw;
}
.feature-title small {
  font-size: 1.49vw;
}
.feature-image {
  margin-top: 2.98vw;
}

/* -------------------------------------------------- */
/* foot */

.foot-body {
  font-size: 1.34vw;
  margin-bottom: 5.99vw;
  max-width: 74.73vw;
}
.foot h2 {
  font-size: 2.98vw;
}

/* faq */

.faq-list {
  margin-bottom: 2.24vw;
}
.faq-list dt::before,
.faq-list dd::before {
  font-size: 3.58vw;
  min-height: 5.97vw;
  min-width: 5.82vw;
}
.faq-list dt i::before,
.faq-list dt i::after {
  height: .29vw;
  right: 1.86vw;
  width: 1.64vw;
}

/* media */

.media-logo img {
  width: 21.15vw;
}

/* -------------------------------------------------- */
/* thanks */

.thanks-head {
  font-size: 2.39vw;
}
.thanks p {
  font-size: 1.19vw;
}
.thanks-button a {
  font-size: 1.34vw;
  background-position: center right 25%;
}

/* -------------------------------------------------- */
/* footer */

.footer-nav:nth-child(1) {
  font-size: 1.19vw;
}
.footer-nav:nth-child(2) {
  font-size: 1.04vw;
}
.footer-small {
  font-size: 1.04vw;
}

}

@media screen and (max-width: 768px) {

/* -------------------------------------------------- */
/* global */

section {
  padding-block: 15vw;
}
h2 {
  font-size: 6.85vw;
}
h2 strong {
  font-size: 10.28vw;
}
p {
  font-size: 4.57vw;
}
.wrapper {
  max-width: 90%;
}

/* component */

.button a,
.button input[type='submit'] {
  background-position: center right 5.3vw;
  background-size: 2.6vw auto;
  font-size: 5.71vw;
  padding: .6em;
  width: 100%;
}
.button span {
  font-size: 4.85vw;
  padding: .1em .25em;
}
.pc {
  display: none;
}
.sp {
  display: block;
}

/* -------------------------------------------------- */
/* header */

.header {
  background: none;
  padding-block: 0;
}
.header::before {
  display: none;
}
.header .wrapper {
  max-width: 100%;
}
.header-logo img {
  width: 34.6vw;
}
.header-body {
  flex-direction: column;
}
.header-content {
  background: url(../images/header.webp) no-repeat center center /cover;
  height: 135.42vw;
  margin-left: 0;
  padding-inline: 5vw;
  position: relative;
  width: 100%;
}
.header-content::before {
  background: linear-gradient(122.27deg, transparent 0%, transparent 7%, rgba(0,0,0,.64) 7%, rgba(0,0,0,.64) 85%, transparent 85%);
  content: '';
  display: block;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 0;
}
.header-logo {
  font-size: 9.28vw;
  margin-bottom: 10vw;
  margin-top: 4vw;
  position: relative;
  text-align: right;
}
.header-title {
  border-left-width: 1px;
  font-size: 9vw;
  margin-bottom: .25em;
  padding: .15em .3em;
  position: relative;
}
.header-content p {
  font-size: 4.57vw;
  margin-bottom: 1em;
  position: relative;
}
.header-list.d-f {
  justify-content: space-between;
}
.header-list li {
  height: 41.71vw;
  margin-right: 0;
  width: 41.71vw;
}
.header-list li::before {
  height: 39.35vw;
  width: 39.35vw;
}
.header-list p {
  font-size: 4.57vw;
  margin-bottom: 0;
}
.header-list strong {
  font-size: 10.28vw;
}
.header-list .en {
  font-size: 10.28vw;
}

/* form */

.form {
  background: #fff;
  margin-top: 0;
  padding: 15vw 5vw;
  width: 100%;
}
.form-title {
  display: block;
  font-size: 8.28vw;
  margin-bottom: 1em;
  padding-left: .5em;
}
.form-title span {
  font-size: 4.57vw;
  margin: 0 0 .3em .5em;
  padding: .2em 1em;
  vertical-align: middle;
}
.form p {
  font-size: 4.57vw;
}
.form small {
  display: block;
  font-size: 4vw;
  margin-top: .5em;
}
.form-item {
  display: block;
  margin-bottom: 9vw;
}
.form-item label {
  font-size: 4.57vw;
  width: 100%;
}
.form-item span {
  font-size: 4vw;
  position: relative;
  top: -1vw;
}
.form-item div {
  margin-top: 2vw;
  width: 100%;
}
.form-item input[type='text'],
.form-item input[type='email'] {
  border-radius: 2.5px;
  font-size: 4.57vw;
  padding: .75em .5em;
}
.form-item .half input[type='text'] {
  width: 48.5%;
}
.form-content p {
  color: var(--black);
  font-size: 4.57vw;
  line-height: 1.6;
  margin-block: 2em;
}

/* general */

.general .header-body {
  height: 20.42vw;
}
.general .header-logo {
  margin: 0;
}
.general .header-logo img {
  width: 36.5vw;
}

/* -------------------------------------------------- */
/* report */

.report-head {
  font-size: 9.14vw;
}
.report-head strong {
  font-size: 13.71vw;
}
.report-head span {
  font-size: 6.85vw;
  height: 23.71vw;
  right: -4vw;
  top: -12vw;
  width: 23.71vw;
}
.report-text {
  margin-bottom: 2em;
}
.report-image.d-f {
  justify-content: space-between;
  margin-bottom: 2.5em;
}
.report-image li {
  height: auto;
  margin-inline: 0;
  width: 49%;
}
.report-image img {
  height: auto;
  width: 100%;
}
.report-button em.pc {
  display: none;
}

/* cta */

.cta {
  padding-bottom: 0;
  padding-top: 10vw;
}
.cta .report-body {
  align-items: center;
  flex-direction: column;
}
.cta .report-image {
  margin-top: 6vw;
  order: 1;
  width: 63.71vw;
}
.cta .report-content {
  margin-left: 0;
  order: 0;
  width: 100%;
}
.cta .report-head {
  line-height: 1.3;
  margin-bottom: .5em;
  text-align: center;
}
.cta .report-head span {
  right: -2.5vw;
}
.cta .report-text {
  text-align: center;
}
.cta .report-button {
  margin-bottom: 0;
}

/* -------------------------------------------------- */
/* market */

.market {
  background-position: top 106vw center;
  background-size: 100% auto;
}
.market-head {
  margin-bottom: 6vw;
}
.market-head strong {
  border-bottom-width: 2px;
}
.market-body.d-f {
  display: block;
}
.market-text p:last-child {
  margin-bottom: 1em;
}
.market-image {
  margin: auto;
  width: 100%;
}

/* -------------------------------------------------- */
/* slider */

.slider {
  padding-block: 5vw 10vw;
}
.slider-head {
  font-size: 9.5vw;
  letter-spacing: 0;
  margin-bottom: 1em;
}
.slider-head strong.en {
  font-size: 15vw;
  letter-spacing: .05em;
}
.slider-head span {
  display: block;
  font-size: 5.14vw;
  margin-left: 0;
  margin-top: 10px;
  padding: .5em;
}

/* -------------------------------------------------- */
/* result */

.result {
  padding-top: 10vw;
}
.result-list {
  margin-bottom: 25px;
}
.result-list li {
  box-shadow: 0 0 4.5px rgba(0,0,0,.12);
  margin-bottom: 10vw;
  padding: 5vw;
}
.result-text {
  order: 1;
  width: 100%;
}
.result-title {
  font-size: 7.14vw;
  margin-bottom: .75em;
  text-align: center;
}
.result-tags {
  margin-bottom: 7.5vw;
  text-align: center;
}
.result-tags span {
  background: var(--green);
  color: #fff;
  display: inline-block;
  font-size: 4.57vw;
  font-weight: 400;
  line-height: 1.3;
  margin-bottom: .1em;
  margin-right: .1em;
  padding: 0 .25em;
}
.result-tags span:last-child {
  margin-right: 0;
}
.result-name {
  font-size: 6vw;
}
.result-image {
  margin-bottom: 5vw;
  order: 0;
  width: 100%;
}
.result-desc {
  align-items: center;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  margin-top: 3vw;
  padding: 12vw 6vw 4vw;
}
.result-desc::before {
  border: 4.57vw solid transparent;
  border-top-color: var(--green);
  left: 50%;
  transform: translateX(-50%);
  top: 5vw;
}
.result-capt {
  font-size: 6.57vw;
  text-align: center;
}
.result-desc p {
  font-size: 4.57vw;
}
.result-button a {
  background-color: var(--black);
  font-size: 5.42vw;
  line-height: 1.3;
  padding-right: 2em;
  text-align: left;
}

/* -------------------------------------------------- */
/* graph */

.graph::before {
  background: linear-gradient(116.5deg, transparent 0%, transparent 8%, #f5f5f5 8%, #f5f5f5 48%, transparent 48%);
}
.graph-head {
  margin-bottom: .25em;
}
.graph-head span {
  font-size: 5.6vw;
  margin-bottom: 7.5px;
}
.graph-head strong {
  font-size: 6.7vw;
}
.graph-head + p {
  font-size: 5.14vw;
  text-align: left;
}
.graph-image img {
  margin-bottom: 20px;
  width: 100%;
}
.graph-image p {
  font-size: 3.42vw;
}
.graph-arrow {
  margin-block: 20px;
}
.graph-arrow img {
  width: 36.71%;
}
.graph-foot {
  background: #eaeaea;
  font-size: 6vw;
  left: -3.5vw;
  padding-block: 1em;
  position: relative;
  width: 97vw;
}
.graph-foot strong {
  font-size: 6.57vw;
}

/* -------------------------------------------------- */
/* feature */

.feature {
  background-position: top 5vw center;
  background-size: 80% auto;
}
.feature-head {
  font-size: 6.85vw;
  left: -5vw;
  margin-bottom: 1.5em;
  position: relative;
  width: 100vw;
}
.feature-head strong {
  font-size: 7.8vw;
}
.feature-text {
  margin-bottom: 10vw;
}
.feature p {
  text-align: left;
}
.feature-slide {
  left: 0;
  margin-bottom: 15vw;
  padding-inline: 5vw;
  width: 100vw;
}
.feature-slide img {
  margin: 2px;
  width: calc(100% / 3 - 4px);
}
.feature-item {
  margin-bottom: 10vw;
}
.feature-item:last-child {
  margin-bottom: 6vw;
}
.feature-num {
  font-size: 3.57vw;
}
.feature-num span {
  font-size: 19vw;
}
.feature-title {
  font-size: 7.42vw;
  line-height: 1.3;
}
.feature-title strong {
  font-size: 10vw;
}
.feature-title small {
  font-size: 2.85vw;
}
.feature-image {
  margin-top: 6vw;
}

/* -------------------------------------------------- */
/* foot */

.foot-body {
  font-size: 4.28vw;
  margin-bottom: 15vw;
  max-width: initial;
}
.foot h2 {
  font-size: 6.85vw;
}

/* faq */

.faq-list {
  margin-bottom: 8vw;
}
.faq-list:last-child {
  margin-bottom: 0;
}
.faq-list dt {
  font-size: 4.57vw;
  padding-right: 2.5em;
}
.faq-list dt::before,
.faq-list dd::before {
  font-size: 8.28vw;
  line-height: 16.28vw;
  margin-right: .25em;
  min-height: 17.28vw;
  min-width: 8.71vw;
}
.faq-list dt i::before,
.faq-list dt i::after {
  height: 2px;
  right: 3vw;
  width: 3.14vw;
}
.faq-list dd p {
  margin-block: 1.5em 0;
  padding-right: 2em;
}

/* company */

.company-table th,
.company-table td {
  display: block;
}
.company-table th {
  border-bottom: 1px solid #eaeaea;
  padding-block: .5em;
  position: relative;
}
.company-table th::after {
  background: var(--green);
  bottom: -1px;
  content: '';
  display: block;
  height: 1.5px;
  left: 0;
  position: absolute;
  width: 19.2vw;
}
.company-table td {
  border-bottom-width: 0;
  padding-block: .5em;
  padding-left: 0;
}

/* media */

.media-logo img {
  width: 40.42vw;
}

/* -------------------------------------------------- */
/* thanks */

.thanks-head {
  font-size: 6.85vw;
}
.thanks p {
  font-size: 4.57vw;
  text-align: left;
}
.thanks p:last-of-type {
  margin-bottom: 3em;
}
.thanks-button a {
  background-position: center right 25%;
  font-size: 5.94vw;
}

/* -------------------------------------------------- */
/* footer */

.footer {
  padding-block: 10vw;
}
.footer-nav:nth-child(1) {
  font-size: 4.57vw;
  margin-bottom: .5em;
}
.footer-nav:nth-child(2) {
  font-size: 4vw;
  margin-bottom: 1em;
}
.footer-nav:nth-child(1) li {
  border-bottom: 1px solid rgba(255,255,255,.4);
  margin: 0;
  padding-block: 1.5em;
  text-align: center;
  width: 100%;
}
.footer-nav:nth-child(2) li {
  margin: 0;
  padding-block: 1em;
  text-align: center;
  width: 100%;
}
.footer-small {
  font-size: 3.42vw;
}

}
