@charset 'UTF-8';
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  font-weight: normal;
  font-size: 100%;
  vertical-align: baseline;
  outline: 0;
}

body {
  line-height: 1;

  -webkit-text-size-adjust: 100%;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

ol,
ul,
li {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

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

a {
  margin: 0;
  padding: 0;
  background: transparent;
  color: #000;
  font-size: 100%;
  text-decoration: none;
  vertical-align: baseline;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

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

/* change border colour to suit your needs
*/
hr {
  display: block;
  height: 1px;
  margin: 1em 0;
  padding: 0;
  border: 0;
  border-top: 1px solid #ccc;
}

input,
select {
  vertical-align: middle;
}

img,
iframe {
  vertical-align: bottom;
}

th {
  text-align: left;
}

*,
*:before,
*:after {
  box-sizing: border-box;
}

/*
@import "./fontawesome/fontawesome.scss";
@import "./fontawesome/solid.scss";
@import "./fontawesome/regular.scss";
@import "./fontawesome/brands.scss";
*/
:root {
  --width-base: 1250px;
  --width-main-column: 930px;
  --width-side-column: 350px;
  --padding-base: 50px;
  --padding-mobile: 5vw;
  /* 色 **************************** */
  --color-green: #00a73c;
  --color-dark-green: #00612a;
  --color-blue: #154dcc;
  --color-pale-blue: #f5f7fc;
  --color-sky: #00a5ff;
  --color-yellow: #fff100;
  --color-brown: #9b6950;
  --color-dark-red: #3c0300;
  --color-white: #fff;
  --color-orange: #ea5514;
  --color-pale-orange: #f39800;
  --color-black: #222;
  --color-main: var(--color-green);
  --color-second: var(--color-blue);
  --color-base: var(--color-white);
  --color-base2: var(--color-gray);
  --color-text: var(--color-black);
  --color-btn: var(--color-navy2);
  --color-bg: var(--color-navy3);
  /* フォント **************************** */
  --font-notosans: Noto Sans JP;
  --font-montserrat: Montserrat;
  --font-hina: Hina Mincho;
  --font-sans-serif: sans-serif;
  --font-serif: serif;
  --font-shingo: "UD新ゴ R", "UD Shin Go Regular";
  --font-shingo-b: "UD新ゴ B", "UD Shin Go Bold";
  --font-shingo-l: "UD新ゴ L", "UD Shin Go Light";
  --font-gothic-base: var(--font-sans-serif);
  --font-mincho-base: var(--font-serif);
  --font-gothic: var(--font-notosans), var(--font-gothic-base);
  --font-mincho: var(--font-hina), var(--font-mincho-base);
  --font-shingo--l: var(--font-shingo-l), var(--font-gothic-base);
  --font-shingo--b: var(--font-shingo-b), var(--font-gothic-base);
}

.bg-green {
  background-color: #00a73c;
}

.text-green {
  color: #00a73c;
}

.bg-dark-green {
  background-color: #00612a;
}

.text-dark-green {
  color: #00612a;
}

.bg-blue {
  background-color: #154dcc;
}

.text-blue {
  color: #154dcc;
}

.bg-pale-blue {
  background-color: #f5f7fc;
}

.text-pale-blue {
  color: #f5f7fc;
}

.bg-sky {
  background-color: #00a5ff;
}

.text-sky {
  color: #00a5ff;
}

.bg-yellow {
  background-color: #fff100;
}

.text-yellow {
  color: #fff100;
}

.bg-brown {
  background-color: #9b6950;
}

.text-brown {
  color: #9b6950;
}

.bg-dark-red {
  background-color: #3c0300;
}

.text-dark-red {
  color: #3c0300;
}

.bg-white {
  background-color: #fff;
}

.text-white {
  color: #fff;
}

.bg-orange {
  background-color: #ea5514;
}

.text-orange {
  color: #ea5514;
}

.bg-pale-orange {
  background-color: #f39800;
}

.text-pale-orange {
  color: #f39800;
}

.bg-black {
  background-color: #222;
}

.text-black {
  color: #222;
}

[data-css-scroll="all"] {
  overflow-y: scroll;
}

@media (prefers-color-scheme: dark) {
  [data-css-scroll="dark"] {
    overflow-y: scroll;
  }
}

@media screen and (max-width: 1920px) {
  [data-css-scroll="ll"] {
    overflow-y: scroll;
  }
}

@media screen and (max-width: 1600px) {
  [data-css-scroll="xl"] {
    overflow-y: scroll;
  }
}

@media screen and (max-width: 1366px) {
  [data-css-scroll="base"] {
    overflow-y: scroll;
  }
}

@media screen and (max-width: 1260px) {
  [data-css-scroll="lg"] {
    overflow-y: scroll;
  }
}

@media screen and (max-width: 992px) {
  [data-css-scroll="md"] {
    overflow-y: scroll;
  }
}

@media screen and (max-width: 768px) {
  [data-css-scroll="sm"] {
    overflow-y: scroll;
  }
}

@media screen and (max-width: 575px) {
  [data-css-scroll="xs"] {
    overflow-y: scroll;
  }
}

@media screen and (max-width: 375px) {
  [data-css-scroll="ss"] {
    overflow-y: scroll;
  }
}

.mb5em {
  margin-bottom: 0.5em;
}

.mt5em {
  margin-top: 0.5em;
}

[data-css-mb="0.5"] {
  margin-bottom: 0.5em;
}

[data-css-mt="0.5"] {
  margin-top: 0.5em;
}

.mb10em {
  margin-bottom: 1em;
}

.mt10em {
  margin-top: 1em;
}

[data-css-mb="1"] {
  margin-bottom: 1em;
}

[data-css-mt="1"] {
  margin-top: 1em;
}

.mb15em {
  margin-bottom: 1.5em;
}

.mt15em {
  margin-top: 1.5em;
}

[data-css-mb="1.5"] {
  margin-bottom: 1.5em;
}

[data-css-mt="1.5"] {
  margin-top: 1.5em;
}

.mb20em {
  margin-bottom: 2em;
}

.mt20em {
  margin-top: 2em;
}

[data-css-mb="2"] {
  margin-bottom: 2em;
}

[data-css-mt="2"] {
  margin-top: 2em;
}

.mb25em {
  margin-bottom: 2.5em;
}

.mt25em {
  margin-top: 2.5em;
}

[data-css-mb="2.5"] {
  margin-bottom: 2.5em;
}

[data-css-mt="2.5"] {
  margin-top: 2.5em;
}

.mb30em {
  margin-bottom: 3em;
}

.mt30em {
  margin-top: 3em;
}

[data-css-mb="3"] {
  margin-bottom: 3em;
}

[data-css-mt="3"] {
  margin-top: 3em;
}

.mb35em {
  margin-bottom: 3.5em;
}

.mt35em {
  margin-top: 3.5em;
}

[data-css-mb="3.5"] {
  margin-bottom: 3.5em;
}

[data-css-mt="3.5"] {
  margin-top: 3.5em;
}

.mb40em {
  margin-bottom: 4em;
}

.mt40em {
  margin-top: 4em;
}

[data-css-mb="4"] {
  margin-bottom: 4em;
}

[data-css-mt="4"] {
  margin-top: 4em;
}

.mb45em {
  margin-bottom: 4.5em;
}

.mt45em {
  margin-top: 4.5em;
}

[data-css-mb="4.5"] {
  margin-bottom: 4.5em;
}

[data-css-mt="4.5"] {
  margin-top: 4.5em;
}

.mb50em {
  margin-bottom: 5em;
}

.mt50em {
  margin-top: 5em;
}

[data-css-mb="5"] {
  margin-bottom: 5em;
}

[data-css-mt="5"] {
  margin-top: 5em;
}

[data-css-inner="10"] {
  padding-right: 10px;
  padding-left: 10px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="10"] {
    padding-right: 0.73206vw;
    padding-left: 0.73206vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="10"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="10"] {
  margin-bottom: 1rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="10"] {
    margin-bottom: 0.73206vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="10"] {
    margin-bottom: 1.30208vw;
  }
}

[data-css-inner="20"] {
  padding-right: 20px;
  padding-left: 20px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="20"] {
    padding-right: 1.46413vw;
    padding-left: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="20"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="20"] {
  margin-bottom: 2rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="20"] {
    margin-bottom: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="20"] {
    margin-bottom: 2.60417vw;
  }
}

[data-css-inner="30"] {
  padding-right: 30px;
  padding-left: 30px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="30"] {
    padding-right: 2.19619vw;
    padding-left: 2.19619vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="30"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="30"] {
  margin-bottom: 3rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="30"] {
    margin-bottom: 2.19619vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="30"] {
    margin-bottom: 3.90625vw;
  }
}

[data-css-inner="40"] {
  padding-right: 40px;
  padding-left: 40px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="40"] {
    padding-right: 2.92826vw;
    padding-left: 2.92826vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="40"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="40"] {
  margin-bottom: 4rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="40"] {
    margin-bottom: 2.92826vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="40"] {
    margin-bottom: 5.20833vw;
  }
}

[data-css-inner="50"] {
  padding-right: 50px;
  padding-left: 50px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="50"] {
    padding-right: 3.66032vw;
    padding-left: 3.66032vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="50"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="50"] {
  margin-bottom: 5rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="50"] {
    margin-bottom: 3.66032vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="50"] {
    margin-bottom: 6.51042vw;
  }
}

[data-css-inner="60"] {
  padding-right: 60px;
  padding-left: 60px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="60"] {
    padding-right: 4.39239vw;
    padding-left: 4.39239vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="60"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="60"] {
  margin-bottom: 6rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="60"] {
    margin-bottom: 4.39239vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="60"] {
    margin-bottom: 7.8125vw;
  }
}

[data-css-inner="70"] {
  padding-right: 70px;
  padding-left: 70px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="70"] {
    padding-right: 5.12445vw;
    padding-left: 5.12445vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="70"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="70"] {
  margin-bottom: 7rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="70"] {
    margin-bottom: 5.12445vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="70"] {
    margin-bottom: 9.11458vw;
  }
}

[data-css-inner="80"] {
  padding-right: 80px;
  padding-left: 80px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="80"] {
    padding-right: 5.85652vw;
    padding-left: 5.85652vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="80"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="80"] {
  margin-bottom: 8rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="80"] {
    margin-bottom: 5.85652vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="80"] {
    margin-bottom: 10.41667vw;
  }
}

[data-css-inner="90"] {
  padding-right: 90px;
  padding-left: 90px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="90"] {
    padding-right: 6.58858vw;
    padding-left: 6.58858vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="90"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="90"] {
  margin-bottom: 9rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="90"] {
    margin-bottom: 6.58858vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="90"] {
    margin-bottom: 11.71875vw;
  }
}

[data-css-inner="100"] {
  padding-right: 100px;
  padding-left: 100px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="100"] {
    padding-right: 7.32064vw;
    padding-left: 7.32064vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="100"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="100"] {
  margin-bottom: 10rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="100"] {
    margin-bottom: 7.32064vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="100"] {
    margin-bottom: 13.02083vw;
  }
}

[data-css-inner="110"] {
  padding-right: 110px;
  padding-left: 110px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="110"] {
    padding-right: 8.05271vw;
    padding-left: 8.05271vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="110"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="110"] {
  margin-bottom: 11rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="110"] {
    margin-bottom: 8.05271vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="110"] {
    margin-bottom: 14.32292vw;
  }
}

[data-css-inner="120"] {
  padding-right: 120px;
  padding-left: 120px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="120"] {
    padding-right: 8.78477vw;
    padding-left: 8.78477vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="120"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="120"] {
  margin-bottom: 12rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="120"] {
    margin-bottom: 8.78477vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="120"] {
    margin-bottom: 15.625vw;
  }
}

[data-css-inner="130"] {
  padding-right: 130px;
  padding-left: 130px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="130"] {
    padding-right: 9.51684vw;
    padding-left: 9.51684vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="130"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="130"] {
  margin-bottom: 13rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="130"] {
    margin-bottom: 9.51684vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="130"] {
    margin-bottom: 16.92708vw;
  }
}

[data-css-inner="140"] {
  padding-right: 140px;
  padding-left: 140px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="140"] {
    padding-right: 10.2489vw;
    padding-left: 10.2489vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="140"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="140"] {
  margin-bottom: 14rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="140"] {
    margin-bottom: 10.2489vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="140"] {
    margin-bottom: 18.22917vw;
  }
}

[data-css-inner="150"] {
  padding-right: 150px;
  padding-left: 150px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="150"] {
    padding-right: 10.98097vw;
    padding-left: 10.98097vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="150"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="150"] {
  margin-bottom: 15rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="150"] {
    margin-bottom: 10.98097vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="150"] {
    margin-bottom: 19.53125vw;
  }
}

[data-css-inner="160"] {
  padding-right: 160px;
  padding-left: 160px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="160"] {
    padding-right: 11.71303vw;
    padding-left: 11.71303vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="160"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="160"] {
  margin-bottom: 16rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="160"] {
    margin-bottom: 11.71303vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="160"] {
    margin-bottom: 20.83333vw;
  }
}

[data-css-inner="170"] {
  padding-right: 170px;
  padding-left: 170px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="170"] {
    padding-right: 12.4451vw;
    padding-left: 12.4451vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="170"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="170"] {
  margin-bottom: 17rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="170"] {
    margin-bottom: 12.4451vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="170"] {
    margin-bottom: 22.13542vw;
  }
}

[data-css-inner="180"] {
  padding-right: 180px;
  padding-left: 180px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="180"] {
    padding-right: 13.17716vw;
    padding-left: 13.17716vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="180"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="180"] {
  margin-bottom: 18rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="180"] {
    margin-bottom: 13.17716vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="180"] {
    margin-bottom: 23.4375vw;
  }
}

[data-css-inner="190"] {
  padding-right: 190px;
  padding-left: 190px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="190"] {
    padding-right: 13.90922vw;
    padding-left: 13.90922vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="190"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="190"] {
  margin-bottom: 19rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="190"] {
    margin-bottom: 13.90922vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="190"] {
    margin-bottom: 24.73958vw;
  }
}

[data-css-inner="200"] {
  padding-right: 200px;
  padding-left: 200px;
}

@media screen and (max-width: 1260px) {
  [data-css-inner="200"] {
    padding-right: 14.64129vw;
    padding-left: 14.64129vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-inner="200"] {
    padding-right: 0;
    padding-left: 0;
  }
}

[data-css-mb="200"] {
  margin-bottom: 20rem;
}

@media screen and (max-width: 1260px) {
  [data-css-mb="200"] {
    margin-bottom: 14.64129vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-mb="200"] {
    margin-bottom: 26.04167vw;
  }
}

[data-css-flex] {
  display: flex;
}

[data-css-flex="row"] {
  flex-direction: row;
}

[data-css-flex="row-center"] {
  flex-direction: row;
  justify-content: center;
}

[data-css-flex="row-right"] {
  flex-direction: row;
  justify-content: flex-end;
}

[data-css-flex="column"] {
  flex-direction: column;
}

[data-css-flex="column-center"] {
  flex-direction: column;
  align-items: center;
}

[data-css-flex="column-right"] {
  flex-direction: column;
  align-items: flex-end;
}

.gap {
  display: flex;
  flex-direction: column;
}

[data-css-gap="10"] {
  gap: 10px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="10"] {
    gap: 0.73206vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="10"] {
    gap: 1.30208vw;
  }
}

.gap--10px {
  gap: 10px;
}

@media screen and (max-width: 768px) {
  .gap--10px {
    gap: 1vw;
  }
}

[data-css-gap="20"] {
  gap: 20px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="20"] {
    gap: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="20"] {
    gap: 2.60417vw;
  }
}

.gap--20px {
  gap: 20px;
}

@media screen and (max-width: 768px) {
  .gap--20px {
    gap: 2vw;
  }
}

[data-css-gap="30"] {
  gap: 30px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="30"] {
    gap: 2.19619vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="30"] {
    gap: 3.90625vw;
  }
}

.gap--30px {
  gap: 30px;
}

@media screen and (max-width: 768px) {
  .gap--30px {
    gap: 3vw;
  }
}

[data-css-gap="40"] {
  gap: 40px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="40"] {
    gap: 2.92826vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="40"] {
    gap: 5.20833vw;
  }
}

.gap--40px {
  gap: 40px;
}

@media screen and (max-width: 768px) {
  .gap--40px {
    gap: 4vw;
  }
}

[data-css-gap="50"] {
  gap: 50px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="50"] {
    gap: 3.66032vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="50"] {
    gap: 6.51042vw;
  }
}

.gap--50px {
  gap: 50px;
}

@media screen and (max-width: 768px) {
  .gap--50px {
    gap: 5vw;
  }
}

[data-css-gap="60"] {
  gap: 60px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="60"] {
    gap: 4.39239vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="60"] {
    gap: 7.8125vw;
  }
}

.gap--60px {
  gap: 60px;
}

@media screen and (max-width: 768px) {
  .gap--60px {
    gap: 6vw;
  }
}

[data-css-gap="70"] {
  gap: 70px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="70"] {
    gap: 5.12445vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="70"] {
    gap: 9.11458vw;
  }
}

.gap--70px {
  gap: 70px;
}

@media screen and (max-width: 768px) {
  .gap--70px {
    gap: 7vw;
  }
}

[data-css-gap="80"] {
  gap: 80px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="80"] {
    gap: 5.85652vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="80"] {
    gap: 10.41667vw;
  }
}

.gap--80px {
  gap: 80px;
}

@media screen and (max-width: 768px) {
  .gap--80px {
    gap: 8vw;
  }
}

[data-css-gap="90"] {
  gap: 90px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="90"] {
    gap: 6.58858vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="90"] {
    gap: 11.71875vw;
  }
}

.gap--90px {
  gap: 90px;
}

@media screen and (max-width: 768px) {
  .gap--90px {
    gap: 9vw;
  }
}

[data-css-gap="100"] {
  gap: 100px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="100"] {
    gap: 7.32064vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="100"] {
    gap: 13.02083vw;
  }
}

.gap--100px {
  gap: 100px;
}

@media screen and (max-width: 768px) {
  .gap--100px {
    gap: 10vw;
  }
}

[data-css-gap="110"] {
  gap: 110px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="110"] {
    gap: 8.05271vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="110"] {
    gap: 14.32292vw;
  }
}

.gap--110px {
  gap: 110px;
}

@media screen and (max-width: 768px) {
  .gap--110px {
    gap: 11vw;
  }
}

[data-css-gap="120"] {
  gap: 120px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="120"] {
    gap: 8.78477vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="120"] {
    gap: 15.625vw;
  }
}

.gap--120px {
  gap: 120px;
}

@media screen and (max-width: 768px) {
  .gap--120px {
    gap: 12vw;
  }
}

[data-css-gap="130"] {
  gap: 130px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="130"] {
    gap: 9.51684vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="130"] {
    gap: 16.92708vw;
  }
}

.gap--130px {
  gap: 130px;
}

@media screen and (max-width: 768px) {
  .gap--130px {
    gap: 13vw;
  }
}

[data-css-gap="140"] {
  gap: 140px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="140"] {
    gap: 10.2489vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="140"] {
    gap: 18.22917vw;
  }
}

.gap--140px {
  gap: 140px;
}

@media screen and (max-width: 768px) {
  .gap--140px {
    gap: 14vw;
  }
}

[data-css-gap="150"] {
  gap: 150px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="150"] {
    gap: 10.98097vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="150"] {
    gap: 19.53125vw;
  }
}

.gap--150px {
  gap: 150px;
}

@media screen and (max-width: 768px) {
  .gap--150px {
    gap: 15vw;
  }
}

[data-css-gap="160"] {
  gap: 160px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="160"] {
    gap: 11.71303vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="160"] {
    gap: 20.83333vw;
  }
}

.gap--160px {
  gap: 160px;
}

@media screen and (max-width: 768px) {
  .gap--160px {
    gap: 16vw;
  }
}

[data-css-gap="170"] {
  gap: 170px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="170"] {
    gap: 12.4451vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="170"] {
    gap: 22.13542vw;
  }
}

.gap--170px {
  gap: 170px;
}

@media screen and (max-width: 768px) {
  .gap--170px {
    gap: 17vw;
  }
}

[data-css-gap="180"] {
  gap: 180px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="180"] {
    gap: 13.17716vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="180"] {
    gap: 23.4375vw;
  }
}

.gap--180px {
  gap: 180px;
}

@media screen and (max-width: 768px) {
  .gap--180px {
    gap: 18vw;
  }
}

[data-css-gap="190"] {
  gap: 190px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="190"] {
    gap: 13.90922vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="190"] {
    gap: 24.73958vw;
  }
}

.gap--190px {
  gap: 190px;
}

@media screen and (max-width: 768px) {
  .gap--190px {
    gap: 19vw;
  }
}

[data-css-gap="200"] {
  gap: 200px;
}

@media screen and (max-width: 1260px) {
  [data-css-gap="200"] {
    gap: 14.64129vw;
  }
}

@media screen and (max-width: 768px) {
  [data-css-gap="200"] {
    gap: 26.04167vw;
  }
}

.gap--200px {
  gap: 200px;
}

@media screen and (max-width: 768px) {
  .gap--200px {
    gap: 20vw;
  }
}

