@charset "UTF-8";
/*! destyle.css v2.0.2 | MIT License | https://github.com/nicolas-cusan/destyle.css */
@import "./kurage-css/kurage.min.css";
@import "./kurage-css/kurage-sp-430.min.css";
@import "./append.css";
*,
::before,
::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

body {
  margin: 0;
}

main {
  display: block;
}

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  margin: 0;
}

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

dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

pre {
  font-family: monospace, monospace;
  font-size: inherit;
}

address {
  font-style: inherit;
}

a {
  background-color: rgba(0, 0, 0, 0);
  text-decoration: none;
  color: inherit;
}

abbr[title] {
  text-decoration: underline;
  text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: inherit;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img,
embed,
object,
iframe {
  vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: rgba(0, 0, 0, 0);
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit;
}

[type=checkbox] {
  -webkit-appearance: checkbox;
  appearance: checkbox;
}

[type=radio] {
  -webkit-appearance: radio;
  appearance: radio;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}

button[disabled],
[type=button][disabled],
[type=reset][disabled],
[type=submit][disabled] {
  cursor: default;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

select::-ms-expand {
  display: none;
}

option {
  padding: 0;
}

fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

legend {
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

label[for] {
  cursor: pointer;
}

details {
  display: block;
}

summary {
  display: list-item;
}

[contenteditable] {
  outline: none;
}

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

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

@media (max-width: 834px) {
  .tab\:hidden {
    display: none;
  }
}
@media (max-width: 834px) {
  .\!tab\:hidden {
    display: none !important;
  }
}
@media (max-width: 430px) {
  .sp\:hidden {
    display: none;
  }
}
@media (max-width: 430px) {
  .\!sp\:hidden {
    display: none !important;
  }
}
.font-100 {
  font-weight: 100;
}

.\!font-100 {
  font-weight: 100 !important;
}

.font-200 {
  font-weight: 200;
}

.\!font-200 {
  font-weight: 200 !important;
}

.font-300 {
  font-weight: 300;
}

.\!font-300 {
  font-weight: 300 !important;
}

.font-400 {
  font-weight: 400;
}

.\!font-400 {
  font-weight: 400 !important;
}

.font-500 {
  font-weight: 500;
}

.\!font-500 {
  font-weight: 500 !important;
}

.font-600 {
  font-weight: 600;
}

.\!font-600 {
  font-weight: 600 !important;
}

.font-700 {
  font-weight: 700;
}

.\!font-700 {
  font-weight: 700 !important;
}

.font-800 {
  font-weight: 800;
}

.\!font-800 {
  font-weight: 800 !important;
}

.font-900 {
  font-weight: 900;
}

.\!font-900 {
  font-weight: 900 !important;
}

.font-bold {
  font-weight: bold;
}

.\!font-bold {
  font-weight: bold !important;
}

.mt-0 {
  margin-top: 0;
}

.\!mt-0 {
  margin-top: 0 !important;
}

.tab\:mt-0 {
  margin-top: 0;
}

.\!tab\:mt-0 {
  margin-top: 0 !important;
}

.sp\:mt-0 {
  margin-top: 0;
}

.\!sp\:mt-0 {
  margin-top: 0 !important;
}

.mb-0 {
  margin-bottom: 0;
}

.\!mb-0 {
  margin-bottom: 0 !important;
}

.tab\:mb-0 {
  margin-bottom: 0;
}

.\!tab\:mb-0 {
  margin-bottom: 0 !important;
}

.sp\:mb-0 {
  margin-bottom: 0;
}

.\!sp\:mb-0 {
  margin-bottom: 0 !important;
}

.ml-0 {
  margin-left: 0;
}

.\!ml-0 {
  margin-left: 0 !important;
}

.tab\:ml-0 {
  margin-left: 0;
}

.\!tab\:ml-0 {
  margin-left: 0 !important;
}

.sp\:ml-0 {
  margin-left: 0;
}

.\!sp\:ml-0 {
  margin-left: 0 !important;
}

.mr-0 {
  margin-right: 0;
}

.\!mr-0 {
  margin-right: 0 !important;
}

.tab\:mr-0 {
  margin-right: 0;
}

.\!tab\:mr-0 {
  margin-right: 0 !important;
}

.sp\:mr-0 {
  margin-right: 0;
}

.\!sp\:mr-0 {
  margin-right: 0 !important;
}

.mh-auto {
  margin-right: auto;
  margin-left: auto;
}

.\!mh-auto {
  margin-right: auto !important;
  margin-left: auto !important;
}

.tab\:mh-auto {
  margin-right: auto;
  margin-left: auto;
}

.\!tab\:mh-auto {
  margin-right: auto !important;
  margin-left: auto !important;
}

.sp\:mh-auto {
  margin-right: auto;
  margin-left: auto;
}

.\!sp\:mh-auto {
  margin-right: auto !important;
  margin-left: auto !important;
}

.pt-0 {
  padding-top: 0;
}

.\!pt-0 {
  padding-top: 0 !important;
}

.pb-0 {
  padding-bottom: 0;
}

.\!pb-0 {
  padding-bottom: 0 !important;
}

.pl-0 {
  padding-left: 0;
}

.\!pl-0 {
  padding-left: 0 !important;
}

.pr-0 {
  padding-right: 0;
}

.\!pr-0 {
  padding-right: 0 !important;
}

.text-left {
  text-align: left;
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

.break-keep {
  word-break: keep-all;
}

.\!break-keep {
  word-break: keep-all !important;
}

@media (max-width: 430px) {
  .sp\:break-all {
    word-break: break-all;
  }
}
@media (max-width: 430px) {
  .sp\:break-normal {
    word-break: normal;
  }
}
@media (max-width: 430px) {
  .\!sp\:break-all {
    word-break: break-all !important;
  }
}
@media (max-width: 834px) {
  .tab\:break-all {
    word-break: break-all;
  }
}
@media (max-width: 834px) {
  .tab\:break-normal {
    word-break: normal;
  }
}
@media (max-width: 834px) {
  .\!tab\:break-all {
    word-break: break-all !important;
  }
}
.bg-white {
  background-color: #fff;
}

.border-none {
  border: none !important;
}

.border-top-none {
  border-top: none !important;
}

.border-bottom-none {
  border-bottom: none !important;
}

.border-left-none {
  border-left: none !important;
}

.border-right-none {
  border-right: none !important;
}

.mt0 {
  margin-top: 0 !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

.ml0 {
  margin-left: 0 !important;
}

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

.text-left {
  text-align: left;
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

@media (max-width: 834px) {
  .tab\:text-center {
    text-align: center;
  }
}
@media (max-width: 834px) {
  .tab\:text-left {
    text-align: left;
  }
}
@media (max-width: 834px) {
  .tab\:text-right {
    text-align: right;
  }
}
@media (max-width: 430px) {
  .sp\:text-center {
    text-align: center;
  }
}
@media (max-width: 430px) {
  .sp\:text-left {
    text-align: left;
  }
}
@media (max-width: 430px) {
  .sp\:text-right {
    text-align: right;
  }
}
.splitter {
  color: rgba(0, 0, 0, 0.2);
  font-weight: normal;
  padding: 0 1rem;
}

.bold {
  font-weight: bold !important;
}

@media (max-width: 834px) {
  .tab\:none {
    display: none;
  }
}
@media (max-width: 430px) {
  .sp\:none {
    display: none !important;
  }
}
.word-break-keep-all {
  word-break: keep-all !important;
}

@media (max-width: 430px) {
  .sp\:word-break-cancel {
    word-break: break-all !important;
  }
}
@media (max-width: 834px) {
  .tab\:word-break-cancel {
    word-break: break-all !important;
  }
}
@media (max-width: 430px) {
  .tel-number,
  .fax-number {
    color: #000;
    text-decoration: none;
  }
}
.color-purpose {
  color: #a0ca27;
}

.color-vision {
  color: #a0ca27;
}

.color-mission {
  color: #52bec5;
}

.color-value {
  color: #02aeae;
}

.color-asset {
  color: #0394c4;
}

.border-color-black {
  border-color: #000 !important;
}

.img-shadow {
  border-radius: 5px;
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);
}

* {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
}

html {
  font-size: 62.5%;
  overflow-x: hidden;
  overflow-y: scroll;
}

html.drawer-open {
  overflow-y: hidden;
}

body {
  width: 100%;
  color: #000;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Noto Sans JP", Arial, Meiryo, sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 2;
  overflow-x: hidden;
  margin-top: calc(72px + 9rem);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (max-width: 834px) {
  body {
    margin-top: calc(72px + 6rem);
  }
}
@media (max-width: 430px) {
  body {
    margin-top: calc(72px + 3rem);
  }
}
body.home {
  margin-top: min(28vw, 20rem);
}

@media (max-width: 834px) {
  body.home {
    margin-top: 21vw;
  }
}
@media (max-width: 430px) {
  body.home {
    margin-top: 28vw;
  }
}
address {
  font-style: normal;
}

a {
  color: #000;
  text-decoration: underline;
  text-decoration-color: rgba(0, 0, 0, 0.2);
  padding: 0 2px;
  transition: all 0.1s ease-in-out;
  text-underline-offset: 6px;
}

a:hover {
  text-decoration: underline;
  text-decoration-color: rgba(0, 0, 0, 0);
}

p {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
}

ul {
  padding-inline-start: 0;
}

ol {
  list-style: decimal inside;
}

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

table tr th {
  min-width: 150px;
  font-weight: 400;
  letter-spacing: 0.05em;
  padding: 2rem 1rem 2rem;
  border-bottom: 2px solid #000;
}

@media (max-width: 430px) {
  table tr th {
    display: block;
    width: 100% !important;
    font-weight: 600;
    padding: 0 0 1rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  }
}
table tr td {
  font-weight: 400;
  padding: 2rem 1rem 2rem 4rem;
  border-bottom: 1px solid #000;
}

@media (max-width: 430px) {
  table tr td {
    display: block;
    width: 100% !important;
    padding: 0;
    margin-bottom: 7vw;
    border: none;
  }
}
table tr td > ul,
table tr td > ol {
  margin-top: 0.5rem;
}

@media (max-width: 430px) {
  table tr td > ul,
  table tr td > ol {
    margin-top: 2rem;
  }
}
@media (max-width: 430px) {
  table tr:last-child td {
    margin-bottom: 0;
  }
}
.fieldset dl {
  font-size: 1.8rem;
}

.fieldset dl dt {
  font-family: YakuHanJP, -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Noto Sans JP", Arial, Meiryo, sans-serif;
  line-height: 1;
  letter-spacing: 0.05em;
  margin-bottom: 3rem;
}

.fieldset dl dt span {
  display: flex;
  align-items: center;
}

.fieldset dl dt span.required::after {
  color: #fff;
  font-size: 1.2rem;
  line-height: 1;
  padding: 0.3rem 0.5rem;
  margin-left: 1rem;
  content: "必須";
  border-radius: 0.25rem;
  background-color: #e62814;
}

.fieldset dl dd {
  line-height: 1;
  margin-bottom: 6rem;
}

.fieldset dl dd p {
  font-size: 1.8rem !important;
  line-height: 1.5 !important;
  margin-bottom: 3rem !important;
}

.fieldset dl dd .radioelement {
  padding-right: 1rem;
}

.fieldset dl dd .radioelement input[type=radio] {
  display: none;
}

.fieldset dl dd .radioelement input[type=radio]:checked + label::before {
  background-image: url("../images/common/form/icon_radio_checked.svg");
}

.fieldset dl dd .radioelement input[type=radio] + label {
  display: inline-flex;
  align-items: center;
  margin-bottom: 1rem;
}

.fieldset dl dd .radioelement input[type=radio] + label::before {
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-right: 5px;
  content: "";
  background-image: url("../images/common/form/icon_radio.svg");
  background-size: contain;
}

.fieldset dl dd input[type=text],
.fieldset dl dd input[type=email],
.fieldset dl dd input[type=tel],
.fieldset dl dd input[type=number],
.fieldset dl dd textarea {
  padding: 1.5rem 1.5rem;
  border: 1px solid rgba(0, 0, 0, 0.2) !important;
  border-radius: 0.25rem;
  transition: border 0.1s ease;
}

.fieldset dl dd input[type=text]:focus-within,
.fieldset dl dd input[type=email]:focus-within,
.fieldset dl dd input[type=tel]:focus-within,
.fieldset dl dd input[type=number]:focus-within,
.fieldset dl dd textarea:focus-within {
  border-color: #228be6 !important;
}

.fieldset dl dd textarea {
  width: 100%;
  min-height: 60rem;
  line-height: 2;
  padding-top: 0.7rem;
  resize: vertical;
}

input[type=submit],
input[type=button] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 260px;
  min-height: 53px;
  color: #fff;
  font-family: Roboto, sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.1em;
  text-align: center;
  text-decoration: none;
  padding: 2px 0 0 0;
  border: 2px solid #000;
  border-radius: 0.25rem;
  background-color: #000;
  background-image: url("../images/common/icon_btn_next_white.svg");
  background-repeat: no-repeat;
  background-position: right 15px center;
  transition: all 0.3s ease-in-out;
  text-underline-offset: 0;
}

@media (max-width: 430px) {
  input[type=submit],
  input[type=button] {
    width: 100%;
  }
}
input[type=submit]:hover,
input[type=button]:hover {
  color: #000;
  border-radius: 0;
  background-color: #fff;
  background-image: url("../images/common/icon_btn_next_black.svg");
  background-position: right 10px center;
}

input[type=button] {
  background-image: none;
}

input[type=button]:hover {
  background-image: none;
}

html.lenis {
  height: auto;
}

.lenis.lenis-smooth {
  scroll-behavior: auto;
}

.lenis.lenis-smooth [data-lenis-prevent] {
  overscroll-behavior: contain;
}

.lenis.lenis-stopped {
  overflow: hidden;
}

.lenis.lenis-scrolling iframe {
  pointer-events: none;
}

.simplebar-scrollbar::before {
  border-radius: 4px;
  background: rgba(0, 0, 0, 0.4) !important;
}

.simplebar-scrollbar.simplebar-visible::before {
  opacity: 1;
}

.simplebar-track {
  background-color: #f8f8f8;
}

.btn--prev,
.btn--next {
  padding-right: 80px !important;
  padding-left: 80px !important;
  background-repeat: no-repeat !important;
}

a.btn {
  text-decoration: none;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 260px;
  min-height: 53px;
  color: #fff;
  font-family: Roboto, "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: normal;
  line-height: 1;
  letter-spacing: 0.1em;
  text-align: center;
  text-decoration: none;
  padding: 2px 20px 0 20px;
  border: 2px solid #000;
  border-radius: 50px;
  background-color: #000;
  transition: all 0.3s ease-in-out;
  text-underline-offset: 0;
}

.btn:hover {
  color: #000;
  text-decoration: none !important;
  background-color: #fff;
}

.btn--next {
  background-image: url("../images/common/icon_btn_next_white.svg");
  background-position: right 15px center;
}

.btn--next:hover {
  background-image: url("../images/common/icon_btn_next_black.svg");
  background-position: right 10px center;
}

.btn--prev {
  background-image: url("../images/common/icon_btn_prev_white.svg");
  background-position: left 15px center;
}

.btn--prev:hover {
  background-image: url("../images/common/icon_btn_prev_black.svg");
  background-position: left 10px center;
}

.btn--lightblue, .btn--lightblue:visited {
  color: #fff;
  border: 2px solid #00a0e9;
  background-color: #00a0e9;
}

.btn--lightblue:hover {
  color: #00a0e9;
  background-color: #fff;
}

.btn--lightblue.btn--prev {
  background-image: url("../images/common/icon_btn_prev_white.svg");
}

.btn--lightblue.btn--prev:hover {
  color: #00a0e9;
  background-image: url("../images/common/icon_btn_prev_lightblue.svg");
}

.btn--lightblue.btn--next {
  background-image: url("../images/common/icon_btn_next_white.svg");
}

.btn--lightblue.btn--next:hover {
  color: #00a0e9;
  background-image: url("../images/common/icon_btn_next_lightblue.svg");
}

.btn--red {
  color: #fff;
  border: 2px solid #e62814;
  background-color: #e62814;
}

.btn--red:hover {
  color: #e62814;
}

.btn--red.btn--prev {
  background-image: url("../images/common/icon_btn_prev_white.svg");
}

.btn--red.btn--prev:hover {
  color: #e62814;
  background-image: url("../images/common/icon_btn_prev_lightblue.svg");
}

.btn--red.btn--next {
  background-image: url("../images/common/icon_btn_next_white.svg");
}

.btn--red.btn--next:hover {
  color: #e62814;
  background-image: url("../images/common/icon_btn_next_lightblue.svg");
}

.btn--white {
  color: #000;
  background-color: #fff;
}

.btn--white:hover {
  color: #fff;
  background-color: #000;
}

.btn--white.btn--prev {
  background-image: url("../images/common/icon_btn_prev_black.svg");
}

.btn--white.btn--prev:hover {
  background-image: url("../images/common/icon_btn_prev_white.svg");
}

.btn--white.btn--next {
  background-image: url("../images/common/icon_btn_next_black.svg");
}

.btn--white.btn--next:hover {
  background-image: url("../images/common/icon_btn_next_white.svg");
}

.btn--hover\:lightblue:hover {
  color: #fff;
  border-color: #228be6;
  background-color: #228be6;
}

.btn--hover\:fontNormal:hover {
  font-weight: normal;
}

.btn--borderNone {
  border: none !important;
}

.btn--border1px {
  border-width: 1px;
}

.btn--full {
  width: 100%;
}

@media (max-width: 834px) {
  .btn--tabFull {
    width: 100%;
  }
}
@media (max-width: 430px) {
  .btn--spFull {
    width: 100%;
  }
}
.btn--bold {
  font-weight: bold;
  font-weight: 600;
}

.btn--roundNone {
  border-radius: 0;
}

.btn--roundSmall {
  border-radius: 0.25rem;
}

.reviewProfileCard {
  display: grid;
  width: 100%;
  overflow: hidden;
  grid-template-columns: auto 1fr;
  gap: 3rem;
}

@media (max-width: 834px) {
  .reviewProfileCard {
    grid-template-columns: 1fr 2fr;
  }
}
@media (max-width: 430px) {
  .reviewProfileCard {
    display: block;
  }
}
.reviewProfileCard__img img {
  width: 100%;
  max-width: 320px;
  height: auto;
}

@media (max-width: 430px) {
  .reviewProfileCard__img img {
    max-width: 100%;
  }
}
.reviewProfileCard__companyName {
  font-weight: 700;
  line-height: 1.3;
}

.reviewProfileCard__person:last-child {
  margin-bottom: 0;
}

.reviewProfileCard__department {
  line-height: 1.3;
}

.reviewProfileCard__name {
  line-height: 1.3;
}

@keyframes line1_out {
  0% {
    top: 50%;
    transform: translate(-50%, -50%) rotate(45deg);
  }
  50% {
    top: 50%;
    transform: translate(-50%, -50%) rotate(0deg);
  }
  100% {
    top: calc(50% - 10px);
    transform: translate(-50%, -50%) rotate(0deg);
  }
}
@keyframes line1_in {
  0% {
    top: calc(50% - 10px);
    transform: translate(-50%, -50%) rotate(0deg);
  }
  50% {
    top: 50%;
    transform: translate(-50%, -50%) rotate(0deg);
  }
  100% {
    top: 50%;
    transform: translate(-50%, -50%) rotate(45deg);
  }
}
@keyframes line3_out {
  0% {
    top: 50%;
    transform: translate(-50%, -50%) rotate(-45deg);
  }
  50% {
    top: 50%;
    transform: translate(-50%, -50%) rotate(0deg);
  }
  100% {
    top: calc(50% + 12px);
    transform: translate(-50%, -50%) rotate(0deg);
  }
}
@keyframes line3_in {
  0% {
    top: calc(50% + 12px);
    transform: translate(-50%, -50%) rotate(0deg);
  }
  50% {
    top: 50%;
    transform: translate(-50%, -50%) rotate(0deg);
  }
  100% {
    top: 50%;
    transform: translate(-50%, -50%) rotate(-45deg);
  }
}
@keyframes line2_out {
  0% {
    top: 50%;
    opacity: 0;
    transform: translateX(-50%) scale(0);
  }
  50% {
    top: 50%;
    transform: translateX(-50%) scale(0);
  }
  100% {
    top: 50%;
    transform: translateX(-50%) scale(1);
  }
}
@keyframes line2_in {
  0% {
    opacity: 1;
    top: 50%;
    transform: translateX(-50%) scale(1);
  }
  50% {
    opacity: 0;
    top: 50%;
    transform: translateX(-50%) scale(1);
  }
  100% {
    opacity: 0;
    top: 50%;
    transform: translateX(-50%) scale(0);
  }
}
html.drawer-open .drawer__btn {
  background: linear-gradient(to top, #283e51, #0a2342);
}

html.drawer-open .drawer__btn__line--1 {
  animation: line1_in 0.4s ease-in-out forwards !important;
}

html.drawer-open .drawer__btn__line--2 {
  animation: line2_in 0.4s ease-in-out forwards !important;
}

html.drawer-open .drawer__btn__line--3 {
  animation: line3_in 0.4s ease-in-out forwards !important;
}

html.drawer-open .drawer__content {
  right: 0;
}

html.drawer-open .drawer__content::before {
  opacity: 1;
}

html.drawer-open .drawer__bg {
  right: -1vw;
  opacity: 0.8;
}

.drawer__btn {
  position: fixed;
  width: 72px;
  height: 72px;
  top: 0;
  right: 0;
  color: #fff;
  z-index: 11;
  background: #000;
}

.drawer__btn:hover {
  cursor: pointer;
}

.drawer__btn__line {
  position: absolute;
  display: block;
  width: 38px;
  height: 2px;
  left: 50%;
  margin: 0 auto;
  background: #fff;
  transform: translateX(-50%);
  transform-origin: center;
}

.drawer__btn__line--1 {
  animation: line1_out 0.4s ease-in-out forwards;
}

.drawer__btn__line--2 {
  animation: line2_out 0.4s ease-in-out forwards;
}

.drawer__btn__line--3 {
  animation: line3_out 0.4s ease-in-out forwards;
}

.drawer__content {
  position: fixed;
  width: 300px;
  top: 0;
  right: -300px;
  z-index: 9;
  overflow-y: auto;
  padding-top: 72px;
  background: rgba(0, 0, 0, 0);
  transition: right 0.2s ease-in-out;
}

.drawer__content::before {
  position: fixed;
  display: none;
  width: 300px;
  height: 72px;
  top: 0;
  right: 0;
  content: "";
  opacity: 0;
  background: #fff;
}

.drawer__content ul {
  display: block;
}

.drawer__content ul li a {
  position: relative;
  display: block;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 1.5;
  text-decoration: none;
  padding: 2rem 5rem 2rem 2rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  background: linear-gradient(to top, #0a2342, #0a2342);
  transition: none;
}

@media (max-width: 430px) {
  .drawer__content ul li a {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }
}
.drawer__content ul li a:hover {
  color: #fff;
  background: linear-gradient(to left, #283e51, #0a2342) !important;
}

.drawer__content ul li a[target=_blank]:before {
  position: absolute;
  display: inline-block;
  width: 20px;
  height: 20px;
  top: 50%;
  right: 1rem;
  content: "";
  background-color: #0a2342;
  background-image: url("../images/common/icon_target_blank_white.svg");
  background-repeat: no-repeat;
  transform: translateY(-50%);
}

.drawer__content ul li:last-child a {
  border-bottom: none;
}

.drawer__content ul li ul li a {
  color: #000;
  padding: 1.5rem 4rem 1.5rem 3rem;
  border-bottom: 1px solid #e5e5e5 !important;
  background: linear-gradient(to top, #ffffff, #ffffff);
}

@media (max-width: 430px) {
  .drawer__content ul li ul li a {
    padding-top: 1rem;
    padding-bottom: 1rem;
  }
}
.drawer__content ul li ul li a:hover {
  color: #fff;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2) !important;
  background: linear-gradient(to left, #283e51, #0a2342);
}

.drawer__content ul li ul li a[target=_blank]:before {
  position: absolute;
  display: inline-block;
  width: 20px;
  height: 20px;
  top: 50%;
  right: 1rem;
  content: "";
  background-color: #fff;
  background-image: url("../images/common/icon_target_blank_black.svg");
  background-repeat: no-repeat;
  transform: translateY(-50%);
}

.drawer__bg {
  position: fixed;
  width: 101vw;
  height: 100vh;
  top: 0;
  right: -200%;
  z-index: 9;
  content: "";
  opacity: 0;
  background: rgba(0, 0, 0, 0.8);
  background: -webkit-linear-gradient(to top, #283e51, #0a2342);
  background: linear-gradient(to top, #283e51, #0a2342);
  transition: opacity 1s;
}

body.preload .header__drawerBtn__line {
  opacity: 0;
}

html.drawer-open .header {
  background-color: #fff;
}

.header {
  position: fixed;
  width: 100%;
  height: 72px;
  top: 0;
  left: 0;
  z-index: 10;
  margin: 0 auto;
  background: rgba(255, 255, 255, 0.9);
}

.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  padding-left: 6rem;
}

@media (max-width: 834px) {
  .header__inner {
    padding-left: 4rem;
  }
}
@media (max-width: 430px) {
  .header__inner {
    padding-left: 3rem;
  }
}
.header__logo {
  display: block;
  width: 180px;
  height: 72px;
  background-image: url("../images/common/logo_m-grit.png");
  background-repeat: no-repeat;
  background-position-y: center;
  background-size: contain;
  transition: opacity 0.2s ease-in-out;
}

@media (max-width: 834px) {
  .header__logo {
    background-position-y: center;
  }
}
.header__logo:hover {
  opacity: 0.6;
}

.main {
  width: 100%;
  margin: 0 auto;
}

body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
body.home .service,
body.home .forte__inner,
body.home .clients__inner,
body.home .hero__txt,
.footer__copyright,
.footer__grid,
body.page .article__header, body.single .article__header {
  max-width: min(90vw, 1280px);
}

@media (max-width: 834px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.home .service,
  body.home .forte__inner,
  body.home .clients__inner,
  body.home .hero__txt,
  .footer__copyright,
  .footer__grid,
  body.page .article__header, body.single .article__header {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.home .service,
  body.home .forte__inner,
  body.home .clients__inner,
  body.home .hero__txt,
  .footer__copyright,
  .footer__grid,
  body.page .article__header, body.single .article__header {
    max-width: calc(100vw - 6rem);
  }
}
body.page .article__content, body.single .article__content,
body.page .article__description, body.single .article__description {
  max-width: min(90vw, 1080px);
}

@media (max-width: 834px) {
  body.page .article__content, body.single .article__content,
  body.page .article__description, body.single .article__description {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page .article__content, body.single .article__content,
  body.page .article__description, body.single .article__description {
    max-width: calc(100vw - 6rem);
  }
}
body.page .article__content p, body.single .article__content p,
body.page .article__description p, body.single .article__description p {
  color: #000;
  font-size: 2rem;
  font-weight: 400;
  line-height: 2;
  margin-bottom: 2.25rem;
}

@media (max-width: 834px) {
  body.page .article__content p, body.single .article__content p,
  body.page .article__description p, body.single .article__description p {
    font-size: 1.8rem;
  }
}
body.page .article__content p:not(:last-child) img, body.single .article__content p:not(:last-child) img,
body.page .article__description p:not(:last-child) img, body.single .article__description p:not(:last-child) img {
  margin-bottom: 2.25rem;
}

body.page .article__content p:last-child, body.single .article__content p:last-child,
body.page .article__description p:last-child, body.single .article__description p:last-child {
  margin-bottom: 0;
}

body.page .article, body.single .article {
  margin-bottom: 12rem;
  opacity: 0;
  transition: all 1s cubic-bezier(0.4, 0, 0.2, 1);
}

@media (max-width: 834px) {
  body.page .article, body.single .article {
    margin-bottom: 6rem;
  }
}
@media (max-width: 430px) {
  body.page .article, body.single .article {
    margin-bottom: 9rem;
  }
}
body.page .article.active, body.single .article.active {
  opacity: 1;
}

body.page .article__header, body.single .article__header {
  position: relative;
  padding-bottom: 6rem;
  margin: 0 auto 6rem;
  border-bottom: 1px solid #000;
}

@media (max-width: 834px) {
  body.page .article__header, body.single .article__header {
    min-height: unset;
  }
}
@media (max-width: 430px) {
  body.page .article__header, body.single .article__header {
    padding-bottom: 4.5rem;
    margin: 0 auto 4.5rem;
    border-bottom: 1px solid #000;
  }
}
body.page .article__header--noBorder, body.single .article__header--noBorder {
  padding-bottom: 0 !important;
  border-bottom: none !important;
}

body.page .article__copy, body.single .article__copy {
  position: absolute;
  display: block;
  width: 100%;
  height: auto;
  top: 50%;
  left: max(-0.55vw, -10px);
  transform: translateY(-50%);
}

@media (max-width: 834px) {
  body.page .article__copy, body.single .article__copy {
    position: inherit;
    top: unset;
    left: unset;
    padding-top: min(7vw, 10rem);
    transform: none;
  }
}
body.page .article__copy span, body.single .article__copy span {
  display: block;
  font-size: min(5vw, 7rem);
  font-weight: bold;
  line-height: 1.3;
  letter-spacing: 0.02em;
  word-break: break-word;
  font-feature-settings: "palt" 1;
}

body.page .article__copy span:last-child, body.single .article__copy span:last-child {
  margin-bottom: 0;
}

@media (max-width: 834px) {
  body.page .article__copy span, body.single .article__copy span {
    display: inline;
    font-size: 2.8rem;
  }
}
@media (max-width: 430px) {
  body.page .article__copy span, body.single .article__copy span {
    font-size: 2.6rem;
  }
}
body.page .article__ttl, body.single .article__ttl {
  display: flex;
  flex-wrap: wrap;
  gap: 0 2rem;
}

@media (max-width: 834px) {
  body.page .article__ttl, body.single .article__ttl {
    flex-direction: column;
    gap: 0.5rem 2rem;
  }
}
body.page .article__ttl--noBorder, body.single .article__ttl--noBorder {
  padding-bottom: 0 !important;
  border-bottom: none !important;
}

body.page .article__ttl__en, body.single .article__ttl__en {
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  font-family: Roboto, sans-serif;
  font-size: min(4vw, 4rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.025em;
  word-break: break-word;
}

@media (max-width: 834px) {
  body.page .article__ttl__en, body.single .article__ttl__en {
    font-size: min(8vw, 4rem);
  }
}
body.page .article__ttl__ja, body.single .article__ttl__ja {
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0.08em;
  word-break: break-word;
  padding-bottom: 5px;
  font-feature-settings: "palt" 1;
}

@media (max-width: 430px) {
  body.page .article__ttl__ja, body.single .article__ttl__ja {
    font-size: min(5vw, 1.4rem);
  }
}
body.page .article__img img, body.single .article__img img {
  position: absolute;
  width: 62%;
  height: auto;
  top: 50%;
  right: 0;
  z-index: -1;
  transform: translateY(-50%);
}

@media (max-width: 834px) {
  body.page .article__img img, body.single .article__img img {
    position: inherit;
    width: 100%;
    top: unset;
    right: unset;
    transform: translateY(0);
  }
}
body.page .article .article__header.hasCopyAndImg, body.single .article .article__header.hasCopyAndImg {
  border-bottom: none;
}

@media (max-width: 834px) {
  body.page .article .article__header.hasCopyAndImg, body.single .article .article__header.hasCopyAndImg {
    margin-bottom: 9rem;
  }
}
@media (max-width: 430px) {
  body.page .article .article__header.hasCopyAndImg, body.single .article .article__header.hasCopyAndImg {
    margin-bottom: 6.75rem;
  }
}
body.page .article .article__header.hasCopyAndImg .article__ttl, body.single .article .article__header.hasCopyAndImg .article__ttl {
  position: absolute;
  top: 9%;
  left: 0;
  transform: translateY(-10%);
}

@media (max-width: 834px) {
  body.page .article .article__header.hasCopyAndImg .article__ttl, body.single .article .article__header.hasCopyAndImg .article__ttl {
    position: inherit;
    top: unset;
    left: unset;
    transform: none;
  }
}
@media (max-width: 834px) {
  body.page .article .article__header.hasCopyAndImg .article__copy, body.single .article .article__header.hasCopyAndImg .article__copy {
    position: inherit;
    top: unset;
    left: unset;
    padding-top: 4.5rem;
    margin-bottom: 4.5rem;
    transform: none;
  }
}
body.page .article .article__header.hasCopyOnly, body.single .article .article__header.hasCopyOnly {
  margin-bottom: 6rem;
  border-bottom: 1px solid #000;
}

@media (max-width: 430px) {
  body.page .article .article__header.hasCopyOnly, body.single .article .article__header.hasCopyOnly {
    padding-bottom: 4.5rem;
    margin-bottom: 4.5rem;
  }
}
body.page .article .article__header.hasCopyOnly .article__copy, body.single .article .article__header.hasCopyOnly .article__copy {
  position: inherit;
  top: unset;
  padding-top: min(7vw, 10rem);
  transform: none;
}

@media (max-width: 834px) {
  body.page .article .article__header.hasCopyOnly .article__copy, body.single .article .article__header.hasCopyOnly .article__copy {
    padding-top: 6rem;
  }
}
@media (max-width: 430px) {
  body.page .article .article__header.hasCopyOnly .article__copy, body.single .article .article__header.hasCopyOnly .article__copy {
    padding-top: 4.5rem;
  }
}
body.page .article .article__header.hasImgOnly, body.single .article .article__header.hasImgOnly {
  padding-bottom: 0;
  margin-bottom: 6rem;
  border-bottom: none;
}

@media (max-width: 430px) {
  body.page .article .article__header.hasImgOnly, body.single .article .article__header.hasImgOnly {
    margin-bottom: 4.5rem;
  }
}
body.page .article .article__header.hasImgOnly .article__ttl, body.single .article .article__header.hasImgOnly .article__ttl {
  padding-bottom: 6rem;
  margin-bottom: 6rem;
  border-bottom: 1px solid #000;
}

@media (max-width: 430px) {
  body.page .article .article__header.hasImgOnly .article__ttl, body.single .article .article__header.hasImgOnly .article__ttl {
    padding-bottom: 4.5rem;
    margin-bottom: 4.5rem;
    border-bottom: 1px solid #000;
  }
}
body.page .article .article__header.hasImgOnly .article__img img, body.single .article .article__header.hasImgOnly .article__img img {
  position: inherit;
  width: 100%;
  top: unset;
  right: unset;
  transform: translateY(0);
}

@media (max-width: 430px) {
  body.page .article .article__header.hasImgOnly .article__img img, body.single .article .article__header.hasImgOnly .article__img img {
    width: 100%;
  }
}
body.page .article__description, body.single .article__description {
  margin: 0 auto 10rem;
}

body.page .article__description:empty, body.single .article__description:empty {
  display: none;
}

body.page .article__content, body.single .article__content {
  margin: 0 auto;
}

body.page .article__content hr, body.single .article__content hr {
  width: 100%;
  height: 1px;
  margin: 4.5rem auto;
  border: none;
  background-color: rgba(0, 0, 0, 0.2);
}

body.page .article__content p img, body.single .article__content p img {
  width: 100%;
  height: auto;
}

body.page .article__content table, body.single .article__content table {
  width: 100%;
  font-size: 2rem;
  margin-bottom: 6rem;
}

@media (max-width: 834px) {
  body.page .article__content table, body.single .article__content table {
    font-size: 1.8rem;
  }
}
@media (max-width: 430px) {
  body.page .article__content table, body.single .article__content table {
    margin-bottom: 4.5rem;
  }
}
body.page .article__content table tr th, body.single .article__content table tr th {
  width: 20%;
}

body.page .article__content table tr td, body.single .article__content table tr td {
  width: 80%;
}

body.page .article__content table tr:first-child th, body.single .article__content table tr:first-child th,
body.page .article__content table tr:first-child td, body.single .article__content table tr:first-child td {
  padding-top: 0;
}

body.page .article__content section, body.single .article__content section {
  padding-bottom: 6rem;
  margin-bottom: 6rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}

body.page .article__content section:last-child, body.single .article__content section:last-child {
  padding-bottom: 0;
  margin-bottom: 0;
  border-bottom: none;
}

@media (max-width: 430px) {
  body.page .article__content section, body.single .article__content section {
    padding-bottom: 4.5rem;
    margin-bottom: 4.5rem;
  }
}
body.page .article__content h2, body.single .article__content h2,
body.page .article__content h3, body.single .article__content h3,
body.page .article__content h4, body.single .article__content h4,
body.page .article__content h5, body.single .article__content h5 {
  letter-spacing: 0.025em;
  font-feature-settings: "palt" 1;
}

body.page .article__content h2, body.single .article__content h2 {
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 2.25rem;
}

@media (max-width: 430px) {
  body.page .article__content h2, body.single .article__content h2 {
    font-size: 2.6rem;
  }
}
body.page .article__content p + h2, body.single .article__content p + h2,
body.page .article__content ol + h2, body.single .article__content ol + h2,
body.page .article__content ul + h2, body.single .article__content ul + h2 {
  margin-top: 9rem !important;
}

@media (max-width: 430px) {
  body.page .article__content p + h2, body.single .article__content p + h2,
  body.page .article__content ol + h2, body.single .article__content ol + h2,
  body.page .article__content ul + h2, body.single .article__content ul + h2 {
    margin-top: 4.5rem !important;
  }
}
body.page .article__content hr + h2, body.single .article__content hr + h2 {
  margin-top: 4.5rem;
}

body.page .article__content h3, body.single .article__content h3 {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 4.5rem;
}

@media (max-width: 430px) {
  body.page .article__content h3, body.single .article__content h3 {
    font-size: 2.2rem;
    line-height: 1.4;
  }
}
body.page .article__content h4, body.single .article__content h4,
body.page .article__content h5, body.single .article__content h5 {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.6;
  margin-bottom: 4.5rem;
}

@media (max-width: 430px) {
  body.page .article__content h4, body.single .article__content h4,
  body.page .article__content h5, body.single .article__content h5 {
    font-size: 1.8rem;
    line-height: 1.5;
  }
}
body.page .article__content ul, body.single .article__content ul {
  list-style: disc inside;
}

body.page .article__content ol, body.single .article__content ol {
  list-style: decimal inside;
}

body.page .article__content ul, body.single .article__content ul,
body.page .article__content ol, body.single .article__content ol {
  margin-bottom: 6rem;
}

body.page .article__content ul:last-child, body.single .article__content ul:last-child,
body.page .article__content ol:last-child, body.single .article__content ol:last-child {
  margin-bottom: 0;
}

@media (max-width: 834px) {
  body.page .article__content ul, body.single .article__content ul,
  body.page .article__content ol, body.single .article__content ol {
    margin-bottom: 4.5rem;
  }
}
body.page .article__content ul li, body.single .article__content ul li,
body.page .article__content ol li, body.single .article__content ol li {
  color: #000;
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.6;
  text-indent: -1em;
  padding-left: 1em;
  margin-bottom: 1.5rem;
}

@media (max-width: 834px) {
  body.page .article__content ul li, body.single .article__content ul li,
  body.page .article__content ol li, body.single .article__content ol li {
    font-size: 1.8rem;
  }
}
body.page .article__content ul li:last-child, body.single .article__content ul li:last-child,
body.page .article__content ol li:last-child, body.single .article__content ol li:last-child {
  margin-bottom: 0;
}

body.page .article__content__copySection, body.single .article__content__copySection {
  padding: 0 0 9rem !important;
  margin-bottom: 9rem !important;
}

body.page .article__content__copySection:first-child, body.single .article__content__copySection:first-child {
  padding-top: 3rem !important;
}

@media (max-width: 430px) {
  body.page .article__content__copySection:first-child, body.single .article__content__copySection:first-child {
    padding-top: 0 !important;
  }
}
@media (max-width: 430px) {
  body.page .article__content__copySection, body.single .article__content__copySection {
    padding: 0 0 4.5rem !important;
    margin-bottom: 4.5rem !important;
  }
}
body.page .article__content__copySection--last, body.single .article__content__copySection--last {
  margin-bottom: 6rem !important;
}

@media (max-width: 430px) {
  body.page .article__content__copySection--last, body.single .article__content__copySection--last {
    margin-bottom: 4.5rem !important;
  }
}
body.page .article__content__copySection h2, body.single .article__content__copySection h2 {
  font-size: 2.2rem;
  font-weight: 600;
  line-height: 1.4;
  word-break: keep-all;
}

@media (max-width: 834px) {
  body.page .article__content__copySection h2, body.single .article__content__copySection h2 {
    font-size: min(4vw, 2.2rem);
  }
}
@media (max-width: 430px) {
  body.page .article__content__copySection h2, body.single .article__content__copySection h2 {
    font-size: 1.6rem;
  }
}
@media (max-width: 374px) {
  body.page .article__content__copySection h2, body.single .article__content__copySection h2 {
    word-break: normal;
  }
}
body.page .article__content__copySection .copy, body.single .article__content__copySection .copy {
  font-size: min(4vw, 4rem);
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 0;
}

@media (max-width: 834px) {
  body.page .article__content__copySection .copy, body.single .article__content__copySection .copy {
    font-size: 5vw;
  }
}
@media (max-width: 430px) {
  body.page .article__content__copySection .copy, body.single .article__content__copySection .copy {
    font-size: 2.2rem;
  }
}
@media (max-width: 374px) {
  body.page .article__content__copySection .copy, body.single .article__content__copySection .copy {
    word-break: normal;
  }
}
body.page .article__content__errors, body.single .article__content__errors {
  margin-bottom: 6rem;
}

@media (max-width: 430px) {
  body.page .article__content__errors, body.single .article__content__errors {
    margin-bottom: 4.5rem;
  }
}
body.page .article__content__errors ul li, body.single .article__content__errors ul li {
  color: #e62814;
  font-family: YakuHanJP, -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Noto Sans JP", Arial, Meiryo, sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 1rem;
}

body.page .article__content__errors ul li::marker, body.single .article__content__errors ul li::marker {
  color: #000;
}

body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
body.home .service,
body.home .forte__inner,
body.home .clients__inner,
body.home .hero__txt,
.footer__copyright,
.footer__grid,
body.page .article__header, body.single .article__header {
  max-width: min(90vw, 1280px);
}

@media (max-width: 834px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.home .service,
  body.home .forte__inner,
  body.home .clients__inner,
  body.home .hero__txt,
  .footer__copyright,
  .footer__grid,
  body.page .article__header, body.single .article__header {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.home .service,
  body.home .forte__inner,
  body.home .clients__inner,
  body.home .hero__txt,
  .footer__copyright,
  .footer__grid,
  body.page .article__header, body.single .article__header {
    max-width: calc(100vw - 6rem);
  }
}
body.page .article__description, body.single .article__description,
body.page .article__content, body.single .article__content {
  max-width: min(90vw, 1080px);
}

@media (max-width: 834px) {
  body.page .article__description, body.single .article__description,
  body.page .article__content, body.single .article__content {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page .article__description, body.single .article__description,
  body.page .article__content, body.single .article__content {
    max-width: calc(100vw - 6rem);
  }
}
.footer {
  color: #fff;
  padding: 6rem 0 10rem;
  background-color: #191918;
}

@media (max-width: 834px) {
  .footer {
    padding-top: 6rem;
    padding-bottom: 10rem;
  }
}
.footer__grid {
  display: grid;
  margin: 0 auto 5rem;
  grid-template-columns: repeat(3, auto);
  grid-template-rows: repeat(2, auto);
}

@media (max-width: 1400px) {
  .footer__grid {
    grid-template-columns: auto 1fr;
    grid-template-rows: repeat(3, auto);
  }
}
@media (max-width: 1140px) {
  .footer__grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(4, auto);
  }
}
.footer__companyName {
  width: 180px;
  height: 32px;
  font-family: Roboto, sans-serif;
  font-size: 4rem;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.025em;
  text-indent: -9999px;
  overflow: hidden;
  margin-bottom: 3rem;
  background-image: url("../images/common/logo_m-grit_white.png");
  background-repeat: no-repeat;
  background-size: contain;
  grid-row: 1;
  grid-column: 1/4;
}

@media (max-width: 1140px) {
  .footer__companyName {
    grid-row: 1;
    grid-column: 1;
  }
}
@media (max-width: 430px) {
  .footer__companyName {
    grid-row: 2;
    grid-column: 1;
  }
}
.footer__left {
  line-height: 1;
  grid-row: 2;
  grid-column: 1;
}

@media (max-width: 1400px) {
  .footer__left {
    padding-bottom: 5rem;
  }
}
@media (max-width: 1140px) {
  .footer__left {
    grid-row: 2;
    grid-column: 1;
  }
}
@media (max-width: 430px) {
  .footer__left {
    grid-row: 3;
    grid-column: 1;
  }
}
.footer__center {
  grid-row: 2;
  grid-column: 2;
}

@media (max-width: 1400px) {
  .footer__center {
    padding-bottom: 5rem;
  }
}
@media (max-width: 1140px) {
  .footer__center {
    grid-row: 3;
    grid-column: 1;
  }
}
@media (max-width: 430px) {
  .footer__center {
    padding-bottom: 0;
    grid-row: 4;
    grid-column: 1;
  }
}
.footer__center ul {
  display: flex;
  justify-content: center;
}

@media (max-width: 1400px) {
  .footer__center ul {
    justify-content: flex-end;
  }
}
@media (max-width: 1140px) {
  .footer__center ul {
    justify-content: flex-start;
  }
}
@media (max-width: 834px) {
  .footer__center ul {
    display: block;
  }
}
.footer__center ul li {
  line-height: 1;
  padding: 0 1.5rem;
  border-right: 1px solid #c2c2c1;
}

@media (max-width: 1400px) {
  .footer__center ul li {
    letter-spacing: 0.025em;
  }
}
@media (max-width: 834px) {
  .footer__center ul li {
    line-height: 1.2;
    padding: 0;
    margin-bottom: 2rem;
    border-right: none;
  }
  .footer__center ul li:last-child {
    margin-bottom: 0;
  }
}
.footer__center ul li:first-child {
  padding-left: 0;
}

.footer__center ul li:last-child {
  padding-right: 0;
  border-right: none;
}

.footer__center ul li a {
  color: #fff;
  text-decoration: none;
  text-decoration-color: rgba(255, 255, 255, 0);
  transition: all 0.2s ease-in-out;
  text-underline-offset: 6px;
}

.footer__center ul li a:hover {
  text-decoration: underline;
  text-decoration-color: rgba(255, 255, 255, 0.5);
}

.footer__right {
  opacity: 0;
  transition-delay: 0s;
  text-align: right;
  transform: translateY(-18px);
  grid-row: 2;
  grid-column: 3;
}

.footer__right.active {
  opacity: 1;
  transition: all 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.25s;
}

@media (max-width: 1400px) {
  .footer__right {
    text-align: left;
    transform: translateY(0);
    grid-row: 3;
    grid-column: 1/3;
  }
}
@media (max-width: 1140px) {
  .footer__right {
    grid-row: 4;
    grid-column: 1;
  }
}
@media (max-width: 430px) {
  .footer__right {
    text-align: center;
    padding-bottom: 5rem;
    grid-row: 1;
    grid-column: 1;
  }
}
@media (max-width: 430px) {
  .footer address {
    font-size: 1.4rem;
  }
}
.footer address span {
  display: inline-block;
}

.footer__address {
  line-height: 1.2;
  padding-bottom: 1.5rem;
}

.footer__telTitle {
  font-family: Roboto, sans-serif;
  font-size: 2rem;
  padding-right: 3px;
}

.footer__telNumber {
  color: #fff;
  font-family: Roboto, sans-serif;
  font-size: 2.4rem;
  font-weight: bold;
  text-decoration: none;
}

.footer__copyright {
  line-height: 1;
  margin: 0 auto;
}

body.home .service__viewBtn,
body.home .forte__viewBtn,
body.home .businessPerformance__head {
  padding-left: 6rem;
}

@media (max-width: 834px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn,
  body.home .businessPerformance__head {
    padding-left: 4rem;
  }
}
@media (max-width: 430px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn,
  body.home .businessPerformance__head {
    padding-left: 3rem;
  }
}
body.home .service__viewBtn,
body.home .forte__viewBtn {
  padding-right: 6rem;
}

@media (max-width: 834px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn {
    padding-right: 4rem;
  }
}
@media (max-width: 430px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn {
    padding-right: 3rem;
  }
}
body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
body.home .service,
body.home .forte__inner,
body.home .clients__inner,
body.home .hero__txt,
body.page .article__header, body.single .article__header,
.footer__grid,
.footer__copyright {
  max-width: min(90vw, 1280px);
}

@media (max-width: 834px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.home .service,
  body.home .forte__inner,
  body.home .clients__inner,
  body.home .hero__txt,
  body.page .article__header, body.single .article__header,
  .footer__grid,
  .footer__copyright {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.home .service,
  body.home .forte__inner,
  body.home .clients__inner,
  body.home .hero__txt,
  body.page .article__header, body.single .article__header,
  .footer__grid,
  .footer__copyright {
    max-width: calc(100vw - 6rem);
  }
}
body.page .article__description, body.single .article__description,
body.page .article__content, body.single .article__content {
  max-width: min(90vw, 1080px);
}

@media (max-width: 834px) {
  body.page .article__description, body.single .article__description,
  body.page .article__content, body.single .article__content {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page .article__description, body.single .article__description,
  body.page .article__content, body.single .article__content {
    max-width: calc(100vw - 6rem);
  }
}
body.home .hero {
  text-align: center;
}

@media (max-width: 834px) {
  body.home .hero {
    text-align: left;
  }
}
body.home .hero__ttl {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(10px) translateZ(0);
  display: block;
  width: calc(100vw - 12rem);
  max-width: 1280px;
  text-align: left;
  margin: 0 auto min(12vw, 16rem);
}

body.home .hero__ttl.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.5s;
  transform: translateY(0) translateZ(0);
}

@media (max-width: 834px) {
  body.home .hero__ttl {
    width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.home .hero__ttl {
    width: calc(100vw - 6rem);
  }
}
body.home .hero__ttl__inner {
  display: block;
  font-feature-settings: "palt" 1;
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(5.4vw, 8.2rem);
  font-weight: 900;
  line-height: 1.4;
  letter-spacing: 0.04em;
  text-align: center;
}

@media (max-width: 834px) {
  body.home .hero__ttl__inner {
    font-size: 8.8vw;
    text-align: left;
  }
}
@media (max-width: 430px) {
  body.home .hero__ttl__inner {
    font-size: 8.7vw;
  }
}
body.home .hero__txt {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(20px) translateZ(0);
  max-width: min(70vw, 1080px) !important;
  text-align: left;
  margin: 0 auto min(14vw, 17rem);
}

body.home .hero__txt.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 1s;
  transform: translateY(0) translateZ(0);
}

@media (max-width: 834px) {
  body.home .hero__txt {
    max-width: calc(100vw - 8rem) !important;
    padding-right: 0;
    padding-left: 0;
    margin-bottom: 14vw;
  }
}
@media (max-width: 430px) {
  body.home .hero__txt {
    max-width: calc(100vw - 6rem) !important;
  }
}
body.home .hero__txt p {
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.025em;
  margin-bottom: min(2vw, 3rem);
}

@media (max-width: 1024px) {
  body.home .hero__txt p {
    font-size: 2.4rem;
    margin-bottom: 3vw;
  }
}
@media (max-width: 834px) {
  body.home .hero__txt p {
    font-size: 2rem;
  }
}
@media (max-width: 430px) {
  body.home .hero__txt p {
    font-size: 1.8rem;
    margin-bottom: 6vw;
  }
}
body.home .hero__txt p:last-child {
  margin-bottom: 0;
}

body.home .hero__img {
  display: flex;
  justify-content: flex-end;
  width: 100%;
  height: auto;
  min-height: 100px;
}

@media (max-width: 430px) {
  body.home .hero__img {
    justify-content: right;
  }
}
body.home .hero__img__inner {
  display: block;
  width: 100%;
  height: auto;
  overflow: hidden;
}

body.home .hero__img video {
  display: block;
  width: 100%;
  height: auto;
  min-height: 100px;
}

body.home .service__viewBtn,
body.home .forte__viewBtn,
body.home .businessPerformance__head {
  padding-left: 6rem;
}

@media (max-width: 834px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn,
  body.home .businessPerformance__head {
    padding-left: 4rem;
  }
}
@media (max-width: 430px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn,
  body.home .businessPerformance__head {
    padding-left: 3rem;
  }
}
body.home .service__viewBtn,
body.home .forte__viewBtn {
  padding-right: 6rem;
}

@media (max-width: 834px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn {
    padding-right: 4rem;
  }
}
@media (max-width: 430px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn {
    padding-right: 3rem;
  }
}
body.home .service__head__ttl__en,
body.home .forte__txt__ttl__en,
body.home .clients__head__ttl,
body.home .businessPerformance__head__en {
  font-size: min(7.2vw, 12rem);
}

@media (max-width: 1023px) {
  body.home .service__head__ttl__en,
  body.home .forte__txt__ttl__en,
  body.home .clients__head__ttl,
  body.home .businessPerformance__head__en {
    font-size: min(8.4vw, 12rem);
  }
}
@media (max-width: 834px) {
  body.home .service__head__ttl__en,
  body.home .forte__txt__ttl__en,
  body.home .clients__head__ttl,
  body.home .businessPerformance__head__en {
    padding-bottom: 5px;
  }
}
@media (max-width: 430px) {
  body.home .service__head__ttl__en,
  body.home .forte__txt__ttl__en,
  body.home .clients__head__ttl,
  body.home .businessPerformance__head__en {
    padding-bottom: 2px;
  }
}
body.home .service__head__ttl__ja,
body.home .forte__txt__ttl__ja {
  font-size: min(6vw, 8rem);
}

@media (max-width: 834px) {
  body.home .service__head__ttl__ja,
  body.home .forte__txt__ttl__ja {
    font-size: min(5.5vw, 8rem);
  }
}
body.home .businessPerformance {
  position: relative;
  aspect-ratio: 1900/1192;
  overflow: hidden;
  background: #fefff2;
}

@media (max-width: 1023px) {
  body.home .businessPerformance {
    aspect-ratio: 1500/2310;
  }
}
body.home .businessPerformance__head {
  position: absolute;
  width: 100%;
  top: min(8vw, 15rem);
  z-index: 4;
}

body.home .businessPerformance__head h2 {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(20px) translateZ(0);
  margin-bottom: 6rem;
}

body.home .businessPerformance__head h2.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0s;
  transform: translateY(0) translateZ(0);
}

@media (max-width: 834px) {
  body.home .businessPerformance__head h2 {
    margin-bottom: 3rem;
  }
}
body.home .businessPerformance__head__en {
  display: block;
  font-family: Roboto, sans-serif;
  font-weight: bold;
  line-height: 0.9;
  margin-bottom: 10px;
  margin-left: -9px;
}

@media (max-width: 834px) {
  body.home .businessPerformance__head__en {
    margin-left: -5px;
    margin-bottom: 0;
  }
}
body.home .businessPerformance__head__ja {
  display: block;
  margin-left: -5px;
}

body.home .businessPerformance__head__ja__grid {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 2rem;
}

@media (max-width: 834px) {
  body.home .businessPerformance__head__ja__grid {
    display: block;
  }
}
body.home .businessPerformance__head__ja__ttl {
  display: block;
  font-feature-settings: "palt" 1;
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(2.9vw, 3.6rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
}

@media (max-width: 834px) {
  body.home .businessPerformance__head__ja__ttl {
    font-size: min(5.5vw, 8rem);
    margin-bottom: 2vw;
  }
}
@media (max-width: 430px) {
  body.home .businessPerformance__head__ja__ttl {
    margin-bottom: 2.8vw;
  }
}
body.home .businessPerformance__head__ja__txt {
  display: block;
  font-feature-settings: "palt" 1;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1;
}

body.home .businessPerformance__head__ja__txt__1 {
  display: block;
  font-size: min(1.8vw, 1.6rem);
  font-weight: 500;
  margin-top: min(0.8vw, 1.2rem);
  margin-bottom: 1rem;
}

@media (max-width: 834px) {
  body.home .businessPerformance__head__ja__txt__1 {
    font-size: 2.4vw;
    margin-top: min(0.7vw, 1rem);
    margin-bottom: 1.6vw;
  }
}
@media (max-width: 430px) {
  body.home .businessPerformance__head__ja__txt__1 {
    font-size: 2.6vw;
    margin-bottom: 1.2vw;
  }
}
body.home .businessPerformance__head__ja__txt__2 {
  display: block;
  font-size: 1.5rem;
}

@media (max-width: 834px) {
  body.home .businessPerformance__head__ja__txt__2 {
    font-size: 2.4vw;
  }
}
@media (max-width: 430px) {
  body.home .businessPerformance__head__ja__txt__2 {
    font-size: 2.6vw;
  }
}
body.home .businessPerformance__head__viewBtn {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(10px) translateZ(0);
}

body.home .businessPerformance__head__viewBtn.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.5s;
  transform: translateY(0) translateZ(0);
}

body.home .businessPerformance__head__viewBtn .btn {
  margin-left: -5px;
  transform-origin: left top;
}

@media (max-width: 1140px) {
  body.home .businessPerformance__head__viewBtn .btn {
    transform: scale(0.9);
  }
}
@media (max-width: 1023px) {
  body.home .businessPerformance__head__viewBtn {
    display: none;
  }
}
body.home .businessPerformance__viewBtn {
  display: none;
  z-index: 4;
}

body.home .businessPerformance__viewBtn__inner {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(10px) translateZ(0);
}

body.home .businessPerformance__viewBtn__inner.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0s;
  transform: translateY(0) translateZ(0);
}

@media (max-width: 1023px) {
  body.home .businessPerformance__viewBtn {
    position: absolute;
    display: block;
    width: calc(100% - 6rem);
    bottom: 14vw;
    left: 50%;
    text-align: center;
    transform: translateX(-50%);
    transform-origin: center center;
  }
}
@media (max-width: 430px) {
  body.home .businessPerformance__viewBtn {
    bottom: 7vw;
  }
}
body.home .businessPerformance__graphic {
  position: relative;
}

body.home .businessPerformance__graphic__main {
  position: absolute;
  width: 100%;
  height: auto;
  aspect-ratio: 1900/1192;
  top: 0;
  left: 0;
  z-index: 3;
}

@media (max-width: 1023px) {
  body.home .businessPerformance__graphic__main {
    aspect-ratio: 1500/2310;
  }
}
body.home .businessPerformance__graphic .areaCircle {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: auto;
  aspect-ratio: 1/1;
  color: #fff;
  line-height: 1;
  opacity: 0;
  border-radius: 1000px;
  background-color: rgba(53, 202, 220, 0.8);
  transition: opacity 1s;
}

body.home .businessPerformance__graphic .areaCircle.active {
  opacity: 1;
}

body.home .businessPerformance__graphic .areaCircle.active .areaCircle__inner {
  opacity: 1;
}

body.home .businessPerformance__graphic .areaCircle__inner {
  display: block;
  opacity: 0.1;
  transition: opacity 2s;
  transition-delay: 1s;
}

body.home .businessPerformance__graphic .areaCircle__txt {
  display: block;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: min(0.3vw, 0.5rem);
  -moz-user-select: none;
  -ms-user-select: none;
  -webkit-user-select: none;
  user-select: none;
}

body.home .businessPerformance__graphic .areaCircle__num {
  display: block;
  font-family: Roboto, sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  text-align: center;
  -moz-user-select: none;
  -ms-user-select: none;
  -webkit-user-select: none;
  user-select: none;
}

body.home .businessPerformance__graphic .areaCircle__1 {
  width: 5.4%;
  top: 73.2%;
  left: 24.3%;
  z-index: 1;
}

body.home .businessPerformance__graphic .areaCircle__1 .areaCircle__txt {
  font-size: min(1.3vw, 1.4rem);
}

@media (max-width: 1023px) {
  body.home .businessPerformance__graphic .areaCircle__1 .areaCircle__txt {
    font-size: min(2vw, 1.4rem);
  }
}
body.home .businessPerformance__graphic .areaCircle__1 .areaCircle__num {
  font-size: min(1.8vw, 3.4rem);
}

@media (max-width: 1023px) {
  body.home .businessPerformance__graphic .areaCircle__1 {
    width: 12%;
    top: 67.5%;
    left: 1.2%;
  }
  body.home .businessPerformance__graphic .areaCircle__1 .areaCircle__num {
    font-size: 3.2vw;
  }
}
@media (max-width: 430px) {
  body.home .businessPerformance__graphic .areaCircle__1 .areaCircle__txt {
    font-size: 2.5vw;
  }
}
body.home .businessPerformance__graphic .areaCircle__2 {
  width: 35%;
  top: 24%;
  left: 29.5%;
  z-index: 2;
}

body.home .businessPerformance__graphic .areaCircle__2 .areaCircle__txt {
  font-size: min(3vw, 5rem);
}

body.home .businessPerformance__graphic .areaCircle__2 .areaCircle__num {
  font-size: min(7vw, 12rem);
}

@media (max-width: 1023px) {
  body.home .businessPerformance__graphic .areaCircle__2 {
    width: 60%;
    top: 33%;
    left: 7%;
  }
  body.home .businessPerformance__graphic .areaCircle__2 .areaCircle__txt {
    font-size: 5vw;
  }
  body.home .businessPerformance__graphic .areaCircle__2 .areaCircle__num {
    font-size: 14vw;
  }
}
body.home .businessPerformance__graphic .areaCircle__3 {
  width: 20.5%;
  top: 59.5%;
  left: 33%;
  z-index: 3;
  background-color: rgba(0, 173, 239, 0.8);
}

body.home .businessPerformance__graphic .areaCircle__3 .areaCircle__txt {
  font-size: min(2vw, 3.4rem);
}

body.home .businessPerformance__graphic .areaCircle__3 .areaCircle__num {
  font-size: min(4vw, 6.8rem);
}

@media (max-width: 1023px) {
  body.home .businessPerformance__graphic .areaCircle__3 {
    width: 32%;
    top: 58%;
    left: 14%;
  }
  body.home .businessPerformance__graphic .areaCircle__3 .areaCircle__txt {
    font-size: 3vw;
  }
  body.home .businessPerformance__graphic .areaCircle__3 .areaCircle__num {
    font-size: 7vw;
  }
}
body.home .businessPerformance__graphic .areaCircle__4 {
  width: 12%;
  top: 41%;
  left: 56.7%;
  z-index: 4;
  background-color: rgba(0, 173, 239, 0.8);
}

body.home .businessPerformance__graphic .areaCircle__4 .areaCircle__txt {
  font-size: min(1vw, 2.6rem);
}

body.home .businessPerformance__graphic .areaCircle__4 .areaCircle__num {
  font-size: min(2.4vw, 6.4rem);
}

@media (max-width: 1023px) {
  body.home .businessPerformance__graphic .areaCircle__4 {
    width: 17%;
    top: 46%;
    left: 53%;
  }
  body.home .businessPerformance__graphic .areaCircle__4 .areaCircle__txt {
    font-size: 2.2vw;
  }
  body.home .businessPerformance__graphic .areaCircle__4 .areaCircle__num {
    font-size: 4.2vw;
  }
}
@media (max-width: 430px) {
  body.home .businessPerformance__graphic .areaCircle__4 .areaCircle__txt {
    font-size: 2.6vw;
  }
}
body.home .businessPerformance__graphic .areaCircle__5 {
  width: 9%;
  top: 60%;
  left: 65%;
  z-index: 5;
}

body.home .businessPerformance__graphic .areaCircle__5 .areaCircle__txt {
  font-size: min(1vw, 2.6rem);
}

body.home .businessPerformance__graphic .areaCircle__5 .areaCircle__num {
  font-size: min(2.4vw, 5rem);
}

@media (max-width: 1023px) {
  body.home .businessPerformance__graphic .areaCircle__5 {
    width: 12%;
    top: 61%;
    left: 63%;
  }
  body.home .businessPerformance__graphic .areaCircle__5 .areaCircle__txt {
    font-size: 2.4vw;
  }
  body.home .businessPerformance__graphic .areaCircle__5 .areaCircle__num {
    font-size: 3.6vw;
  }
}
@media (max-width: 430px) {
  body.home .businessPerformance__graphic .areaCircle__5 .areaCircle__txt {
    font-size: 2.6vw;
  }
}
body.home .businessPerformance__graphic .areaCircle__6 {
  width: 17%;
  top: 39.5%;
  left: 73.3%;
  z-index: 6;
  background-color: rgba(0, 173, 239, 0.8);
}

body.home .businessPerformance__graphic .areaCircle__6 .areaCircle__txt {
  font-size: min(1.7vw, 2.8rem);
}

body.home .businessPerformance__graphic .areaCircle__6 .areaCircle__num {
  font-size: min(3.6vw, 7rem);
}

@media (max-width: 1023px) {
  body.home .businessPerformance__graphic .areaCircle__6 {
    width: 27%;
    top: 48%;
    left: 72%;
  }
  body.home .businessPerformance__graphic .areaCircle__6 .areaCircle__txt {
    font-size: 2.8vw;
  }
  body.home .businessPerformance__graphic .areaCircle__6 .areaCircle__num {
    font-size: 5.6vw;
  }
}
body.home .businessPerformance__graphic .areaCircle__7 {
  width: 14.7%;
  top: 11%;
  left: 80.6%;
  z-index: 7;
}

body.home .businessPerformance__graphic .areaCircle__7 .areaCircle__txt {
  font-size: min(1.5vw, 2.6rem);
}

body.home .businessPerformance__graphic .areaCircle__7 .areaCircle__num {
  font-size: min(3.5vw, 6rem);
}

@media (max-width: 1023px) {
  body.home .businessPerformance__graphic .areaCircle__7 {
    width: 23%;
    top: 30%;
    left: 74%;
  }
  body.home .businessPerformance__graphic .areaCircle__7 .areaCircle__txt {
    font-size: 2.4vw;
  }
  body.home .businessPerformance__graphic .areaCircle__7 .areaCircle__num {
    font-size: 5.6vw;
  }
}
@media (max-width: 430px) {
  body.home .businessPerformance__graphic .areaCircle__7 .areaCircle__txt {
    font-size: 2.6vw;
  }
}
body.home .businessPerformance__graphic__map,
body.home .businessPerformance__graphic__bg {
  position: absolute;
  width: 100%;
  height: auto;
  aspect-ratio: 1900/1192;
  top: 0;
  left: 0;
  content: "";
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}

@media (max-width: 1023px) {
  body.home .businessPerformance__graphic__map,
  body.home .businessPerformance__graphic__bg {
    aspect-ratio: 1500/2310;
  }
}
body.home .businessPerformance__graphic__map {
  opacity: 0;
  transition-delay: 0s;
  z-index: 2;
  background-image: url("../images/home/bp_map.png");
}

body.home .businessPerformance__graphic__map.active {
  opacity: 1;
  transition: all 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.5s;
}

@media (max-width: 1023px) {
  body.home .businessPerformance__graphic__map {
    background-image: url("../images/home/bp_map_sp.png");
  }
}
body.home .businessPerformance__graphic__bg {
  opacity: 0;
  transition-delay: 0s;
  z-index: 1;
  background-image: url("../images/home/bp_bg.png");
}

body.home .businessPerformance__graphic__bg.active {
  opacity: 1;
  transition: all 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0s;
}

@media (max-width: 1023px) {
  body.home .businessPerformance__graphic__bg {
    background-image: url("../images/home/bp_bg_sp.png");
  }
}
body.home .service__viewBtn,
body.home .forte__viewBtn,
body.home .businessPerformance__head {
  padding-left: 6rem;
}

@media (max-width: 834px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn,
  body.home .businessPerformance__head {
    padding-left: 4rem;
  }
}
@media (max-width: 430px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn,
  body.home .businessPerformance__head {
    padding-left: 3rem;
  }
}
body.home .service__viewBtn,
body.home .forte__viewBtn {
  padding-right: 6rem;
}

@media (max-width: 834px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn {
    padding-right: 4rem;
  }
}
@media (max-width: 430px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn {
    padding-right: 3rem;
  }
}
body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
body.home .service,
body.home .forte__inner,
body.home .clients__inner,
body.page .article__header, body.single .article__header,
.footer__grid,
.footer__copyright,
body.home .hero__txt {
  max-width: min(90vw, 1280px);
}

@media (max-width: 834px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.home .service,
  body.home .forte__inner,
  body.home .clients__inner,
  body.page .article__header, body.single .article__header,
  .footer__grid,
  .footer__copyright,
  body.home .hero__txt {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.home .service,
  body.home .forte__inner,
  body.home .clients__inner,
  body.page .article__header, body.single .article__header,
  .footer__grid,
  .footer__copyright,
  body.home .hero__txt {
    max-width: calc(100vw - 6rem);
  }
}
body.page .article__description, body.single .article__description,
body.page .article__content, body.single .article__content {
  max-width: min(90vw, 1080px);
}

@media (max-width: 834px) {
  body.page .article__description, body.single .article__description,
  body.page .article__content, body.single .article__content {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page .article__description, body.single .article__description,
  body.page .article__content, body.single .article__content {
    max-width: calc(100vw - 6rem);
  }
}
body.home .service__head__ttl__en,
body.home .forte__txt__ttl__en,
body.home .clients__head__ttl,
body.home .businessPerformance__head__en {
  font-size: min(7.2vw, 12rem);
}

@media (max-width: 1023px) {
  body.home .service__head__ttl__en,
  body.home .forte__txt__ttl__en,
  body.home .clients__head__ttl,
  body.home .businessPerformance__head__en {
    font-size: min(8.4vw, 12rem);
  }
}
@media (max-width: 834px) {
  body.home .service__head__ttl__en,
  body.home .forte__txt__ttl__en,
  body.home .clients__head__ttl,
  body.home .businessPerformance__head__en {
    padding-bottom: 5px;
  }
}
@media (max-width: 430px) {
  body.home .service__head__ttl__en,
  body.home .forte__txt__ttl__en,
  body.home .clients__head__ttl,
  body.home .businessPerformance__head__en {
    padding-bottom: 2px;
  }
}
body.home .service__head__ttl__ja,
body.home .forte__txt__ttl__ja {
  font-size: min(6vw, 8rem);
}

@media (max-width: 834px) {
  body.home .service__head__ttl__ja,
  body.home .forte__txt__ttl__ja {
    font-size: min(5.5vw, 8rem);
  }
}
body.home .clients {
  padding-top: min(14vw, 13rem);
  padding-bottom: min(14vw, 13rem);
}

body.home .clients__inner {
  margin: 0 auto;
}

@media (max-width: 834px) {
  body.home .clients__inner {
    max-width: 100vw !important;
  }
}
@media (max-width: 834px) {
  body.home .clients__inner {
    padding-right: 4rem;
    padding-left: 4rem;
  }
}
@media (max-width: 430px) {
  body.home .clients__inner {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}
body.home .clients__head {
  margin-bottom: min(14vw, 13rem);
}

body.home .clients__head__ttl {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(10px) translateZ(0);
  display: block;
  font-family: Roboto, sans-serif;
  font-weight: bold;
  line-height: 1;
  margin-bottom: 2rem;
}

body.home .clients__head__ttl.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0;
  transform: translateY(0) translateZ(0);
}

@media (max-width: 834px) {
  body.home .clients__head__ttl {
    margin-bottom: 0;
  }
}
@media (max-width: 430px) {
  body.home .clients__head__ttl {
    margin-bottom: 2px;
  }
}
body.home .clients__head__txt {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-gap: 3rem;
}

@media (max-width: 834px) {
  body.home .clients__head__txt {
    display: block;
  }
}
body.home .clients__head__txt__ttl {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(10px) translateZ(0);
  display: block;
  font-size: 3.4rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
  font-feature-settings: "palt" 1;
}

body.home .clients__head__txt__ttl.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0;
  transform: translateY(0) translateZ(0);
}

@media (max-width: 834px) {
  body.home .clients__head__txt__ttl {
    font-size: min(5.5vw, 8rem);
    margin-bottom: 7vw;
  }
}
body.home .clients__head__txt__description {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(10px) translateZ(0);
  font-size: 2rem;
  font-weight: 600;
  line-height: 2;
}

body.home .clients__head__txt__description.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.5s;
  transform: translateY(0) translateZ(0);
}

@media (max-width: 834px) {
  body.home .clients__head__txt__description {
    font-size: 1.8rem;
  }
}
@media (max-width: 430px) {
  body.home .clients__head__txt__description {
    font-size: 1.6rem;
  }
}
body.home .clients__banners {
  opacity: 0;
  transition-delay: 0s;
  transform: translateX(10px) translateZ(0);
}

body.home .clients__banners.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.75s;
  transform: translateX(0) translateZ(0);
}

body.home .clients__banners .swiper {
  width: 100%;
  height: auto;
}

body.home .clients__banners .swiper-wrapper {
  transition-timing-function: linear;
}

body.home .clients__banners .swiper-slide {
  display: flex;
  align-items: center;
  justify-content: start;
}

body.home .clients__banners .swiper-slide img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 344/90;
  /* vertical-align: auto; */
  object-fit: cover;
}

body.home .clients__banners .swiper-horizontal > .swiper-scrollbar,
body.home .clients__banners .swiper-scrollbar.swiper-scrollbar-horizontal {
  height: 8px;
  width: 100%;
  bottom: 0;
  left: 0;
}

body.home .clients__banners .swiper-scrollbar {
  display: none;
  background: rgba(0, 0, 0, 0.05);
}

body.home .clients__banners .swiper-scrollbar-drag {
  background: #ddd;
}

body.home .service__viewBtn,
body.home .forte__viewBtn,
body.home .businessPerformance__head {
  padding-left: 6rem;
}

@media (max-width: 834px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn,
  body.home .businessPerformance__head {
    padding-left: 4rem;
  }
}
@media (max-width: 430px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn,
  body.home .businessPerformance__head {
    padding-left: 3rem;
  }
}
body.home .service__viewBtn,
body.home .forte__viewBtn {
  padding-right: 6rem;
}

@media (max-width: 834px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn {
    padding-right: 4rem;
  }
}
@media (max-width: 430px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn {
    padding-right: 3rem;
  }
}
body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
body.home .service,
body.home .forte__inner,
body.page .article__header, body.single .article__header,
.footer__grid,
.footer__copyright,
body.home .hero__txt,
body.home .clients__inner {
  max-width: min(90vw, 1280px);
}

@media (max-width: 834px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.home .service,
  body.home .forte__inner,
  body.page .article__header, body.single .article__header,
  .footer__grid,
  .footer__copyright,
  body.home .hero__txt,
  body.home .clients__inner {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.home .service,
  body.home .forte__inner,
  body.page .article__header, body.single .article__header,
  .footer__grid,
  .footer__copyright,
  body.home .hero__txt,
  body.home .clients__inner {
    max-width: calc(100vw - 6rem);
  }
}
body.page .article__description, body.single .article__description,
body.page .article__content, body.single .article__content {
  max-width: min(90vw, 1080px);
}

@media (max-width: 834px) {
  body.page .article__description, body.single .article__description,
  body.page .article__content, body.single .article__content {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page .article__description, body.single .article__description,
  body.page .article__content, body.single .article__content {
    max-width: calc(100vw - 6rem);
  }
}
body.home .service__head__ttl__en,
body.home .forte__txt__ttl__en,
body.home .businessPerformance__head__en,
body.home .clients__head__ttl {
  font-size: min(7.2vw, 12rem);
}

@media (max-width: 1023px) {
  body.home .service__head__ttl__en,
  body.home .forte__txt__ttl__en,
  body.home .businessPerformance__head__en,
  body.home .clients__head__ttl {
    font-size: min(8.4vw, 12rem);
  }
}
@media (max-width: 834px) {
  body.home .service__head__ttl__en,
  body.home .forte__txt__ttl__en,
  body.home .businessPerformance__head__en,
  body.home .clients__head__ttl {
    padding-bottom: 5px;
  }
}
@media (max-width: 430px) {
  body.home .service__head__ttl__en,
  body.home .forte__txt__ttl__en,
  body.home .businessPerformance__head__en,
  body.home .clients__head__ttl {
    padding-bottom: 2px;
  }
}
body.home .service__head__ttl__ja,
body.home .forte__txt__ttl__ja {
  font-size: min(6vw, 8rem);
}

@media (max-width: 834px) {
  body.home .service__head__ttl__ja,
  body.home .forte__txt__ttl__ja {
    font-size: min(5.5vw, 8rem);
  }
}
body.home .forte {
  padding: min(14vw, 13rem) 0;
  background-color: #f8f8f8;
}

body.home .forte__inner {
  margin: 0 auto;
}

@media (max-width: 834px) {
  body.home .forte__inner {
    max-width: 100vw !important;
  }
}
body.home .forte__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: min(7vw, 10rem);
}

@media (max-width: 834px) {
  body.home .forte__grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 834px) {
  body.home .forte__img {
    order: 2;
  }
}
body.home .forte__img img {
  opacity: 0;
  transition-delay: 0s;
  transform: translateX(-20px) translateZ(0);
  width: 100%;
  height: auto;
}

body.home .forte__img img.active {
  opacity: 1;
  transition: opacity 1.5s cubic-bezier(0.4, 0, 0.2, 1), transform 1.5s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0s;
  transform: translateX(0) translateZ(0);
}

@media (max-width: 834px) {
  body.home .forte__img img {
    width: 100vw;
  }
}
@media (max-width: 834px) {
  body.home .forte__txt {
    order: 1;
    padding-right: 4rem;
    padding-left: 4rem;
  }
}
@media (max-width: 430px) {
  body.home .forte__txt {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}
body.home .forte__txt__ttl {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(20px) translateZ(0);
}

body.home .forte__txt__ttl.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0s;
  transform: translateY(0) translateZ(0);
}

body.home .forte__txt__ttl__en {
  display: block;
  font-family: Roboto, sans-serif;
  font-weight: bold;
  line-height: 1;
}

body.home .forte__txt__ttl__ja {
  display: block;
  font-feature-settings: "palt" 1;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
  margin-bottom: min(5vw, 5rem);
}

@media (max-width: 834px) {
  body.home .forte__txt__ttl__ja {
    margin-bottom: 7vw;
  }
}
body.home .forte__txt__description {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(20px) translateZ(0);
  font-size: 2rem;
  font-weight: 600;
  line-height: 2;
  margin-bottom: min(5vw, 5rem);
}

body.home .forte__txt__description.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.25s;
  transform: translateY(0) translateZ(0);
}

@media (max-width: 834px) {
  body.home .forte__txt__description {
    font-size: 1.8rem;
    margin-bottom: 7vw;
  }
}
@media (max-width: 430px) {
  body.home .forte__txt__description {
    font-size: 1.6rem;
  }
}
body.home .forte__txt__viewBtn {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(10px) translateZ(0);
  margin-bottom: 0 !important;
}

body.home .forte__txt__viewBtn.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.5s;
  transform: translateY(0) translateZ(0);
}

@media (max-width: 834px) {
  body.home .forte__txt__viewBtn {
    display: none;
  }
}
body.home .forte__viewBtn {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(10px) translateZ(0);
  display: none;
}

body.home .forte__viewBtn.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 1.25s;
  transform: translateY(0) translateZ(0);
}

@media (max-width: 834px) {
  body.home .forte__viewBtn {
    display: block;
    text-align: center;
    padding-top: 14vw;
  }
}
@media (max-width: 430px) {
  body.home .forte__viewBtn {
    text-align: center;
  }
}
body.home .service__viewBtn,
body.home .businessPerformance__head,
body.home .forte__viewBtn {
  padding-left: 6rem;
}

@media (max-width: 834px) {
  body.home .service__viewBtn,
  body.home .businessPerformance__head,
  body.home .forte__viewBtn {
    padding-left: 4rem;
  }
}
@media (max-width: 430px) {
  body.home .service__viewBtn,
  body.home .businessPerformance__head,
  body.home .forte__viewBtn {
    padding-left: 3rem;
  }
}
body.home .service__viewBtn,
body.home .forte__viewBtn {
  padding-right: 6rem;
}

@media (max-width: 834px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn {
    padding-right: 4rem;
  }
}
@media (max-width: 430px) {
  body.home .service__viewBtn,
  body.home .forte__viewBtn {
    padding-right: 3rem;
  }
}
body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
body.home .service,
body.page .article__header, body.single .article__header,
.footer__grid,
.footer__copyright,
body.home .hero__txt,
body.home .clients__inner,
body.home .forte__inner {
  max-width: min(90vw, 1280px);
}

@media (max-width: 834px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.home .service,
  body.page .article__header, body.single .article__header,
  .footer__grid,
  .footer__copyright,
  body.home .hero__txt,
  body.home .clients__inner,
  body.home .forte__inner {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.home .service,
  body.page .article__header, body.single .article__header,
  .footer__grid,
  .footer__copyright,
  body.home .hero__txt,
  body.home .clients__inner,
  body.home .forte__inner {
    max-width: calc(100vw - 6rem);
  }
}
body.page .article__description, body.single .article__description,
body.page .article__content, body.single .article__content {
  max-width: min(90vw, 1080px);
}

@media (max-width: 834px) {
  body.page .article__description, body.single .article__description,
  body.page .article__content, body.single .article__content {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page .article__description, body.single .article__description,
  body.page .article__content, body.single .article__content {
    max-width: calc(100vw - 6rem);
  }
}
body.home .service__head__ttl__en,
body.home .businessPerformance__head__en,
body.home .clients__head__ttl,
body.home .forte__txt__ttl__en {
  font-size: min(7.2vw, 12rem);
}

@media (max-width: 1023px) {
  body.home .service__head__ttl__en,
  body.home .businessPerformance__head__en,
  body.home .clients__head__ttl,
  body.home .forte__txt__ttl__en {
    font-size: min(8.4vw, 12rem);
  }
}
@media (max-width: 834px) {
  body.home .service__head__ttl__en,
  body.home .businessPerformance__head__en,
  body.home .clients__head__ttl,
  body.home .forte__txt__ttl__en {
    padding-bottom: 5px;
  }
}
@media (max-width: 430px) {
  body.home .service__head__ttl__en,
  body.home .businessPerformance__head__en,
  body.home .clients__head__ttl,
  body.home .forte__txt__ttl__en {
    padding-bottom: 2px;
  }
}
body.home .service__head__ttl__ja,
body.home .forte__txt__ttl__ja {
  font-size: min(6vw, 8rem);
}

@media (max-width: 834px) {
  body.home .service__head__ttl__ja,
  body.home .forte__txt__ttl__ja {
    font-size: min(5.5vw, 8rem);
  }
}
body.home .service {
  padding-top: min(14vw, 13rem);
  padding-bottom: min(14vw, 13rem);
  margin: 0 auto;
}

body.home .service__head {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(20px) translateZ(0);
  display: grid;
  margin-bottom: min(7vw, 13rem);
  grid-template-columns: 1fr 1fr;
  gap: min(7vw, 10rem);
}

body.home .service__head.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0s;
  transform: translateY(0) translateZ(0);
}

@media (max-width: 1280px) {
  body.home .service__head {
    grid-template-columns: 1fr;
    gap: min(5vw, 5rem);
  }
}
@media (max-width: 834px) {
  body.home .service__head {
    margin-bottom: min(9.3333333333vw, 8.6666666667rem);
    gap: 0;
  }
}
@media (max-width: 430px) {
  body.home .service__head {
    margin-bottom: 14vw;
  }
}
body.home .service__head__ttl {
  display: block;
}

@media (max-width: 834px) {
  body.home .service__head__ttl {
    margin-bottom: 7vw;
  }
}
body.home .service__head__ttl__en {
  display: block;
  font-family: Roboto, sans-serif;
  font-weight: bold;
  line-height: 1;
}

body.home .service__head__ttl__ja {
  display: block;
  font-feature-settings: "palt" 1;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
}

body.home .service__head__description {
  display: flex;
  align-items: center;
}

body.home .service__head__description p {
  font-size: 2rem;
  font-weight: 600;
  line-height: 2;
}

@media (max-width: 834px) {
  body.home .service__head__description p {
    font-size: 1.8rem;
  }
}
@media (max-width: 430px) {
  body.home .service__head__description p {
    font-size: 1.6rem;
  }
}
body.home .service__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: min(7vw, 10rem);
}

@media (max-width: 834px) {
  body.home .service__grid {
    grid-template-columns: 1fr;
    gap: min(9.3333333333vw, 8.6666666667rem);
  }
}
@media (max-width: 430px) {
  body.home .service__grid {
    gap: 14vw;
  }
}
body.home .service__item__1 .service__item__img__wrapper {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(20px) translateZ(0);
}

body.home .service__item__1 .service__item__img__wrapper.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.25s;
  transform: translateY(0) translateZ(0);
}

body.home .service__item__1 .service__item__ttl {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(20px) translateZ(0);
}

body.home .service__item__1 .service__item__ttl.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.5s;
  transform: translateY(0) translateZ(0);
}

body.home .service__item__1 .service__item__description {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(20px) translateZ(0);
}

body.home .service__item__1 .service__item__description.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.75s;
  transform: translateY(0) translateZ(0);
}

body.home .service__item__2 .service__item__img__wrapper {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(20px) translateZ(0);
}

body.home .service__item__2 .service__item__img__wrapper.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.5s;
  transform: translateY(0) translateZ(0);
}

body.home .service__item__2 .service__item__ttl {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(20px) translateZ(0);
}

body.home .service__item__2 .service__item__ttl.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.75s;
  transform: translateY(0) translateZ(0);
}

body.home .service__item__2 .service__item__description {
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(20px) translateZ(0);
}

body.home .service__item__2 .service__item__description.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 1s;
  transform: translateY(0) translateZ(0);
}

body.home .service__item .clipPathShadow {
  filter: drop-shadow(15px 15px 10px rgba(0, 0, 0, 0.38));
}

@media (max-width: 834px) {
  body.home .service__item .clipPathShadow {
    filter: drop-shadow(10px 10px 7.5px rgba(0, 0, 0, 0.3));
  }
}
@media (max-width: 430px) {
  body.home .service__item .clipPathShadow {
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.3));
  }
}
body.home .service__item__img {
  position: relative;
  aspect-ratio: 1066/710;
  overflow: hidden;
  margin-bottom: min(5vw, 5rem);
  object-fit: contain;
}

@media (max-width: 834px) {
  body.home .service__item__img {
    aspect-ratio: 1320/580;
  }
}
body.home .service__item__img.clipPath {
  clip-path: polygon(min(40px, 4vw) 0, 100% 0%, 100% calc(100% - min(40px, 4vw)), calc(100% - min(40px, 4vw)) 100%, 0 100%, 0 min(40px, 4vw));
}

body.home .service__item__img img {
  position: absolute;
  width: 100%;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(1.01);
}

body.home .service__item__img--1 img {
  top: unset;
  bottom: 0;
  transform: translate(-50%, 0) scale(1.01);
}

@media (max-width: 834px) {
  body.home .service__item__img--2 img {
    transform: translate(-50%, -42%) scale(1.01);
  }
}
body.home .service__item__ttl {
  margin-bottom: 3rem;
}

body.home .service__item__ttl__en {
  display: block;
  font-family: Roboto, sans-serif;
  font-size: min(4.9vw, 6rem);
  font-weight: bold;
  line-height: 1;
  white-space: nowrap;
  margin-bottom: 1rem;
}

@media (max-width: 834px) {
  body.home .service__item__ttl__en {
    font-size: 6vw;
  }
}
body.home .service__item__ttl__ja {
  display: block;
  font-feature-settings: "palt" 1;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
}

@media (max-width: 834px) {
  body.home .service__item__ttl__ja {
    font-size: min(4vw, 2.6rem);
  }
}
@media (max-width: 430px) {
  body.home .service__item__ttl__ja {
    font-size: 4vw;
  }
}
body.home .service__item__description {
  font-size: 2rem;
  font-weight: 400;
  line-height: 2;
}

@media (max-width: 834px) {
  body.home .service__item__description {
    font-size: 1.8rem;
  }
}
@media (max-width: 430px) {
  body.home .service__item__description {
    font-size: 1.6rem;
  }
}
body.home .service__viewBtn {
  display: block;
  text-align: center;
  padding-top: min(9.3333333333vw, 8.6666666667rem);
  opacity: 0;
  transition-delay: 0s;
  transform: translateY(10px) translateZ(0);
}

body.home .service__viewBtn.active {
  opacity: 1;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 1.25s;
  transform: translateY(0) translateZ(0);
}

@media (max-width: 430px) {
  body.home .service__viewBtn {
    text-align: center;
    padding-top: 14vw;
    padding-right: 0;
    padding-left: 0;
  }
}
body.page .article .article__header.hasCopyOnly, body.single .article .article__header.hasCopyOnly {
  padding-bottom: min(7vw, 5rem);
  margin-bottom: 0;
  border-bottom: none;
}

body.page-template-page-company .sign {
  max-width: min(90vw, 1280px);
  text-align: right;
  padding-bottom: 6rem;
  margin: 0 auto 6rem;
  border-bottom: 1px solid #000;
}

@media (max-width: 834px) {
  body.page-template-page-company .sign {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page-template-page-company .sign {
    max-width: calc(100vw - 6rem);
  }
}
@media (max-width: 430px) {
  body.page-template-page-company .sign {
    padding-bottom: 4.5rem;
    margin-bottom: 4.5rem;
  }
}
body.page-template-page-company .sign__companyName {
  font-size: 1.8rem;
  line-height: 1;
  margin-bottom: 1rem;
}

body.page-template-page-company .sign__position {
  font-size: 1.8rem;
  line-height: 1;
  margin-bottom: 2rem;
}

body.page-template-page-company .sign__name {
  font-size: 2.2rem;
  font-weight: bold;
  line-height: 1;
}

@media (max-width: 430px) {
  .management-philosophy__linkMessage {
    text-align: center;
  }
}
@media (max-width: 430px) {
  body.page\.customer-reviews\.index .reviewProfileCard__left {
    margin-bottom: 0;
  }
}
body.page\.customer-reviews\.index .reviewProfileCard__img {
  overflow: hidden;
}

body.page\.customer-reviews\.index .reviewProfileCard__img img {
  width: 100%;
  min-width: 100px;
  height: auto;
  transition: all 0.2s ease-in-out;
  transform-origin: center;
}

@media (max-width: 430px) {
  body.page\.customer-reviews\.index .reviewProfileCard__img {
    max-width: unset;
    text-align: center;
  }
  body.page\.customer-reviews\.index .reviewProfileCard__img img {
    width: 50%;
  }
}
@media (max-width: 430px) {
  body.page\.customer-reviews\.index .reviewProfileCard__companyLogo {
    text-align: center;
  }
}
body.page\.customer-reviews\.index .reviewProfileCard__companyLogo img {
  transform: scale(0.75);
  transform-origin: top left;
}

@media (max-width: 430px) {
  body.page\.customer-reviews\.index .reviewProfileCard__companyLogo img {
    width: 100%;
    max-width: 240px;
    transform: unset;
    transform-origin: unset;
  }
}
body.page\.customer-reviews\.index .reviewCard__link {
  display: block;
  text-decoration: none;
  transition: all 0.2s ease-in-out;
}

@media (max-width: 430px) {
  body.page\.customer-reviews\.index .reviewCard__link {
    padding: 0 !important;
  }
}
body.page\.customer-reviews\.index .reviewCard__link:hover {
  opacity: 0.8;
}

@media (max-width: 430px) {
  body.page\.customer-reviews\.index .reviewCard__link:hover {
    opacity: 1;
  }
}
body.page\.customer-reviews\.index .reviewCard__link:hover .reviewProfileCard__img img {
  transform: scale(1.01);
}

@media (max-width: 430px) {
  body.page\.customer-reviews\.index .reviewCard__link:hover .reviewProfileCard__img img {
    transform: scale(1);
  }
}
@media (max-width: 430px) {
  body.page\.customer-reviews\.index .reviewCard__link {
    padding: 4.5rem 0;
  }
}
body.page\.customer-reviews\.index .reviewCard:nth-child(2) .reviewCard__link {
  padding-top: 0;
}

body.page\.customer-reviews\.index .reviewCard__copy {
  font-weight: 700;
  line-height: 1.5;
}

@media (max-width: 430px) {
  body.page\.customer-reviews\.index .reviewCard__copy {
    line-height: 1.3;
  }
}
body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
body.page .article__header, body.single .article__header,
.footer__grid,
.footer__copyright,
body.home .hero__txt,
body.home .clients__inner,
body.home .forte__inner,
body.home .service {
  max-width: min(90vw, 1280px);
}

@media (max-width: 834px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.page .article__header, body.single .article__header,
  .footer__grid,
  .footer__copyright,
  body.home .hero__txt,
  body.home .clients__inner,
  body.home .forte__inner,
  body.home .service {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader,
  body.page .article__header, body.single .article__header,
  .footer__grid,
  .footer__copyright,
  body.home .hero__txt,
  body.home .clients__inner,
  body.home .forte__inner,
  body.home .service {
    max-width: calc(100vw - 6rem);
  }
}
body.page .article__description, body.single .article__description,
body.page .article__content, body.single .article__content {
  max-width: min(90vw, 1080px);
}

@media (max-width: 834px) {
  body.page .article__description, body.single .article__description,
  body.page .article__content, body.single .article__content {
    max-width: calc(100vw - 8rem);
  }
}
@media (max-width: 430px) {
  body.page .article__description, body.single .article__description,
  body.page .article__content, body.single .article__content {
    max-width: calc(100vw - 6rem);
  }
}
body.page\.customer-reviews\.detail .article__header, body.single\.customer-reviews\.detail .article__header {
  padding-bottom: 0;
  margin-bottom: min(7vw, 10rem);
  border-bottom: none;
}

body.page\.customer-reviews\.detail .article__copy, body.single\.customer-reviews\.detail .article__copy,
body.page\.customer-reviews\.detail .article__img, body.single\.customer-reviews\.detail .article__img {
  display: none;
}

body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader {
  display: grid;
  padding-bottom: 6rem;
  margin: 0 auto 6rem;
  border-bottom: 1px solid #000;
  grid-template-columns: 1fr auto;
  grid-gap: min(3.5vw, 5rem);
}

@media (max-width: 834px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader {
    margin-bottom: 0;
    border-bottom: none;
    grid-gap: 4.5rem;
    grid-template-columns: 1fr;
  }
}
@media (max-width: 430px) {
  body.page\.customer-reviews\.detail .article__detailHeader, body.single\.customer-reviews\.detail .article__detailHeader {
    padding-bottom: 4.5rem;
  }
}
body.page\.customer-reviews\.detail .article__detailHeader__txt__copy, body.single\.customer-reviews\.detail .article__detailHeader__txt__copy {
  margin-bottom: min(3vw, 3rem) !important;
}

@media (max-width: 834px) {
  body.page\.customer-reviews\.detail .article__detailHeader__txt__copy, body.single\.customer-reviews\.detail .article__detailHeader__txt__copy {
    margin-bottom: 4.5rem !important;
  }
}
@media (max-width: 430px) {
  body.page\.customer-reviews\.detail .article__detailHeader__txt__copy, body.single\.customer-reviews\.detail .article__detailHeader__txt__copy {
    margin-bottom: 3rem !important;
  }
}
body.page\.customer-reviews\.detail .article__detailHeader__txt__copy p, body.single\.customer-reviews\.detail .article__detailHeader__txt__copy p {
  font-weight: bold;
  line-height: 1.3;
  letter-spacing: 0.02em;
  word-break: break-word;
  font-feature-settings: "palt" 1;
}

body.page\.customer-reviews\.detail .article__detailHeader__txt__copy p:last-child {
  margin-bottom: 0;
}

@media (max-width: 834px) {
  body.page\.customer-reviews\.detail .article__detailHeader__txt__copy p, body.single\.customer-reviews\.detail .article__detailHeader__txt__copy p {
    display: inline;
  }
}
body.page\.customer-reviews\.detail .article__detailHeader__txt__profile p, body.single\.customer-reviews\.detail .article__detailHeader__txt__profile p {
  line-height: 1.3;
  font-weight: normal;
}

@media (max-width: 834px) {
  body.page\.customer-reviews\.detail .article__detailHeader__img, body.single\.customer-reviews\.detail .article__detailHeader__img {
    text-align: center;
  }
}
body.page\.customer-reviews\.detail .article__detailHeader__img img, body.single\.customer-reviews\.detail .article__detailHeader__img img {
  width: 100%;
  height: auto;
}

@media (max-width: 430px) {
  body.page\.customer-reviews\.detail .article__detailHeader__img img, body.single\.customer-reviews\.detail .article__detailHeader__img img {
    width: 85%;
  }
}
body.page\.contact\.complete dl,
body.page\.contact\.confirm dl {
  margin-bottom: 6rem;
}

@media (max-width: 430px) {
  body.page\.contact\.complete dl,
  body.page\.contact\.confirm dl {
    margin-bottom: 4.5rem;
  }
}
body.page\.contact\.complete dl dd,
body.page\.contact\.confirm dl dd {
  padding-bottom: 5rem;
  margin-bottom: 6rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  line-height: 2;
}

body.page\.contact\.complete dl dd:last-child,
body.page\.contact\.confirm dl dd:last-child {
  margin-bottom: 0;
}

@media (max-width: 430px) {
  body.page\.contact\.complete dl dd,
  body.page\.contact\.confirm dl dd {
    padding-bottom: 3.5rem;
    margin-bottom: 4.5rem;
  }
}
body.page\.contact\.confirm input[type=submit],
body.page\.contact\.confirm input[type=button] {
  margin-bottom: 1.5rem;
}

body.page\.contact\.complete dl,
body.page\.contact\.confirm dl {
  margin-bottom: 6rem;
}

@media (max-width: 430px) {
  body.page\.contact\.complete dl,
  body.page\.contact\.confirm dl {
    margin-bottom: 4.5rem;
  }
}
body.page\.contact\.complete dl dd,
body.page\.contact\.confirm dl dd {
  padding-bottom: 5rem;
  margin-bottom: 6rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
  line-height: 2;
}

body.page\.contact\.complete dl dd:last-child,
body.page\.contact\.confirm dl dd:last-child {
  margin-bottom: 0;
}

@media (max-width: 430px) {
  body.page\.contact\.complete dl dd,
  body.page\.contact\.confirm dl dd {
    padding-bottom: 3.5rem;
    margin-bottom: 4.5rem;
  }
}
body.page\.contact\.complete dl dd:last-child {
  padding-bottom: 0;
  margin-bottom: 0;
  border-bottom: none;
}

body.page .article__content ul.access_list, body.single .article__content ul.access_list {
  margin-bottom: 2.25rem;
}

@media (max-width: 834px) {
  body.page .article__content ul.access_list, body.single .article__content ul.access_list {
    margin-bottom: 2.25rem;
  }
}
a:visited {
  color: black;
}

.c-pagenav {
  display: flex;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  list-style: none !important;
}
.c-pagenav a, .c-pagenav a:visited, .c-pagenav a:active {
  font-size: 16px;
  text-decoration: none;
  color: black;
}
.c-pagenav a:hover, .c-pagenav a:visited:hover, .c-pagenav a:active:hover {
  text-decoration: underline;
}
.c-pagenav li:first-child:before {
  content: "<";
  margin-right: 8px;
}
.c-pagenav li:nth-child(2):after {
  content: ">";
  margin-left: 8px;
}

.c-docsnav {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
  list-style: none !important;
}
.c-docsnav li {
  width: calc((100% - 40px) / 3);
}
@media (max-width: 834px) {
  .c-docsnav li {
    width: calc((100% - 20px) / 2);
  }
}
@media (max-width: 430px) {
  .c-docsnav li {
    width: 100%;
  }
}
.c-docsnav li {
  padding: 0 !important;
  margin: 0 !important;
  text-indent: inherit !important;
}
.c-docsnav a, .c-docsnav a:visited, .c-docsnav a:active {
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  padding: 15px 10px;
  color: black;
}
.c-docsnav a:before, .c-docsnav a:visited:before, .c-docsnav a:active:before {
  content: "";
  width: 20px;
  height: 20px;
  background: url("../images/common/docs.png") no-repeat center center;
}
.c-docsnav a:hover, .c-docsnav a:visited:hover, .c-docsnav a:active:hover {
  border: 1px solid rgba(0, 0, 0, 0.5);
  color: black;
}

body.page .article__content .c-docs p + h2, body.page .article__content .c-docs ul + h2 {
  margin-top: 24px !important;
}
body.page .article__content .c-docs ul {
  margin-bottom: 2.25rem;
}

.c-docs__date {
  font-size: 14px !important;
  text-align: right;
}

.drawer__content ul > li > ul {
  margin-left: 0 !important;
}

/* WordPress 管理バー表示時の上余白 */
body.admin-bar {
  padding-top: 32px;
}
body.admin-bar .header, body.admin-bar .drawer__btn, body.admin-bar .drawer__content {
  top: 32px;
}

/* モバイル対応 */
@media (max-width: 782px) {
  body.admin-bar {
    padding-top: 46px;
  }
}
.useful_articles {
  padding-bottom: 6rem !important;
  margin-bottom: 6rem !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}
.useful_articles h2 {
  font-size: 4rem !important;
  margin-bottom: 0.4em !important;
}
.useful_articles h2 + h3 {
  margin-bottom: 4rem !important;
  margin-top: 0 !important;
}
.useful_articles h3 {
  margin-bottom: 1.5rem !important;
  margin-top: 4rem !important;
}
.useful_articles ul {
  margin-bottom: 1rem !important;
}
.useful_articles__img {
  aspect-ratio: 16/8 !important;
  overflow: hidden !important;
  border-radius: 10px !important;
}
.useful_articles__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.usefulArticlesList {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  margin-top: 4rem;
}
@media (max-width: 834px) {
  .usefulArticlesList {
    grid-template-columns: 1fr;
    gap: 30px;
  }
}

.usefulArticleCard {
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  transition: transform 0.3s ease;
}
.usefulArticleCard:hover {
  transform: translateY(-5px);
}
.usefulArticleCard:hover .usefulArticleCard__img img {
  transform: scale(1.05);
}
.usefulArticleCard__link {
  text-decoration: none;
  color: inherit;
  display: block;
}
.usefulArticleCard__link:hover {
  text-decoration: none;
}
.usefulArticleCard__img {
  aspect-ratio: 16/9;
  overflow: hidden;
}
.usefulArticleCard__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}
.usefulArticleCard__body {
  padding: 2.5rem;
}
.usefulArticleCard__ttl {
  font-size: 2.2rem !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  margin-bottom: 1.5rem !important;
  color: #000;
}
.usefulArticleCard__subTtl {
  font-size: 1.5rem !important;
  line-height: 1.6 !important;
  color: #666;
  margin: 0 !important;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.btn--bold {
  color: #fff !important;
}
.btn--bold:hover {
  color: black !important;
}

.footer__hours {
  font-size: 1.4rem;
  margin-top: 1rem;
}/*# sourceMappingURL=style.css.map */