@charset "UTF-8";
/* -----------------------------------------------
* Plugins エントリーポイント
-------------------------------------------------- */
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}
.slick-list:focus {
  outline: none;
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.slick-track:before, .slick-track:after {
  content: "";
  display: table;
}
.slick-track:after {
  clear: both;
}
.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}
[dir=rtl] .slick-slide {
  float: right;
}
.slick-slide img {
  display: block;
}
.slick-slide.slick-loading img {
  display: none;
}
.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .slick-slide {
  display: block;
}
.slick-loading .slick-slide {
  visibility: hidden;
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

/*------------------------------------------------------------------------------
  reset
------------------------------------------------------------------------------*/
html,
input,
textarea,
select,
button {
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
}

html {
  color: #242424;
  background: #fff;
  font-size: 16px;
  line-height: 1.6;
  overflow-wrap: break-word;
}
body {
  background: #fff;
  margin: 0;
}

*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

img {
  border: 0;
  margin: 0;
  vertical-align: top;
  max-width: 100%;
  height: auto;
}

figure {
  margin: 0;
}

p {
  margin: 0;
  padding: 0;
}

a {
  color: inherit;
  text-decoration: none;
}

input,
select,
textarea,
button {
  color: inherit;
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

select::-ms-expand {
  display: none;
}

textarea {
  resize: vertical;
}

::-webkit-input-placeholder {
  color: #ccc;
}

:-ms-input-placeholder {
  color: #ccc;
}

::-ms-input-placeholder {
  color: #ccc;
}

::-moz-placeholder {
  color: #ccc;
}

::placeholder {
  color: #ccc;
}

button {
  border: none;
  cursor: pointer;
}

label {
  cursor: pointer;
}

table {
  border-collapse: collapse;
}

ul,
ol {
  list-style: none;
  margin: 0;
  padding: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 14px;
  font-weight: 400;
  margin: 0;
  padding: 0;
}

main {
  display: block;
}

#wrapper {
  position: relative;
}

.inner-block {
  margin: 0 auto;
  position: relative;
}

dl, dt, dd {
  padding: 0;
  margin: 0;
}

.ib {
  display: inline-block;
}

.c-svg {
  display: inline-block;
  fill: currentColor;
  vertical-align: top;
}

.Sans {
  font-family: "Noto Sans JP", sans-serif;
}

.GoldenBook {
  font-family: "goldenbook", serif;
}

/* -----------------------------------------------
* Modules エントリーポイント
-------------------------------------------------- */
/* --------------------------------
c-header
----------------------------------- */
.c-header {
  padding-block: 50px;
}

.c-footer {
  background-color: #242424;
  color: #fff;
  padding-block: 65px;
}
.c-footer .wrap {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 16px;
}
.c-footer .wrap .sns-area,
.c-footer .wrap .link-area {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px 44px;
}
.c-footer .wrap .sns-area > ul,
.c-footer .wrap .link-area > ul {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 22px;
}
.c-footer .wrap .sns-area > p {
  font-size: 14px;
  letter-spacing: 0.1em;
}
.c-footer .wrap .sns-area > ul li a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: -webkit-transform 0.3s ease-in-out;
  transition: -webkit-transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
}
.c-footer .wrap .sns-area > ul li a:focus-visible {
  -webkit-transform: translateY(5px);
          transform: translateY(5px);
}
.c-footer .wrap .sns-area > ul li img {
  width: 27px;
}
.c-footer .wrap .link-area {
  font-size: 12px;
  gap: 54px;
}
.c-footer .wrap .link-area > ul {
  gap: 15px;
}
.c-footer .wrap .link-area > ul li a {
  -webkit-text-decoration: underline transparent;
          text-decoration: underline transparent;
  -webkit-transition: -webkit-text-decoration-color 0.3s ease-in-out;
  transition: -webkit-text-decoration-color 0.3s ease-in-out;
  transition: text-decoration-color 0.3s ease-in-out;
  transition: text-decoration-color 0.3s ease-in-out, -webkit-text-decoration-color 0.3s ease-in-out;
}
.c-footer .wrap .link-area > ul li a:focus-visible {
  -webkit-text-decoration-color: #fff;
          text-decoration-color: #fff;
}
.c-footer .wrap .link-area .copyright {
  font-size: 12px;
}

.c-gray-ttl {
  pointer-events: none;
}
.c-gray-ttl .inner-block {
  padding-left: 0;
  margin-left: 0;
  max-width: inherit;
}
.c-gray-ttl .ttl {
  text-align: right;
  text-transform: uppercase;
  font-size: clamp(80px, 13.66vw, 200px);
  color: #EEEEEE;
  font-family: "goldenbook", serif;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 0.7;
}