[data-css-gap="1em"] {
  gap: 1em;
}

.gap--1em {
  gap: 1em;
}

[data-css-gap="2em"] {
  gap: 2em;
}

.gap--2em {
  gap: 2em;
}

[data-css-gap="3em"] {
  gap: 3em;
}

.gap--3em {
  gap: 3em;
}

[data-css-gap="4em"] {
  gap: 4em;
}

.gap--4em {
  gap: 4em;
}

[data-css-gap="5em"] {
  gap: 5em;
}

.gap--5em {
  gap: 5em;
}

[data-css-gap="6em"] {
  gap: 6em;
}

.gap--6em {
  gap: 6em;
}

[data-css-gap="7em"] {
  gap: 7em;
}

.gap--7em {
  gap: 7em;
}

[data-css-gap="8em"] {
  gap: 8em;
}

.gap--8em {
  gap: 8em;
}

[data-css-gap="9em"] {
  gap: 9em;
}

.gap--9em {
  gap: 9em;
}

[data-css-gap="10em"] {
  gap: 10em;
}

.gap--10em {
  gap: 10em;
}

.display-xl {
  display: none;
}

@media screen and (max-width: 1600px) {
  .display-xl {
    display: block;
  }
  .none-xl {
    display: none;
  }
  [data-display="xl"] {
    display: block;
  }
  [data-display-none="xl"] {
    display: none;
  }
}

.display-lg {
  display: none;
}

@media screen and (max-width: 1260px) {
  .display-lg {
    display: block;
  }
  .none-lg {
    display: none;
  }
  [data-display="lg"] {
    display: block;
  }
  [data-display-none="lg"] {
    display: none;
  }
}

.display-md {
  display: none;
}

@media screen and (max-width: 992px) {
  .display-md {
    display: block;
  }
  .none-md {
    display: none;
  }
  [data-display="md"] {
    display: block;
  }
  [data-display-none="md"] {
    display: none;
  }
}

.display-sm {
  display: none;
}

@media screen and (max-width: 768px) {
  .display-sm {
    display: block;
  }
  .none-sm {
    display: none;
  }
  [data-display="sm"] {
    display: block;
  }
  [data-display-none="sm"] {
    display: none;
  }
}

.display-xs {
  display: none;
}

@media screen and (max-width: 575px) {
  .display-xs {
    display: block;
  }
  .none-xs {
    display: none;
  }
  [data-display="xs"] {
    display: block;
  }
  [data-display-none="xs"] {
    display: none;
  }
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  border: 0;
  white-space: nowrap;

  clip: rect(0, 0, 0, 0);
}

html {
  font-size: 62.5%;
}

@media screen and (max-width: 768px) {
  html {
    font-size: 3.6vw;
  }
}

body {
  color: var(--color-text);
  font-size: 1.6rem;
  font-family: var(--font-gothic);
  word-wrap: break-word;
}

@media screen and (max-width: 1366px) {
  body {
    font-size: 1.1713vw;
  }
}

@media screen and (max-width: 768px) {
  body {
    font-size: 3.2vw;
  }
}

.textLeft {
  text-align: left;
}

.textRight {
  text-align: right;
}

.textCenter {
  text-align: center;
}

.textJustify {
  text-align: justify;

  text-justify: inter-ideograph;
}

.weightBold {
  font-weight: bold;
}

.text-common {
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 2;

  font-feature-settings: normal;
}