.c-img-area {
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.c-img-area .img {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
  width: 100%;
}
.c-img-area .img img {
  width: 100%;
}

.c-txt-line {
  -webkit-text-decoration: underline #707070;
          text-decoration: underline #707070;
  text-underline-offset: 8px;
}

.slick-list {
  overflow-x: clip;
}

.slick-track {
  overflow-x: clip;
}

.slick-dots {
  margin-top: 24px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  gap: 18px;
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.slick-dots li {
  cursor: pointer;
  border-radius: 50%;
  width: 12px;
  height: 12px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.slick-dots li button {
  border: 1px solid #555555;
  -webkit-transition: border-color 0.3s ease-in-out, background-color 0.3s ease-in-out;
  transition: border-color 0.3s ease-in-out, background-color 0.3s ease-in-out;
  position: relative;
  padding: 0;
  font-size: 0;
  line-height: 0;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  aspect-ratio: 1;
  border-radius: 50%;
}
.slick-dots li button:focus-visible {
  background-color: #fff;
}
.slick-dots li.slick-active button {
  border-color: #fff;
}

.js-accordion-cont {
  display: none;
}
.c-btn-wrap {
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
}
.c-btn-wrap .c-btn01,
.c-btn-wrap .c-btn02 {
  margin-inline: 0;
}

.c-btn01 {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
  border: 1px solid #242424;
  border-radius: 100vw;
  padding: 17px 24px 17px 38px;
  width: 100%;
  max-width: 381px;
  margin-inline: auto;
  background-color: transparent;
}
.c-btn01:focus-visible {
  background-color: #242424;
  color: #fff;
}
.c-btn01.white {
  background-color: #fff;
  color: #0C153E;
}
.c-btn01.white:focus-visible {
  background-color: rgba(255, 255, 255, 0.5);
  color: #0C153E;
}
.c-btn01.blue {
  background-color: #B8BDD6;
  color: #0C153E;
}
.c-btn01.blue:focus-visible {
  background-color: rgba(184, 189, 214, 0.5);
  color: #0C153E;
}
.c-btn01.transparent {
  color: #fff;
  border-color: #fff;
}
.c-btn01.transparent:focus-visible {
  background-color: #fff;
  color: #242424;
}
.c-btn01 .inn-txt {
  font-size: 16px;
  letter-spacing: 0.01em;
}
.c-btn01 .inn-txt .en {
  font-size: 14px;
  font-family: "goldenbook", serif;
  margin-left: 1.3em;
}
.c-btn01 svg {
  fill: transparent;
  stroke: currentColor;
}

.c-btn02 {
  display: grid;
  grid-template-columns: 1fr auto;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #fff;
  width: 100%;
  max-width: 561px;
  margin-inline: auto;
  padding: 27px 18px;
}
.c-btn02:focus-visible {
  background-color: #B8BDD6;
}
.c-btn02 .inn-txt {
  font-size: 16px;
  letter-spacing: 0.01em;
  width: 100%;
  text-align: center;
}
.c-btn02 svg {
  fill: transparent;
  stroke: currentColor;
}

/* -----------------------------------------------
* Page エントリーポイント
-------------------------------------------------- */
/* -----------------------------------------------
* home Module
* homeページ用
-------------------------------------------------- */
main {
  overflow-x: hidden;
}

.home .mv-section .top-area {
  padding-block: 42px 72px;
  display: grid;
  grid-template-columns: auto min(50%, 402px);
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.home .mv-section .top-area .text-area .txt {
  font-size: 26px;
  line-height: 1.7307692308;
  letter-spacing: 0.12em;
}
.home .mv-section .top-area .logo-area {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px;
}
.home .mv-section .top-area .logo-area img {
  -webkit-filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));
          filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));
}
.home .mv-section .img-area {
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.home .mv-section .img-area .img {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
      -ms-flex: 1;
          flex: 1;
  width: 100%;
}
.home .mv-section .img-area .img img {
  width: 100%;
}
.home .reason-section {
  position: relative;
  z-index: 3;
  padding-block: 72px;
}
.home .reason-section::after {
  position: absolute;
  content: "";
  z-index: -1;
  width: 527px;
  height: 446px;
  background-image: url("../img/home/bg-img01.webp");
  background-repeat: no-repeat;
  right: 0;
  top: 0;
}
.home .reason-section > .inner-block {
  grid-area: contents;
}
.home .reason-section h2.ttl {
  grid-area: ttl;
  font-size: 24px;
  line-height: 1.875;
  letter-spacing: 0.1em;
  font-weight: 400;
}
.home .reason-section h2.ttl .num {
  font-size: 34px;
  color: #003F92;
  line-height: 1;
}
.home .reason-section .reason-list-area {
  grid-area: list;
  background: #F7F7F7;
  padding: 50px 50px 70px 50px;
}
.home .reason-section .reason-list-area .ttl {
  margin-bottom: 32px;
  font-size: 20px;
  line-height: 1.85;
  letter-spacing: 0.1em;
}
.home .reason-section .reason-list-area .ttl::before {
  content: "───";
  letter-spacing: 0;
  font-size: 20px;
}
.home .reason-section .reason-list-area .reason-list > li {
  padding-left: 36px;
  position: relative;
  font-size: 14px;
  line-height: 1.8;
}
.home .reason-section .reason-list-area .reason-list > li + li {
  margin-top: 21px;
}
.home .reason-section .reason-list-area .reason-list > li::before {
  position: absolute;
  content: "";
  background: url("../img/home/ico-checkbox.svg") no-repeat center center/contain;
  width: 24px;
  height: 1.8em;
  top: 0;
  left: 0;
}
.home .reason-section .img-area .img img {
  width: 100%;
}
.home .series-section .series-area {
  background-image: url("../img/home/bg-img02.webp");
  background-repeat: no-repeat;
  background-position: calc(100% + 100px) bottom;
  background-size: 350px;
}
.home .series-section .series-area:nth-of-type(2) {
  background-position: -100px calc(100% + 80px);
}
.home .series-section .series-area .ttl {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 20px;
}
.home .series-section .series-area .ttl .sub-txt {
  font-size: 11px;
  letter-spacing: 0.1em;
  font-weight: 500;
}
.home .series-section .series-area .txt {
  font-size: 18px;
  line-height: 2.2222222222;
  letter-spacing: 0.1em;
}
.home .feature-section {
  padding-block: 125px 116px;
  background-color: #EEEEEE;
  position: relative;
}
.home .feature-section::before {
  position: absolute;
  content: "";
  background: url("../img/home/bg-img03.webp") no-repeat top left/cover;
  width: clamp(0rem, -14.795rem + 47.344vw, 25.625rem);
  height: 1074px;
  top: 0;
  right: 0;
}
.home .feature-section > .inner-block > .top-txt {
  font-size: 20px;
  line-height: 2;
  letter-spacing: 0.1em;
}
.home .feature-section > .inner-block > .ttl {
  font-size: 30px;
  line-height: 1.6666666667;
  letter-spacing: 0.1em;
  margin-block: 56px 120px;
}
.home .feature-section .feature-area {
  overflow-x: clip;
  position: relative;
}
.home .feature-section .feature-area + .feature-area {
  margin-top: 100px;
}
.home .feature-section .feature-area .inner-block {
  background-color: #0C153E;
  color: #fff;
  padding-block: 100px;
}
.home .feature-section .feature-area .inner-block::before {
  position: absolute;
  content: "";
  background-color: #EEEEEE;
}
.home .feature-section .feature-area.lighting::after {
  position: absolute;
  content: "";
  mix-blend-mode: hard-light;
  background-image: url("../img/home/bg-img04.webp");
  background-repeat: no-repeat;
}
.home .feature-section .feature-area.cleaning::after {
  position: absolute;
  content: "";
  mix-blend-mode: hard-light;
  background-image: url("../img/home/bg-img05.webp");
  background-repeat: no-repeat;
}
.home .feature-section .feature-area .contents-wrap {
  position: relative;
  z-index: 10;
  display: grid;
  gap: 0 50px;
}
.home .feature-section .feature-area .contents-wrap .text-area {
  grid-area: text;
}
.home .feature-section .feature-area .contents-wrap .ttl {
  margin-bottom: 32px;
}
.home .feature-section .feature-area .contents-wrap .ttl .inn-txt {
  display: block;
  font-size: 30px;
  line-height: 2;
  letter-spacing: 0.1em;
}
.home .feature-section .feature-area .contents-wrap .ttl .inn-txt.small {
  font-size: 14px;
}
.home .feature-section .feature-area .contents-wrap .txt {
  font-size: 14px;
  line-height: 2.2857142857;
  letter-spacing: 0.1em;
  font-weight: 500;
  font-family: "Noto Sans JP", sans-serif;
}
.home .feature-section .feature-area .contents-wrap .txt:nth-of-type(2) {
  margin-top: 32px;
}
.home .feature-section .feature-area .contents-wrap .c-btn-wrap {
  grid-area: btn;
}
.home .feature-section .feature-area .contents-wrap .c-btn-wrap .c-btn01 {
  padding-inline: 20px 16px;
}
.home .feature-section .feature-area .contents-wrap .c-btn-wrap .c-btn01 .inn-txt {
  font-size: 12px;
}
.home .feature-section .feature-area .contents-wrap .slider-area {
  grid-area: slider;
}
.home .feature-section .note-area {
  padding-top: 40px;
  font-family: "Noto Sans JP", sans-serif;
}
.home .feature-section .note-area .top-txt {
  margin-bottom: 20px;
  font-size: 12px;
  font-weight: 500;
}
.home .feature-section .note-area .accordion-area .accordion-cont {
  padding: 10px 0;
}
.home .feature-section .note-area .accordion-area .accordion-cont .head {
  font-size: 14px;
}
.home .feature-section .note-area .accordion-area .accordion-cont .head + .head {
  margin-top: 4px;
}
.home .feature-section .note-area .accordion-area .accordion-cont .body {
  margin-top: 5px;
  padding-left: 1.2em;
  font-size: 12px;
}
.home .feature-section .note-area .accordion-area .accordion-cont .body.indent {
  padding-left: 1.2em;
}
.home .feature-section .note-area .accordion-area .accordion-cont .body + .head {
  margin-top: 15px;
}
.home .feature-section .note-area .accordion-area .accordion-cont .note {
  font-size: 12px;
}
.home .feature-section .note-area .accordion-area .accordion-cont .note + .head {
  margin-top: 15px;
}
.home .feature-section .note-area .accordion-area .accordion-btn {
  display: grid;
  grid-template-columns: repeat(2, auto);
  justify-items: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 22px;
  width: 100%;
  padding: 27px 18px 27px 52px;
  border: 1px solid #242424;
}
.home .feature-section .note-area .accordion-area .accordion-btn:focus-visible {
  background-color: #B8BDD6;
}
.home .feature-section .note-area .accordion-area .accordion-btn.is-active .line > span:nth-child(2) {
  rotate: 180deg;
}
.home .feature-section .note-area .accordion-area .accordion-btn .inn-txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  letter-spacing: 0.1em;
  font-weight: 500;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  text-align: center;
}
.home .feature-section .note-area .accordion-area .accordion-btn .line {
  display: block;
  width: 30px;
  aspect-ratio: 1;
  position: relative;
}
.home .feature-section .note-area .accordion-area .accordion-btn .line > span {
  position: absolute;
  inset: 0;
  margin: auto;
  display: block;
  width: 100%;
  height: 1px;
  background-color: #242424;
}
.home .feature-section .note-area .accordion-area .accordion-btn .line > span:nth-child(2) {
  -webkit-transition: rotate 0.3s ease-in-out;
  transition: rotate 0.3s ease-in-out;
  rotate: 90deg;
}
.home .coordinate-section .coordinate-list-area .ttl-area {
  margin-block: 36px 108px;
}
.home .coordinate-section .coordinate-list-area .ttl-area .ttl {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0px 50px;
}
.home .coordinate-section .coordinate-list-area .ttl-area .ttl .logo-wrap {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  width: 100%;
  max-width: 402px;
}
.home .coordinate-section .coordinate-list-area .ttl-area .ttl .logo-wrap img {
  -webkit-filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));
          filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.2));
}
.home .coordinate-section .coordinate-list-area .ttl-area .ttl .sub-ttl {
  font-size: 16px;
  letter-spacing: 0.01em;
}
.home .coordinate-section .coordinate-list-area .coordinate-list li {
  counter-increment: i 1;
}
.home .coordinate-section .coordinate-list-area .coordinate-list li + li {
  margin-top: 50px;
}
.home .coordinate-section .coordinate-list-area .coordinate-list li .ttl {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 18px;
  text-align: center;
  font-size: 22px;
  line-height: 1.6818181818;
  letter-spacing: 0.1em;
}
.home .coordinate-section .coordinate-list-area .coordinate-list li .ttl::before {
  content: "0" counter(i) ".";
  font-family: "goldenbook", serif;
  font-size: 37px;
  line-height: 1.1891891892;
}
.home .showroom-section {
  padding-block: 170px 150px;
  background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(36, 36, 36, 0.6)), to(rgba(36, 36, 36, 0.6))), url("../img/home/showroom-img01.webp");
  background-image: linear-gradient(rgba(36, 36, 36, 0.6), rgba(36, 36, 36, 0.6)), url("../img/home/showroom-img01.webp");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}
.home .showroom-section .inner-block {
  text-align: center;
}
.home .showroom-section .ttl {
  font-size: 24px;
  line-height: 1.6666666667;
  letter-spacing: 0.1em;
  color: #fff;
}
.home .showroom-section .c-btn-wrap {
  margin-block: 62px 56px;
}
@media only screen and (max-width: 767px) {
  body {
    position: relative;
    -webkit-appearance: none;
    -webkit-text-size-adjust: 100%;
  }
  input,
  select,
  textarea {
    font-size: 16px !important;
  }
  #wrapper {
    min-width: 320px;
  }
  .inner-block {
    padding-left: 20px;
    padding-right: 20px;
  }
  .ib-sp {
    display: inline-block;
  }
  .pc {
    display: none !important;
  }
  .c-header {
    padding-block: 20px;
  }
  .c-header .inner-block {
    padding-inline: 24px;
  }
  .c-header .logo {
    max-width: 80px;
  }
  .c-footer {
    padding-block: 50px;
  }
  .c-footer .wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 40px;
  }
  .c-footer .wrap .sns-area {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .c-footer .wrap .sns-area > p {
    font-size: 18px;
  }
  .c-footer .wrap .sns-area > ul {
    gap: 30px;
  }
  .c-footer .wrap .sns-area > ul li img {
    width: 36px;
  }
  .c-footer .wrap .link-area {
    font-size: 14px;
    gap: 12px;
    -webkit-box-pack: space-evenly;
    -webkit-justify-content: space-evenly;
        -ms-flex-pack: space-evenly;
            justify-content: space-evenly;
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
  .c-footer .wrap .link-area > ul {
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
  }
  .c-footer .wrap .link-area .copyright {
    min-width: -webkit-max-content;
    min-width: -moz-max-content;
    min-width: max-content;
    font-size: 14px;
  }
  .c-gray-ttl .inner-block {
    padding-right: 0;
  }
  .c-img-area:not(.row) {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .c-txt-line {
    text-underline-offset: 4px;
  }
  .c-btn-wrap {
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .c-btn01 {
    gap: 8px;
    padding: 13px 20px 13px 32px;
  }
  .c-btn01 .inn-txt {
    font-size: 14px;
  }
  .c-btn01 .inn-txt .en {
    font-size: 12px;
  }
  .home .mv-section .top-area {
    padding-block: 28px 48px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 24px;
  }
  .home .mv-section .top-area .text-area {
    text-align: center;
  }
  .home .mv-section .top-area .text-area .txt {
    font-size: 18px;
  }
  .home .mv-section .top-area .logo-area {
    max-width: 320px;
  }
  .home .mv-section .img-area {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .home .reason-section {
    padding-block: 40px 100px;
  }
  .home .reason-section::after {
    width: 303px;
    height: 373px;
    background-position: calc(100% + 140px) -160px;
    background-size: 400px 373px;
  }
  .home .reason-section h2.ttl {
    text-align: center;
    font-size: 16px;
    line-height: 1.875;
  }
  .home .reason-section h2.ttl .num {
    font-size: 26px;
  }
  .home .reason-section .reason-list-area {
    padding: 36px 24px;
    margin-block: 20px 45px;
  }
  .home .reason-section .reason-list-area .ttl {
    margin-bottom: 16px;
    font-size: 16px;
  }
  .home .reason-section .reason-list-area .reason-list > li + li {
    margin-top: 16px;
  }
  .home .reason-section .reason-list-area .reason-list > li {
    font-size: 12px;
    line-height: 1.6666666667;
  }
  .home .reason-section .reason-list-area .reason-list > li::before {
    width: 22px;
    height: 1.6666666667em;
  }
  .home .reason-section .img-area .img {
    display: block;
    text-align: left;
    max-width: clamp(252px, 60vw, 460px);
  }
  .home .reason-section .img-area .img:nth-child(2) {
    margin-top: 8px;
    text-align: right;
    margin-left: auto;
  }
  .home .series-section .series-area {
    background-position: calc(100% + 20px) center;
    background-size: 180px;
  }
  .home .series-section .series-area:nth-of-type(2) {
    background-position: -20px bottom;
  }
  .home .series-section .series-area .desc-area {
    padding-block: 36px 72px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .home .series-section .series-area .ttl {
    gap: clamp(1rem, -0.143rem + 5.714vw, 1.25rem);
  }
  .home .series-section .series-area .txt {
    margin-block: 30px 36px;
    text-align: center;
    font-size: 14px;
    line-height: 1.8571428571;
    letter-spacing: 0.05em;
  }
  .home .series-section .series-area .c-btn-wrap .c-btn01 {
    max-width: 294px;
  }
  .home .feature-section {
    padding-block: 95px 40px;
  }
  .home .feature-section > .inner-block > .top-txt {
    font-size: 15px;
  }
  .home .feature-section > .inner-block > .ttl {
    font-size: clamp(1.25rem, 0.107rem + 5.714vw, 1.5rem);
    line-height: 1.5;
    margin-block: 30px 60px;
  }
  .home .feature-section .feature-area .inner-block {
    padding-block: 0px 80px;
  }
  .home .feature-section .feature-area .inner-block::before {
    width: 100%;
    height: max(92px, (100vw - 40px) / 1.541 / 2);
    left: 0;
    top: -1px;
  }
  .home .feature-section .feature-area.lighting::after {
    background-position: left top;
    background-size: contain;
    width: 213px;
    height: 186px;
    top: max(182px, (100vw - 40px) / 1.541);
    left: -25px;
  }
  .home .feature-section .feature-area.cleaning::after {
    background-image: url("../img/home/bg-img06.webp");
    background-position: 56px center;
    background-size: 281px 276px;
    width: 225px;
    height: 276px;
    bottom: 35px;
    right: 0px;
  }
  .home .feature-section .feature-area .contents-wrap {
    grid-template-columns: 100%;
    grid-template-areas: "slider" "text" "btn";
  }
  .home .feature-section .feature-area .contents-wrap .ttl {
    margin-top: 48px;
  }
  .home .feature-section .feature-area .contents-wrap .ttl .inn-txt {
    font-size: 24px;
  }
  .home .feature-section .feature-area .contents-wrap .ttl .inn-txt.small {
    font-size: 12px;
  }
  .home .feature-section .feature-area .contents-wrap .c-btn-wrap {
    -webkit-flex-wrap: nowrap;
        -ms-flex-wrap: nowrap;
            flex-wrap: nowrap;
    margin-top: 48px;
  }
  .home .feature-section .feature-area .contents-wrap .c-btn-wrap .c-btn01 {
    -webkit-box-flex: 1;
    -webkit-flex: 1;
        -ms-flex: 1;
            flex: 1;
    text-align: center;
    padding: 11px 12px 11px 15px;
  }
  .home .feature-section .feature-area .contents-wrap .slider-area img {
    width: 100%;
  }
  .home .feature-section .note-area {
    padding-top: 24px;
  }
  .home .feature-section .note-area .top-txt {
    margin-bottom: 24px;
  }
  .home .feature-section .note-area .accordion-area .accordion-btn {
    padding-block: 18px;
    padding-left: clamp(2.625rem, -0.232rem + 14.286vw, 3.25rem);
  }
  .home .feature-section .note-area .accordion-area .accordion-btn .inn-txt {
    font-size: 14px;
  }
  .home .feature-section .note-area .accordion-area .accordion-btn .line {
    width: 24px;
  }
  .home .coordinate-section .c-gray-ttl .ttl {
    font-size: clamp(3.5rem, 3.241rem + 1.061vw, 3.75rem);
  }
  .home .coordinate-section .coordinate-list-area .ttl-area {
    margin-block: 20px 72px;
  }
  .home .coordinate-section .coordinate-list-area .ttl-area .ttl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    row-gap: 8px;
  }
  .home .coordinate-section .coordinate-list-area .ttl-area .ttl .logo-wrap {
    max-width: 320px;
  }
  .home .coordinate-section .coordinate-list-area .ttl-area .ttl .sub-ttl {
    font-size: 14px;
  }
  .home .coordinate-section .coordinate-list-area .coordinate-list li + li {
    margin-top: 36px;
  }
  .home .coordinate-section .coordinate-list-area .coordinate-list li .ttl {
    margin-bottom: 12px;
    gap: 11px;
    font-size: 14px;
  }
  .home .coordinate-section .coordinate-list-area .coordinate-list li .ttl::before {
    font-size: 22px;
  }
  .home .showroom-section {
    padding-block: 100px;
  }
  .home .showroom-section .ttl {
    font-size: 16px;
    line-height: 2.5;
  }
  .home .showroom-section .c-btn-wrap {
    row-gap: 32px;
  }
  .home .showroom-section .c-btn-wrap .c-btn01 {
    padding: 16px 22px 16px 36px;
  }
}
@media only screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
  .inner-block {
    padding-inline: 40px;
    max-width: 1180px;
  }
  .ib-pc {
    display: inline-block;
  }
  .sp {
    display: none !important;
  }
  .c-footer .wrap .link-area {
    margin-left: auto;
  }
  .home .reason-section {
    display: grid;
    grid-template-columns: clamp(300px, 33vw, 600px) 1fr;
    grid-template-areas: "img contents";
    gap: clamp(24px, 2.92vw, 40px);
  }
  .home .reason-section::after {
    background-position: left -210px;
    background-size: 733px 683px;
  }
  .home .reason-section > .inner-block {
    -webkit-align-self: center;
        -ms-flex-item-align: center;
            align-self: center;
    width: 100%;
    max-width: 960px;
  }
  .home .reason-section h2.ttl {
    margin-top: 52px;
  }
  .home .reason-section .reason-list-area {
    margin-top: 40px;
    margin-bottom: 52px;
  }
  .home .reason-section .img-area {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 16px;
    height: 100%;
  }
  .home .reason-section .img-area .img {
    width: 100%;
    max-width: 300px;
  }
  .home .reason-section .img-area .img:nth-child(2) {
    margin-top: auto;
    margin-left: auto;
  }
  .home .series-section .series-area .desc-area {
    padding-block: 80px;
    display: grid;
    grid-template-areas: "ttl ttl" "txt btn";
    gap: 32px 16px;
  }
  .home .series-section .series-area .ttl {
    grid-area: ttl;
  }
  .home .series-section .series-area .txt {
    grid-area: txt;
  }
  .home .series-section .series-area .c-btn-wrap {
    grid-area: btn;
    justify-self: end;
    align-self: end;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
  .home .feature-section .feature-area.lighting::after {
    background-position: left -80px;
    background-size: 150%;
    width: clamp(200px, 19.39vw, 265px);
    height: 100%;
    right: 0;
    top: 0;
  }
  .home .feature-section .feature-area.lighting .inner-block {
    padding-left: 0;
    padding-right: 28px;
  }
  .home .feature-section .feature-area.lighting .inner-block::before {
    width: clamp(101px, 36vw + 1px, 377px);
    height: 102px;
    left: -1px;
    top: -1px;
  }
  .home .feature-section .feature-area.lighting .inner-block::after {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background-color: #0C153E;
    left: calc(100% - 1px);
    top: 0;
  }
  .home .feature-section .feature-area.lighting .contents-wrap {
    grid-template-columns: min(50% - 25px, 522px) min(50% - 25px, 450px);
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    grid-template-areas: "slider text" "btn btn";
  }
  .home .feature-section .feature-area.cleaning::after {
    background-position: -286px top;
    background-size: 630px 662px;
    width: 350px;
    height: 540px;
    left: 0;
    bottom: 0;
  }
  .home .feature-section .feature-area.cleaning .inner-block {
    padding-left: 72px;
    padding-right: 0;
  }
  .home .feature-section .feature-area.cleaning .inner-block::before {
    width: clamp(101px, 36vw + 1px, 377px);
    height: 102px;
    right: -1px;
    top: -1px;
  }
  .home .feature-section .feature-area.cleaning .inner-block::after {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background-color: #0C153E;
    right: calc(100% - 1px);
    top: 0;
  }
  .home .feature-section .feature-area.cleaning .contents-wrap {
    grid-template-columns: min(50% - 25px, 450px) min(50% - 25px, 522px);
    grid-template-areas: "text slider" "btn btn";
    -webkit-box-pack: end;
    -webkit-justify-content: end;
        -ms-flex-pack: end;
            justify-content: end;
  }
  .home .feature-section .feature-area.cleaning .contents-wrap .c-btn-wrap {
    justify-self: start;
  }
  .home .feature-section .feature-area.cleaning .contents-wrap .slider-area .slick-dots {
    -webkit-box-pack: start;
    -webkit-justify-content: flex-start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  .home .feature-section .feature-area .contents-wrap {
    row-gap: 22px;
  }
  .home .feature-section .feature-area .contents-wrap .c-btn-wrap {
    max-width: 450px;
    justify-self: end;
  }
  .home .showroom-section .inner-block {
    max-width: 880px;
  }
}
@media (any-hover: hover) {
  a,
  a::before,
  a::after,
  button,
  button::before,
  button::after {
    -webkit-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
  }
  .c-footer .wrap .sns-area > ul li a:hover {
    -webkit-transform: translateY(5px);
            transform: translateY(5px);
  }
  .c-footer .wrap .link-area > ul li a:hover {
    -webkit-text-decoration-color: #fff;
            text-decoration-color: #fff;
  }
  .slick-dots li button:hover {
    background-color: #fff;
  }
  .c-btn01:hover {
    background-color: #242424;
    color: #fff;
  }
  .c-btn01.white:hover {
    background-color: rgba(255, 255, 255, 0.5);
    color: #0C153E;
  }
  .c-btn01.blue:hover {
    background-color: rgba(184, 189, 214, 0.5);
    color: #0C153E;
  }
  .c-btn01.transparent:hover {
    background-color: #fff;
    color: #242424;
  }
  .c-btn02:hover {
    background-color: #B8BDD6;
  }
  .home .feature-section .note-area .accordion-area .accordion-btn:hover {
    background-color: #B8BDD6;
  }
}
@media only screen and (max-width: 767px) and (max-width: 390px) {
  .c-footer .wrap .link-area {
    font-size: clamp(0.75rem, 0.179rem + 2.857vw, 0.875rem);
  }
  .c-footer .wrap .link-area .copyright {
    font-size: clamp(0.75rem, 0.179rem + 2.857vw, 0.875rem);
  }
  .home .feature-section .feature-area .contents-wrap .ttl .inn-txt {
    font-size: clamp(1.375rem, 0.804rem + 2.857vw, 1.5rem);
  }
  .home .coordinate-section .c-gray-ttl .ttl {
    font-size: clamp(3rem, 0.714rem + 11.429vw, 3.5rem);
  }
  .home .showroom-section .ttl {
    font-size: clamp(0.875rem, 0.304rem + 2.857vw, 1rem);
  }
}
@media (prefers-reduced-motion: no-preference) {
  .js--scroll-item {
    opacity: 0;
    translate: 0 20px;
    -webkit-transition: opacity 0.6s ease-out;
    transition: opacity 0.6s ease-out;
  }
  .js--scroll-item.is-shown {
    opacity: 1;
    -webkit-animation: scroll-blur 0.6s 0.2s forwards;
            animation: scroll-blur 0.6s 0.2s forwards;
  }
  .js--scroll-item.no-translate {
    translate: 0 0;
  }
  .js--scroll-item.to-bottom {
    translate: 0 -20px;
  }
  .js--scroll-item.to-left {
    translate: 20px 0;
  }
  .js--scroll-item.to-right {
    translate: -20px 0;
  }
  @-webkit-keyframes scroll-blur {
    100% {
      translate: 0 0;
    }
  }
  @keyframes scroll-blur {
    100% {
      translate: 0 0;
    }
  }
  .c-btn01.animate {
    outline-width: 1px;
    outline-offset: 0;
    outline-color: #bcc7f8;
    outline-style: solid;
    -webkit-animation: animateOutline 4s ease infinite;
            animation: animateOutline 4s ease infinite;
  }
  @-webkit-keyframes animateOutline {
    0% {
      outline-width: 1px;
      outline-offset: 0;
      outline-color: rgba(0, 130, 206, 0);
    }
    10% {
      outline-color: #bcc7f8;
    }
    /* The animation finishes at 50% */
    50% {
      outline-width: 7px;
      outline-offset: 4px;
      outline-color: rgba(0, 130, 206, 0);
    }
    100% {
      outline-width: 7px;
      outline-offset: 4px;
      outline-color: rgba(102, 102, 102, 0);
    }
  }
  @keyframes animateOutline {
    0% {
      outline-width: 1px;
      outline-offset: 0;
      outline-color: rgba(0, 130, 206, 0);
    }
    10% {
      outline-color: #bcc7f8;
    }
    /* The animation finishes at 50% */
    50% {
      outline-width: 7px;
      outline-offset: 4px;
      outline-color: rgba(0, 130, 206, 0);
    }
    100% {
      outline-width: 7px;
      outline-offset: 4px;
      outline-color: rgba(102, 102, 102, 0);
    }
  }
}
@media only screen and (prefers-reduced-motion: no-preference) and (min-width: 768px) {
  .js--scroll-item.no-translate-pc {
    translate: 0 0;
  }
  .js--scroll-item.to-top-pc {
    translate: 0 20px;
  }
  .js--scroll-item.to-bottom-pc {
    translate: 0 -20px;
  }
  .js--scroll-item.to-left-pc {
    translate: 20px 0;
  }
  .js--scroll-item.to-right-pc {
    translate: -20px 0;
  }
}
@media only screen and (prefers-reduced-motion: no-preference) and (max-width: 767px) {
  .js--scroll-item.no-translate-sp {
    translate: 0 0;
  }
  .js--scroll-item.to-top-sp {
    translate: 0 20px;
  }
  .js--scroll-item.to-bottom-sp {
    translate: 0 -20px;
  }
  .js--scroll-item.to-left-sp {
    translate: 20px 0;
  }
  .js--scroll-item.to-right-sp {
    translate: -20px 0;
  }
}
@media only screen and (max-width: 390px) {
  .home .mv-section .top-area .text-area .txt {
    font-size: clamp(0.938rem, 0.08rem + 4.286vw, 1.125rem);
  }
  .home .series-section .series-area .ttl .sub-txt {
    font-size: clamp(0.563rem, -0.009rem + 2.857vw, 0.688rem);
  }
}
@media only screen and (min-width: 768px) and (max-width: 960px) {
  .home .reason-section .img-area .img {
    max-width: 250px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 840px) {
  .home .series-section .series-area .txt {
    font-size: clamp(1rem, -0.333rem + 2.778vw, 1.125rem);
  }
}
@media only screen and (min-width: 1180px) {
  .home .feature-section .feature-area.cleaning .contents-wrap .slider-area {
    position: relative;
  }
}