@media screen and (max-width: 1260px) {
  .text-common {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .text-common {
    font-size: 3.6vw;
  }
}

.textMarker {
  background: linear-gradient(
    to bottom,
    transparent 0,
    transparent 50%,
    rgba(var(color-main), 0.25) 50%,
    rgba(var(color-main), 0.25) 100%
  );
}

[data-css-font="mincho"] {
  font-family: var(--font-mincho) !important;
}

[data-css-font="gothic"] {
  font-family: var(--font-gothic) !important;
}

sub {
  font-weight: inherit;
  font-size: 75%;
}

html {
  scroll-behavior: smooth;
}

body {
  display: grid;
  width: 100%;
  min-height: 100vh;
  background-color: var(--color-gray);

  grid-template:
    "header" auto
    "main" 1fr
    "footer" auto
    / 100%;
}

@media screen and (max-width: 768px) {
  body {
    grid-template:
      "header" auto
      "main" 1fr
      "footer" auto
      / 100%;
  }
}

.header {
  grid-area: header;
}

.footer {
  grid-area: footer;
}

.main-visual {
  grid-area: main-visual;
}

.main {
  position: relative;
  z-index: 2;
  width: 100%;
  overflow: hidden;

  grid-area: main;
}

.wrap-1column {
  display: flex;
  justify-content: center;
}

.wrap-2column {
  display: flex;
  flex-flow: row-reverse nowrap;
  justify-content: space-between;
}

@media screen and (max-width: 1260px) {
  .wrap-2column {
    flex-flow: column nowrap;
    margin-bottom: 50px;
  }
}

@media screen and (max-width: 575px) {
  .wrap-2column {
    margin-bottom: 0;
  }
}

.main-column {
  width: var(--width-main-column);
}

@media screen and (max-width: 1260px) {
  .main-column {
    width: 100%;
    margin-bottom: 50px;
  }
}

.sidebar {
  position: sticky;
  top: 0;
  left: 0;
  width: var(--width-side-column);
}

@media screen and (max-width: 992px) {
  .sidebar {
    width: 100%;
  }
}

body:not(.index) .wrap {
  padding: 40px 0 0;
}

@media screen and (max-width: 575px) {
  body:not(.index) .wrap {
    padding: 5vw 0 18vw;
  }
}

.inner {
  padding: 0 140px;
}

@media screen and (max-width: 1260px) {
  .inner {
    padding: 0;
  }
}

.clearfix:after {
  display: block;
  clear: both;
  content: "";
}

.flexCenter {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
}

.flexLeft {
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
}

.flexRight {
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-end;
}

.relative {
  position: relative;
}

.absolute {
  position: absolute;
}

.fullWidth {
  width: 100%;
  min-width: var(--width-base);
}

@media screen and (max-width: 1260px) {
  .fullWidth {
    min-width: 100%;
  }
}

.contents {
  width: var(--width-base);
  margin-right: auto;
  margin-left: auto;
}

@media screen and (max-width: 992px) {
  .contents {
    width: 100%;
  }
}

@media screen and (max-width: 1260px) {
  .sp-contents {
    width: 100%;
    padding-right: 6.4%;
    padding-left: 6.4%;
  }
}

.content {
  max-width: calc(var(--width-base) + var(--padding-base) * 2);
  margin-right: auto;
  margin-left: auto;
  padding-right: var(--padding-base);
  padding-left: var(--padding-base);
}

@media screen and (max-width: 1260px) {
  .content {
    max-width: 100%;
    padding-right: var(--padding-mobile);
    padding-left: var(--padding-mobile);
  }
}

.content--page {
  padding-top: 10rem;
  padding-bottom: 20rem;
}

@media screen and (max-width: 768px) {
  .content--page {
    padding-top: 13.02083vw;
    padding-bottom: 26.04167vw;
  }
}

.page-main--a + .content--page {
  margin-top: -37rem;
}

.content--characteristic {
  margin-top: -75rem;
  padding-top: 10rem;
}

@media screen and (max-width: 768px) {
  .content--characteristic {
    padding-top: 13.02083vw;
  }
}

.content__inner {
  padding-right: 80px;
  padding-left: 80px;
}

@media screen and (max-width: 1260px) {
  .content__inner {
    max-width: 100%;
    padding-right: 0;
    padding-left: 0;
  }
}

.content__inner--160 {
  padding-right: 160px;
  padding-left: 160px;
}

.content__inner--240 {
  padding-right: 240px;
  padding-left: 240px;
}

.content__inner--320 {
  padding-right: 320px;
  padding-left: 320px;
}

.container {
  max-width: calc(var(--width-base) + var(--padding-base) * 2);
  margin-right: auto;
  margin-left: auto;
  padding-right: var(--padding-base);
  padding-left: var(--padding-base);
}

@media screen and (max-width: 1260px) {
  .container {
    max-width: 100%;
    padding-right: var(--padding-mobile);
    padding-left: var(--padding-mobile);
  }
}

.section {
  padding-top: min(16.92708vw, 13rem);
  padding-bottom: min(19.53125vw, 15rem);
}

.alignfull {
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
}

@media screen and (max-width: 992px) {
  .alignfull-md {
    padding-right: 0;
    padding-left: 0;
  }
}

@media screen and (max-width: 768px) {
  .alignfull-sm {
    padding-right: 0;
    padding-left: 0;
  }
}

@media screen and (max-width: 575px) {
  .alignfull-xs {
    padding-right: 0;
    padding-left: 0;
  }
}

.header {
  right: 0;
  left: 0;
  z-index: 9999;
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
  background-color: transparent;
}

@media screen and (max-width: 768px) {
  .header {
    padding-top: 2.5vw;
    padding-bottom: 2.5vw;
  }
}

.header .content {
  display: flex;
  justify-content: space-between;
}

.header__logo {
  display: inline-block;
}

.header__logo a {
  display: block;
}

@media screen and (max-width: 768px) {
  .header__logo img {
    width: auto;
    height: 8vw;
  }
}

.header__nav {
  display: flex;
  align-items: center;
  gap: 3em;
  padding-bottom: 0.5em;
}

@media screen and (max-width: 1366px) {
  .header__nav {
    flex-flow: row wrap;
    justify-content: flex-end;
    gap: 1em;
    padding-bottom: 0;
  }
}

@media screen and (max-width: 992px) {
  .header__nav {
    display: none;
  }
}

.header__nav a {
  display: block;
  color: var(--color-main);
  font-weight: bold;
  transition: color 1s;
}

.header__nav a:hover,
.header__nav a:focus {
  opacity: 0.7;
}

.header__nav a.header__nav__btn {
  padding: 1em 2.5em;
  border-radius: 1.5em;
  background-color: var(--color-main);
  color: var(--color-white);
}

.menu-header-container {
  position: relative;
  z-index: 3;
}

.menu-header-container .menu {
  display: flex;
  align-items: center;
  gap: 2rem;
  position: relative;
  font-size: 1.6rem;
}

@media screen and (max-width: 768px) {
  .menu-header-container .menu {
    gap: 0;
  }
}

.menu-header-container .menu a {
  color: var(--color-main);
  transition: color 1s;
}

@media screen and (max-width: 768px) {
  .menu-header-container .menu a {
    display: flex;
    flex-flow: column nowrap;
    justify-content: center;
    align-items: center;
    gap: 1vw;
    width: 12vw;
    height: 12vw;
  }
}

@media screen and (max-width: 1366px) {
  .menu-header-container .menu > li > a {
    font-size: 1.4rem;
  }
}

.menu-header-container .menu-item:hover > .megamenu {
  visibility: visible;
  opacity: 1;
  transform: translate(-50%, 0);
}

.menu-header-container .megamenu {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  top: 6.25vw;
  left: 50%;
  z-index: 3;
  transform: translate(-50%, -5%);
  width: 90vw;
  max-width: 800px;
  padding: 4.5rem 4.5rem 3rem;
  border-radius: 1rem;
  background-color: var(--color-white);
  transition: 0.25s;
}

.menu-header-container .megamenu::before {
  display: block;
  position: absolute;
  top: -1.875vw;
  z-index: -1;
  width: 100%;
  height: 100px;
  content: "";
}

.menu-header-container .megamenu__top {
  display: flex;
  gap: 2rem;
  min-height: 14rem;
  max-height: 22rem;
  padding-bottom: 2em;
}

.menu-header-container .megamenu__bottom {
  display: flex;
  justify-content: space-between;
  padding-top: 1em;
  border-top: 1px solid var(--color-main);
}

.menu-header-container .megamenu__parent {
  width: 28rem;
}

.menu-header-container .megamenu__head {
  margin-bottom: 1em;
  color: var(--color-main);
  font-size: 2.4rem;
}

.menu-header-container .megamenu__sub {
  color: var(--color-main);
  font-size: 1.6rem;
}

.menu-header-container .megamenu__sub-menu {
  display: flex;
  flex-flow: column wrap;
  gap: 1em 3em;
  font-size: 1.5rem;
  line-height: 1.5;
}

.menu-cta-container {
  position: relative;
  z-index: 2;
}

.menu-cta-container .menu {
  display: flex;
  align-items: center;
  gap: 1em;
  position: relative;
  font-size: 1.5rem;
}

@media screen and (max-width: 768px) {
  .menu-cta-container .menu {
    gap: 2vw;
  }
}

.menu-cta-container a {
  display: block;
  padding: 0.125em 1em;
  border: 1px solid var(--color-main);
  border-radius: 0.875em;
  color: var(--color-main);
  font-weight: 500;
  line-height: 1;
  transition: color 0.5s, background-color 0.5s;
}

.menu-cta-container a:hover {
  background-color: var(--color-main);
  color: var(--color-white);
}

@media screen and (max-width: 768px) {
  .menu-cta-container a {
    font-size: 2vw;
  }
}

.menu-cta-container--header .menu-item:last-child,
.menu-cta-container--drawer .menu-item:last-child {
  display: none;
}

.footer__cta {
  padding-top: 9rem;
  padding-bottom: 8rem;
  background-image: linear-gradient(-30deg, rgba(0, 153, 217, 0.2) 0, rgba(0, 167, 60, 0.2) 100%);
}

@media screen and (max-width: 1366px) {
  .footer__cta {
    padding-top: 6.58858vw;
    padding-bottom: 5.85652vw;
  }
}

@media screen and (max-width: 768px) {
  .footer__cta {
    padding-top: 11.71875vw;
    padding-bottom: 10.41667vw;
  }
}

.footer__top {
  padding-top: 6.5rem;
  padding-bottom: 6.5rem;
  background-color: var(--color-dark-green);
}

@media screen and (max-width: 768px) {
  .footer__top {
    padding-top: 10vw;
    padding-bottom: 10vw;
  }
}

.footer__top__inner {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
  height: 100%;
  margin-bottom: 6.5rem;
}

@media screen and (max-width: 1366px) {
  .footer__top__inner {
    margin-bottom: 4.75842vw;
  }
}

@media screen and (max-width: 768px) {
  .footer__top__inner {
    margin-bottom: 10vw;
  }
}

@media screen and (max-width: 1366px) {
  .footer__logo {
    width: 39.45827vw;
  }
}

@media screen and (max-width: 768px) {
  .footer__logo {
    display: block;
    width: 70.18229vw;
    max-width: 100%;
    margin-right: auto;
    margin-left: auto;
  }
}

.footer__logo__img {
  display: block;
}

@media screen and (max-width: 1366px) {
  .footer__logo__img {
    width: 100%;
    height: auto;
  }
}

@media screen and (max-width: 768px) {
  .footer__logo__img {
    max-width: 100%;
  }
}

.footer__top-links {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

@media screen and (max-width: 1366px) {
  .footer__top-links {
    flex-direction: column;
    align-items: flex-start;
    gap: 5vw;
  }
}

.footer__link {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 28rem;
  height: 6rem;
  border: 1px solid var(--color-white);
  border-radius: 3.5rem;
  background-color: var(--color-white);
  color: var(--color-dark-green);
  font-weight: bold;
  font-size: 1.6rem;
  transition: color 0.5s, background-color 0.5s;
}

@media screen and (max-width: 1366px) {
  .footer__link {
    width: 20.4978vw;
    height: 4.39239vw;
    font-size: 1.1713vw;
  }
}

@media screen and (max-width: 768px) {
  .footer__link {
    width: 49.47917vw;
    height: 9.11458vw;
    margin-right: auto;
    margin-left: auto;
    font-size: 2.60417vw;
  }
}

.footer__link:hover,
.footer__link:focus {
  background-color: var(--color-dark-green);
  color: var(--color-white);
}

.footer__link::after {
  position: absolute;
  top: 0;
  right: 0.75em;
  bottom: 0;
  height: 1em;
  margin: auto;
  font-family: "Material Icons";
}

.footer__link[data-icon="filter_none"]::after {
  right: 1.5em;
  font-weight: 100;
  content: "\e3e0";
}

.footer__bnrs {
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 2em;
}

@media screen and (max-width: 1366px) {
  .footer__bnrs {
    align-self: flex-end;
  }
}

@media screen and (max-width: 768px) {
  .footer__bnrs {
    justify-content: center;
    gap: 2.5vw;
  }
}

.footer__bnrs li {
  flex: 1;
}

.footer__bnrs li img {
  max-width: 100%;
  height: auto;
  border-radius: 0.5rem;
}

.footer__bottom {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 8rem;
  background-color: #037234;
  font-size: min(3.2vw, 2.4rem);
}

@media screen and (max-width: 1366px) {
  .footer__bottom {
    height: 5.85652vw;
  }
}

@media screen and (max-width: 768px) {
  .footer__bottom {
    height: 10.41667vw;
  }
}

.footer__nav {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 3em;
}

@media screen and (max-width: 768px) {
  .footer__nav {
    display: none;
  }
}

.footer__nav a {
  color: var(--color-white);
  font-weight: bold;
}

.footer__copy {
  color: var(--color-white);
  font-size: 1.4rem;
}

@media screen and (max-width: 1366px) {
  .footer__copy {
    font-size: 1.02489vw;
  }
}

@media screen and (max-width: 768px) {
  .footer__copy {
    font-size: 2.60417vw;
  }
}

.cta {
  display: flex;
  flex-flow: row wrap;
}

@media screen and (max-width: 768px) {
  .cta {
    flex-flow: column nowrap;
  }
}

.cta__box {
  display: flex;
  flex: 1;
  flex-direction: column;
  align-items: center;
  gap: 2em;
  height: 20rem;
  font-size: 1.8rem;
}

@media screen and (max-width: 1366px) {
  .cta__box {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .cta__box {
    font-size: 2.34375vw;
  }
}

.cta__box--tel {
  border-right: 1px solid var(--color-white);
}

@media screen and (max-width: 768px) {
  .cta__box--tel {
    padding-bottom: 10vw;
    border-right: none;
    border-bottom: 1px solid var(--color-white);
  }
}

.cta__box--tel a {
  color: var(--color-main);
  font-weight: bold;
  font-size: 6rem;
  font-family: var(--font-montserrat);
}

@media screen and (max-width: 1366px) {
  .cta__box--tel a {
    font-size: 4.39239vw;
  }
}

@media screen and (max-width: 768px) {
  .cta__box--tel a {
    font-size: 7.8125vw;
  }
}

.cta__box--tel a::before {
  display: inline-block;
  width: 0.75em;
  height: 0.75em;
  background: url(../images/icon-tel.svg) no-repeat center center/contain;
  content: "";
}

@media screen and (max-width: 768px) {
  .cta__box--mail {
    padding-top: 10vw;
  }
}

@media screen and (max-width: 768px) {
  .cta__box--mail a {
    font-size: 3.90625vw;
  }
}

.cta__head,
.cta__time {
  font-weight: bold;
}

.breadcrumbs {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 10rem;
  font-size: 1.6rem;
}

@media screen and (max-width: 768px) {
  .breadcrumbs {
    display: none;
  }
}

.breadcrumbs a,
.breadcrumbs span {
  color: var(--color-main);
}

.form {
  /* プレースホルダー */
  /* 入力欄 */
  /* 入力欄 */
  /* 日付 */
  /* 数値 */
  /* スピンボタン非表示*/
  /* レンジ */
  /* カラーピッカー */
}

.form input[type="text"],
.form input[type="email"],
.form input[type="tel"],
.form input[type="search"],
.form input[type="url"],
.form input[type="password"],
.form input[type="datetime"],
.form input[type="date"],
.form input[type="month"],
.form input[type="week"],
.form input[type="time"],
.form input[type="datetime-local"],
.form input[type="number"],
.form input[type="range"],
.form input[type="color"],
.form input[type="submit"],
.form input[type="button"],
.form input[type="image"],
.form select,
.form button,
.form textarea,
.form progress {
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  background: none;
  font-family: var(--font-gothic);
  outline: none;

  appearance: none;
}

.form ::placeholder {
  opacity: 0.3;
  color: #000;
}

.form input[type="text"],
.form input[type="email"],
.form input[type="tel"],
.form input[type="search"],
.form input[type="url"],
.form input[type="password"],
.form input[type="datetime"],
.form input[type="date"],
.form input[type="month"],
.form input[type="week"],
.form input[type="time"],
.form input[type="datetime-local"],
.form input[type="number"],
.form input[type="range"] {
  width: 100%;
  padding: 0.4em 1em;
  border: 1px solid #ccc;
  color: #333;
}

.form input[type="text"],
.form input[type="email"],
.form input[type="tel"],
.form input[type="search"],
.form input[type="url"],
.form input[type="password"],
.form textarea {
  background: #fff;
  font-size: 16px;
}

.form input[type="datetime"],
.form input[type="date"],
.form input[type="month"],
.form input[type="week"],
.form input[type="time"],
.form input[type="datetime-local"] {
  font-size: 16px;
}

.form input[type="number"]::-webkit-outer-spin-button,
.form input[type="number"]::-webkit-inner-spin-button {
  margin: 0;

  -webkit-appearance: none;
}

.form input[type="number"] {
  -moz-appearance: textfield;
}

.form select {
  width: 100%;
  margin-right: 0.05em;
  padding: 0.75em 2em 0.75em 1em;
  border: 1px solid #ccc;
  background: #fff url(../images/icon-tri.png) no-repeat right 0.5em center;
  font-size: 16px;
}

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

.form textarea {
  width: 100%;
  height: 300px;
  /* ieでスクロールバー非表示 */
  padding: 0.5em 1em;
  overflow: hidden;
  border: 1px solid #ccc;
}

.form input[type="submit"],
.form input[type="button"],
.form button {
  cursor: pointer;
}

.main-visual {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .main-visual {
    overflow: hidden;
  }
}

.main-visual__picture {
  display: block;
}

.main-visual__img {
  width: 100%;
  height: auto;
}

.drawer-wrap {
  display: none;
}

@media screen and (max-width: 992px) {
  .drawer-wrap {
    display: block;
  }
}

.nav-input {
  display: none;
}

#nav-drawer {
  position: relative;
}

.nav-unshown {
  display: none;
}

.drawer-btn {
  position: fixed;
  top: 2rem;
  right: 2rem;
  z-index: 10000;
  cursor: pointer;
}

@media screen and (max-width: 992px) {
  .drawer-btn {
    display: block;
    width: 6rem;
    height: 6rem;
    border-radius: 50%;
    background-color: var(--color-main);
  }
}

@media screen and (max-width: 768px) {
  .drawer-btn {
    top: 1.5vw;
    right: 1.5vw;
    width: 9vw;
    height: 9vw;
  }
}

.drawer-btn__line {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 40%;
  height: 0.1rem;
  margin: auto;
  background-color: var(--color-white);
  transition: transform 0.5s;

  transform-origin: center;
}

.drawer-btn__line--1 {
  transform: translateY(0.5rem);
}

@media screen and (max-width: 768px) {
  .drawer-btn__line--1 {
    transform: translateY(-0.97656vw);
  }
}

.nav-input:checked + .drawer-btn .drawer-btn__line--1 {
  transform: translateY(0) rotate(30deg);
}

.drawer-btn__line--2 {
  transform: translateY(-0.5rem);
}

@media screen and (max-width: 768px) {
  .drawer-btn__line--2 {
    transform: translateY(0.97656vw);
  }
}

.nav-input:checked + .drawer-btn .drawer-btn__line--2 {
  transform: translateY(0) rotate(-30deg);
}

.nav-close-cover {
  opacity: 0;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99;
  width: 100%;
  height: 100%;
  background: white;
  transition: 0.3s ease-in-out;
}

.nav-input:checked ~ .nav-close-cover {
  display: block;
  opacity: 0.75;
}

.nav-content {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 9999;
  width: 32rem;
  max-width: 100%;
  height: 100%;
  padding: 9rem 3rem 3rem 4rem;
  overflow: auto;
  background: var(--color-white);
  transition: 0.3s ease-in-out;
  /* 右からフェイドインしながら開く */
  /* 左からフェイドインしながら開く */
  /* 右上から円形に広がりながら開く */
  /* 左上から円形に広がりながら開く */
}

@media screen and (max-width: 768px) {
  .nav-content {
    width: 64vw;
    padding: 18vw 6vw 6vw 8vw;
  }
}

.nav-content[data-open="fadeInRight"] {
  opacity: 0;
  transform: translateX(105%);
}

.nav-input:checked ~ .nav-content[data-open="fadeInRight"] {
  opacity: 1;
  transform: translateX(0%);
}

.nav-content[data-open="fadeInLeft"] {
  opacity: 0;
  transform: translateX(-105%);
}

.nav-input:checked ~ .nav-content[data-open="fadeInLeft"] {
  opacity: 1;
  transform: translateX(0);
}

.nav-content[data-open="circleInRight"] {
  clip-path: circle(0 at 100% 0);
  transition: clip-path 0.8s cubic-bezier(0.645, 0.045, 0.355, 1) 0s, transform 0s cubic-bezier(0.645, 0.045, 0.355, 1) 0.8s;
}

.nav-input:checked ~ .nav-content[data-open="circleInRight"] {
  clip-path: circle(1100px at 100% 0);
  transform: translateX(0);
  transition: clip-path 0.8s cubic-bezier(0.645, 0.045, 0.355, 1) 0s, transform 0s cubic-bezier(0.645, 0.045, 0.355, 1) 0.8s;
}

.nav-content[data-open="circleInLeft"] {
  clip-path: circle(0 at 0 0);
  transition: clip-path 0.8s cubic-bezier(0.645, 0.045, 0.355, 1) 0s, transform 0s cubic-bezier(0.645, 0.045, 0.355, 1) 0.8s;
}

.nav-input:checked ~ .nav-content[data-open="circleInLeft"] {
  clip-path: circle(1100px at 0 0);
  transform: translateX(0);
  transition: clip-path 0.8s cubic-bezier(0.645, 0.045, 0.355, 1) 0s, transform 0s cubic-bezier(0.645, 0.045, 0.355, 1) 0.8s;
}

.menu-drawer-container {
  margin-bottom: 20vw;
}

.menu-drawer-container .menu {
  display: flex;
  flex-flow: column nowrap;
  gap: 2em;
  font-weight: 500;
  line-height: 2;
}

@media screen and (max-width: 768px) {
  .menu-drawer-container .menu {
    font-size: 3vw;
  }
}

.menu-drawer-container .menu > .menu-item > a {
  font-weight: bold;
}

.menu-drawer-container .menu > .menu-item > a.menu-drawer-container__btn {
  display: inline-block;
  padding: 1em 2.5em;
  border-radius: 1.5em;
  background-color: var(--color-main);
  color: var(--color-white);
  line-height: 1;
}

.menu-drawer-container .sub-menu {
  padding: 0 1em;
}

.menu-drawer-container .sub-menu > .menu-item {
  margin-top: 1.5em;
}

.menu-drawer-container .sub-menu > .menu-item > a {
  display: block;
  font-weight: 400;
}

/*
#overview
トップに戻る
*/
/*
#styleguide
トップに戻る

```
<div>
<a id="js-pagetop" class="pagetop" href="#top">
	<span></span>
</a>
</div>
```
*/
.pagetop {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  opacity: 0.5;
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 5;
  width: 80px;
  height: 80px;
  background-color: var(--color-main);
  color: var(--color-white);
  text-align: center;
  transition: transform 0.25s, opacity 0.5s;

  transform-origin: center;
}

.pagetop:hover {
  opacity: 1;
}

@media screen and (max-width: 768px) {
  .pagetop {
    right: 3vw;
    bottom: 3vw;
    width: 12vw;
    height: 12vw;
  }
}

.pagetop[data-shape="circle"] {
  border-radius: 50%;
}

.pagetop[data-stroke="true"] {
  border: 5px solid var(--color-white);
}

@media screen and (max-width: 768px) {
  .pagetop[data-stroke="true"] {
    border: 0.75vw solid var(--color-white);
  }
}

.pagetop:before {
  display: block;
  position: absolute;
  top: 35%;
  right: 0;
  bottom: auto;
  left: 0;
  transform: rotate(135deg);
  width: 30%;
  height: 30%;
  margin: auto;
  border-bottom: 3px solid var(--color-white);
  border-left: 3px solid var(--color-white);
  content: "";
}

@media screen and (max-width: 768px) {
  .pagetop:before {
    top: 3.5vw;
    width: 4vw;
    height: 4vw;
    border-bottom: 0.75vw solid var(--color-white);
    border-left: 0.75vw solid var(--color-white);
  }
}

.pagetop::after {
  margin-bottom: 1.75em;
  color: var(--color-white);
  font-size: 1rem;
  font-family: var(--font-montserrat);
  content: attr(data-text);
}

@media screen and (max-width: 768px) {
  .pagetop::after {
    margin-bottom: 1.25em;
    font-size: 2vw;
  }
}

.pagetop[data-active="fadeIn"] {
  opacity: 0;
}

.pagetop[data-active="fadeIn"].active {
  opacity: 0.5;
}

.pagetop[data-active="zoomIn"] {
  transform: scale(0, 0);
}

.pagetop[data-active="zoomIn"].active {
  transform: scale(1, 1);
}

.pagetop[data-active="slideInRight"] {
  transform: translateX(110%);
}

.pagetop[data-active="slideInRight"].active {
  transform: translateX(0);
}

.pagetop[data-active="slideInUp"] {
  transform: translateY(110%);
}

.pagetop[data-active="slideInUp"].active {
  transform: translateY(0);
}

.pagetop[data-active="slideInCorner"] {
  transform: translate(200%, 200%);
}

.pagetop[data-active="slideInCorner"].active {
  transform: translate(0, 0);
}

.list-num-period {
  counter-reset: cnt;
}

.list-num-period > li {
  list-style-position: inside;
  padding-left: 1.6em;
  text-indent: -0.6em;
  counter-increment: cnt;
}

.list-num-period > li:before {
  margin-right: 0.5em;
  content: counter(cnt) ".";
}

.list-num-period .list-num-period {
  margin: 1em;
}

.list-num-period .list-num-period .list-num-period {
  margin: 1em;
}

.list-num-brackets > li {
  list-style-position: inside;
  margin-left: 2em;
  text-indent: -1em;
  counter-increment: cnt;
}

.list-num-brackets > li:before {
  margin-right: 0.5em;
  content: counter(cnt) ")";
}

.list-caution > li {
  margin-left: 1em;
  text-indent: -1em;
}

.list-caution > li:before {
  content: "※";
}

.list-circle > li {
  margin-left: 1.5em;
  text-indent: -1.5em;
}

.list-circle > li:before {
  margin-right: 0.5em;
  content: "●";
}

.list-circle-border > li {
  margin-left: 1em;
  text-indent: -1em;
}

.list-circle-border > li:before {
  content: "○";
}

.list-dot > li {
  margin-left: 1em;
  text-indent: -1em;
}

.list-dot > li:before {
  content: "・";
}

.list-item {
  display: flex;
  flex-flow: row wrap;
}

.list-item li:not(:last-child):after {
  margin: 0 0.25em;
  content: "　";
}

.list-dia > li {
  margin-left: 1.5em;
  text-indent: -1.5em;
}

.list-dia > li:before {
  margin-right: 0.5em;
  content: "◆";
}

[data-css-list] > li {
  margin-left: 1em;
  text-indent: -1em;
}

[data-css-list="・"] > li:before {
  content: "・";
}

[data-css-list="●"] > li:before {
  content: "●";
}

[data-css-list="◯"] > li:before {
  content: "◯";
}

[data-css-list="◆"] > li:before {
  content: "◆";
}

[data-css-list="※"] > li:before {
  content: "※";
}

[data-css-list="★"] > li:before {
  content: "★";
}

[data-css-list="num-round"] > li:nth-child(1)::before {
  content: "①";
}

[data-css-list="num-round"] > li:nth-child(2)::before {
  content: "②";
}

[data-css-list="num-round"] > li:nth-child(3)::before {
  content: "③";
}

[data-css-list="num-round"] > li:nth-child(4)::before {
  content: "④";
}

[data-css-list="num-round"] > li:nth-child(5)::before {
  content: "⑤";
}

[data-css-list="num-round"] > li:nth-child(6)::before {
  content: "⑥";
}

[data-css-list="num-round"] > li:nth-child(7)::before {
  content: "⑦";
}

[data-css-list="num-round"] > li:nth-child(8)::before {
  content: "⑧";
}

[data-css-list="num-round"] > li:nth-child(9)::before {
  content: "⑨";
}

[data-css-list="num-round"] > li:nth-child(10)::before {
  content: "⑩";
}

[data-css-list="num-round"] > li:nth-child(11)::before {
  content: "⑪";
}

[data-css-list="num-round"] > li:nth-child(12)::before {
  content: "⑫";
}

[data-css-list="num-round"] > li:nth-child(13)::before {
  content: "⑬";
}

[data-css-list="num-round"] > li:nth-child(14)::before {
  content: "⑭";
}

[data-css-list="num-round"] > li:nth-child(15)::before {
  content: "⑮";
}

[data-css-list="num-round"] > li:nth-child(16)::before {
  content: "⑯";
}

[data-css-list="num-round"] > li:nth-child(17)::before {
  content: "⑰";
}

[data-css-list="num-round"] > li:nth-child(18)::before {
  content: "⑱";
}

[data-css-list="num-round"] > li:nth-child(19)::before {
  content: "⑲";
}

[data-css-list="num-round"] > li:nth-child(20)::before {
  content: "⑳";
}

[data-css-list="num-round-black"] > li:nth-child(1)::before {
  content: "❶";
}

[data-css-list="num-round-black"] > li:nth-child(2)::before {
  content: "❷";
}

[data-css-list="num-round-black"] > li:nth-child(3)::before {
  content: "❸";
}

[data-css-list="num-round-black"] > li:nth-child(4)::before {
  content: "❹";
}

[data-css-list="num-round-black"] > li:nth-child(5)::before {
  content: "❺";
}

[data-css-list="num-round-black"] > li:nth-child(6)::before {
  content: "❻";
}

[data-css-list="num-round-black"] > li:nth-child(7)::before {
  content: "❼";
}

[data-css-list="num-round-black"] > li:nth-child(8)::before {
  content: "❽";
}

[data-css-list="num-round-black"] > li:nth-child(9)::before {
  content: "❾";
}

[data-css-list="num-round-black"] > li:nth-child(10)::before {
  content: "❿";
}

[data-css-list="num-round-black"] > li:nth-child(11)::before {
  content: "⓫";
}

[data-css-list="num-round-black"] > li:nth-child(12)::before {
  content: "⓬";
}

[data-css-list="num-round-black"] > li:nth-child(13)::before {
  content: "⓭";
}

[data-css-list="num-round-black"] > li:nth-child(14)::before {
  content: "⓮";
}

[data-css-list="num-round-black"] > li:nth-child(15)::before {
  content: "⓯";
}

[data-css-list="num-round-black"] > li:nth-child(16)::before {
  content: "⓰";
}

[data-css-list="num-round-black"] > li:nth-child(17)::before {
  content: "⓱";
}

[data-css-list="num-round-black"] > li:nth-child(18)::before {
  content: "⓲";
}

[data-css-list="num-round-black"] > li:nth-child(19)::before {
  content: "⓳";
}

[data-css-list="num-round-black"] > li:nth-child(20)::before {
  content: "⓴";
}

[data-css-list="alphabet-l"] > li:nth-child(1)::before {
  content: "A";
}

[data-css-list="alphabet-l"] > li:nth-child(2)::before {
  content: "B";
}

[data-css-list="alphabet-l"] > li:nth-child(3)::before {
  content: "C";
}

[data-css-list="alphabet-l"] > li:nth-child(4)::before {
  content: "D";
}

[data-css-list="alphabet-l"] > li:nth-child(5)::before {
  content: "E";
}

[data-css-list="alphabet-l"] > li:nth-child(6)::before {
  content: "F";
}

[data-css-list="alphabet-l"] > li:nth-child(7)::before {
  content: "G";
}

[data-css-list="alphabet-l"] > li:nth-child(8)::before {
  content: "H";
}

[data-css-list="alphabet-l"] > li:nth-child(9)::before {
  content: "I";
}

[data-css-list="alphabet-l"] > li:nth-child(10)::before {
  content: "J";
}

[data-css-list="alphabet-l"] > li:nth-child(11)::before {
  content: "K";
}

[data-css-list="alphabet-l"] > li:nth-child(12)::before {
  content: "L";
}

[data-css-list="alphabet-l"] > li:nth-child(13)::before {
  content: "M";
}

[data-css-list="alphabet-l"] > li:nth-child(14)::before {
  content: "N";
}

[data-css-list="alphabet-l"] > li:nth-child(15)::before {
  content: "O";
}

[data-css-list="alphabet-l"] > li:nth-child(16)::before {
  content: "P";
}

[data-css-list="alphabet-l"] > li:nth-child(17)::before {
  content: "Q";
}

[data-css-list="alphabet-l"] > li:nth-child(18)::before {
  content: "R";
}

[data-css-list="alphabet-l"] > li:nth-child(19)::before {
  content: "S";
}

[data-css-list="alphabet-l"] > li:nth-child(20)::before {
  content: "T";
}

[data-css-list="alphabet-l"] > li:nth-child(21)::before {
  content: "U";
}

[data-css-list="alphabet-l"] > li:nth-child(22)::before {
  content: "V";
}

[data-css-list="alphabet-l"] > li:nth-child(23)::before {
  content: "W";
}

[data-css-list="alphabet-l"] > li:nth-child(24)::before {
  content: "X";
}

[data-css-list="alphabet-l"] > li:nth-child(25)::before {
  content: "Y";
}

[data-css-list="alphabet-l"] > li:nth-child(26)::before {
  content: "Z";
}

[data-css-list="alphabet-s"] > li {
  margin-left: 2em;
  text-indent: -2em;
}

[data-css-list="alphabet-s"] > li::before {
  margin-right: 2em;
}

[data-css-list="alphabet-s"] > li:nth-child(1)::before {
  content: "a" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(2)::before {
  content: "b" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(3)::before {
  content: "c" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(4)::before {
  content: "d" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(5)::before {
  content: "e" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(6)::before {
  content: "f" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(7)::before {
  content: "g" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(8)::before {
  content: "h" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(9)::before {
  content: "i" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(10)::before {
  content: "j" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(11)::before {
  content: "k" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(12)::before {
  content: "l" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(13)::before {
  content: "m" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(14)::before {
  content: "n" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(15)::before {
  content: "o" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(16)::before {
  content: "p" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(17)::before {
  content: "q" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(18)::before {
  content: "r" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(19)::before {
  content: "s" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(20)::before {
  content: "t" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(21)::before {
  content: "u" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(22)::before {
  content: "v" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(23)::before {
  content: "w" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(24)::before {
  content: "x" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(25)::before {
  content: "y" ".";
}

[data-css-list="alphabet-s"] > li:nth-child(26)::before {
  content: "z" ".";
}

[data-mark] {
  margin-left: 1em;
  text-indent: -1em;
}

[data-mark]::before {
  content: attr(data-mark);
}

.nav-link {
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
  gap: 40px;
  width: 100%;
  margin-top: 3em;
}

.nav-link--right {
  justify-content: flex-end;
}

.nav-link--center {
  justify-content: center;
}

@media screen and (max-width: 768px) {
  .nav-link {
    gap: 5vw;
  }
}

.nav-link__item {
  font-size: 1.7rem;
}

@media screen and (max-width: 768px) {
  .nav-link__item {
    font-size: 4vw;
  }
}

.nav-link__item--prev {
  order: 1;
}

.nav-link__item--next {
  order: 3;
}

.nav-link__item--archive {
  order: 2;
}

.nav-link__link {
  display: inline-block;
  padding-bottom: 1em;
  border-bottom: 3px solid var(--color-blue);
  color: var(--color-blue);
  font-weight: bold;
  font-size: 1.7rem;
  line-height: 1.5;
  text-align: center;
  transition: color 0.25s, border 0.25s;
}

@media screen and (max-width: 768px) {
  .nav-link__link {
    font-size: 4vw;
  }
}

.nav-link__link:hover {
  opacity: 0.7;
}

.nav-link__link::before,
.nav-link__link::after {
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: -10%;
}

.nav-link__link--prev::before {
  transform: rotate(180deg);
  margin-right: 1em;
  content: "";
}

.nav-link__link--next::after {
  margin-left: 1em;
  content: "";
}

.nav-link__link--archive::after {
  margin-left: 0.5em;
  color: var(--color-gray);
  vertical-align: -5%;
  content: "●";
}

/*
#overview
ページ送り
*/
/*
#styleguide
ページ送り

```
<ol class="pagination">
	<li>
		<a class="pager prev" href="">prev</a>
	</li>
	<li>
		<a class="pager" href="">1</a>
	</li>
	<li>
		<a class="pager" href="">2</a>
	</li>
	<li>
		<a class="pager current" href="">3</a>
	</li>
	<li>
		<a class="pager" href="">4</a>
	</li>
	<li>
		<a class="pager" href="">5</a>
	</li>
	<li>
		<a class="pager next" href="">next</a>
	</li>
</ol>
```
*/
.pagination {
  display: flex;
  justify-content: center;
}

@media screen and (max-width: 768px) {
  .pagination {
    overflow-x: scroll;
  }
}

.pagination__inner {
  display: flex;
  align-items: center;
  position: relative;
}

.pagination__item {
  margin: 0 0.5em;
  font-size: 1.8rem;
}

@media screen and (max-width: 1260px) {
  .pagination__item {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .pagination__item {
    margin: 0 0.25em;
    font-size: 4vw;
  }
}

.pagination__link {
  display: inline-block;
  min-width: 32px;
  height: 1.5em;
  font-size: 1.8rem;
  line-height: 1.5;
  text-align: center;
  transition: color 0.25s, border 0.25s;
}

@media screen and (max-width: 1260px) {
  .pagination__link {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .pagination__link {
    min-width: 10vw;
    height: 10vw;
    font-size: 4vw;
    line-height: 10vw;
  }
}

.pagination__link:hover,
.pagination__link--current {
  font-weight: bold;
}

.pagination__link--first,
.pagination__link--last,
.pagination__link--prev,
.pagination__link--next {
  display: flex;
  justify-content: center;
  align-items: center;
}

.pagination__link--first:before,
.pagination__link--first:after,
.pagination__link--last:before,
.pagination__link--last:after,
.pagination__link--prev:before,
.pagination__link--prev:after,
.pagination__link--next:before,
.pagination__link--next:after {
  display: block;
  width: 0.35em;
  height: 0.35em;
  border-top: 2px solid var(--text-color);
  border-right: 2px solid var(--text-color);
  content: "";

  transform-origin: center;
}

.pagination__link--first:before,
.pagination__link--first:after {
  content: none;
}

.pagination__link--prev:before {
  transform: rotate(-135deg);
}

.pagination__link--prev:after {
  content: none;
}

.pagination__link--last:before,
.pagination__link--last:after {
  content: none;
}

.pagination__link--next:before {
  transform: rotate(45deg);
}

.pagination__link--next:after {
  content: none;
}

::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar:hover {
  width: 10px;
}

::-webkit-scrollbar-track {
  border-radius: 3px;
  box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.1);
  background: var(--color-white);
}

::-webkit-scrollbar-track:hover {
  border-radius: 5px;
}

::-webkit-scrollbar-thumb {
  border-radius: 3px;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.3);
  background: var(--color-main);
}

::-webkit-scrollbar-thumb:hover {
  border-radius: 5px;
}

.breadcrumb::-webkit-scrollbar {
  width: 2px;
  height: 2px;
}

.horizontal-table--sm-scroll::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

[data-css-scroll]::-webkit-scrollbar {
  width: 20px;
  height: 20px;
}

[data-css-scroll]::-webkit-scrollbar-track {
  margin: 1px;
  border-radius: 10px;
  background: var(--color-white);
  outline: 1px solid var(--color-black);
}

[data-css-scroll]::-webkit-scrollbar-thumb {
  width: 10px;
  height: 10px;
  border: 5px solid var(--color-white);
  border-radius: 10px;
  background: var(--color-gray);
}

[data-css-scroll]::-webkit-scrollbar:vertical {
  display: none;
}

/*
#overview
ボタン
*/
a[href^="tel:"] {
  pointer-events: none;
}

a[href^="tel:"]:hover,
a[href^="tel:"]:focus {
  pointer-events: none;
}

@media screen and (max-width: 575px) {
  a[href^="tel:"] {
    pointer-events: auto;
  }
}

.btn {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 38rem;
  height: 7rem;
  border: 1px solid var(--color-main);
  border-radius: 3.5rem;
  background-color: var(--color-main);
  color: var(--color-white);
  font-weight: bold;
  font-size: 2rem;
  transition: color 0.5s, background-color 0.5s;
}

@media screen and (max-width: 1366px) {
  .btn {
    width: 27.81845vw;
    height: 5.12445vw;
    font-size: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  .btn {
    width: 49.47917vw;
    height: 9.11458vw;
    font-size: 2.60417vw;
  }
}

.btn:hover,
.btn:focus {
  background-color: var(--color-white);
  color: var(--color-main);
}

.btn--alt {
  background-color: var(--color-white);
  color: var(--color-main);
}

.btn--alt:hover,
.btn--alt:focus {
  background-color: var(--color-main);
  color: var(--color-white);
}

.btn::after {
  position: absolute;
  top: 0;
  right: 0.75em;
  bottom: 0;
  height: 1em;
  margin: auto;
  font-family: "Material Icons";
}

.btn[data-icon="arrow_circle_right"]::after {
  font-size: 1.5em;
  content: "\eaaa";
}

.btn[data-icon="filter_none"]::after {
  right: 1.5em;
  font-weight: 100;
  content: "\e3e0";
}

.head {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 1.25em;
  color: var(--color-blue);
  font-weight: bold;
  font-size: 4.2rem;
  line-height: calc(64 / 42);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .head {
    font-size: 3.07467vw;
  }
}

@media screen and (max-width: 768px) {
  .head {
    font-size: 5.46875vw;
  }
}

.footer__cta .head {
  margin-bottom: 1.5em;
}

@media screen and (max-width: 768px) {
  .head__img {
    width: auto;
    height: 6.6vw;
  }
}

.head::after {
  display: block;
  background-image: linear-gradient(to right, #0099d9 0, #00a73c 100%);
  background-clip: text;
  font-weight: bold;
  font-size: calc(20 / 42 * 100%);
  font-family: var(--font-montserrat);
  content: attr(data-text);

  -webkit-text-fill-color: transparent;
}

.head2 {
  margin-bottom: 1em;
  color: var(--color-blue);
  font-weight: bold;
  font-size: 2.8rem;
  line-height: 1.25;
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .head2 {
    font-size: 2.04978vw;
  }
}

@media screen and (max-width: 768px) {
  .head2 {
    font-size: 5.6vw;
  }
}

.head3 {
  display: flex;
  justify-content: center;
  align-items: center;
  width: fit-content;
  min-width: 45rem;
  height: 8rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 3em;
  padding-left: 3em;
  border-radius: 4rem;
  background-image: linear-gradient(to right, #0099d9 0, #00a73c 100%);
  color: var(--color-white);
  font-weight: bold;
  font-size: 2.8rem;
  line-height: 1.25;
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .head3 {
    min-width: 32.9429vw;
    height: 5.85652vw;
    border-radius: 2.92826vw;
    font-size: 2.04978vw;
  }
}

@media screen and (max-width: 768px) {
  .head3 {
    min-width: auto;
    max-width: 100%;
    height: 10.41667vw;
    border-radius: 5.20833vw;
    font-size: 3.64583vw;
  }
}

.iruv-coat .head3,
.nanobeatwater .head3 {
  position: relative;
  top: -4rem;
}

@media screen and (max-width: 768px) {
  .iruv-coat .head3,
  .nanobeatwater .head3 {
    top: -1.5em;
  }
}

.inner-wrap {
  display: flex;
  flex-direction: column;
  gap: 10rem;
}

@media screen and (max-width: 1366px) {
  .inner-wrap {
    gap: 7.32064vw;
  }
}

@media screen and (max-width: 768px) {
  .inner-wrap {
    gap: 13.02083vw;
  }
}

.inner-section {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

@media screen and (max-width: 1366px) {
  .inner-section {
    padding-top: 2.92826vw;
    padding-bottom: 2.92826vw;
  }
}

@media screen and (max-width: 768px) {
  .inner-section {
    padding-top: 5.20833vw;
    padding-bottom: 5.20833vw;
  }
}

.frame {
  border-radius: 2rem;
  box-shadow: 4px 4px 6px rgba(0, 153, 217, 0.2);
}

@media screen and (max-width: 1366px) {
  .frame {
    padding: 2.92826vw;
    border-radius: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  .frame {
    padding: 5.20833vw;
    border-radius: 2.60417vw;
  }
}

.frame--white {
  background-color: var(--color-white);
}

.frame--blue {
  background-color: #ebf8ff;
}

.frame--iruv,
.frame--nanobeatwater {
  position: relative;
  padding: 0 7rem 7rem;
}

@media screen and (max-width: 1366px) {
  .frame--iruv,
  .frame--nanobeatwater {
    padding: 0 5.12445vw 5.12445vw;
  }
}

@media screen and (max-width: 768px) {
  .frame--iruv,
  .frame--nanobeatwater {
    padding: 0 5vw 9.11458vw;
  }
}

.drawer-nav {
  display: flex;
  flex-flow: column wrap;
  gap: 60px;
  width: fit-content;
  height: 420px;
}

@media screen and (max-width: 768px) {
  .drawer-nav {
    gap: 4vw;
    height: 68vw;
  }
}

.drawer-nav__item {
  width: 160px;
}

@media screen and (max-width: 768px) {
  .drawer-nav__item {
    width: 30vw;
  }
}

.drawer-nav__item--parent::before {
  margin-bottom: 0.5em;
}

.drawer-nav [href]::after {
  content: "";
}

.drawer-nav__link {
  display: block;
  color: var(--color-blue);
  font-size: 1.5rem;
  line-height: 2;
}

@media screen and (max-width: 768px) {
  .drawer-nav__link {
    font-size: 2.8vw;
  }
}

.drawer-nav__link:hover,
.drawer-nav__link:focus {
  opacity: 0.7;
}

.drawer-nav__link--parent {
  position: relative;
  padding-bottom: 0.25em;
  border-bottom: 2px solid var(--color-blue);
  font-weight: bold;
  font-size: 1.7rem;
  letter-spacing: 0.1em;
}

@media screen and (max-width: 768px) {
  .drawer-nav__link--parent {
    font-size: 3vw;
  }
}

.drawer-nav__link--parent::after {
  display: block;
  position: absolute;
  top: 0.35em;
  right: 0;
  width: 22px;
  height: 22px;
  content: "";
}

.drawer-nav__link--children {
  font-size: 1.5rem;
  letter-spacing: 0.025em;
}

@media screen and (max-width: 992px) {
  .drawer-nav__link--children {
    font-size: 1.6vw;
  }
}

.drawer-nav__children {
  margin-top: 1em;
}

.js-fadeInUp {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1s, transform 1s;
  transition-delay: 0.2s;
}

.js-fadeInUp.show {
  opacity: 1;
  transform: translateY(0);
}

.js-fadeIn {
  opacity: 0;
  transition: opacity 2s;
}

.js-fadeIn.show {
  opacity: 1;
}

.js-fadeInRight {
  opacity: 0;
  transform: translateX(-100px);
  transition: opacity 2s, transform 2s;
  transition-delay: 0.2s;
}

.js-fadeInRight.show {
  opacity: 1;
  transform: translateX(0);
}

.js-fadeInLeft {
  opacity: 0;
  transform: translateX(100px);
  transition: opacity 2s, transform 2s;
  transition-delay: 0.2s;
}

.js-fadeInLeft.show {
  opacity: 1;
  transform: translateX(0);
}

.horizontal-table__inner {
  width: 100%;
  border-top: 1px solid var(--color-navy2);
  line-height: 1.75;
  letter-spacing: 0.1em;
}

.horizontal-table__row {
  border-bottom: 1px solid var(--color-navy2);
}

@media screen and (max-width: 1260px) {
  .horizontal-table__row {
    font-size: 1.3vw;
  }
}

@media screen and (max-width: 768px) {
  .horizontal-table__row {
    font-size: 3.6vw;
  }
}

.horizontal-table__head {
  width: 220px;
  padding: 1em 0;
}

.horizontal-table__text {
  padding: 1em 0;
  word-break: break-word;
  vertical-align: top;
}

.horizontal-table__placeholder {
  margin-top: 0.5em;
  font-size: 75%;
}

.confirm .horizontal-table__placeholder,
.entry-confirm .horizontal-table__placeholder {
  display: none;
}

.horizontal-table__placeholder:before {
  content: "例：";
}

.horizontal-table--contact .horizontal-table__head {
  width: 250px;
  padding: 1em 4em 0.75em 1em;
}

.horizontal-table--contact .horizontal-table__head:after {
  display: inline-block;
  padding: 0.25em 0.5em;
  border-radius: 3px;
  color: var(--color-white);
  font-size: 75%;
}

.horizontal-table--contact .horizontal-table__head--require,
.horizontal-table--contact .horizontal-table__head--optional {
  position: relative;
}

.horizontal-table--contact .horizontal-table__head--require:after,
.horizontal-table--contact .horizontal-table__head--optional:after {
  position: absolute;
  top: 1.5em;
  right: 1em;
}

.horizontal-table--contact .horizontal-table__head--require:after {
  background-color: var(--color-red);
  content: "必須";
}

.horizontal-table--contact .horizontal-table__head--optional:after {
  background-color: var(--color-main);
  content: "任意";
}

@media screen and (max-width: 768px) {
  .horizontal-table--sm-scroll {
    padding-bottom: 5vw;
    overflow-x: auto;
  }
  .horizontal-table--sm-vertical .horizontal-table__head {
    display: list-item;
    list-style: none;
    width: 100%;
    padding: 0.75em 0 0.25em;
    font-weight: bold;
    font-size: 3.6vw;
  }
  .horizontal-table--sm-vertical .horizontal-table__text {
    display: list-item;
    list-style: none;
    width: 100%;
    padding: 0.25em 0 0.75em;
    font-size: 3.3vw;
  }
  .horizontal-table--sm-vertical--contact .horizontal-table__head {
    width: 100%;
    padding: 1em 1em 0.5em;
  }
}

@media screen and (max-width: 575px) {
  .horizontal-table--xs-scroll {
    padding-bottom: 5vw;
    overflow-x: auto;
  }
  .horizontal-table--xs-vertical .horizontal-table__head {
    display: list-item;
    list-style: none;
    width: 100%;
    padding: 1em 1em 0.5em;
    font-weight: bold;
  }
  .horizontal-table--xs-vertical .horizontal-table__text {
    display: list-item;
    list-style: none;
    width: 100%;
    padding: 0.5em 1em 1em;
  }
  .horizontal-table--xs-vertical--contact .horizontal-table__head {
    width: 100%;
    padding: 1em 1em 0.5em;
  }
}

.vertical-table__inner {
  width: 100%;
  line-height: 1.75;
  letter-spacing: 0.1em;
}

.vertical-table__row {
  border-bottom: 1px solid var(--color-navy2);
}

.vertical-table__head {
  display: list-item;
  list-style: none;
  padding: 1em 0;
}

.vertical-table__text {
  display: list-item;
  list-style: none;
  padding: 1em 0;
  vertical-align: top;
}

.vertical-table__job {
  font-weight: bold;
  font-size: 125%;
}

.vertical-table__placeholder {
  margin-top: 0.5em;
  font-size: 75%;
}

.confirm .vertical-table__placeholder,
.entry-confirm .vertical-table__placeholder {
  display: none;
}

.vertical-table__placeholder:before {
  content: "例：";
}

.vertical-table--contact .vertical-table__head {
  padding: 2em 0 0.75em 0;
}

.vertical-table--contact .vertical-table__head:after {
  display: inline-block;
  padding: 0.25em 0.75em;
  color: var(--color-main);
  font-size: 75%;
}

.vertical-table--contact .vertical-table__head--require,
.vertical-table--contact .vertical-table__head--optional {
  position: relative;
}

.vertical-table--contact .vertical-table__head--require:after,
.vertical-table--contact .vertical-table__head--optional:after {
  margin-left: 2em;
}

.vertical-table--contact .vertical-table__head--require:after {
  background-color: var(--color-sub);
  content: "必須";
}

.vertical-table--contact .vertical-table__head--optional:after {
  background-color: var(--color-gray2);
  content: "任意";
}

.vertical-table--contact .vertical-table__text {
  padding: 0.75em 0 2em 0;
}

@media screen and (max-width: 768px) {
  .vertical-table--sm-scroll {
    padding-bottom: 5vw;
    overflow-x: auto;
  }
}

@media screen and (max-width: 575px) {
  .vertical-table--xs-scroll {
    padding-bottom: 5vw;
    overflow-x: auto;
  }
}

/*　ふわっと　*/
[data-animation="fluffy"] {
  animation: fluffy ease-in-out 2s infinite alternate;
}

@keyframes fluffy {
  0% {
    transform: translate(0%, 0%);
  }
  100% {
    transform: translate(0%, -30px);
  }
}

/*　ジャンプ　*/
[data-animation="jump"] {
  animation: jump 5s infinite;
}

@keyframes jump {
  0% {
    transform: translate(0, 0px);
  }
  3% {
    transform: translate(0, -20px);
  }
  5% {
    transform: translate(0, 0px);
  }
  6% {
    transform: translate(0, -5px);
  }
  7% {
    transform: translate(0, 0px);
  }
  100% {
    transform: translate(0, 0px);
  }
}

/*　振り子　*/
[data-animation="pendulum"] {
  animation: pendulum ease-in-out 3s infinite alternate;

  transform-origin: top;
}

@keyframes pendulum {
  0% {
    transform: rotate(10deg);
  }
  100% {
    transform: rotate(-10deg);
  }
}

/*　バウンド　*/
[data-animation="bound"] {
  animation: bound 0.6s alternate infinite;
}

@keyframes bound {
  0% {
    transform: translate(0%, 0%) rotateX(25deg);
  }
  100% {
    transform: translate(0%, -60px);
  }
}

.cta-title {
  margin-bottom: 1.5em;
  padding: 0.5em 1.5em;
  border: 1px solid var(--color-black);
  border-radius: 20px;
  font-size: 3.2rem;
  line-height: 1.5;
  font-family: var(--font-mincho);
  letter-spacing: 0.1em;
  text-align: center;
  text-indent: 0.1em;
}

@media screen and (max-width: 1260px) {
  .cta-title {
    border-radius: 1.46413vw;
    font-size: 2.34261vw;
  }
}

@media screen and (max-width: 768px) {
  .cta-title {
    font-size: 4.5vw;
  }
}

.cta-list {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: 0 2em;
  font-size: 2.4rem;
  line-height: calc(40 / 24);
}

@media screen and (max-width: 1260px) {
  .cta-list {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .cta-list {
    font-size: 4vw;
  }
}

.cta-list + p {
  margin-top: 1em;
}

@media screen and (max-width: 768px) {
  .cta-list + p {
    text-align: center;
  }
}

.faq-wrap {
  max-width: 103rem;
  margin-right: auto;
  margin-left: auto;
  padding: min(5rem, 2.5vw) min(7rem, 5vw) min(7rem, 5vw);
  border: 1px solid var(--color-blue);
  border-radius: min(2.6rem, 5vw);
  box-shadow: 4px 4px 6px rgba(0, 153, 217, 0.2);
  background-color: var(--color-white);
}

.faq-box {
  border-bottom: 1px solid var(--color-blue);
}

.faq-box__q,
.faq-box__a {
  position: relative;
}

.faq-box__q::before,
.faq-box__a::before {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  left: 3.2rem;
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  color: var(--color-white);
  font-weight: bold;
  font-family: var(--font-montserrat);
}

@media screen and (max-width: 1366px) {
  .faq-box__q::before,
  .faq-box__a::before {
    left: 2.34261vw;
    width: 2.92826vw;
    height: 2.92826vw;
    font-size: 2.19619vw;
  }
}

@media screen and (max-width: 768px) {
  .faq-box__q::before,
  .faq-box__a::before {
    left: 2.08333vw;
    width: 5.20833vw;
    height: 5.20833vw;
    font-size: 3.90625vw;
  }
}

.faq-box__q {
  padding-top: 2em;
  padding-right: 10rem;
  padding-bottom: 2em;
  padding-left: 10rem;
  font-weight: bold;
  font-size: 1.8rem;
  line-height: calc(29 / 16);
  cursor: pointer;
}

@media screen and (max-width: 1366px) {
  .faq-box__q {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .faq-box__q {
    padding-top: 1em;
    padding-right: 6vw;
    padding-bottom: 1em;
    padding-left: 9vw;
    font-size: 3.51563vw;
  }
}

.faq-box__q::before {
  top: 1em;
  background-color: var(--color-blue);
  font-size: 2.5rem;
  content: "Q";
}

@media screen and (max-width: 1366px) {
  .faq-box__q::before {
    font-size: 1.83016vw;
  }
}

@media screen and (max-width: 768px) {
  .faq-box__q::before {
    font-size: 3.25521vw;
  }
}

.faq-box__q::after {
  position: absolute;
  top: 1.5em;
  right: 1.5em;
  color: var(--color-blue);
  font-size: 1.5em;
  line-height: 1;
  content: "";
}

@media screen and (max-width: 768px) {
  .faq-box__q::after {
    top: 0.75em;
    right: 0;
  }
}

.faq-box[data-active="true"] .faq-box__q::after {
  content: "―";
}

.faq-box[data-active="false"] .faq-box__q::after {
  content: "＋";
}

.faq-box__a {
  max-height: 50rem;
  padding-top: 1.5em;
  padding-right: 10rem;
  padding-bottom: 2em;
  padding-left: 10rem;
  background-color: var(--color-pale-blue);
  line-height: calc(29 / 16);
  transition: 0.15s;
}

@media screen and (max-width: 768px) {
  .faq-box__a {
    padding-right: 6vw;
    padding-left: 9vw;
  }
}

.faq-box[data-active="true"] .faq-box__a {
  height: auto;
  overflow: auto;
}

.faq-box[data-active="false"] .faq-box__a {
  height: 0;
  padding-top: 0;
  padding-bottom: 0;
  overflow: hidden;
}

.faq-box__a::before {
  top: 0.75em;
  background-image: linear-gradient(to right, #0099d9 0, #00a73c 100%);
  font-size: 3rem;
  content: "A";
}

@media screen and (max-width: 1366px) {
  .faq-box__a::before {
    font-size: 2.19619vw;
  }
}

@media screen and (max-width: 768px) {
  .faq-box__a::before {
    font-size: 3.90625vw;
  }
}

.icons {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: 1.2rem;
}

@media screen and (max-width: 1366px) {
  .icons {
    gap: 0.87848vw;
  }
}

@media screen and (max-width: 768px) {
  .icons {
    gap: 1.5625vw;
  }
}

.section--air-eco-top .icons {
  gap: 2rem;
}

@media screen and (max-width: 1366px) {
  .section--air-eco-top .icons {
    gap: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  .section--air-eco-top .icons {
    gap: 2.60417vw;
  }
}

section .icons {
  margin-bottom: 3em;
}

@media screen and (max-width: 1366px) {
  .icons__item {
    width: 8.19912vw;
  }
}

@media screen and (max-width: 768px) {
  .icons__item {
    width: 15.88542vw;
  }
}

@media screen and (max-width: 1366px) {
  .section--air-eco-top .icons__item {
    width: 11.71303vw;
  }
}

@media screen and (max-width: 768px) {
  .section--air-eco-top .icons__item {
    width: 20.83333vw;
  }
}

@media screen and (max-width: 1366px) {
  .icons__img {
    max-width: 100%;
    height: auto;
  }
}

.electric-section {
  position: relative;
  margin-bottom: 13rem;
  padding: 3rem;
  border-radius: 2rem;
  box-shadow: 4px 4px 6px rgba(0, 153, 217, 0.2);
  background-color: var(--color-white);
}

@media screen and (max-width: 1366px) {
  .electric-section {
    margin-bottom: 9.51684vw;
    padding: 2.19619vw;
    border-radius: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  .electric-section {
    margin-bottom: 22.13542vw;
    padding: 7.5vw 5vw;
    border-radius: 3.90625vw;
  }
}

.electric-section::after {
  display: block;
  clip-path: polygon(0% 0%, 100% 0, 100% 60%, 50% 100%, 0 60%);
  position: absolute;
  top: 100%;
  right: 0;
  left: 0;
  width: fit-content;
  margin: auto;
  padding: 1em 2em 2.5em;
  background-image: linear-gradient(to bottom, #0099d9 0, #00a73c 100%);
  color: var(--color-white);
  font-weight: bold;
  font-size: 2.4rem;
  text-align: center;
  content: "現状電気代から…";
}

@media screen and (max-width: 1366px) {
  .electric-section::after {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .electric-section::after {
    font-size: 3.90625vw;
  }
}

.electric-header {
  display: flex;
  justify-content: center;
  align-items: baseline;
  gap: 1em;
  margin-bottom: 1.5em;
}

.electric-header li {
  font-size: calc(12 / 16 * 100%);
}

.electric-head {
  color: var(--color-blue);
  font-weight: bold;
  font-size: 2.4rem;
}

@media screen and (max-width: 1366px) {
  .electric-head {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .electric-head {
    font-size: 3.90625vw;
  }
}

.electric-wrap {
  display: flex;
  justify-content: center;
  gap: 3em;
}

@media screen and (max-width: 768px) {
  .electric-wrap {
    flex-direction: column;
    gap: 1em;
  }
}

.electric-box {
  display: flex;
  justify-content: center;
  align-items: baseline;
  font-size: 2rem;
}

@media screen and (max-width: 1366px) {
  .electric-box {
    font-size: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  .electric-box {
    justify-content: space-between;
    font-size: 3.125vw;
  }
}

.electric-box dt::before {
  color: var(--color-blue);
  content: "■";
}

.electric-box dt::after {
  content: "…";
}

.electric-box dd {
  color: var(--color-blue);
  font-weight: bold;
  font-size: calc(30 / 20 * 100%);
  font-family: var(--font-montserrat);
}

.performance-catch {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  margin-bottom: 2em;
  font-size: 2.4rem;
}

@media screen and (max-width: 1366px) {
  .performance-catch {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .performance-catch {
    gap: 1em;
    font-size: 4vw;
  }
}

.performance-catch__text {
  font-weight: bold;
  text-align: center;
  vertical-align: baseline;
}

.performance-catch__text--m {
  background-image: linear-gradient(to bottom, transparent 0, transparent 70%, var(--color-yellow) 70%, var(--color-yellow) 100%);
  font-size: calc(32 / 24 * 100%);
}

@media screen and (max-width: 768px) {
  .performance-catch__text--m {
    background-image: linear-gradient(
      to bottom,
      transparent 0,
      transparent 35%,
      var(--color-yellow) 35%,
      var(--color-yellow) 50%,
      transparent 50%,
      transparent 85%,
      var(--color-yellow) 85%,
      var(--color-yellow) 100%
    );
    font-size: calc(40 / 24 * 100%);
    line-height: 1.25;
  }
}

.performance-catch__text--m::before,
.performance-catch__text--m::after {
  position: absolute;
  margin: 0;
}

.performance-catch__text--m::before {
  left: -1em;
  margin-right: 0 !important;
}

.performance-catch__text--m::after {
  right: -1em;
  margin-left: 0 !important;
}

.performance-catch__text--m > span {
  font-weight: bold;
  font-size: calc(42 / 32 * 100%);
  font-family: var(--font-montserrat);
  vertical-align: baseline;
}

.performance-realize {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 3em;
}

.performance-realize__text {
  margin-bottom: 1em;
  padding-bottom: 0.25em;
  background-image: linear-gradient(to bottom, transparent 0, transparent 70%, var(--color-yellow) 70%, var(--color-yellow) 100%);
  font-size: 1.8rem;
}

@media screen and (max-width: 1366px) {
  .performance-realize__text {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .performance-realize__text {
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    align-items: baseline;
    width: 75%;
    background-image: linear-gradient(
      to bottom,
      transparent 0,
      transparent 50%,
      var(--color-yellow) 50%,
      var(--color-yellow) 70%,
      transparent 70%,
      transparent 100%
    );
    font-size: 3.125vw;
    line-height: 1.25;
    letter-spacing: 0.05em;
  }
}

@media screen and (max-width: 768px) {
  .performance-realize__text__1 {
    width: 100%;
    text-align: center;
  }
}

.performance-realize__text__2 {
  font-size: calc(32 / 18 * 100%);
}

@media screen and (max-width: 768px) {
  .performance-realize__text__2--2 {
    width: 100%;
    text-align: center;
  }
}

.performance-realize__text__3 {
  font-size: calc(72 / 18 * 100%);
  font-family: var(--font-montserrat);
}

.performance-realize__text__3 span {
  font-size: calc(50 / 72 * 100%);
}

.performance-realize__text__4 {
  font-size: calc(42 / 18 * 100%);
}

.performance-realize__text span {
  font-weight: bold;
}

.performance-realize__caution {
  font-size: 1.2rem;
  line-height: calc(18 / 12);
}

@media screen and (max-width: 1366px) {
  .performance-realize__caution {
    font-size: 0.87848vw;
  }
}

@media screen and (max-width: 768px) {
  .performance-realize__caution {
    font-size: 2.34375vw;
  }
}

.performance-wrap {
  padding: 6rem;
  border-bottom: 1px solid rgba(0, 153, 217, 0.2);
  border-radius: 2rem;
  box-shadow: 4px 4px 6px rgba(0, 153, 217, 0.2);
  background-color: var(--color-white);
}

@media screen and (max-width: 1366px) {
  .performance-wrap {
    padding: 4.39239vw;
    border-radius: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  .performance-wrap {
    padding: 5vw;
    border-radius: 2.60417vw;
  }
}

.performance-box {
  padding-top: 6rem;
  padding-bottom: 6rem;
}

@media screen and (max-width: 1366px) {
  .performance-box {
    padding-top: 4.39239vw;
    padding-bottom: 4.39239vw;
  }
}

@media screen and (max-width: 768px) {
  .performance-box {
    padding-top: 7.8125vw;
    padding-bottom: 7.8125vw;
  }
}

.performance-box:first-child {
  padding-top: 0;
}

.performance-box:last-child {
  padding-bottom: 0;
}

.performance-box:not(:last-child) {
  border-bottom: 1px solid rgba(0, 153, 217, 0.2);
}

.performance-box__header {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
}

@media screen and (max-width: 768px) {
  .performance-box__header {
    flex-direction: column;
    align-items: normal;
  }
}

.performance-box__head {
  display: flex;
  align-items: center;
  gap: 1em;
  margin-bottom: 2em;
}

@media screen and (max-width: 768px) {
  .performance-box__head {
    margin-bottom: 1em;
  }
}

.performance-box__example {
  display: flex;
  align-items: center;
  gap: 0.5em;
  padding: 0.35em 1.5em;
  border: 2px solid var(--color-blue);
  border-radius: 8.5em;
  color: var(--color-blue);
  font-weight: bold;
  font-size: 1.8rem;
}

@media screen and (max-width: 1366px) {
  .performance-box__example {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .performance-box__example {
    font-size: 2.60417vw;
  }
}

.performance-box__example span {
  font-weight: bold;
  font-size: calc(30 / 18 * 100%);
  font-family: var(--font-montserrat);
}

.performance-box__title {
  font-weight: bold;
  font-size: 1.8rem;
}

@media screen and (max-width: 1366px) {
  .performance-box__title {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .performance-box__title {
    font-size: 3.51563vw;
  }
}

.performance-box__wrap {
  display: flex;
  flex-flow: row-reverse wrap;
  justify-content: space-between;
  gap: calc((113rem - 55.4rem * 2));
}

@media screen and (max-width: 768px) {
  .performance-box__wrap {
    flex-direction: column;
    gap: 5vw;
  }
}

.performance-box__contents {
  flex: 1;
}

.performance-box__days {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0 1em;
  width: 100%;
  margin-bottom: 1em;
  padding-top: 0.25em;
  padding-bottom: 0.25em;
  background-color: #0099d9;
  color: var(--color-white);
  font-size: 1.8rem;
  line-height: 1.5;
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .performance-box__days {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .performance-box__days {
    font-size: 3.6vw;
  }
}

.performance-box__days span {
  font-weight: bold;
}

.performance-box__caution {
  font-size: 1.2rem;
  line-height: calc(18 / 12);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .performance-box__caution {
    font-size: 0.87848vw;
  }
}

@media screen and (max-width: 768px) {
  .performance-box__caution {
    font-size: 2.34375vw;
  }
}

.performance-box__rate {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 2em;
  margin-bottom: 2em;
}

@media screen and (max-width: 768px) {
  .performance-box__rate {
    margin-left: auto;
  }
}

.performance-box__percent {
  padding-bottom: 0.1em;
  background-image: linear-gradient(to bottom, transparent 0, transparent 60%, var(--color-yellow) 60%, var(--color-yellow) 100%);
  color: var(--color-orange);
  font-size: 4.5rem;
}

@media screen and (max-width: 1366px) {
  .performance-box__percent {
    font-size: 3.29429vw;
  }
}

@media screen and (max-width: 768px) {
  .performance-box__percent {
    font-size: 5.85938vw;
  }
}

.performance-box__percent span {
  font-weight: bold;
  font-family: var(--font-montserrat);
}

.performance-box__percent > span {
  font-size: calc(52 / 35 * 100%);
}

.performance-box__percent > span > span {
  font-size: calc(40 / 52 * 100%);
}

.performance-box__kwh {
  font-size: 2.4rem;
  line-height: calc(40 / 24);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .performance-box__kwh {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .performance-box__kwh {
    font-size: 3.125vw;
  }
}

.performance-box__kwh li {
  font-weight: bold;
}

.performance-box__img {
  flex: 1;
  align-self: flex-start;
  width: fit-content;
  max-width: 100%;
  height: auto;
}

@media screen and (max-width: 1366px) {
  .performance-box__img {
    width: 39.53148vw;
  }
}

@media screen and (max-width: 768px) {
  .performance-box__img {
    width: 100%;
  }
}

.performance-box__graph {
  width: 100%;
  height: auto;
}

.performance-caution {
  margin-top: 4em;
  line-height: calc(29 / 16);
}

@media screen and (max-width: 1366px) {
  .performance-caution {
    font-size: 1.1713vw;
  }
}

@media screen and (max-width: 768px) {
  .performance-caution {
    font-size: 2.08333vw;
  }
}

.mechanism-patent {
  position: relative;
  margin-bottom: 11rem;
  padding-left: 21.7rem;
  font-size: 2.4rem;
}

@media screen and (max-width: 1366px) {
  .mechanism-patent {
    margin-bottom: 8.05271vw;
    padding-left: 15.8858vw;
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .mechanism-patent {
    margin-bottom: 14.32292vw;
    padding-left: 0;
    font-size: 3.125vw;
  }
}

.mechanism-patent::before {
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  width: 18.8rem;
  height: 15.8rem;
  margin: auto;
  background: url(../images/patent-label.svg) no-repeat center center/contain;
  content: "";
}

@media screen and (max-width: 1366px) {
  .mechanism-patent::before {
    width: 13.76281vw;
    height: 11.56662vw;
  }
}

@media screen and (max-width: 768px) {
  .mechanism-patent::before {
    display: block;
    position: relative;
    right: 0;
    width: 24.47917vw;
    height: 20.57292vw;
    margin-right: auto;
    margin-bottom: 1em;
    margin-left: auto;
  }
}

.mechanism-patent__head {
  margin-bottom: 0.5em;
  color: var(--color-blue);
  font-weight: bold;
  font-size: calc(28 / 24 * 100%);
}

@media screen and (max-width: 768px) {
  .mechanism-patent__head {
    text-align: center;
  }
}

.mechanism-patent__head::before {
  display: inline-block;
  margin-right: 0.5em;
  padding-right: 0.5em;
  padding-left: 0.5em;
  border: 2px solid var(--color-orange);
  border-radius: 0.75em;
  color: var(--color-orange);
  font-style: italic;
  line-height: 1.5;
  font-family: var(--font-montserrat);
  content: "NEW";
}

.mechanism-patent__text {
  font-weight: bold;
  line-height: calc(40 / 24);
}

.mechanism-patent__text span {
  font-weight: bold;
}

.mechanism-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 9rem;
}

@media screen and (max-width: 1366px) {
  .mechanism-wrap {
    gap: 6.58858vw;
  }
}

@media screen and (max-width: 768px) {
  .mechanism-wrap {
    gap: 5vw;
  }
}

.mechanism-box {
  position: relative;
  width: 103rem;
  margin-top: 4rem;
  padding: 8.5rem 11rem 7rem;
  border-radius: 2rem;
  box-shadow: 4px 4px 6px rgba(0, 153, 217, 0.2);
  background-color: #ebf8ff;
}

@media screen and (max-width: 1366px) {
  .mechanism-box {
    width: 75.40264vw;
    margin-top: 2.92826vw;
    padding: 6.22255vw 8.05271vw 5.12445vw;
    border-radius: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  .mechanism-box {
    width: 100%;
    margin-top: 5.20833vw;
    padding: 9vw 5vw 5vw;
    border-radius: 2.60417vw;
  }
}

.mechanism-box__head {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.75em;
  position: absolute;
  top: -4rem;
  right: 0;
  left: 0;
  width: 48rem;
  height: 8rem;
  margin: auto;
  border-radius: 4rem;
  background-image: linear-gradient(to right, #0099d9 0, #00a73c 100%);
  color: var(--color-white);
  font-weight: bold;
  font-size: 2.8rem;
}

@media screen and (max-width: 1366px) {
  .mechanism-box__head {
    top: -2.92826vw;
    width: 35.13909vw;
    height: 5.85652vw;
    border-radius: 2.92826vw;
    font-size: 2.04978vw;
  }
}

@media screen and (max-width: 768px) {
  .mechanism-box__head {
    top: -5.20833vw;
    width: 80%;
    height: 10.41667vw;
    border-radius: 5.20833vw;
    font-size: 4.55729vw;
  }
}

.mechanism-box__title {
  display: flex;
  align-items: center;
  gap: 0.25em;
  font-size: 2.8rem;
}

@media screen and (max-width: 1366px) {
  .mechanism-box__title {
    font-size: 2.04978vw;
  }
}

@media screen and (max-width: 768px) {
  .mechanism-box__title {
    font-size: 4.55729vw;
  }
}

.mechanism-box__title span {
  padding-top: 0.25em;
  padding-bottom: 0.25em;
  border-bottom: 2px solid var(--color-white);
  font-weight: bold;
  font-size: calc(18 / 28 * 100%);
}

.mechanism-box__title[data-num]::after {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  background-color: var(--color-white);
  color: var(--color-blue);
  font-weight: bold;
  font-size: calc(30 / 28 * 100%);
  font-family: var(--font-montserrat);
  content: attr(data-num);
}

@media screen and (max-width: 1366px) {
  .mechanism-box__title[data-num]::after {
    width: 2.92826vw;
    height: 2.92826vw;
  }
}

@media screen and (max-width: 768px) {
  .mechanism-box__title[data-num]::after {
    width: 6.51042vw;
    height: 6.51042vw;
  }
}

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

.mechanism-box__content {
  display: flex;
  flex-direction: column;
  gap: 4.5rem;
}

@media screen and (max-width: 1366px) {
  .mechanism-box__content {
    gap: 3.29429vw;
  }
}

@media screen and (max-width: 768px) {
  .mechanism-box__content {
    gap: 5.85938vw;
  }
}

.mechanism-box__top {
  font-weight: 500;
  font-size: 1.8rem;
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .mechanism-box__top {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .mechanism-box__top {
    font-size: 3.51563vw;
    line-height: 1.75;
  }
}

.mechanism-box__inner--1 {
  padding: 1.5em;
  background-color: var(--color-white);
}

.mechanism-box__inner--1 figure {
  display: flex;
  flex-direction: column;
  gap: 1em;
}

.mechanism-box__inner--1 figure img {
  display: block;
  max-width: 100%;
  height: auto;
  margin-right: auto;
  margin-left: auto;
}

.mechanism-box__inner--2 {
  display: flex;
  gap: 3em;
}

@media screen and (max-width: 768px) {
  .mechanism-box__inner--2 {
    flex-direction: column;
    align-items: center;
    gap: 1em;
  }
}

.mechanism-box__inner--2 p {
  line-height: calc(29 / 16 * 100%);
}

.mechanism-box__inner--2 figcaption {
  margin-top: 0.75em;
  text-align: center;
}

.mechanism-box__inner figcaption {
  color: var(--color-blue);
  font-weight: 500;
}

.mechanism-box__flow {
  display: block;
  margin-right: auto;
  margin-left: auto;
}

@media screen and (max-width: 1366px) {
  .mechanism-box__flow {
    width: auto;
    height: 8.34553vw;
  }
}

@media screen and (max-width: 768px) {
  .mechanism-box__flow {
    max-width: 100%;
    height: 11.71875vw;
  }
}

.model-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: calc((1250px - (384px * 3)) / 2);
  margin-bottom: 5rem;
}

@media screen and (max-width: 1366px) {
  .model-wrap {
    margin-bottom: 3.66032vw;
  }
}

@media screen and (max-width: 768px) {
  .model-wrap {
    flex-direction: column;
    align-items: center;
    gap: 5vw;
    margin-bottom: 6.51042vw;
  }
}

.model-box {
  width: 38.4rem;
  overflow: hidden;
  border-radius: 2rem;
  box-shadow: 4px 4px 6px rgba(0, 153, 217, 0.2);
  background-color: var(--color-white);
}

@media screen and (max-width: 1366px) {
  .model-box {
    width: 28.11127vw;
    border-radius: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  .model-box {
    width: 100%;
    border-radius: 2.60417vw;
  }
}

.model-box__head {
  padding: 1em;
  background-image: linear-gradient(to right, #0099d9 0, #00a73c 100%);
  color: var(--color-white);
  font-weight: bold;
  font-size: 1.8rem;
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .model-box__head {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .model-box__head {
    font-size: 3.51563vw;
  }
}

.model-box__content {
  padding: 4rem;
}

@media screen and (max-width: 1366px) {
  .model-box__content {
    padding: 2.92826vw;
  }
}

@media screen and (max-width: 768px) {
  .model-box__content {
    padding: 5.20833vw;
  }
}

.model-box__img {
  display: block;
  max-width: 100%;
  height: auto;
  margin-right: auto;
  margin-bottom: 1em;
  margin-left: auto;
}

@media screen and (max-width: 768px) {
  .model-box__img {
    object-fit: contain;
    max-height: 30vw;
  }
}

.model-box__text {
  font-weight: 500;
  line-height: calc(29 / 16);
}

.model-box__caution {
  margin-top: 0.5em;
  font-weight: 500;
  font-size: calc(12 / 16 * 100%);
  line-height: calc(29 / 16);
}

.method-list {
  margin-bottom: 2em;
  font-size: 1.8rem;
  line-height: calc(36 / 18);
}

@media screen and (max-width: 1366px) {
  .method-list {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .method-list {
    font-size: 2.34375vw;
  }
}

.method-list > li {
  font-weight: 500;
}

.maintenance-wrap {
  display: flex;
  justify-content: center;
  gap: 5em;
}

@media screen and (max-width: 768px) {
  .maintenance-wrap {
    flex-direction: column;
    align-items: center;
    gap: 5vw;
  }
}

.maintenance-caution {
  margin-top: 1em;
  font-size: 1.2rem;
  line-height: calc(18 / 12);
}

@media screen and (max-width: 1366px) {
  .maintenance-caution {
    font-size: 0.87848vw;
  }
}

@media screen and (max-width: 768px) {
  .maintenance-caution {
    font-size: 2.34375vw;
  }
}

@media screen and (max-width: 1366px) {
  .maintenance-img {
    width: 10.83455vw;
    height: auto;
  }
}

@media screen and (max-width: 768px) {
  .maintenance-img {
    width: 39.0625vw;
    max-width: 14.8rem;
  }
}

.sales-type-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 2em;
  margin-bottom: 7rem;
}

@media screen and (max-width: 1366px) {
  .sales-type-wrap {
    justify-content: center;
    margin-bottom: 5.12445vw;
  }
}

@media screen and (max-width: 768px) {
  .sales-type-wrap {
    margin-bottom: 9.11458vw;
  }
}

.sales-type-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 38.4rem;
}

@media screen and (max-width: 1366px) {
  .sales-type-box {
    width: 28.11127vw;
  }
}

@media screen and (max-width: 768px) {
  .sales-type-box {
    gap: 5vw;
    width: 41vw;
  }
}

.sales-type-box__head {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 7rem;
  margin-bottom: 0.5em;
  border-radius: 3.5rem;
  background-image: linear-gradient(to right, #0099d9 0, #00a73c 100%);
  color: var(--color-white);
  font-weight: bold;
  font-size: 3.2rem;
  font-family: var(--font-montserrat);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .sales-type-box__head {
    height: 5.12445vw;
    border-radius: 2.56223vw;
    font-size: 2.34261vw;
  }
}

@media screen and (max-width: 768px) {
  .sales-type-box__head {
    height: 7vw;
    border-radius: 3.5vw;
    font-size: 3.5vw;
  }
}

.sales-type-box__img {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 26rem;
}

@media screen and (max-width: 1366px) {
  .sales-type-box__img {
    height: 19.03367vw;
  }
}

@media screen and (max-width: 768px) {
  .sales-type-box__img {
    height: 26vw;
  }
}

.sales-type-box__img img {
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: 100%;
}

.sales-type-box__text {
  width: 100%;
  border-bottom: 4px solid var(--color-blue);
  font-weight: bold;
  font-size: 3.2rem;
  line-height: calc(58 / 32);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .sales-type-box__text {
    font-size: 2.34261vw;
  }
}

@media screen and (max-width: 768px) {
  .sales-type-box__text {
    font-size: 3.5vw;
  }
}

.sales-type-caution {
  line-height: calc(29 / 16);
}

@media screen and (max-width: 1366px) {
  .sales-type-caution {
    font-size: 1.1713vw;
  }
}

@media screen and (max-width: 768px) {
  .sales-type-caution {
    font-size: 2.08333vw;
  }
}

.caution-box {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: fit-content;
  border: 1px solid var(--color-orange);
  background-color: var(--color-white);
}

@media screen and (max-width: 768px) {
  .caution-box {
    flex-direction: column;
    align-items: flex-start;
    border: none;
    background-color: transparent;
  }
}

.caution-box__head {
  padding-right: 1em;
  padding-left: 1em;
  background-color: var(--color-orange);
  color: var(--color-white);
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 2;
}

@media screen and (max-width: 1366px) {
  .caution-box__head {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .caution-box__head {
    font-size: 3.2vw;
    line-height: 1.75;
  }
}

.caution-box__text {
  display: inline-block;
  padding-right: 1em;
  padding-left: 1em;
  line-height: 2;
}

@media screen and (max-width: 768px) {
  .caution-box__text {
    padding-top: 0.75em;
    padding-bottom: 0.75em;
    border: 1px solid var(--color-orange);
    background-color: var(--color-white);
    line-height: 1.75;
  }
}

.gx .main {
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), rgba(0, 118, 185, 0.12) calc(100% - 1px)),
    linear-gradient(90deg, transparent calc(100% - 1px), rgba(0, 118, 185, 0.12) calc(100% - 1px));
  background-position: center center;
  background-size: 40px 40px;
  background-repeat: repeat;
}

@media screen and (max-width: 768px) {
  .gx .main {
    background-size: 5vw 5vw;
  }
}

.section--index {
  display: flex;
  position: relative;
  max-width: 100%;
}

@media screen and (max-width: 768px) {
  .section--index {
    flex-direction: column-reverse;
    gap: 5vw;
    padding-top: 0 !important;
  }
}

.section--index--reverse {
  flex-flow: row-reverse nowrap;
}

@media screen and (max-width: 768px) {
  .section--index--reverse {
    flex-direction: column-reverse;
  }
}

.slash {
  position: relative;
}

.slash::before,
.slash::after {
  display: inline-block;
  position: relative;
  width: 2px;
  height: 1.5em;
  background-color: var(--color-text);
  content: "";
}

@media screen and (max-width: 768px) {
  .slash::before,
  .slash::after {
    display: block;
    position: absolute;
    bottom: 0;
  }
}

.slash::before {
  transform: rotate(-30deg) translateY(15%);
  margin-right: 0.5em;

  transform-origin: right bottom;
}

@media screen and (max-width: 768px) {
  .slash::before {
    left: -1em;
  }
}

.slash::after {
  transform: rotate(30deg) translateY(15%);
  margin-left: 0.5em;

  transform-origin: left bottom;
}

@media screen and (max-width: 768px) {
  .slash::after {
    right: -1em;
  }
}

.top-catch {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  font-size: 4.2rem;
}

@media screen and (max-width: 1366px) {
  .top-catch {
    font-size: 3.07467vw;
  }
}

@media screen and (max-width: 768px) {
  .top-catch {
    font-size: 6vw;
  }
}

.top-catch__text {
  font-weight: bold;
  line-height: 1.5;
  text-align: center;
}

.top-catch__text--s {
  display: flex;
  font-size: calc(28 / 42 * 100%);
}

@media screen and (max-width: 768px) {
  .top-catch__text--s {
    flex-direction: column;
    align-items: center;
    margin-bottom: 0.5em;
  }
}

.top-catch__text--s > span:first-child::after {
  display: inline-block;
  width: 1em;
  height: 1em;
  margin: 0 0.25em;
  border-radius: 50%;
  background-color: var(--color-orange);
  color: var(--color-white);
  line-height: 1;
  font-family: var(--font-montserrat);
  text-align: center;
  content: "&";
}

@media screen and (max-width: 768px) {
  .top-catch__text--s > span:first-child::after {
    display: block;
    margin: 0 auto;
  }
}

.top-catch__text span {
  font-weight: bold;
}

.index-box {
  width: 60rem;
}

@media screen and (max-width: 1366px) {
  .index-box {
    width: 43.92387vw;
  }
}

@media screen and (max-width: 768px) {
  .index-box {
    width: 100%;
  }
}

.index-box__list {
  display: flex;
  gap: 1em;
  margin-bottom: 2em;
}

.index-box__item {
  padding: 0.5em 1em;
  border-radius: 1em;
  color: var(--color-white);
  font-weight: bold;
}

.index-box__list--air-eco .index-box__item {
  background-image: linear-gradient(to bottom, var(--color-orange) 0, var(--color-pale-orange) 100%);
  font-size: 3.2rem;
}

@media screen and (max-width: 1366px) {
  .index-box__list--air-eco .index-box__item {
    font-size: 2.34261vw;
  }
}

@media screen and (max-width: 768px) {
  .index-box__list--air-eco .index-box__item {
    font-size: 4.16667vw;
  }
}

.index-box__list--r-optimizer .index-box__item {
  background-color: var(--color-blue);
  font-size: 2.4rem;
}

@media screen and (max-width: 1366px) {
  .index-box__list--r-optimizer .index-box__item {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .index-box__list--r-optimizer .index-box__item {
    font-size: 3.125vw;
  }
}

.index-box__head {
  margin-bottom: 1em;
  font-weight: bold;
  font-size: 2.4rem;
}

@media screen and (max-width: 1366px) {
  .index-box__head {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .index-box__head {
    font-size: 3.125vw;
  }
}

.index-box__head::after {
  display: block;
  width: 100%;
  height: 9.8rem;
  margin-top: 1em;
  content: "";
}

@media screen and (max-width: 1366px) {
  .index-box__head::after {
    height: 7.17423vw;
  }
}

@media screen and (max-width: 768px) {
  .index-box__head::after {
    height: 12.76042vw;
  }
}

/* .index-box__head--bealeat::after{
  height: 34rem;
}

.index-box__head--ikazuch::after{
  height: 21rem;
} */

.index-box__head--air-eco::after {
  background: url(../images/head-air-eco@2x.jpg) no-repeat left center/contain;
}

.index-box__head--r-optimizer::after {
  background: url(../images/head-green-flow@2x.png) no-repeat left center/contain;
}

.index-box__head--iruv-coat::after {
  background: url(../images/head-iruv-coat@2x.jpg) no-repeat left center/contain;
}

.index-box__head--nanobeatwater::after {
  background: url(../images/head-nanobeatwater@2x.jpg) no-repeat left center/contain;
}

.index-box__head--bealeat::after {
  height: 34rem;
  background: url(../images/head-bealeat.png) no-repeat left center/contain;
}

.index-box__head--ikazuchi::after {
  height: 21rem;
  background: url(../images/head-ikazuchi.png) no-repeat left center/contain;
}

@media screen and (max-width: 768px) {
  .index-box__head--bealeat::after {
    height: 60vw;
  }

  .index-box__head--ikazuchi::after {
    height: 32vw;
  }
}

.index-box__catch {
  margin-bottom: 1em;
  color: var(--color-blue);
  font-weight: bold;
  font-size: 3.2rem;
  line-height: calc(64 / 42);
}

@media screen and (max-width: 1366px) {
  .index-box__catch {
    font-size: 2.92826vw;
  }
}

@media screen and (max-width: 768px) {
  .index-box__catch {
    font-size: 5.46875vw;
  }
}

.index-box__catch span {
  font-weight: bold;
  font-size: calc(36 / 42 * 100%);
}

.index-box__text {
  margin-bottom: 3em;
  line-height: calc(29 / 16);
}

.index-box__links {
  display: flex;
  flex-direction: column;
  gap: 2em;
}

.index-circle {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 65.6rem;
  height: 65.6rem;
  border-radius: 50%;
  background-image: linear-gradient(150deg, rgba(0, 153, 217, 0.15) 0, rgba(0, 167, 60, 0.15) 100%);
}

@media screen and (max-width: 1366px) {
  .index-circle {
    width: 48.02343vw;
    height: 48.02343vw;
  }
}

@media screen and (max-width: 768px) {
  .index-circle {
    width: 75vw;
    height: 75vw;
    margin-right: auto;
    margin-left: auto;
  }
}

.index-circle img {
  height: auto;
}

@media screen and (max-width: 1366px) {
  .index-circle--air-eco img {
    width: 100%;
  }
}

@media screen and (max-width: 1366px) {
  .index-circle--r-optimizer img {
    width: 80%;
  }
}

@media screen and (max-width: 1366px) {
  .index-circle--iruv-coat img {
    width: 90%;
  }
}

@media screen and (max-width: 1366px) {
  .index-circle--nanobeatwater img {
    width: 90%;
  }

}

.index-circle--bealeat img,
.index-circle--ikazuchi img {
  width: 65%;
}

.swiper-button-prev,
.swiper-button-next {
  width: 6.2rem;
  height: 6.2rem;
  border-radius: 50%;
  background-color: var(--color-green);
  color: var(--color-white);
}

@media screen and (max-width: 768px) {
  .swiper-button-prev,
  .swiper-button-next {
    opacity: 0.25;
    width: 7.5vw;
    height: 7.5vw;
  }
}

.swiper-button-prev::after,
.swiper-button-next::after {
  font-size: 2.6rem;
}

@media screen and (max-width: 768px) {
  .swiper-button-prev::after,
  .swiper-button-next::after {
    font-size: 3vw;
  }
}

.swiper-button-prev {
  left: -10rem;
}

@media screen and (max-width: 1366px) {
  .swiper-button-prev {
    left: -6.2rem;
  }
}

@media screen and (max-width: 768px) {
  .swiper-button-prev {
    left: -5vw;
  }
}

.swiper-button-next {
  right: -10rem;
}

@media screen and (max-width: 1366px) {
  .swiper-button-next {
    right: -6.2rem;
  }
}

@media screen and (max-width: 768px) {
  .swiper-button-next {
    right: -5vw;
  }
}

.section--vision {
  margin-top: -1px;
  background-color: var(--color-white);
}

.vision-wrap {
  background-image: linear-gradient(to right, rgba(0, 153, 217, 0.2) 0, rgba(0, 167, 60, 0.2) 100%);
}

.vision-wrap::after {
  display: block;
  width: 100%;
  height: 35rem;
  background: url(../images/vision-bg.jpg) no-repeat center center/cover;
  content: "";
}

@media screen and (max-width: 768px) {
  .vision-wrap::after {
    height: 25vw;
  }
}

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

.vision-text__jp {
  margin-bottom: 0.5em;
  font-weight: bold;
  font-size: 3.2rem;
  line-height: calc(58 / 32 * 100%);
}

@media screen and (max-width: 1366px) {
  .vision-text__jp {
    font-size: 2.34261vw;
  }
}

@media screen and (max-width: 768px) {
  .vision-text__jp {
    font-size: 4.16667vw;
  }
}

.vision-text__en {
  color: #3ba58e;
  font-weight: 600;
  font-size: 2.4rem;
  line-height: calc(36 / 18 * 100%);
  font-family: var(--font-montserrat);
}

@media screen and (max-width: 1366px) {
  .vision-text__en {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .vision-text__en {
    font-size: 3.125vw;
  }
}

@media screen and (max-width: 768px) {
  .vision-text-scroll {
    width: 200%;
    height: 20vw;
  }
}

.company-text {
  font-size: 2.4rem;
  line-height: calc(50 / 24 * 100%);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .company-text {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .company-text {
    font-size: 3.125vw;
  }
}

.company-text p {
  font-weight: bold;
}

.company-text p:not(:last-child) {
  margin-bottom: 1em;
}

.service-top-text {
  margin-bottom: 1em;
  font-weight: bold;
  font-size: 1.8rem;
  line-height: calc(30 / 18 * 100%);
}

@media screen and (max-width: 1366px) {
  .service-top-text {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .service-top-text {
    font-size: 3.2vw;
  }
}

.service-top-catch {
  margin-bottom: 4em;
  color: var(--color-blue);
  font-weight: bold;
  font-size: 2.8rem;
  line-height: calc(48 / 28 * 100%);
}

@media screen and (max-width: 1366px) {
  .service-top-catch {
    font-size: 2.04978vw;
  }
}

@media screen and (max-width: 768px) {
  .service-top-catch {
    font-size: 3.64583vw;
  }
}

.service-image-wrap {
  margin-bottom: 11rem;
}

@media screen and (max-width: 1366px) {
  .service-image-wrap {
    margin-bottom: 8.05271vw;
  }
}

@media screen and (max-width: 768px) {
  .service-image-wrap {
    margin-bottom: 14.32292vw;
  }
}

.service-image {
  display: block;
  max-width: 100%;
  height: auto;
  margin-right: auto;
  margin-left: auto;
}

@media screen and (max-width: 768px) {
  .service-image {
    max-width: 150%;
  }
}

.service-text {
  margin-bottom: 18rem;
  font-size: 2.8rem;
  line-height: calc(64 / 28 * 100%);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .service-text {
    margin-bottom: 13.17716vw;
    font-size: 2.04978vw;
  }
}

@media screen and (max-width: 768px) {
  .service-text {
    margin-bottom: 23.4375vw;
    font-size: 3.64583vw;
  }
}

.service-text p {
  font-weight: bold;
}

.service-text__bg {
  display: inline-block;
  padding: 0.5em 1em;
  background-image: linear-gradient(to right, #0099d9 0, #00a73c 100%);
  color: var(--color-white);
  font-weight: bold;
  line-height: 1;
}

@media screen and (max-width: 768px) {
  .service-text__bg {
    display: block;
    width: fit-content;
    margin-right: auto;
    margin-left: auto;
    line-height: 1.5;
  }
}

.service-text__bg span {
  font-weight: bold;
  font-size: calc(50 / 28 * 100%);
}

@media screen and (max-width: 768px) {
  .service-text__bg span {
    display: block;
  }
}

.service-wrap-wrap {
  display: flex;
  flex-direction: column;
  gap: 14rem;
}

@media screen and (max-width: 1366px) {
  .service-wrap-wrap {
    gap: 10.2489vw;
  }
}

@media screen and (max-width: 768px) {
  .service-wrap-wrap {
    gap: 18.22917vw;
    width: 100%;
  }
}

.service-wrap {
  display: flex;
  position: relative;
}

.service-wrap::after {
  display: block;
  position: absolute;
  bottom: 12rem;
  aspect-ratio: 816 / 503;
  width: 81.6rem;
  height: auto;
  background-color: var(--color-white);
  content: "";
}

@media screen and (max-width: 1366px) {
  .service-wrap::after {
    bottom: 8.78477vw;
    width: 59.73646vw;
  }
}

@media screen and (max-width: 768px) {
  .service-wrap::after {
    order: 1;
    position: relative;
    bottom: auto;
    transform: scale(110%);
    width: 106.25vw;
  }
}

.service-wrap--1 {
  padding-top: 8rem;
}

@media screen and (max-width: 1366px) {
  .service-wrap--1 {
    padding-top: 5.85652vw;
  }
}

@media screen and (max-width: 768px) {
  .service-wrap--1 {
    flex-direction: column;
    padding-top: 0;
  }
}

.service-wrap--1::after {
  right: 0;
  background: url(../images/index-service-1.jpg) no-repeat center center/cover;
}

.service-wrap--2 {
  flex-direction: row-reverse;
  padding-top: 23rem;
}

@media screen and (max-width: 1366px) {
  .service-wrap--2 {
    padding-top: 16.83748vw;
  }
}

@media screen and (max-width: 768px) {
  .service-wrap--2 {
    flex-direction: column;
    padding-top: 0;
  }
}

.service-wrap--2::after {
  left: 0;
  background: url(../images/index-service-2.jpg) no-repeat center center/cover;
}

.service-box {
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1;
  width: 57.4rem;
  padding: 10rem 0;
  border-radius: 2.6rem;
  box-shadow: 4px 4px 6px rgba(0, 153, 217, 0.2);
  background-color: #ebf8ff;
}

@media screen and (max-width: 1366px) {
  .service-box {
    width: 42.0205vw;
    padding: 7.32064vw 0;
    border-radius: 1.90337vw;
  }
}

@media screen and (max-width: 768px) {
  .service-box {
    order: 2;
    width: 100%;
    margin-top: -10vw;
    padding: 10vw;
    border-radius: 3.38542vw;
  }
}

.service-box__inner {
  display: flex;
  flex-direction: column;
  gap: 1em;
  width: calc(384 / 574 * 100%);
}

@media screen and (max-width: 768px) {
  .service-box__inner {
    align-items: center;
    width: 100%;
  }
}

.service-box__head {
  color: var(--color-blue);
  font-weight: bold;
  font-size: 3.2rem;
  line-height: calc(58 / 32 * 100%);
}

@media screen and (max-width: 1366px) {
  .service-box__head {
    font-size: 2.34261vw;
  }
}

@media screen and (max-width: 768px) {
  .service-box__head {
    font-size: 4.16667vw;
  }
}

.service-box__text {
  line-height: calc(29 / 16 * 100%);
}

.service-ba-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 6rem;
}

@media screen and (max-width: 1366px) {
  .service-ba-wrap {
    margin-top: 4.39239vw;
  }
}

@media screen and (max-width: 768px) {
  .service-ba-wrap {
    justify-content: center;
    gap: 5vw;
    margin-top: 12vw;
  }
}

.service-ba-wrap picture {
  display: block;
}

@media screen and (max-width: 1366px) {
  .service-ba-wrap picture {
    width: 42.75256vw;
  }
}

@media screen and (max-width: 768px) {
  .service-ba-wrap picture {
    width: 80%;
  }
}

.service-ba-wrap picture img {
  max-width: 100%;
  height: auto;
}

.workflow-list {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7rem;
  width: 113rem;
  margin-right: auto;
  margin-left: auto;
}

@media screen and (max-width: 1366px) {
  .workflow-list {
    gap: 5.12445vw;
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .workflow-list {
    gap: 9.11458vw;
  }
}

.workflow-list__item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  width: 100%;
  padding: 4rem;
  border-radius: 2rem;
  box-shadow: 4px 4px 6px rgba(0, 153, 217, 0.2);
  background-color: var(--color-white);
}

@media screen and (max-width: 768px) {
  .workflow-list__item {
    flex-direction: column;
    align-items: flex-start;
    gap: 5vw;
    padding: 5vw;
    border-radius: 2.60417vw;
  }
}

.workflow-list__item:not(:last-child)::after {
  clip-path: polygon(50% 100%, 0 0, 100% 0);
  position: absolute;
  right: 0;
  bottom: -4.5rem;
  left: 0;
  width: 25rem;
  height: 4.5rem;
  margin: auto;
  background: linear-gradient(to right, rgba(0, 153, 217, 0.4) 0, rgba(0, 167, 60, 0.4) 100%);
  content: "";
}

@media screen and (max-width: 1366px) {
  .workflow-list__item:not(:last-child)::after {
    bottom: -3.29429vw;
    width: 18.30161vw;
    height: 3.29429vw;
  }
}

@media screen and (max-width: 768px) {
  .workflow-list__item:not(:last-child)::after {
    bottom: -5.85938vw;
    width: 32.55208vw;
    height: 5.85938vw;
  }
}

.workflow-list__item__head {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.75em;
  width: calc(440 / 1060 * 100%);
  height: 8rem;
  border-radius: 4rem;
  background-image: linear-gradient(to right, #0099d9 0, #00a73c 100%);
  color: var(--color-white);
  font-weight: bold;
  font-size: 2.8rem;
}

@media screen and (max-width: 1366px) {
  .workflow-list__item__head {
    height: 5.85652vw;
    border-radius: 2.92826vw;
    font-size: 2.04978vw;
  }
}

@media screen and (max-width: 768px) {
  .workflow-list__item__head {
    width: 100%;
    height: 10.41667vw;
    border-radius: 5.20833vw;
    font-size: 4.55729vw;
  }
}

.workflow-list__item__step {
  display: flex;
  align-items: center;
  gap: 0.25em;
  font-size: 2.8rem;
}

@media screen and (max-width: 1366px) {
  .workflow-list__item__step {
    font-size: 2.04978vw;
  }
}

@media screen and (max-width: 768px) {
  .workflow-list__item__step {
    font-size: 3.64583vw;
  }
}

.workflow-list__item__step span {
  padding-top: 0.25em;
  padding-bottom: 0.25em;
  border-bottom: 2px solid var(--color-white);
  font-weight: bold;
  font-size: calc(18 / 28 * 100%);
}

.workflow-list__item__step[data-num]::after {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  background-color: var(--color-white);
  color: var(--color-blue);
  font-weight: bold;
  font-size: calc(30 / 28 * 100%);
  font-family: var(--font-montserrat);
  content: attr(data-num);
}

@media screen and (max-width: 1366px) {
  .workflow-list__item__step[data-num]::after {
    width: 2.92826vw;
    height: 2.92826vw;
  }
}

@media screen and (max-width: 768px) {
  .workflow-list__item__step[data-num]::after {
    width: 6.51042vw;
    height: 6.51042vw;
  }
}

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

.workflow-list__item__content {
  width: calc(574 / 1060 * 100%);
}

@media screen and (max-width: 768px) {
  .workflow-list__item__content {
    width: 100%;
  }
}

.workflow-list__item__text {
  font-weight: bold;
  font-size: 1.8rem;
  line-height: calc(30 / 18 * 100%);
}

@media screen and (max-width: 768px) {
  .workflow-list__item__text {
    font-size: 3.6vw;
  }
}

.workflow-list__item__caution {
  line-height: calc(30 / 16 * 100%);
}

@media screen and (max-width: 768px) {
  .workflow-list__item__caution {
    font-size: 3.2vw;
  }
}

.workflow-list__item__caution li::before {
  content: "●";
}

.achievements-list-wrap {
  margin-bottom: 10rem;
}

@media screen and (max-width: 1366px) {
  .achievements-list-wrap {
    margin-bottom: 7.32064vw;
  }
}

@media screen and (max-width: 768px) {
  .achievements-list-wrap {
    margin-bottom: 13.02083vw;
  }
}

.achievements-list-wrap p {
  font-weight: bold;
  font-size: 2.4rem;
  line-height: calc(40 / 24 * 100%);
}

@media screen and (max-width: 1366px) {
  .achievements-list-wrap p {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .achievements-list-wrap p {
    font-size: 3.125vw;
  }
}

.achievements-list {
  display: grid;
  gap: 3.3rem;
  margin-bottom: 2em;

  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(auto, 1fr);
}

@media screen and (max-width: 1366px) {
  .achievements-list {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media screen and (max-width: 768px) {
  .achievements-list {
    gap: 5vw;

    grid-template-columns: repeat(2, 1fr);
  }
}

.index .achievements-list {
  gap: 3.3rem;
}

@media screen and (max-width: 768px) {
  .index .achievements-list {
    gap: 5vw;
  }
}

.iruv-coat .achievements-list {
  gap: 1.6rem;
}

@media screen and (max-width: 768px) {
  .iruv-coat .achievements-list {
    gap: 5vw;
  }
}

.achievements-list__item {
  width: 100%;
  overflow: hidden;
}

.achievements-list__item > span {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  background-color: var(--color-blue);
  color: var(--color-white);
  font-weight: bold;
  font-size: 1.8rem;
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .achievements-list__item > span {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .achievements-list__item > span {
    font-size: 3.6vw;
  }
}

.index .achievements-list__item > span {
  height: 6rem;
}

@media screen and (max-width: 1366px) {
  .index .achievements-list__item > span {
    height: 4.39239vw;
  }
}

@media screen and (max-width: 768px) {
  .index .achievements-list__item > span {
    height: 7.8125vw;
  }
}

.iruv-coat .achievements-list__item > span {
  height: 3.6rem;
}

@media screen and (max-width: 1366px) {
  .iruv-coat .achievements-list__item > span {
    height: 2.63543vw;
  }
}

@media screen and (max-width: 768px) {
  .iruv-coat .achievements-list__item > span {
    height: 4.6875vw;
  }
}

.nanobeatwater .achievements-list__item > span {
  height: 4.5rem;
}

@media screen and (max-width: 1366px) {
  .nanobeatwater .achievements-list__item > span {
    height: 3.29429vw;
  }
}

@media screen and (max-width: 768px) {
  .nanobeatwater .achievements-list__item > span {
    height: 5.85938vw;
  }
}

.index .achievements-list__item {
  border-radius: 2rem;
}

@media screen and (max-width: 1366px) {
  .index .achievements-list__item {
    border-radius: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  .index .achievements-list__item {
    border-radius: 2.60417vw;
  }
}

.index .achievements-list__item::after {
  display: block;
  aspect-ratio: 287 / 193;
  width: 100%;
  height: auto;
  content: "";
}

.index .achievements-list__item:nth-child(1)::after {
  background: url(../images/index-achievement-1.jpg) no-repeat center center/cover;
}

.index .achievements-list__item:nth-child(2)::after {
  background: url(../images/index-achievement-2.jpg) no-repeat center center/cover;
}

.index .achievements-list__item:nth-child(3)::after {
  background: url(../images/index-achievement-3.jpg) no-repeat center center/cover;
}

.index .achievements-list__item:nth-child(4)::after {
  background: url(../images/index-achievement-4.jpg) no-repeat center center/cover;
}

.index .achievements-list__item:nth-child(5)::after {
  background: url(../images/index-achievement-5.jpg) no-repeat center center/cover;
}

.index .achievements-list__item:nth-child(6)::after {
  background: url(../images/index-achievement-6.jpg) no-repeat center center/cover;
}

.index .achievements-list__item:nth-child(7)::after {
  background: url(../images/index-achievement-7.jpg) no-repeat center center/cover;
}

.index .achievements-list__item:nth-child(8)::after {
  background: url(../images/index-achievement-8.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1rem 0;
}

@media screen and (max-width: 768px) {
  .iruv-coat .achievements-list__item {
    gap: 1.30208vw;
  }
}

.iruv-coat .achievements-list__item span {
  order: 1;
}

.iruv-coat .achievements-list__item::before {
  order: 2;
}

.iruv-coat .achievements-list__item::after {
  order: 3;
}

.iruv-coat .achievements-list__item::before,
.iruv-coat .achievements-list__item::after {
  display: block;
  aspect-ratio: 145 / 184;
  width: calc(145 / 301 * 100%);
  height: auto;
  content: "";
}

.iruv-coat .achievements-list__item:nth-child(1)::before {
  background: url(../images/iruv-achievement-1-1.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(1)::after {
  background: url(../images/iruv-achievement-1-2.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(2)::before {
  background: url(../images/iruv-achievement-2-1.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(2)::after {
  background: url(../images/iruv-achievement-2-2.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(3)::before {
  background: url(../images/iruv-achievement-3-1.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(3)::after {
  background: url(../images/iruv-achievement-3-2.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(4)::before {
  background: url(../images/iruv-achievement-4-1.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(4)::after {
  background: url(../images/iruv-achievement-4-2.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(5)::before {
  background: url(../images/iruv-achievement-5-1.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(5)::after {
  background: url(../images/iruv-achievement-5-2.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(6)::before {
  background: url(../images/iruv-achievement-6-1.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(6)::after {
  background: url(../images/iruv-achievement-6-2.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(7)::before {
  background: url(../images/iruv-achievement-7-1.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(7)::after {
  background: url(../images/iruv-achievement-7-2.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(8)::before {
  background: url(../images/iruv-achievement-8-1.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(8)::after {
  background: url(../images/iruv-achievement-8-2.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(9)::before {
  background: url(../images/iruv-achievement-9-1.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(9)::after {
  background: url(../images/iruv-achievement-9-2.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(10)::before {
  background: url(../images/iruv-achievement-10-1.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(10)::after {
  background: url(../images/iruv-achievement-10-2.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(11)::before {
  background: url(../images/iruv-achievement-11-1.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(11)::after {
  background: url(../images/iruv-achievement-11-2.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(12)::before {
  background: url(../images/iruv-achievement-12-1.jpg) no-repeat center center/cover;
}

.iruv-coat .achievements-list__item:nth-child(12)::after {
  background: url(../images/iruv-achievement-12-2.jpg) no-repeat center center/cover;
}

.achievements-map__head {
  margin-bottom: 1.5em;
  color: #ea5514;
  font-weight: bold;
  font-size: 4.2rem;
  line-height: calc(64 / 42 * 100%);
  text-align: center;
}

@media screen and (max-width: 768px) {
  .achievements-map__head {
    position: relative;
    width: fit-content;
    margin-right: auto;
    margin-left: auto;
    font-size: 5.46875vw;
  }
}

.achievements-map__head::before,
.achievements-map__head::after {
  display: inline-block;
  width: 2px;
  height: 1.5em;
  background-color: var(--color-black);
  vertical-align: bottom;
  content: "";
}

@media screen and (max-width: 768px) {
  .achievements-map__head::before,
  .achievements-map__head::after {
    position: absolute;
    bottom: 0;
    height: 2em;
  }
}

.achievements-map__head::before {
  transform: rotate(-30deg);
  margin-right: 1em;
}

@media screen and (max-width: 768px) {
  .achievements-map__head::before {
    left: -1em;
  }
}

.achievements-map__head::after {
  transform: rotate(30deg);
  margin-left: 1em;
}

@media screen and (max-width: 768px) {
  .achievements-map__head::after {
    right: -1em;
  }
}

.map-achievements {
  max-width: 100%;
  height: auto;
}

@media screen and (max-width: 768px) {
  .map-achievements {
    max-width: 150%;
  }
}

.future-catch {
  margin-bottom: 0.25em;
  color: #3ba58e;
  font-weight: bold;
  font-size: 4.2rem;
  line-height: calc(64 / 42 * 100%);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .future-catch {
    font-size: 3.07467vw;
  }
}

@media screen and (max-width: 768px) {
  .future-catch {
    font-size: 5.46875vw;
  }
}

.future-text {
  margin-bottom: 1em;
  font-weight: bold;
  font-size: 2.4rem;
  line-height: calc(40 / 24 * 100%);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .future-text {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .future-text {
    font-size: 3.125vw;
  }
}

.future-wrap {
  display: flex;
  gap: 2rem;
}

@media screen and (max-width: 768px) {
  .future-wrap {
    flex-direction: column;
  }
}

.future-box {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 1.5em;
  padding: 8rem;
  background-color: var(--color-white);
}

@media screen and (max-width: 1366px) {
  .future-box {
    padding: 5.85652vw;
  }
}

@media screen and (max-width: 768px) {
  .future-box {
    padding: 10vw 5vw;
  }
}

.future-box__image {
  margin-top: 0;
  margin-bottom: auto;
  text-align: center;
}

.future-box__image img {
  max-width: 100%;
  height: auto;
}

.future-box__head {
  font-weight: bold;
  font-size: 2.3rem;
  line-height: calc(38 / 23 * 100%);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .future-box__head {
    font-size: 1.68375vw;
  }
}

@media screen and (max-width: 768px) {
  .future-box__head {
    font-size: 4.6vw;
  }
}

.future-box__text {
  font-weight: 500;
  font-size: 1.8rem;
  line-height: calc(30 / 18 * 100%);
}

@media screen and (max-width: 1366px) {
  .future-box__text {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .future-box__text {
    font-size: 3.6vw;
  }
}

.future-box__caution {
  margin-left: 1em;
  line-height: 1.5;
  text-indent: -1em;
}

.future-box__caution::before {
  content: "※";
}

.iruv-coat .features-wrap {
  margin-bottom: 15rem;
}

@media screen and (max-width: 1366px) {
  .iruv-coat .features-wrap {
    margin-bottom: 10.98097vw;
  }
}

@media screen and (max-width: 768px) {
  .iruv-coat .features-wrap {
    margin-bottom: 19.53125vw;
  }
}

.iruv-frame-wrap {
  display: flex;
  flex-direction: column;
  gap: 18rem;
}

@media screen and (max-width: 1366px) {
  .iruv-frame-wrap {
    gap: 13.17716vw;
  }
}

@media screen and (max-width: 768px) {
  .iruv-frame-wrap {
    gap: 23.4375vw;
  }
}

.iruv-compare-wrap,
.iruv-ability-wrap {
  display: flex;
  justify-content: center;
}

@media screen and (max-width: 768px) {
  .iruv-compare-wrap,
  .iruv-ability-wrap {
    flex-direction: column;
    align-items: center;
  }
}

.iruv-compare-wrap {
  gap: 4.5rem;
}

@media screen and (max-width: 768px) {
  .iruv-compare-wrap {
    gap: 5vw;
    width: 100%;
  }
}

.iruv-compare-wrap picture,
.iruv-compare-wrap img {
  max-width: 100%;
  height: auto;
}

@media screen and (max-width: 768px) {
  .iruv-compare-wrap picture,
  .iruv-compare-wrap img {
    width: 100%;
  }
}

.iruv-ability-text {
  display: block;
  position: absolute;
  top: -4em;
  right: 0;
  left: 0;
  width: fit-content;
  margin: auto;
  font-weight: bold;
  font-size: 2.4rem;
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .iruv-ability-text {
    top: -5em;
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .iruv-ability-text {
    top: -4em;
    font-size: 3.125vw;
  }
}

.iruv-ability-text::before,
.iruv-ability-text::after {
  display: inline-block;
  width: 2px;
  height: 1.5em;
  background-color: var(--color-black);
  vertical-align: bottom;
  content: "";
}

@media screen and (max-width: 768px) {
  .iruv-ability-text::before,
  .iruv-ability-text::after {
    position: absolute;
    bottom: 0;
    height: 2em;
  }
}

.iruv-ability-text::before {
  transform: rotate(-30deg);
  margin-right: 1em;
}

@media screen and (max-width: 768px) {
  .iruv-ability-text::before {
    left: -1em;
  }
}

.iruv-ability-text::after {
  transform: rotate(30deg);
  margin-left: 1em;
}

@media screen and (max-width: 768px) {
  .iruv-ability-text::after {
    right: -1em;
  }
}

.iruv-ability-wrap {
  align-items: flex-end;
  gap: 2rem;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .iruv-ability-wrap {
    align-items: center;
    gap: 7vw;
  }
}

@media screen and (max-width: 768px) {
  .iruv-ability-wrap picture {
    width: 75%;
  }
}

@media screen and (max-width: 768px) {
  .iruv-ability-wrap picture img {
    width: 100%;
    height: auto;
  }
}

@media screen and (max-width: 768px) {
  .iruv-ability-box {
    display: flex;
    align-items: center;
  }
}

.iruv-ability-box::before {
  display: block;
  clip-path: polygon(0% 20%, 78% 20%, 78% 0%, 100% 50%, 78% 100%, 78% 80%, 0% 80%);
  width: 18.2rem;
  height: 4.4rem;
  margin-bottom: 2em;
  background-color: #000;
  content: "";
}

@media screen and (max-width: 768px) {
  .iruv-ability-box::before {
    transform: rotate(90deg);
    width: 23.69792vw;
    height: 5.72917vw;
    margin-bottom: 0;

    transform-origin: center;
  }
}

.iruv-ability-box p {
  font-weight: bold;
}

.iruv-ability-box p:nth-child(1) {
  margin-bottom: 0.5em;
  font-size: 1.8rem;
}

@media screen and (max-width: 768px) {
  .iruv-ability-box p:nth-child(1) {
    font-size: 3.6vw;
  }
}

.iruv-ability-box p:nth-child(2) {
  color: #ea5514;
  font-size: 2.5rem;
  line-height: 1.25;
  font-family: var(--font-montserrat);
}

@media screen and (max-width: 768px) {
  .iruv-ability-box p:nth-child(2) {
    font-size: 5vw;
  }
}

.iruv-ability-box p:nth-child(2) > span {
  font-weight: bold;
  font-size: calc(30 / 25 * 100%);
}

.iruv-ability-box p:nth-child(2) > span > span {
  font-weight: bold;
  font-size: calc(43 / 30 * 100%);
}

.iruv-performance-text {
  margin-bottom: 2em;
  padding-right: 10rem;
  padding-left: 10rem;
  font-weight: 500;
  line-height: calc(29 / 16);
}

@media screen and (max-width: 1366px) {
  .iruv-performance-text {
    font-size: 1.1713vw;
  }
}

@media screen and (max-width: 768px) {
  .iruv-performance-text {
    padding: 0;
    font-size: 3.2vw;
  }
}

.iruv-performance-wrap {
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

@media screen and (max-width: 768px) {
  .iruv-performance-wrap {
    flex-direction: column;
    align-items: center;
  }
}

.iruv-performance-wrap--1 {
  gap: calc(150 / 1250 * 100%);
}

@media screen and (max-width: 768px) {
  .iruv-performance-wrap--1 {
    gap: 5vw;
  }
}

@media screen and (max-width: 1366px) {
  .iruv-performance-wrap--1 img {
    width: 32.28404vw;
  }
}

@media screen and (max-width: 768px) {
  .iruv-performance-wrap--1 img {
    width: 60vw;
  }
}

.iruv-performance-wrap--2 {
  gap: calc(100 / 1250 * 100%);
}

@media screen and (max-width: 768px) {
  .iruv-performance-wrap--2 {
    gap: 5vw;
  }
}

@media screen and (max-width: 1366px) {
  .iruv-performance-wrap--2 img {
    width: 35.94436vw;
  }
}

@media screen and (max-width: 768px) {
  .iruv-performance-wrap--2 img {
    width: 60vw;
  }
}

.iruv-performance-wrap picture {
  display: block;
}

.iruv-performance-wrap picture img {
  display: block;
  height: auto;
}

.achievements-text {
  margin-bottom: 1em;
  color: var(--color-blue);
  font-weight: bold;
  font-size: 3.2rem;
  line-height: calc(58 / 32);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .achievements-text {
    font-size: 2.34261vw;
  }
}

@media screen and (max-width: 768px) {
  .achievements-text {
    font-size: 4.16667vw;
  }
}

.features-wrap {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: 4.5rem;
}

@media screen and (max-width: 1366px) {
  .features-wrap {
    gap: 5vw;
  }
}

.features-box {
  list-style-position: inside;
  position: relative;
  width: fit-content;
  margin-top: 4rem;
  counter-increment: cnt;
}

@media screen and (max-width: 1366px) {
  .features-box {
    margin-top: 2.92826vw;
  }
}

@media screen and (max-width: 768px) {
  .features-box {
    margin-top: 5.20833vw;
  }
}

.iruv-coat .features-box:nth-child(-n + 3) .features-box__inner {
  display: grid;
  gap: 0 4.5rem;

  grid-template-areas:
    "head  image"
    "text  image";
  grid-template-columns: 1fr 306px;
  grid-template-rows: auto auto;
}

@media screen and (max-width: 768px) {
  .iruv-coat .features-box:nth-child(-n + 3) .features-box__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
}

.iruv-coat .features-box:nth-child(-n + 3) .features-box__inner .features-box__head {
  align-self: flex-end;
}

@media screen and (max-width: 768px) {
  .iruv-coat .features-box:nth-child(-n + 3) .features-box__inner .features-box__head {
    align-self: center;
  }
}

.iruv-coat .features-box:nth-child(-n + 3) .features-box__inner .features-box__text {
  align-self: flex-start;
}

@media screen and (max-width: 768px) {
  .iruv-coat .features-box:nth-child(-n + 3) .features-box__inner .features-box__text {
    align-self: center;
  }
}

.features-wrap--1 .features-box:nth-child(1) {
  margin-left: calc(100% / 6);
}

@media screen and (max-width: 768px) {
  .features-wrap--1 .features-box:nth-child(1) {
    margin-left: 0;
  }
}

.features-wrap--1 .features-box:nth-child(2) {
  margin-right: calc(100% / 6);
}

@media screen and (max-width: 768px) {
  .features-wrap--1 .features-box:nth-child(2) {
    margin-right: 0;
  }
}

.features-box::before {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  z-index: 3;
  width: fit-content;
  margin: -0.5em auto 0;
  padding-bottom: 0.25em;
  border-bottom: 0.4rem solid #00a73c;
  background-image: linear-gradient(to right, #0099d9 0, #00a73c 100%);
  background-clip: text;
  font-weight: bold;
  font-size: 3.2rem;
  line-height: 1;
  font-family: var(--font-montserrat);
  content: "0" counter(cnt);

  -webkit-text-fill-color: transparent;
}

@media screen and (max-width: 1366px) {
  .features-box::before {
    border-bottom: 0.29283vw solid #00a73c;
    font-size: 2.34261vw;
  }
}

@media screen and (max-width: 768px) {
  .features-box::before {
    border-bottom: 0.52083vw solid #00a73c;
    font-size: 4.16667vw;
  }
}

.features-box::after {
  display: block;
  position: absolute;
  top: -4rem;
  right: 0;
  left: 0;
  z-index: 1;
  width: 10rem;
  height: 10rem;
  margin: auto;
  border-radius: 50%;
  box-shadow: 4px 4px 6px rgba(0, 153, 217, 0.2);
  background-color: #ebf8ff;
  content: "";
}

@media screen and (max-width: 1366px) {
  .features-box::after {
    top: -2.92826vw;
    width: 7.32064vw;
    height: 7.32064vw;
  }
}

@media screen and (max-width: 768px) {
  .features-box::after {
    top: -5.20833vw;
    width: 13.02083vw;
    height: 13.02083vw;
  }
}

.features-box--white::after {
  background-color: var(--color-white);
}

.features-box__inner {
  display: block;
  position: relative;
  z-index: 2;
  width: 38.4rem;
  height: 100%;
  padding: 6rem 4rem 4rem;
  border-radius: 2.6rem;
  box-shadow: 4px 4px 6px rgba(0, 153, 217, 0.2);
  background-color: #ebf8ff;
}

@media screen and (max-width: 1366px) {
  .features-box__inner {
    width: 26vw;
    padding: 4.39239vw 2.92826vw 2.92826vw;
    border-radius: 1.90337vw;
  }
}

@media screen and (max-width: 768px) {
  .features-box__inner {
    width: 100%;
    padding: 7.8125vw 5vw 5vw;
    border-radius: 3.38542vw;
  }
}

.features-box--white .features-box__inner {
  background-color: var(--color-white);
}

.features-box--full .features-box__inner {
  width: 113rem;
}

@media screen and (max-width: 1366px) {
  .features-box--full .features-box__inner {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .features-box--full .features-box__inner {
    width: 100%;
  }
}

.features-box__head {
  margin-bottom: 0.5em;
  font-weight: bold;
  font-size: 2.4rem;
  line-height: calc(30 / 18);
  text-align: center;

  grid-area: head;
}

@media screen and (max-width: 1366px) {
  .features-box__head {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .features-box__head {
    font-size: 4.8vw;
  }
}

.features-box--full .features-box__head {
  text-align: left;
}

.features-box__text {
  font-size: 1.8rem;
  line-height: calc(30 / 18);

  grid-area: text;
}

@media screen and (max-width: 1366px) {
  .features-box__text {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .features-box__text {
    font-size: 3.6vw;
  }
}

.features-box__text span {
  color: #dc000c;
  font-weight: 500;
}

.features-box__image {
  grid-area: image;
}

@media screen and (max-width: 768px) {
  .features-box__image {
    margin-top: 1em;
  }
}

.nanobeatwater-top-text {
  margin-bottom: 2em;
  font-weight: bold;
  font-size: 3.2rem;
  line-height: calc(58 / 32);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .nanobeatwater-top-text {
    font-size: 2.34261vw;
  }
}

@media screen and (max-width: 768px) {
  .nanobeatwater-top-text {
    font-size: 4.16667vw;
  }
}

.nanobeatwater-top-text span {
  display: block;
  color: var(--color-blue);
  font-weight: bold;
  font-size: calc(42 / 32 * 100%);
}

.nanobeatwater-top-img {
  display: flex;
  align-items: center;
  gap: 3em;
  margin-bottom: 12rem;
}

@media screen and (max-width: 1366px) {
  .nanobeatwater-top-img {
    gap: 2.19619vw;
    margin-bottom: 8.78477vw;
  }
}

@media screen and (max-width: 768px) {
  .nanobeatwater-top-img {
    flex-direction: column;
    gap: 3.90625vw;
    margin-bottom: 15.625vw;
  }
}

@media screen and (max-width: 1366px) {
  .nanobeatwater-top-img img {
    width: 43.92387vw;
    height: auto;
  }
}

@media screen and (max-width: 768px) {
  .nanobeatwater-top-img img {
    width: 100%;
  }
}

.nanobeatwater-top-img figcaption {
  font-weight: bold;
  font-size: 3.2rem;
  line-height: calc(58 / 32);
}

@media screen and (max-width: 1366px) {
  .nanobeatwater-top-img figcaption {
    font-size: 2.34261vw;
  }
}

@media screen and (max-width: 768px) {
  .nanobeatwater-top-img figcaption {
    font-size: 4.16667vw;
  }
}

.nanobeatwater-text {
  margin-bottom: 2em;
  padding-right: 6em;
  padding-left: 6em;
  font-weight: bold;
  font-size: 1.8rem;
  line-height: calc(30 / 18);
}

@media screen and (max-width: 1366px) {
  .nanobeatwater-text {
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .nanobeatwater-text {
    padding-right: 0;
    padding-left: 0;
    font-size: 3.6vw;
  }
}

.nanobeatwater-text--purification,
.nanobeatwater-text--kikurage {
  margin-bottom: 5em;
}

.resonance-img {
  display: block;
  max-width: 100%;
  height: auto;
  margin-right: auto;
  margin-left: auto;
}

@media screen and (max-width: 768px) {
  .resonance-img {
    max-width: 200%;
  }
}

.purification-wrap {
  display: flex;
  justify-content: center;
  gap: 3em;
}

@media screen and (max-width: 768px) {
  .purification-wrap {
    flex-direction: column;
    align-items: center;
    gap: 5vw;
  }
}

.purification-wrap img {
  max-width: 100%;
  height: auto;
  margin-bottom: 1.5em;
}

@media screen and (max-width: 768px) {
  .purification-wrap img {
    margin-bottom: 1em;
  }
}

.purification-wrap figcaption {
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .purification-wrap figcaption {
    font-size: 1.1713vw;
  }
}

@media screen and (max-width: 768px) {
  .purification-wrap figcaption {
    font-size: 2.08333vw;
  }
}

.kikurage-test {
  display: flex;
  justify-content: center;
  margin-bottom: 1em;
  font-size: 2.4rem;
}

@media screen and (max-width: 1366px) {
  .kikurage-test {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .kikurage-test {
    font-size: 4.8vw;
  }
}

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

.kikurage-test__head::after {
  content: "：";
}

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

.kikurage-top-wrap {
  display: flex;
  justify-content: center;
  gap: 3em;
  margin-bottom: 3em;
}

@media screen and (max-width: 768px) {
  .kikurage-top-wrap {
    gap: 3.90625vw;
  }
}

.kikurage-top-wrap img {
  max-width: 100%;
  height: auto;
}

.kikurage-wrap {
  display: grid;
  align-items: end;
  gap: 2rem;
  margin-bottom: 3em;

  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(auto-fill, 1fr);
}

@media screen and (max-width: 1366px) {
  .kikurage-wrap {
    gap: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  .kikurage-wrap {
    gap: 2.60417vw;

    grid-template-columns: repeat(1, 1fr);
  }
}

.kikurage-box {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

@media screen and (max-width: 1366px) {
  .kikurage-box {
    gap: 0.73206vw;
  }
}

@media screen and (max-width: 768px) {
  .kikurage-box {
    gap: 1.30208vw;
    width: 100%;
  }
}

.kikurage-box__text {
  margin-bottom: 0.5em;
}

.kikurage-box__text--1 {
  font-weight: bold;
  font-size: 2.4rem;
}

@media screen and (max-width: 1366px) {
  .kikurage-box__text--1 {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .kikurage-box__text--1 {
    font-size: 3.125vw;
  }
}

.kikurage-box__text--2 {
  color: #dc000c;
  font-weight: bold;
  font-size: 2.8rem;
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .kikurage-box__text--2 {
    font-size: 2.04978vw;
  }
}

@media screen and (max-width: 768px) {
  .kikurage-box__text--2 {
    font-size: 3.64583vw;
  }
}

.kikurage-box__text--2::before,
.kikurage-box__text--2::after {
  display: inline-block;
  width: 2px;
  height: 1.5em;
  background-color: var(--color-black);
  vertical-align: -30%;
  content: "";
}

.kikurage-box__text--2::before {
  transform: rotate(-30deg);
  margin-right: 0.5em;
}

.kikurage-box__text--2::after {
  transform: rotate(30deg);
  margin-left: 0.5em;
}

.kikurage-box__head {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 4.5rem;
  background: var(--color-blue);
  color: var(--color-white);
  font-weight: bold;
  font-size: 2.4rem;
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .kikurage-box__head {
    height: 3.29429vw;
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .kikurage-box__head {
    height: 5.85938vw;
    font-size: 3.51563vw;
  }
}

.kikurage-box__images {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

@media screen and (max-width: 1366px) {
  .kikurage-box__images {
    gap: 0.73206vw;
  }
}

@media screen and (max-width: 768px) {
  .kikurage-box__images {
    flex-direction: row;
    gap: 1.30208vw;
    width: 100%;
  }
}

.kikurage-box__images picture {
  display: block;
  width: 100%;
}

@media screen and (max-width: 768px) {
  .kikurage-box__images picture {
    flex: 1;
    width: auto;
  }
}

.kikurage-box__images img {
  object-fit: cover;
  aspect-ratio: 270/315;
  width: 100%;
  height: auto;
}

.kikurage-text {
  font-weight: bold;
  font-size: 3.2rem;
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .kikurage-text {
    font-size: 2.34261vw;
  }
}

@media screen and (max-width: 768px) {
  .kikurage-text {
    font-size: 4.16667vw;
  }
}

.kikurage-text span {
  color: #ea5514;
  font-weight: bold;
  font-family: var(--font-montserrat);
}

.kikurage-text span span:nth-child(1) {
  font-weight: bold;
  font-size: calc(72 / 32 * 100%);
}

.kikurage-text span span:nth-child(2) {
  font-weight: 600;
  font-size: calc(60 / 32 * 100%);
}

.award-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 5rem;
}

@media screen and (max-width: 1366px) {
  .award-wrap {
    gap: 3.66032vw;
  }
}

@media screen and (max-width: 768px) {
  .award-wrap {
    gap: 5vw;
  }
}

.award-box {
  display: block;
}

.award-box img {
  display: block;
  max-width: 100%;
  height: auto;
  margin-bottom: 0.5em;
}

@media screen and (max-width: 1366px) {
  .award-box img {
    width: 43.92387vw;
  }
}

@media screen and (max-width: 768px) {
  .award-box img {
    width: 40vw;
  }
}

.award-box figcaption {
  font-weight: bold;
  font-size: 2.8rem;
  line-height: calc(40 / 24);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .award-box figcaption {
    font-size: 2.04978vw;
  }
}

@media screen and (max-width: 768px) {
  .award-box figcaption {
    font-size: 3.64583vw;
  }
}

.award-box figcaption p {
  font-weight: bold;
}

.award-box figcaption p:last-child {
  color: #dc000c;
}

.sgs-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8rem;
}

@media screen and (max-width: 1366px) {
  .sgs-wrap {
    gap: 5.85652vw;
  }
}

@media screen and (max-width: 768px) {
  .sgs-wrap {
    gap: 5vw;
  }
}

.sgs-box {
  display: block;
}

.sgs-box img {
  display: block;
  max-width: 100%;
  height: auto;
  margin-bottom: 1.5em;
}

@media screen and (max-width: 1366px) {
  .sgs-box img {
    width: 43.92387vw;
  }
}

@media screen and (max-width: 768px) {
  .sgs-box img {
    width: 40vw;
  }
}

.sgs-box figcaption {
  font-weight: bold;
  font-size: 2.4rem;
  line-height: calc(40 / 24);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .sgs-box figcaption {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .sgs-box figcaption {
    font-size: 3.125vw;
  }
}

.field-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: calc((1250px - (384px * 3)) / 2);
  margin-bottom: 5rem;
}

@media screen and (max-width: 1366px) {
  .field-wrap {
    margin-bottom: 3.66032vw;
  }
}

@media screen and (max-width: 768px) {
  .field-wrap {
    flex-direction: column;
    align-items: center;
    gap: 5vw;
    margin-bottom: 6.51042vw;
  }
}

.field-box {
  width: 35rem;
  overflow: hidden;
  border-radius: 2rem;
  box-shadow: 4px 4px 6px rgba(0, 153, 217, 0.2);
  background-color: var(--color-white);
}

@media screen and (max-width: 1366px) {
  .field-box {
    width: 25.62225vw;
    border-radius: 1.46413vw;
  }
}

@media screen and (max-width: 768px) {
  .field-box {
    width: 100%;
    border-radius: 2.60417vw;
  }
}

.field-box__head {
  padding: 0.75em;
  background-image: linear-gradient(to right, #0099d9 0, #00a73c 100%);
  color: var(--color-white);
  font-weight: bold;
  font-size: 2.4rem;
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .field-box__head {
    font-size: 1.75695vw;
  }
}

@media screen and (max-width: 768px) {
  .field-box__head {
    font-size: 3.51563vw;
  }
}

.field-box__content {
  padding: 4rem;
}

@media screen and (max-width: 1366px) {
  .field-box__content {
    padding: 2.92826vw;
  }
}

@media screen and (max-width: 768px) {
  .field-box__content {
    padding: 5.20833vw;
  }
}

.field-box__img {
  display: block;
  max-width: 100%;
  height: auto;
  margin-right: auto;
  margin-bottom: 1em;
  margin-left: auto;
}

@media screen and (max-width: 1366px) {
  .field-box__img {
    width: 13.17716vw;
  }
}

@media screen and (max-width: 768px) {
  .field-box__img {
    object-fit: contain;
    width: auto;
    max-height: 30vw;
  }
}

.field-box__text {
  font-weight: 500;
  line-height: calc(29 / 16);
  text-align: center;
}

.section {
  position: relative;
}

body:not(.gx) .section .btn[href^="mailto"] {
  position: absolute;
  right: 0;
  bottom: -1.5em;
  left: 0;
  z-index: 1;
  margin: auto;
}

.air-eco .top-catch {
  margin-bottom: 1em;
}

.features-list {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  margin-bottom: 10rem;
  counter-reset: cnt;
}

@media screen and (max-width: 1366px) {
  .features-list {
    margin-bottom: 7.32064vw;
  }
}

@media screen and (max-width: 768px) {
  .features-list {
    justify-content: center;
    gap: 5vw;
    margin-bottom: 13.02083vw;
  }
}

.features-list__item {
  list-style-position: inside;
  position: relative;
  height: 15.5rem;
  margin-top: 4rem;
  counter-increment: cnt;
}

@media screen and (max-width: 1366px) {
  .features-list__item {
    height: 11.347vw;
    margin-top: 2.92826vw;
  }
}

@media screen and (max-width: 768px) {
  .features-list__item {
    height: 20.18229vw;
    margin-top: 5.20833vw;
  }
}

.features-list__item > span {
  display: block;
  position: relative;
  z-index: 1;
  width: 27.5rem;
  height: 100%;
  padding: 6rem 2.5rem 0;
  border-radius: 2.6rem;
  box-shadow: 4px 4px 6px rgba(0, 153, 217, 0.2);
  background-color: #ebf8ff;
  font-weight: bold;
  font-size: 1.8rem;
  line-height: calc(30 / 18);
  text-align: center;
}

@media screen and (max-width: 1366px) {
  .features-list__item > span {
    width: 20.13177vw;
    padding: 4.39239vw 1.83016vw 2.92826vw;
    border-radius: 1.90337vw;
    font-size: 1.31772vw;
  }
}

@media screen and (max-width: 768px) {
  .features-list__item > span {
    width: 35.80729vw;
    padding: 7.8125vw 3.25521vw 5.20833vw;
    border-radius: 3.38542vw;
    font-size: 2.34375vw;
  }
}

.features-list__item > span > span {
  display: block;
  margin-left: 1em;
  padding-right: 1em;
  padding-left: 1em;
  font-size: 1.2rem;
  line-height: calc(18 / 12);
  text-align: left;
  text-indent: -1em;
}

@media screen and (max-width: 1366px) {
  .features-list__item > span > span {
    font-size: 0.87848vw;
  }
}

@media screen and (max-width: 768px) {
  .features-list__item > span > span {
    font-size: 1.5625vw;
  }
}

.features-list__item > span > span::before {
  content: "※";
}

.features-list__item::before {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  z-index: 2;
  width: fit-content;
  margin: -0.5em auto 0;
  padding-bottom: 0.25em;
  border-bottom: 0.4rem solid #00a73c;
  background-image: linear-gradient(to right, #0099d9 0, #00a73c 100%);
  background-clip: text;
  font-weight: bold;
  font-size: 3.2rem;
  line-height: 1;
  font-family: var(--font-montserrat);
  content: "0" counter(cnt);

  -webkit-text-fill-color: transparent;
}

@media screen and (max-width: 1366px) {
  .features-list__item::before {
    border-bottom: 0.29283vw solid #00a73c;
    font-size: 2.34261vw;
  }
}

@media screen and (max-width: 768px) {
  .features-list__item::before {
    border-bottom: 0.52083vw solid #00a73c;
    font-size: 4.16667vw;
  }
}

.features-list__item::after {
  display: block;
  position: absolute;
  top: -4rem;
  right: 0;
  left: 0;
  z-index: 0;
  width: 10rem;
  height: 10rem;
  margin: auto;
  border-radius: 50%;
  box-shadow: 4px 4px 6px rgba(0, 153, 217, 0.2);
  background-color: #ebf8ff;
  content: "";
}

@media screen and (max-width: 1366px) {
  .features-list__item::after {
    top: -2.92826vw;
    width: 7.32064vw;
    height: 7.32064vw;
  }
}

@media screen and (max-width: 768px) {
  .features-list__item::after {
    top: -5.20833vw;
    width: 13.02083vw;
    height: 13.02083vw;
  }
}

.features-text {
  margin-bottom: 1em;
  line-height: calc(29 / 16);
}

.scroll-x {
  width: 100%;
  overflow-x: auto;
}

.features-table {
  max-width: 100%;
  height: auto;
}

@media screen and (max-width: 768px) {
  .features-table {
    width: auto;
    max-width: none;
    height: 50vw;
  }
}

/* ---------- 2025.08 GREEN FLOW 修正 ---------- */
.r-optimizer {
  .section--features .container {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .model-box {
    position: relative;
    overflow: visible;
  }
  .model-box:not(:last-child)::after {
    position: absolute;

    margin: auto;
    clip-path: polygon(0 0, 0% 100%, 100% 50%);

    background: linear-gradient(to right, rgba(0, 153, 217, 0.4) 0, rgba(0, 167, 60, 0.4) 100%);
    content: "";

    right: -111%;
    bottom: 25%;
    left: 0;
    width: 4rem;
    height: 14.5rem;
  }

  .performance-wrap {
    margin: 0 auto;
    max-width: 780px;
    padding: 2rem 4rem;
  }
  .performance-realize__text {
    text-align: center;
    margin: 0 auto;
    margin-top: 2rem;
  }

  .mechanism__text {
    font-size: 2.4rem;
    font-weight: bold;
    line-height: calc(40 / 24);
    text-align: center;
    padding-bottom: 6rem;
  }

  .mechanism__text span {
    font-weight: bold;
  }

  .mechanism-wrap {
    margin-top: 6rem;
  }
}

@media screen and (max-width: 1024px) {
  .r-optimizer {
    .model-box:not(:last-child)::after {
      right: -117%;
      bottom: 17%;
      left: 0;
      width: 4rem;
      height: 13.5rem;
    }
  }
}

@media screen and (max-width: 768px) {
  .r-optimizer {
    .model-box__img {
      max-height: none;
    }
    .performance-wrap {
      padding: 1rem;
    }
    .model-box:not(:last-child)::after {
      clip-path: polygon(50% 100%, 0 0, 100% 0);
      bottom: -5.85938vw;
      width: 32.55208vw;
      height: 5.85938vw;
      right: 0;
      left: 0;
    }
    .mechanism__text {
      font-size: 1.5rem;
      padding-bottom: 3rem;
    }
    .model-wrap {
      gap: 10vw;
    }
    .mechanism-box__top {
      text-align: left;
    }
    .mechanism-wrap {
      margin-top: 3rem;
    }
    .performance-wrap + .performance-realize__text {
      margin-top: 2.5em;
    }
    .performance-realize__text {
      margin-top: 0;
    }
    .mechanism-box__inner--1 {
      padding: 0.5em;
    }
  }
}

@media screen and (max-width: 1366px) {
  .model-box:not(:last-child)::after {
    bottom: -3.29429vw;
    width: 18.30161vw;
    height: 3.29429vw;
  }
}

.pdf + .pdf{
  margin-top: 5rem
}

.pdf img{
  width: 100%;
  height: auto;
}

@media screen and (max-width: 768px) {
  .pdf img {
    width: 180%;
    height: auto;
  }
}
