@charset "UTF-8";
.site-main {
  margin-top: 9.2rem;
}

.site-container {
  position: relative;
}

.section-wrap {
  width: 100%;
  padding: 10rem 3rem 11.2rem;
}

.content + .content {
  margin-top: 8rem;
}

.youtubeWrap {
  width: 100%;
  max-width: 960px;
  margin: 0 auto;
  aspect-ratio: 16/9;
}
.youtubeWrap.md {
  max-width: 700px;
}
.youtubeWrap iframe {
  width: 100%;
  height: 100%;
  vertical-align: bottom;
}

.sliderType-01 .slick-arrow {
  width: 5.8rem;
  height: 5.8rem;
  border-radius: 50%;
  background-color: var(--color-primary);
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  position: absolute;
  top: 50%;
  margin-top: -2.9rem;
  z-index: 9;
}
.sliderType-01 .slick-arrow::before, .sliderType-01 .slick-arrow::after {
  content: "";
  background-color: #FFF;
  position: absolute;
}
.sliderType-01 .slick-arrow::before {
  width: 2.2rem;
  height: 2px;
  top: 50%;
  left: 50%;
  margin-top: 0.2rem;
  margin-left: -1.1rem;
}
.sliderType-01 .slick-arrow::after {
  width: 1rem;
  height: 2px;
  top: 50%;
  margin-top: 0.2rem;
}
.sliderType-01 .slick-prev {
  left: -2.9rem;
}
.sliderType-01 .slick-prev::after {
  transform: rotate(-45deg);
  transform-origin: left bottom;
  right: 50%;
}
.sliderType-01 .slick-next {
  right: -2.9rem;
}
.sliderType-01 .slick-next::after {
  transform: rotate(45deg);
  transform-origin: right bottom;
  left: 50%;
}

.spOnly {
  display: none;
}
@media screen and (max-width: 833px) {
  .spOnly {
    display: inherit;
  }
}

.headline-01 {
  margin-bottom: 3.6rem;
  text-align: center;
  line-height: 1;
}
.headline-01 .title {
  font-family: "Playfair Display", serif;
  font-size: 7rem;
  font-weight: 400;
  letter-spacing: 0.05em;
}
.headline-01 .caption {
  margin-top: 1em;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  display: block;
  font-weight: 500;
}
.headline-01.light {
  color: #FFF;
}
.headline-02 {
  margin-bottom: 0.75em;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 2.4rem;
  font-weight: 500;
}
.headline-03 {
  margin-bottom: 3rem;
  padding-bottom: 0.3em;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 2.6rem;
  font-weight: 500;
  border-bottom: 2px solid #000;
}
.headline-04 {
  margin-bottom: 5rem;
  text-align: center;
  line-height: 1;
}
.headline-04::after {
  content: "";
  width: 5rem;
  height: 2px;
  margin: 3rem auto 0;
  display: block;
  background-color: var(--color-primary);
}
.headline-04 .title {
  font-family: "Playfair Display", serif;
  font-size: 4.5rem;
  font-weight: 400;
  letter-spacing: 0.05em;
}
.headline-04 .caption {
  margin-top: 1em;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  display: block;
  font-weight: 500;
}

.btn {
  width: fit-content;
  display: block;
}
.btn-center {
  margin-right: auto;
  margin-left: auto;
}
.btn-more {
  width: 30rem;
  max-width: 100%;
  margin-top: 6rem;
  padding: 1.6rem 3rem 1.6rem 4.5rem;
  display: block;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 1.6rem;
  font-weight: 700;
  color: #FFF;
  text-align: center;
  line-height: 1.5;
  background-color: var(--color-primary);
  position: relative;
}
.btn-more::before, .btn-more::after {
  content: "";
  background-color: #FFF;
  position: absolute;
}
.btn-more::before {
  width: 2.4rem;
  height: 2px;
  top: 50%;
  left: 1.6rem;
  margin-top: 0.2rem;
}
.btn-more::after {
  width: 1rem;
  height: 2px;
  transform: rotate(45deg);
  transform-origin: right bottom;
  top: 50%;
  left: 3rem;
  margin-top: 0.2rem;
}

.btn-more.color2 {
  background-color: #00C100;
}
.btn-more.outline {
  background-color: #FFF;
  border: 2px solid var(--color-primary);
  color: #333333;
}
.btn-more.outline::before, .btn-more.outline::after {
  content: "";
  background-color: var(--color-primary);
}
.btn-more.fit {
  width: fit-content;
  padding-right: 3rem;
  padding-left: 5.4rem;
}
.btn-top {
  width: 5.2rem;
  height: 5.2rem;
  background-color: var(--color-primary);
  position: fixed;
  right: 2rem;
  bottom: 2.4rem;
}
.page-id-269 .btn-top, .page-id-333 .btn-top, .page-id-337 .btn-top {
  background-color: #000;
}
.btn-top::before, .btn-top::after {
  content: "";
  width: 2rem;
  height: 0.2rem;
  background-color: #FFF;
  border-radius: 0.2rem;
  display: block;
  position: absolute;
  margin-top: -1rem;
}
.btn-top::before {
  transform: rotate(-45deg);
  transform-origin: right center;
  top: 50%;
  right: 50%;
}
.btn-top::after {
  transform: rotate(45deg);
  transform-origin: left center;
  top: 50%;
  left: 50%;
}
.btn-group {
  display: flex;
  justify-content: center;
}
.btn-group .btn {
  margin: 0;
}
.btn-group .btn + .btn {
  margin-left: 3rem;
}
.btn-submit {
  width: 24.9rem;
  max-width: 100%;
  margin-top: 6.4rem;
  padding: 2rem 3rem 2rem 4.5rem;
  display: block;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 1.6rem;
  font-weight: 500;
  color: #FFF;
  text-align: center;
  line-height: 1;
  background-color: var(--color-primary);
}
.btn-confirm {
  width: 24.9rem;/*30rem;*/
  max-width: 100%;
  margin-top: 6.4rem;
  padding: 2rem 3rem 2rem 4.5rem;
  display: block;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 1.6rem;
  font-weight: 500;
  color: #FFF;
  text-align: center;
  line-height: 1.3;
  background-color: var(--color-primary);
}
.page-id-269 .btn-confirm, .page-id-333 .btn-confirm, .page-id-337 .btn-confirm, 
.page-id-269 .btn-submit, .page-id-333 .btn-submit, .page-id-337 .btn-submit {
  background-color: #000;
}

.submit-area {
  position: relative;
}
.submit-area::before, .submit-area::after {
  content: "";
  background-color: #FFF;
  position: absolute;
}
.submit-area::before {
  width: 2.4rem;
  height: 1px;
  top: 50%;
  left: 1.6rem;
  margin-top: 0.2rem;
}
.submit-area::after {
  width: 1rem;
  height: 1px;
  transform: rotate(45deg);
  transform-origin: right bottom;
  top: 50%;
  left: 3rem;
  margin-top: 0.2rem;
}

.text-center {
  text-align: center;
}
.text-right {
  text-align: right;
}
.text-serif {
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
}
.text-caution {
  color: #E30A20;
}
.text-bold {
  font-weight: bold;
}
.text-accent {
  color: var(--color-primary);
}
.text-lg {
  font-size: 2.4rem;
}
.text-md {
  font-size: 1.8rem;
}
.text-sm {
  font-size: 1.2rem;
}

@media (min-width: 834px) {
  .text-center-pc {
    text-align: center;
  }
}
.img-round {
  border-radius: 1.2rem;
  overflow: hidden;
}
.img-round img {
  width: 100%;
}
.img-fit img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

ul {
  list-style-type: none;
}
ul.dot {
  list-style-type: none;
}
ul.dot li {
  text-indent: -1.1em;
  margin-left: 1.1em;
}
ul.dot li:before {
  content: "・";
}
ul.dot li:not(:last-child) {
  margin-bottom: 0.3em;
}
ul.note {
  list-style-type: none;
}
ul.note li {
  text-indent: -1.1em;
  margin-left: 1.1em;
}
ul.note li:before {
  content: "※";
  font-family: sans-serif;
}
ul.note li:not(:last-child) {
  margin-bottom: 0.3em;
}

.ol-type01 {
  counter-reset: number 0;
}
.ol-type01 li {
  padding-left: 3em;
  text-indent: -3em;
  list-style: none;
}
.ol-type01 li::before {
  counter-increment: number 1;
  content: "（" counter(number) "）";
}
.ol-type01 li:not(:last-child) {
  margin-bottom: 0.5em;
}
.ol-type02 {
  counter-reset: number 0;
}
.ol-type02 li {
  padding-left: 1.2em;
  text-indent: -1.2em;
  list-style: none;
}
.ol-type02 li::before {
  counter-increment: number 1;
  content: counter(number) ". ";
}
.ol-type02 li:not(:last-child) {
  margin-bottom: 0.5em;
}

.pager-number {
  margin-top: 10rem;
  display: flex;
  justify-content: center;
}
.pager-number .page-numbers {
  width: 3.6rem;
  height: 3.6rem;
  margin: 0 0.6rem;
  background-color: #FFF;
  border-radius: 50%;
  font-size: 1.6rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pager-number .page-numbers.current {
  background-color: #000;
  color: #FFF;
}
.pager-number .prev, .pager-number .next {
  width: auto;
  position: relative;
}
.pager-number .prev::before, .pager-number .prev::after, .pager-number .next::before, .pager-number .next::after {
  content: "";
  width: 1.2rem;
  height: 1px;
  background-color: #000;
  border-radius: 1px;
  position: absolute;
}
.pager-number .prev::before, .pager-number .next::before {
  bottom: 50%;
  margin-bottom: -1px;
}
.pager-number .prev::after, .pager-number .next::after {
  top: 50%;
}
.pager-number .prev {
  padding-left: 2.5rem;
}
.pager-number .prev::before {
  left: 0;
  transform: rotate(-45deg);
  transform-origin: left bottom;
}
.pager-number .prev::after {
  left: 0;
  transform: rotate(45deg);
  transform-origin: left top;
}
.pager-number .next {
  padding-right: 2.5rem;
}
.pager-number .next::before {
  right: 0;
  transform: rotate(45deg);
  transform-origin: right bottom;
}
.pager-number .next::after {
  right: 0;
  transform: rotate(-45deg);
  transform-origin: right top;
}

@media (min-width: 834px) {
  .l-column {
    display: flex;
    flex-wrap: wrap;
  }
  .l-column + .l-column {
    margin-top: 8rem;
  }
  .l-column.reverse {
    flex-direction: row-reverse;
  }
  .l-column.reverse .fixed-width {
    justify-content: flex-start;
  }
  .l-column.type01 {
    justify-content: space-between;
  }
  .l-column.type01 .image {
    width: 47.5%;
  }
  .l-column.type01 .image img + img {
    margin-top: 3.2rem;
  }
  .l-column.type01 .text {
    width: 48%;
  }
  .l-column.type01 .title {
    margin-bottom: 0.5em;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
    font-size: 2.6rem;
    font-weight: 500;
  }
  .l-column.col-half {
    justify-content: space-between;
  }
  .l-column.col-half .col-inner {
    width: 50%;
  }
  .l-column.col-half .pd-left {
    padding-left: 100px;
  }
  .l-column.col2 {
    margin-bottom: -5%;
    justify-content: space-between;
  }
  .l-column.col2 .col-inner {
    width: 47.5%;
    margin-bottom: 5%;
  }  
  .l-column.col3 {
    margin-bottom: -3.8%;
  }
  .l-column.col3 .col-inner {
    width: 30.8%;
    margin: 0 3.8% 3.8% 0;
  }
  .l-column.col3 .col-inner:nth-child(3n) {
    margin-right: 0;
  }
  .l-column.col4 {
    margin-bottom: -3%;
  }
  .l-column.col4 .col-inner {
    width: 22.75%;
    margin: 0 3% 3% 0;
  }
  .l-column.col4 .col-inner:nth-child(4n) {
    margin-right: 0;
  }
  .l-column.col5 {
    margin-bottom: -2.5%;
  }
  .l-column.col5 .col-inner {
    width: 18%;
    margin: 0 2.5% 2.5% 0;
  }
  .l-column.col5 .col-inner:nth-child(5n) {
    margin-right: 0;
  }
  .l-column.vCenter {
    align-items: center;
  }
  .l-column.hzCenter {
    justify-content: center;
  }
  .l-column.hzCenter .col-inner:last-child {
    margin-right: 0;
  }
  .l-column .fixed-width {
    display: flex;
    justify-content: flex-end;
  }
  .l-column .fixed-width img {
    max-width: none;
    flex: none;
  }
}
.column-overflow {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
.column-overflow.reverse {
  flex-direction: row-reverse;
}
.column-overflow.right {
  margin-right: calc(50% - 50vw);
}
.column-overflow.right .image-area {
  border-radius: 12px 0 0 12px;
  overflow: hidden;
}
.column-overflow.left {
  margin-left: calc(50% - 50vw);
}
.column-overflow.left .image-area {
  border-radius: 0 12px 12px 0;
  overflow: hidden;
}
.column-overflow.v-bottom {
  align-items: flex-end;
}
.column-overflow .text-area {
  flex: none;
}

.site-header {
  width: 100%;
  padding: 2rem 4rem 2rem 2rem;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999;
  background-color: #FFF;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: #FFFFFF;
  box-shadow: 0 0 16px rgba(0, 0, 0, 0.1);
}
.site-header a {
  color: #222222;
}

.header-title {
  line-height: 0;
}
.header-title a {
  display: block;
}

.menu-header-menu-container {
  margin-left: auto;
  font-size: 1.6rem;
}

.header-sub-menu {
  display: none;
}

.sub-menu-title {
  width: 36.6rem;
  padding: 0 2.8rem;
  background-color: #000000;
  color: #FFF;
  flex: none;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sub-menu-title .headline-01 {
  margin: auto;
}
.sub-menu-title .headline-01 .title {
  font-size: 4rem;
  line-height: 1.125;
}

@media screen and (min-width: 1120px) {
  .menu-header-menu-container ul {
    display: flex;
  }
  .menu-header-menu-container li:not(:last-child) {
    margin-right: 1.4375em;
  }
  .menu-header-menu-container .has-child {
    margin-bottom: -5rem;
    padding-bottom: 5rem;
  }
  .sub-menu-tggle {
    display: none;
  }
  .header-sub-menu {
    width: 100%;
    background-color: #FFF;
    position: fixed;
    top: 9.4rem;
    left: 0;
  }
  .header-sub-menu .inner {
    display: flex;
  }
  .sub-menu-list {
    width: 100%;
    margin-bottom: -1.4375em;
    padding: 2.5rem 2.8rem;
    flex-wrap: wrap;
  }
  .sub-menu-list li {
    width: 22.5rem;
    margin-bottom: 1.4375em;
    text-align: center;
    line-height: 1;
    flex: none;
  }
  .sub-menu-list .sub-image {
    width: 100%;
    margin-bottom: 0.8rem;
    padding-bottom: 65.8%;
    background-color: #CCC;
    position: relative;
  }
  .sub-menu-list .sub-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
  }
}
@media screen and (max-width: 1119px) {
  .main-navigation {
    display: contents;
  }
  .main-navigation.toggled .menu-header-menu-container {
    display: block;
  }
  .menu-header-menu-container {
    display: none;
    width: 100%;
    height: 100%;
    padding-top: 6rem;
    padding-bottom: 3rem;
    background-color: rgba(0, 0, 0, 0.8);
    overflow-y: auto;
    position: fixed;
    top: 0;
    left: 0;
  }
  .menu-header-menu-container li {
    padding: 0.7em 0;
    border-bottom: 1px solid #FFF;
    text-align: center;
  }
  .menu-header-menu-container a {
    color: #FFF;
  }
  .menu-header-menu-container .has-child {
    position: relative;
  }
  .sub-menu-tggle {
    width: 3.4rem;
    height: 3.4rem;
    position: absolute;
    top: 0.7rem;
    right: 2rem;
  }
  .sub-menu-tggle::before, .sub-menu-tggle::after {
    content: "";
    background-color: #FFF;
    position: absolute;
  }
  .sub-menu-tggle::before {
    width: 2.3rem;
    height: 0.1rem;
    top: 50%;
    left: 0.6rem;
  }
  .sub-menu-tggle::after {
    width: 0.1rem;
    height: 2.3rem;
    top: 0.6rem;
    left: 50%;
    transition: transform 0.3s ease-in-out;
  }
  .sub-menu-tggle.open::after {
    transform: rotate(90deg);
  }
  .sub-menu-title {
    display: none;
  }
  .sub-menu-list {
    margin-top: 0.7em;
    margin-bottom: -0.7em;
    position: relative;
  }
  .sub-menu-list::before {
    content: "";
    width: 100%;
    height: 100%;
    background-color: var(--color-primary);
    opacity: 0.5;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
  }
  .sub-menu-list li {
    border-top: 1px solid #FFF;
    border-bottom: none;
  }
  .sub-menu-list .sub-image {
    display: none;
  }
}
.hamburger-menu {
  z-index: 99;
}
.hamburger-menu > div {
  width: 4rem;
  height: 2.8rem;
  cursor: pointer;
  position: relative;
}
.hamburger-menu span {
  width: 100%;
  height: 0.3rem;
  display: block;
  position: absolute;
  left: 0;
  background: #000000;
  transition: 0.35s ease-in-out;
}
.hamburger-menu span:nth-child(1) {
  top: 0;
}
.hamburger-menu span:nth-child(2) {
  top: 1.2rem;
}
.hamburger-menu span:nth-child(3) {
  top: 2.4rem;
}
.hamburger-menu[aria-expanded=true] span {
  background: #FFF;
}
.hamburger-menu[aria-expanded=true] span:nth-child(1) {
  top: 1.2rem;
  transform: rotate(315deg);
}
.hamburger-menu[aria-expanded=true] span:nth-child(2) {
  opacity: 0;
  transform: rotate(360deg);
}
.hamburger-menu[aria-expanded=true] span:nth-child(3) {
  top: 1.2rem;
  transform: rotate(-315deg);
}

@media screen and (min-width: 1120px) {
  .hamburger-menu {
    display: none;
  }
}
.site-footer {
  padding: 4.7rem 3rem 4rem;
  border-top: 2px solid var(--color-primary);
}
.site-footer .site-navi {
  margin-bottom: -1em;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1;
  display: flex;
  flex-wrap: wrap;
}
.site-footer .site-navi li {
  margin-bottom: 1em;
}
.site-footer .site-navi li:not(:last-child) {
  margin-right: 1.56em;
}
.site-footer .btn-contact {
  width: 24.6rem;
  max-width: 100%;
  margin-top: 2rem;
  padding: 1.8rem 3rem 1.8rem 4.5rem;
  display: block;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 1.6rem;
  font-weight: 500;
  color: #FFF;
  text-align: center;
  line-height: 1.3;
  background-color: #000;
  position: relative;
}
.site-footer .address {
  margin-top: 1em;
  line-height: 1.625;
}
.site-footer .banner {
  display: block;
  width: fit-content;
}
.site-footer .banner + .link-privacy {
  margin-top: 2rem;
}
.site-footer .link-privacy {
  font-size: 1.4rem;
  display: inline-block;
}

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

.footer-title {
  margin-bottom: 2rem;
  line-height: 0;
}
.footer-title a {
  display: block;
}

.footer-navi {
  width: 66%;
}
.footer-navi .menu {
  margin-bottom: -5rem;
  display: flex;
  flex-wrap: wrap;
}
.footer-navi .menu > li {
  width: 25%;
  margin-bottom: 5rem;
}
.footer-navi .menu > li > a {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 1.6rem;
}
.footer-navi .sub-menu {
  margin-top: 1.6rem;
  font-size: 1.4rem;
}
.footer-navi .sub-menu li + li {
  margin-top: 0.4em;
}
.footer-navi .sub-menu a {
  color: #666666;
}

.copyright {
  margin-top: 1.5em;
  font-size: 1.2rem;
  line-height: 1;
}

*:focus {
  outline: none;
}

input::-webkit-input-placeholder {
  color: rgba(51, 51, 51, 0.3);
}
input:-ms-input-placeholder {
  color: rgba(51, 51, 51, 0.3);
}
input::-moz-placeholder {
  color: rgba(51, 51, 51, 0.3);
}
input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0px 1000px #F5F5F5 inset;
}

textarea {
  vertical-align: bottom;
}
textarea::-webkit-input-placeholder {
  color: rgba(51, 51, 51, 0.3);
}
textarea:-ms-input-placeholder {
  color: rgba(51, 51, 51, 0.3);
}
textarea::-moz-placeholder {
  color: rgba(51, 51, 51, 0.3);
}
textarea:-webkit-autofill {
  -webkit-box-shadow: 0 0 0px 1000px #F5F5F5 inset;
}

select {
  appearance: none;
  background-image: url(../../images/contact/arrow_select.png);
  background-repeat: no-repeat;
  background-position: right 1.1rem center;
  background-size: 1.55rem;
}
select::-ms-expand {
  display: none;
}
select.form-control {
  width: auto;
  padding-right: 5rem;
}

.radio-wrap.horizon {
  margin-bottom: -20px;
  padding-top: 20px;
  padding-bottom: 20px;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.radio-wrap.horizon > * {
  margin-right: 32px;
  margin-bottom: 20px;
}
.radio-wrap.horizon > *:last-child {
  margin-right: 0;
}
.radio-wrap.vertical > *:not(:last-child) {
  margin-bottom: 1em;
}

.radio {
  position: absolute;
  opacity: 0;
}
.radio + span {
  display: flex;
  align-items: center;
  line-height: 1;
}
.radio + span:before {
  content: "";
  border-radius: 4px;
  border: 1px solid #E2E2E2;
  display: inline-block;
  width: 24px;
  height: 24px;
  position: relative;
  top: 0;
  margin-right: 0.5em;
  vertical-align: top;
  cursor: pointer;
  text-align: center;
  transition: all 0.3s ease;
}
.radio:checked + span:before {
  background-color: #FFF;
  box-shadow: inset 0 0 0 7px #E30A20;
  border-color: #E30A20;
}
.radio:focus + span:before {
  outline: none;
  border-color: #E30A20;
}
.radio:disabled + span:before {
  box-shadow: inset 0 0 0 4px #f4f4f4;
  border-color: #b4b4b4;
  background: #b4b4b4;
}
.radio + span:empty:before {
  margin-right: 0;
}

.checkbox-wrap {
  padding-top: 18px;
  padding-bottom: 18px;
}

.checkbox-list.horizon {
  margin-bottom: -1.75em;
}
.checkbox-list.horizon .check-label {
  margin-bottom: 1.75em;
  display: inline-block;
}
.checkbox-list.horizon .check-label:not(:last-child) {
  margin-right: 2em;
}

.checkbox-input {
  display: none;
}
.checkbox-input:checked + .checkbox-parts:before {
  border-color: var(--color-primary);
  background-color: var(--color-primary);
}
.checkbox-input:checked + .checkbox-parts:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0.5rem;
  width: 0.6rem;
  height: 1rem;
  transform: rotate(40deg);
  border-bottom: 0.2rem solid #FFF;
  border-right: 0.2rem solid #FFF;
  margin-top: -0.75rem;
}

.checkbox-parts {
  padding-left: 2.6rem;
  position: relative;
}
.checkbox-parts:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 1.6rem;
  height: 1.6rem;
  border: 1px solid #000;
  border-radius: 0;
  margin-top: -9px;
}

.form-area {
  margin-right: auto;
  margin-left: auto;
}
.form-area .link-button {
  margin-top: 80px;
}

.form-group:not(:last-of-type) {
  margin-bottom: 80px;
}

.form-horizon .form-box {
  display: flex;
  align-items: flex-start;
}
.form-horizon .form-box dt {
  width: 36%;
  padding-top: 17px;
  flex: none;
  position: relative;
}
.form-horizon .form-box dd {
  width: 100%;
  position: relative;
}
.form-horizon.confirm dt {
  padding-top: 0.4rem;
}

.form-vertical .form-box dt {
  margin-bottom: 12px;
}

.form-box:not(:last-child) {
  margin-bottom: 4rem;
}
.form-box dt {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
  position: relative;
}
.form-box .form-inner:not(:last-child) {
  margin-bottom: 12px;
}
.form-box .required::before {
  padding: 0.4rem 0.7rem;
  color: #FFF;
  font-size: 1.4rem;
  font-weight: bold;
  background-color: #AB0000;
}
.form-box .required_jp::before {
  content: "必須";
  margin-right: 0.4rem;
}
.form-box .required_en::before {
  content: "required";
  margin: 0 0.7rem;
}
.form-box .error {
  margin-top: 0.5em;
  color: #E30A20;
  font-size: 13px;
}
.form-box .note {
  margin-top: 1em;
  color: #868585;
}

.form-column {
  display: flex;
  align-items: center;
}
.form-column .col-inner {
  width: 100%;
  align-items: flex-start;
}
.form-column .col-inner:not(:last-of-type) {
  margin-right: 12px;
}
.form-column .col-inner + .note {
  margin-left: 20px;
}
.form-column .label {
  margin-right: 1em;
  flex: none;
  font-size: 14px;
}
.form-column .spacer {
  width: 20px;
  display: block;
}

.form-control {
  width: 100%;
  padding: 1.2rem 1em;
  background-color: #FFF;
  border: 1px solid #CCC;
  border-radius: 0;
  line-height: 1.5;
}

.form-postcode {
  position: relative;
}
.form-postcode::before {
  content: "〒";
  position: absolute;
  top: 20px;
  left: 1.5em;
}
.form-postcode .form-control {
  padding-left: 2.8em;
}

textarea.form-control {
  height: 23.9rem;
}

.hero-visual {
  width: 100%;
  height: 70rem;
  position: relative;
}

.hero-video {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.hero-video::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: url(../../images/home/splash.png) repeat center/4px;
}
.hero-video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-image {
  width: 100%;
  height: 100%;
}
.hero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-text {
  width: 1128px;
  max-width: 100%;
  margin: 0 auto;
  color: #FFF;
  text-align: center;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}

#products-slider {
  margin-bottom: 0;
}
#products-slider .slick-list {
  overflow: visible;
}
#products-slider .products-card {
  margin: 0 2.25rem;
}
#products-slider20 .products-card {
	margin: 0 1.25rem;
}
#products-slider .slick-arrow {
  top: 12rem;
}

@media (min-width: 1460px) {
  #products-slider .slick-prev {
    left: -13rem;
  }
  #products-slider .slick-next {
    right: -13rem;
  }
}
.home-about {
  background: url(../../images/home/about_bg.jpg) no-repeat center/cover;
  position: relative;
}
.home-about::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.75);
}
.home-about .content {
  position: relative;
}
.home-about h3 {
  margin-bottom: 0.5em;
  font-size: 2.6rem;
  font-weight: 500;
}

.about-archive-list {
  margin: 8rem -1.4rem 0;
}
.about-archive-list .about-card {
  margin: 0 1.4rem;
}
.about-archive-list .slick-prev {
  left: -1.5rem;
}
.about-archive-list .slick-next {
  right: -1.5rem;
}

.about-card {
  border: 1px solid #999999;
}

@media (min-width: 1420px) {
  .about-archive-list .slick-prev {
    left: -9.6rem;
  }
  .about-archive-list .slick-next {
    right: -9.6rem;
  }
}
#voice-slider {
  margin-bottom: 0;
}
#voice-slider .slick-list {
  overflow: visible;
}
#voice-slider .voice-card {
  margin: 0 1.8rem;
}
#voice-slider .slick-arrow {
  top: 15rem;
}

@media (min-width: 1460px) {
  #voice-slider .slick-prev {
    left: -13rem;
  }
  #voice-slider .slick-next {
    right: -13rem;
  }
}
.home-strength {
  margin-top: 7.2rem;
  background: url(../../images/home/strength_bg.jpg) no-repeat center/cover;
  position: relative;
}
.home-strength::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.75);
}
.home-strength .content {
  position: relative;
}
.home-strength .headline-01 {
  text-align: left;
}

.strengt-wrap {
  display: flex;
}
.strengt-wrap .left-area {
  width: 30.2rem;
  margin-right: 4%;
  flex: none;
}
.strengt-wrap .right-area {
  width: 100%;
  display: flex;
  justify-content: space-between;
}

@media (min-width: 834px) {
  .strengt-wrap .headline-01 .title {
    font-size: 6rem;
    letter-spacing: 0.02em;
  }
}
.strength-card {
  width: 30.6%;
  position: relative;
}
.strength-card.up {
  top: -14.5rem;
}
.strength-card.middle {
  top: -3.7rem;
}
.strength-card dt {
  margin-top: -11.2rem;
  margin-left: 1rem;
  color: #FFF;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 2.2rem;
  font-weight: 500;
  line-height: 1;
  position: absolute;
  top: 100%;
  z-index: 2;
}
.strength-card dt span {
  margin-bottom: 1rem;
  font-family: "Playfair Display", serif;
  font-size: 10rem;
  font-weight: 400;
  display: block;
}
.strength-card .image {
  width: 100%;
  padding-bottom: 150%;
  display: block;
  position: relative;
}
.strength-card .image img {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  object-fit: cover;
}

.services-wrap {
  display: flex;
  justify-content: space-between;
}
.services-wrap .inner {
  width: 47.5%;
  display: block;
}
.services-wrap .banner {
  width: 100%;
  padding-bottom: 52.6%;
  display: block;
  position: relative;
}
.services-wrap .banner img {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  object-fit: cover;
}
.services-wrap .text {
  width: 35rem;
  height: 9.2rem;
  color: #FFF;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 2.2rem;
  font-weight: 500;
  background-color: rgba(101, 170, 221, 0.85);
  outline: 1px solid rgba(255, 255, 255, 0.8);
  outline-offset: -0.5rem;
  text-align: center;
  line-height: 1.4545454545;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

#blog-slider {
  margin-bottom: 0;
}
#blog-slider .slick-list {
  overflow: visible;
}
#blog-slider .blog-card {
  margin: 0 1.8rem;
}
#blog-slider .slick-arrow {
  top: 9.7rem;
}

@media (min-width: 1460px) {
  #blog-slider .slick-prev {
    left: -13rem;
  }
  #blog-slider .slick-next {
    right: -13rem;
  }
}
.sns-wrap {
  display: flex;
  justify-content: space-between;
}
.sns-wrap:not(:last-child) {
  margin-bottom: 4.9rem;
}

@media (min-width: 834px) {
  .sns-wrap .line-area {
    width: 62.5%;
  }
}
.line-area {
  max-width: 75rem;
  padding: 2.8rem 5.8rem;
  border: 4px solid #C9F2CA;
}
.line-area h3 {
  margin-bottom: 2.8rem;
  color: #00C100;
  font-size: 3.4rem;
  font-weight: bold;
  text-align: center;
}
.line-area .point {
  margin-bottom: 3.5rem;
  color: #333;
  font-size: 2.3rem;
  font-weight: bold;
  display: flex;
  align-items: center;
}
.line-area .point .label {
  margin-right: 1.2rem;
  padding: 0.56rem 1.2rem;
  color: #FFF;
  background-color: #00C100;
  flex: none;
}
.line-area .point p {
  margin-top: -0.4em;
  line-height: 1.2;
}
.line-area .point .large {
  color: #00C100;
  font-size: 3.6rem;
}
.line-area .line-detail {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.line-area .text-area {
  width: 73.8%;
  color: #333;
  font-size: 1.7rem;
  font-weight: bold;
}
.line-area .text-area p {
  line-height: 1.6470588235;
}
.line-area .line-btn {
  max-width: 30rem;
  padding-left: 4rem;
  height: 5.6rem;
  color: #00C100;
  font-size: 1.6rem;
  font-weight: bold;
  border: 2px solid #00C100;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
.line-area .line-btn::before, .line-area .line-btn::after {
  content: "";
  background-color: #00C100;
  position: absolute;
}
.line-area .line-btn::before {
  width: 2.4rem;
  height: 2px;
  top: 50%;
  left: 1.6rem;
  margin-top: 0.2rem;
}
.line-area .line-btn::after {
  width: 1rem;
  height: 2px;
  transform: rotate(45deg);
  transform-origin: right bottom;
  top: 50%;
  left: 3rem;
  margin-top: 0.2rem;
}
.line-area .qr-area {
  width: 21.4%;
}

.qr-area {
  text-align: center;
}
.qr-area dt {
  margin-bottom: 0.9rem;
  color: #00C100;
  font-size: 1.6rem;
  font-weight: bold;
}

@media (min-width: 835px) and (max-width: 1260px) {
  .sns-wrap .line-area {
    padding-right: 3.8095238095vw;
    padding-left: 3.8095238095vw;
  }
  .sns-wrap .line-area h3 {
    font-size: 2.6984126984vw;
  }
  .sns-wrap .line-area .point {
    font-size: 1.8253968254vw;
  }
  .sns-wrap .line-area .point .large {
    font-size: 2.6984126984vw;
  }
  .sns-wrap .line-area .text-area {
    font-size: 1.3492063492vw;
  }
  .sns-wrap .line-area .qr-area dt {
    font-size: 1.2698412698vw;
  }
}
.sns-widget-area {
  width: 33.5%;
  height: 42rem;
  overflow: hidden;
  background-color: #f1f1f1;
}
.sns-widget-area .inner {
  width: 100%;
  height: 100%;
}

.sns-link-banner .banner {
  width: 47.5%;
  display: block;
}

.home-lead-column .pic {
  width: 100%;
  text-align: center;
}
.home-lead-column .title {
  margin-bottom: 0.75em;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 2.6rem;
  font-weight: 500;
}
.home-lead-column .btn-more {
  margin-top: 4rem;
}

@media (min-width: 834px) {
  .home-lead-column {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .home-lead-column .pic {
    width: 50%;
    flex: none;
  }
}
@media (max-width: 833px) {
  .home-lead-column .pic {
    margin-bottom: 3rem;
  }
  .home-lead-column .title {
    font-size: 2.2rem;
  }
  .home-lead-column .btn-more {
    margin-left: auto;
    margin-right: auto;
  }
}
.home-lead-vertical .pic {
  margin-bottom: 4rem;
  text-align: center;
}

.lower-headline {
  height: 30rem;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.lower-headline .pic {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.lower-headline .pic::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.4);
}
.lower-headline .pic img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.lower-headline .headline-01 {
  margin-bottom: 0;
  color: #FFF;
  position: relative;
  z-index: 2;
}

@media (min-width: 834px) {
  .lower-headline .headline-01 .title br {
    display: none;
  }
}
.breadcrumbs {
  width: 126rem;
  margin-top: 1rem;
  margin-bottom: 1rem;
  padding-right: 3rem;
  padding-left: 3rem;
  font-size: 1.4rem;
}
.breadcrumbs + .section-wrap {
  padding-top: 5rem;
}

.type-page > .section-wrap:first-of-type {
  padding-top: 5rem;
}

.products-archive-list {
  margin-bottom: -8rem;
  display: flex;
  flex-wrap: wrap;
}
.products-archive-list .products-card {
  width: 31%;
  max-width: 37rem;
  margin-right: 3.5%;
  margin-bottom: 8rem;
}
.products-archive-list .products-card:nth-child(3n) {
  margin-right: 0;
}
#products-slider20.products-archive-list {
  margin-bottom: -10rem;
  display: flex;
  flex-wrap: wrap;
}
#products-slider20.products-archive-list .products-card {
  width: 23.125%;
  margin: 0 2.5% 0 0;
}
#products-slider20.products-archive-list .products-card:nth-child(4n) {
  margin-right: 0;
}
#products-slider20.products-card .eye-catch {
  margin-bottom: 1rem;
}
.products-card .eye-catch {
  margin-bottom: 1rem;
}
.products-card .product-name {
  margin-bottom: 0.3em;
  text-align: center;
  font-size: 2.6rem;
}
.products-card .product-text {
  text-align: center;
  line-height: 1.625;
}

.products-search-block {
  margin-bottom: 10rem;
}

.search-group + .search-group {
  margin-top: 4.4rem;
}
.search-group .search-reset {
  margin-top: 3.2rem;
  color: var(--color-primary);
  text-decoration: underline;
  line-height: 1;
}

.search-criteria-box + .search-criteria-box {
  margin-top: 3.2rem;
}
.search-criteria-box dt {
  margin-bottom: 0.4em;
  font-size: 1.8rem;
  font-weight: 700;
}

.switch-criteria {
  opacity: 0.5;
  pointer-events: none;
  transition: opacity 0.3s ease-in-out;
}
.switch-criteria.active {
  opacity: 1;
  pointer-events: auto;
}

.serch-result {
  margin-bottom: 1em;
  font-size: 2.4rem;
}

.product-header {
  max-width: 900px;
  margin: 0 auto 3.6rem;
}

.product-name {
  margin-bottom: 0.6em;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 3.2rem;
  font-weight: 500;
}

.product-slider-block {
  max-width: 900px;
  margin: 0 auto;
}

.product-slider .slick-slide img {
  margin-right: auto;
  margin-left: auto;
}
.product-slider .slick-arrow {
  width: 3.2rem;
  height: 6.2rem;
  position: absolute;
  top: 50%;
  margin-top: -3.1rem;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
.product-slider .slick-arrow::before, .product-slider .slick-arrow::after {
  content: "";
  width: 4.2rem;
  height: 0.4rem;
  background-color: var(--color-primary);
  border-radius: 0.2rem;
  display: block;
  position: absolute;
}
.product-slider .slick-prev {
  margin-right: 6rem;
  right: 100%;
}
.product-slider .slick-prev::before {
  transform: rotate(-45deg);
  transform-origin: right bottom;
  top: 0;
  right: 0;
}
.product-slider .slick-prev::after {
  transform: rotate(45deg);
  transform-origin: right top;
  bottom: 0;
  right: 0;
}
.product-slider .slick-next {
  margin-left: 6rem;
  left: 100%;
}
.product-slider .slick-next::before {
  transform: rotate(45deg);
  transform-origin: left bottom;
  top: 0;
  left: 0;
}
.product-slider .slick-next::after {
  transform: rotate(-45deg);
  transform-origin: left top;
  bottom: 0;
  left: 0;
}

.product-thumbnail {
  margin-top: 0.6rem;
}
.product-thumbnail .slick-track {
  display: flex;
  justify-content: center;
  transform: unset !important;
}
.product-thumbnail .slick-slide {
  width: 20%;
  max-width: 17.5rem;
  padding-bottom: 11.4rem;
  position: relative;
}
.product-thumbnail .slick-slide + .slick-slide {
  margin-left: 0.6rem;
}
.product-thumbnail .slick-slide img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  position: absolute;
  top: 0;
  left: 0;
}

.product-spec-block {
  margin-top: 6.8rem;
}

.spec-list .price-wrap > span + span {
  margin-left: 1em;
}

@media (min-width: 834px) {
  .spec-list {
    display: flex;
    justify-content: space-between;
  }
  .spec-list .inner {
    width: 47.5%;
  }
}
.dl-table dl {
  display: flex;
  border-bottom: 1px solid #CCCCCC;
}
.dl-table dl:first-child {
  border-top: 1px solid #CCCCCC;
}
.dl-table dl:first-child dt::before {
  content: "";
  width: 100%;
  height: 2px;
  background-color: var(--color-primary);
  position: absolute;
  top: -1px;
  left: 0;
}
.dl-table dt {
  width: 20rem;
  padding-top: 1em;
  padding-bottom: 1em;
  flex: none;
  font-weight: 600;
  text-align: center;
  position: relative;
}
.dl-table dt::after {
  content: "";
  width: 100%;
  height: 2px;
  background-color: var(--color-primary);
  position: absolute;
  left: 0;
  bottom: -2px;
}
.dl-table dd {
  width: 100%;
  padding-top: 1em;
  padding-bottom: 1em;
  padding-left: 1.375em;
}
.dl-table a {
  color: var(--color-primary);
  text-decoration: underline;
}

.product-movie-block {
  margin-top: 7.6rem;
}

@media (min-width: 834px) {
  .product-movie-block {
    display: flex;
    justify-content: center;
  }
  .product-movie-block .inner {
    width: 46.7%;
    max-width: 56rem;
  }
  .product-movie-block .inner + .inner {
    margin-left: 8rem;
  }
}
.voice-archive-list {
  margin-bottom: -5rem;
  display: flex;
  flex-wrap: wrap;
}
.voice-archive-list .voice-card {
  width: 22.75%;
  max-width: 27.3rem;
  margin-right: 3%;
  margin-bottom: 5rem;
}
.voice-archive-list .voice-card:nth-child(4n) {
  margin-right: 0;
}

.voice-card {
  text-align: center;
}
.voice-card .eye-catch {
  margin-bottom: 1.2rem;
}
.voice-card .salon-name {
  margin-bottom: 0.3rem;
  font-weight: 700;
  line-height: 1.4;
}
.voice-card .customer-name {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 2.6rem;
  font-weight: 500;
}
.voice-card .use-items {
  margin-top: 1.2rem;
}
.voice-card .use-items dt {
  border: 1px solid #000;
  font-weight: 700;
}
.voice-card .use-items dd {
  margin-top: 0.8rem;
  font-weight: 700;
}
.voice-card .use-items a {
  text-decoration: underline;
}

@media (min-width: 834px) {
  .voice-column {
    display: flex;
    justify-content: space-between;
  }
  .voice-slider-block {
    width: 33.5%;
    max-width: 40rem;
  }
  .voice-detail-block {
    width: 61%;
  }
}
.voice-thumbnail {
  margin-top: 0.4rem;
  margin-right: -0.2rem;
  margin-left: -0.2rem;
}
.voice-thumbnail .slick-slide {
  margin: 0 0.2rem;
}
.voice-thumbnail .slick-slide img {
  width: 100%;
}

.voice-detail-block .user-name {
  margin-bottom: 0.6em;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 2.6rem;
  font-weight: 500;
}

.post-navigation {
  margin-top: 3.8rem;
}
.post-navigation .nav-links {
  padding: 0 3rem;
  display: flex;
  font-weight: 700;
}
.post-navigation .nav-links a {
  position: relative;
}
.post-navigation .nav-links a::before, .post-navigation .nav-links a::after {
  content: "";
  background-color: var(--color-primary);
  position: absolute;
  top: 50%;
  margin-top: 0.2rem;
}
.post-navigation .nav-links a::before {
  width: 2.4rem;
  height: 2px;
}
.post-navigation .nav-links a::after {
  width: 1.2rem;
  height: 2px;
}
.post-navigation .nav-previous {
  margin-right: auto;
}
.post-navigation .nav-previous a {
  padding-left: 3.6rem;
}
.post-navigation .nav-previous a::before {
  left: 0;
}
.post-navigation .nav-previous a::after {
  transform: rotate(-45deg);
  transform-origin: left bottom;
  left: 0;
}
.post-navigation .nav-next {
  margin-left: auto;
}
.post-navigation .nav-next a {
  padding-right: 3.6rem;
}
.post-navigation .nav-next a::before {
  right: 0;
}
.post-navigation .nav-next a::after {
  transform: rotate(45deg);
  transform-origin: right bottom;
  right: 0;
}

.pv-link {
  margin-top: 4rem;
  display: flex;
  justify-content: center;
}
.pv-link > a {
  margin: 0;
}
.pv-link > a + a {
  margin-left: 5rem;
}

.blog-archive-list {
  margin-bottom: -5rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.blog-archive-list .blog-card {
  width: 47%;
  max-width: 37.6rem;
  margin-bottom: 5rem;
}
.blog-archive-list.carousel .blog-card {
  max-width: 27.3rem;
}

.blog-card .eye-catch {
  margin-bottom: 1rem;
}
.blog-card .blog-title {
  margin-top: 0.4em;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 1.8rem;
  font-weight: 500;
}
.blog-card .date {
  font-weight: 700;
}
.blog-card .category {
  margin-left: 0.8em;
  padding: 0 0.4em;
  background-color: #000;
  color: #FFF;
  font-size: 1.4rem;
  display: inline-block;
}

@media (min-width: 834px) {
  .blog-detail {
    padding-top: 5rem;
  }
  .blog-column-wrapper {
    display: flex;
    justify-content: space-between;
  }
  .blog-column-wrapper .main-column {
    width: 66.7%;
    max-width: 80rem;
  }
  .blog-column-wrapper .side-column {
    width: 25%;
    max-width: 30rem;
  }
}
.blog-column-wrapper .main-column .nav-links {
  padding: 0;
}

.blog-header .blog-title {
  margin-bottom: 0.6em;
  padding-bottom: 0.4em;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 3rem;
  font-weight: 500;
  border-bottom: 2px solid #000;
}
.blog-header .blog-info {
  margin-bottom: 2.5rem;
  display: flex;
  align-items: center;
}
.blog-header .date {
  font-weight: 700;
}
.blog-header .category {
  margin-left: 0.8em;
  padding: 0 0.4em;
  background-color: #000;
  color: #FFF;
  font-size: 1.4rem;
}
.blog-header .share-link {
  margin-left: auto;
}

.share-link {
  display: flex;
  align-items: center;
}
.share-link li + li {
  margin-left: 1rem;
}

.post-content h1, .post-content h2, .post-content h3, .post-content h4, .post-content h5, .post-content h6 {
  margin-bottom: 0.5em;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-weight: 500;
}
.post-content h2 {
  font-size: 2.6rem;
}
.post-content .wp-block-image {
  margin-bottom: 3rem;
}
.post-content * + h1, .post-content * + h2, .post-content * + h3, .post-content * + h4, .post-content * + h5, .post-content * + h6 {
  margin-top: 1.5em;
}
.post-content * + .wp-block-image {
  margin-top: 5rem;
}

.widget-area .widget_block + .widget_block {
  margin-top: 4rem;
}
.widget-area .widget_block h2 {
  margin-bottom: 2rem;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 2.4rem;
  font-weight: 500;
  border-bottom: 2px solid #000;
}

.wp-block-categories-list {
  margin-right: -1.2rem;
  margin-bottom: -1.2rem;
  display: flex;
  flex-wrap: wrap;
}
.wp-block-categories-list .cat-item {
  margin-right: 1.2rem;
  margin-bottom: 1.2rem;
  padding: 0.2em 0.5em;
  border: 1px solid #000;
  font-weight: 700;
}

.wp-block-latest-posts__list li {
  display: grid;
  gap: 0.5rem 1rem;
  grid-template-areas: "area01 area02" "area01 area03";
  grid-template-columns: 36% 64%;
}
.wp-block-latest-posts__list li + li {
  margin-top: 2.5rem;
}
.wp-block-latest-posts__list li .wp-block-latest-posts__featured-image {
  height: 7.7rem;
  grid-area: area01;
}
.wp-block-latest-posts__list li .wp-block-latest-posts__featured-image a {
  height: 100%;
  display: block;
}
.wp-block-latest-posts__list li .wp-block-latest-posts__featured-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.wp-block-latest-posts__list li .wp-block-latest-posts__post-date {
  grid-area: area02;
}
.wp-block-latest-posts__list li .wp-block-latest-posts__post-title {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-weight: 500;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  text-align: justify;
  grid-area: area03;
}

.brand-visual-lead {
  height: 40rem;
  margin-bottom: 8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.brand-visual-lead .bg {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.brand-visual-lead .bg::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.4);
}
.brand-visual-lead .bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.brand-visual-lead .text {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  color: #FFF;
  text-align: center;
  position: relative;
  z-index: 2;
}
.brand-visual-lead .logo {
  margin-bottom: 3rem;
}
.brand-visual-lead .logo img {
  width: var(--logo-width);
}
.brand-visual-lead .catch {
  font-size: 3.2rem;
  font-weight: 400;
}
.brand-visual-lead p {
  margin-top: 0.4em;
  font-size: 1.8rem;
  line-height: 1.7777777778;
}

.page-navi-top {
  margin-bottom: 5rem;
}
.page-navi-top .btn-more {
  margin-top: 0;
}

.column-type01 {
  justify-content: space-between;
}
.column-type01 .image {
  width: 31.34%;
}
.column-type01 .text {
  width: 65.41%;
}

.img-border img {
  border: 1px solid #CCC;
}

.cut-img-wrap figcaption {
  margin-top: 0.8rem;
}

.reason-othrer figcaption {
  margin-top: 1.4rem;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 2.2rem;
  font-weight: 500;
  text-align: center;
}

.scissors-detail dt {
  margin-bottom: 1.4rem;
  font-size: 2.2rem;
}
.scissors-detail:not(:last-child) {
  margin-bottom: 3.4rem;
}

.services-nav {
  margin-bottom: 5.4rem;
}
.services-nav .btn-more {
  display: flex;
  justify-content: center;
  align-items: center;
}

.column-type02 {
  justify-content: space-between;
}
.column-type02 .image {
  width: 33.33%;
}
.column-type02 .text {
  width: 62.75%;
}

.column-type03 {
  justify-content: space-between;
}
.column-type03 .image {
  width: 11.08%;
  min-width: 13.2rem;
}
.column-type03 .text {
  width: 85.16%;
}
.column-type03 .text .btn-more {
  margin-top: 0;
}

.column-type04 {
  justify-content: space-between;
}
.column-type04 .image {
  width: 14.04%;
}
.column-type04 .text {
  width: 80.66%;
}
.services-block:not(:last-child) {
  margin-bottom: 10rem;
}
.services-block .services-headline {
  padding: 0.68rem 0;
  color: #FFF;
  font-size: 2.6rem;
  font-weight: bold;
  background-color: var(--color-primary);
  text-align: center;
}
.services-block.green .services-headline {
  background-color: #00C100;
}
.services-block.green dt {
  border-color: #00C100;
}
.services-block.green .service-detail:first-of-type {
  margin-top: 5.5rem;
}
.services-block .service-detail:first-of-type {
  margin-top: 4.5rem;
}
.services-block .service-detail .l-column + .l-column {
  margin-top: 6.5rem;
}
.service-detail:not(:last-child) {
  margin-bottom: 6rem;
}
.service-detail .headline-03 {
  margin-bottom: 4rem;
}
.service-detail .title {
  margin-bottom: 4rem;
  padding-bottom: 0.5rem;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 2.6rem;
  border-bottom: 2px solid #000;
}
.service-detail figcaption {
  margin-bottom: 1rem;
  color: #00C100;
  font-weight: bold;
  text-align: center;
  line-height: 1;
}
.service-detail .dl-table dt {
  width: 65.6%;
}
.service-detail .dl-table dd {
  text-align: center;
}

ul.note.custom {
  margin-top: 3.6rem;
  font-size: 1.4rem;
  line-height: 1.7142857143;
}
ul.note.custom li:not(:last-child) {
  margin-bottom: 0;
}

.services-message {
  margin-top: 1.4rem;
}
.services-message span {
  margin-bottom: 4.6rem;
  display: block;
}

.services-ol {
  margin-left: 1.5em;
  font-weight: bold;
  line-height: 1.875;
}

.maintenance-wrap {
  margin-top: 7rem;
}

.flow-wrap .image {
  height: 16.85rem;
  background-color: #EFF6FC;
  border-radius: 0.85rem;
  border: 2px solid #489BD7;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
.flow-wrap .image figcaption {
  width: 4.7rem;
  height: 4.7rem;
  margin-bottom: 0;
  background-color: var(--color-primary);
  border-radius: 50%;
  line-height: 2;
  position: absolute;
  top: -2.35rem;
  left: -2.35rem;
}
.flow-wrap h4 {
  margin-bottom: 1.7rem;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 2.6rem;
}

.about-fees-wrap {
  margin-bottom: 3rem;
  display: flex;
}

.about-fees dt {
  margin-bottom: 1.4rem;
  color: var(--color-primary);
  font-size: 2.2rem;
}
.about-fees:first-child {
  margin-right: 3.2rem;
}

.service-add {
  font-size: 2.4rem;
  line-height: 1.5;
}
.service-add span {
  font-size: 1.6rem;
  line-height: 1.875;
}

.lower-line {
  display: flex;
  justify-content: center;
}
.lower-line .line-area .text-area {
  width: 70.6%;
}
.lower-line .line-area .qr-area {
  width: 24.9%;
}
.lower-line .line-area .qr-area dt {
  font-size: 1.8rem;
}

.company-nav .btn-more {
  margin-top: 0;
  white-space: nowrap;
}

.greeting-wrap {
  display: flex;
}
.greeting-wrap figure {
  width: 31.3rem;
  margin-right: 5.7rem;
}
.greeting-wrap figure img {
  width: 100%;
}
.greeting-wrap .text-right {
  text-align: right;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-weight: 500;
}
.greeting-wrap .post {
  margin-right: 1.8rem;
  font-size: 2rem;
}
.greeting-wrap .name {
  font-size: 3rem;
}

.greeting-text {
  width: 69.2%;
}

.company-content:first-of-type {
  margin-top: 7.5rem;
}
.company-content:not(:last-child) {
  margin-bottom: 7.5rem;
}
.company-content .bold {
  font-weight: bold;
}

.center-text {
  width: 80rem;
  max-width: 100%;
  margin: 0 auto 5rem auto;
}

.line-content:not(:last-child) {
  margin-bottom: 6rem;
}
.line-content .qr-area {
  margin-top: 5rem;
}
.line-content .qr-area dt {
  font-size: 1.8rem;
}
.line-content .line-add-button {
  max-width: 29.2rem;
}

.line-method {
  display: flex;
}
.line-method li {
  width: 20%;
  margin-right: 6.66%;
  position: relative;
}
.line-method li:nth-child(4) {
  margin-right: 0;
}
.line-method li:not(:last-child):after {
  content: "";
  width: 2.8rem;
  height: 5.2rem;
  background: url(../../images/line/arrow.png) no-repeat center/contain;
  position: absolute;
  top: 16rem;
  right: -22.3%;
}
.line-method figure {
  margin-bottom: 1.7rem;
  text-align: center;
}
.line-method p {
  line-height: 1.625;
}

.line-headline {
  font-size: 2.3rem;
  font-weight: bold;
}
.line-headline .green {
  margin-right: 2.3rem;
  padding: 0.9rem 1.7rem;
  color: #FFF;
  background-color: #00C100;
}
.line-headline .big {
  color: #00C100;
  font-size: 3.6rem;
}

.service-list {
  margin-top: 4.7rem;
  margin-left: 1em;
  font-size: 1.8rem;
  font-weight: bold;
}
.service-list li:not(:last-child) {
  margin-bottom: 4.7rem;
}
.service-list .btn-group {
  margin-top: 2.2rem;
  margin-left: -1em;
}

.btn-group.left {
  justify-content: flex-start;
}

.btn-more.wide {
  width: auto;
  padding-left: 5rem;
  display: inline-block;
}

.contact-message {
  margin-bottom: 4.9rem;
  display: flex;
  justify-content: space-between;
}

.text-card {
  width: 47.5%;
  line-height: 1.875;
}

.contact-form-area {
  padding: 8rem 8.6rem;
  background-color: #F2F2F2;
}
.contact-form-area dt span:nth-child(1)::after {
  content: "／";
}

@media (max-width: 833px) {
  .pcOnly,
  .spHide {
    display: none;
  }
  .sliderType-01 .slick-arrow {
    width: 4rem;
    height: 4rem;
    margin-top: -2rem;
  }
  .sliderType-01 .slick-arrow::before {
    width: 1.6rem;
    margin-top: 0;
    margin-left: -0.8rem;
  }
  .sliderType-01 .slick-arrow::after {
    margin-top: 0;
  }
  .sliderType-01 .slick-prev {
    left: -1rem;
  }
  .sliderType-01 .slick-prev::after {
    margin-right: -0.2rem;
  }
  .sliderType-01 .slick-next {
    right: -1rem;
  }
  .sliderType-01 .slick-next::after {
    margin-left: -0.2rem;
  }
  .btn-more {
    margin-top: 4.8rem;
  }
  .btn-group {
    display: block;
  }
  .btn-group .btn + .btn {
    margin-top: 1.5rem;
    margin-left: 0;
  }
  .btn-group.sp_center .btn {
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .btn-submit {
    margin-top: 2rem;
  }
  select.form-control {
    width: 100%;
  }
  .form-horizon .form-box {
    display: block;
  }
  .form-horizon .form-box dt {
    width: 100%;
    margin-bottom: 1rem;
    padding-top: 0;
  }
  .form-box .required::before {
    padding: 0.2rem 0.3rem;
    font-size: 1.2rem;
  }
  .site-header {
    padding: 1.6rem 2rem 1.6rem 1.6rem;
  }
  .header-title a {
    width: 22.2rem;
  }
  .header-title a img {
    width: 100%;
  }
  .site-footer {
    padding-top: 0;
    padding-right: 0;
    padding-left: 0;
  }
  .site-footer .site-navi {
    display: none;
  }
  .site-footer .btn-contact {
    margin-right: auto;
    margin-left: auto;
  }
  .site-footer .address {
    margin-top: 3.6rem;
  }
  .site-footer .banner {
    width: fit-content;
    margin: 0 auto;
    display: block;
  }
  .site-footer .link-privacy {
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
    display: block;
  }
  .footer-inner {
    flex-wrap: wrap;
    flex-direction: column-reverse;
  }
  .site-info {
    border-top: 1px solid #CCCCCC;
    padding-top: 3.6rem;
    padding-right: 2rem;
    padding-left: 2rem;
  }
  .footer-title {
    margin-bottom: 3.4rem;
  }
  .footer-title a {
    width: 22.2rem;
    margin: 0 auto;
  }
  .footer-title a img {
    width: 100%;
  }
  .footer-navi {
    width: 100%;
  }
  .footer-navi .menu {
    margin-bottom: 0;
  }
  .footer-navi .menu > li {
    width: 50%;
    margin-bottom: 2.4rem;
    padding-top: 2.4rem;
    border-top: 1px solid #CCCCCC;
  }
  .footer-navi .menu > li:nth-child(1), .footer-navi .menu > li:nth-child(2) {
    border-top: none;
  }
  .footer-navi .menu > li:nth-child(odd) {
    padding-left: 1.8rem;
  }
  .footer-navi .menu > li:nth-child(even) {
    padding-right: 1.8rem;
  }
  .copyright {
    text-align: center;
  }
  .headline-01 {
    margin-bottom: 2.8rem;
  }
  .headline-01 .title {
    font-size: 4.6rem;
  }
  .headline-01 .caption {
    margin-top: 1em;
    font-size: 1.6rem;
  }
  .headline-04 .title {
    font-size: 3.6rem;
  }
  .btn-more.fit {
    width: 30rem;
  }
  .checkbox-list.horizon {
    margin-bottom: -0.8em;
  }
  .checkbox-list.horizon .check-label {
    margin-bottom: 0.8em;
    display: inline-block;
  }
  .checkbox-list.horizon .check-label:not(:last-child) {
    margin-right: 1em;
  }
  .site-main {
    margin-top: 8.4rem;
  }
  .section-wrap {
    padding: 6rem 1.8rem 6rem;
  }
  .content + .content {
    margin-top: 4rem;
  }
  .text-lg {
    font-size: 2rem;
  }
  .l-column {
    display: flex;
    flex-wrap: wrap;
  }
  .l-column + .l-column {
    margin-top: 4rem;
  }
  .l-column .col-inner {
    width: 100%;
  }
  .l-column.type01 .image {
    width: 100%;
  }
  .l-column.type01 .image img {
    width: 100%;
  }
  .l-column.type01 .image img + img {
    margin-top: 1.6rem;
  }
  .l-column.type01 .image + .text {
    margin-top: 1em;
  }
  .l-column.type01 .text {
    width: 100%;
  }
  .l-column.type01 .title {
    margin-bottom: 0.5em;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
    font-size: 2.6rem;
    font-weight: 500;
  }
  .l-column.col2 .col-inner, .l-column.col3 .col-inner {
    width: 100%;
  }
  .l-column.col2 .col-inner + .col-inner, .l-column.col3 .col-inner + .col-inner {
    margin-top: 2rem;
  }
  .l-column.col2 .col-inner .col-inner + .col-inner, .l-column.col3 .col-inner .col-inner + .col-inner {
    margin-top: 1rem;
  }
  .l-column.col2 .col-inner img, .l-column.col3 .col-inner img {
    width: 100%;
  }
  .l-column.sp_col1 .col-inner {
    width: 100%;
  }
  .l-column.sp_col1 .col-inner + .col-inner {
    margin-top: 2rem;
  }
  .l-column.sp_col2 {
    margin-bottom: -5%;
    justify-content: space-between;
  }
  .l-column.sp_col2 .col-inner {
    width: 47.5%;
    margin-bottom: 5%;
  }
  .l-column.sp_col3 {
    margin-bottom: -3.8%;
  }
  .l-column.sp_col3 .col-inner {
    width: 30.8%;
    margin: 0 3.8% 3.8% 0;
  }
  .l-column.sp_col3 .col-inner:nth-child(3n) {
    margin-right: 0;
  }
  .hero-visual {
    height: 100vw;
  }
  .hero-text {
    width: 32.2rem;
  }
  #products-slider .slick-list {
    overflow: hidden;
  }
  #products-slider .slick-list {
    margin: 0 -1rem;
  }
  #products-slider .products-card {
    margin: 0 1rem;
  }
  #products-slider20 .products-card {
    margin: 0 1rem;
  }
  #voice-slider {
    padding: 0 2rem;
  }
  #voice-slider .voice-card {
    margin: 0 1.4rem;
  }
  .home-strength {
    margin-top: 0;
  }
  .home-strength .headline-01 {
    text-align: center;
  }
  .strengt-wrap {
    display: block;
  }
  .strengt-wrap .left-area {
    width: 100%;
    margin-right: 0;
  }
  .strengt-wrap .right-area {
    width: 100%;
    margin-top: 4.8rem;
    display: block;
  }
  .strengt-wrap .btn-more {
    margin-right: auto;
    margin-left: auto;
  }
  .strength-card {
    width: 100%;
    margin-bottom: 9.2rem;
  }
  .strength-card.up {
    top: auto;
  }
  .strength-card.middle {
    top: auto;
  }
  .strength-card dt {
    margin-top: -7.8rem;
  }
  .strength-card .image {
    padding-bottom: 67.6%;
  }
  .services-wrap {
    margin-right: -1.8rem;
    margin-left: -1.8rem;
    display: block;
  }
  .services-wrap .inner {
    width: 100%;
  }
  .services-wrap .inner + .inner {
    margin-top: 3rem;
  }
  .services-wrap .text {
    width: 31rem;
    font-size: 2rem;
  }
  #blog-slider .slick-list {
    overflow: hidden;
  }
  #blog-slider .slick-list {
    margin: 0 -1rem;
  }
  #blog-slider .blog-card {
    margin: 0 1rem;
  }
  #blog-slider .slick-arrow {
    top: 12rem;
  }
  #blog-slider + .btn-more {
    margin-top: 3.2rem;
  }
  .sns-wrap {
    display: block;
  }
  .sns-wrap:not(:last-child) {
    margin-bottom: 2rem;
  }
  .line-area {
    width: 100%;
    max-width: 100%;
    padding: 2rem 1.8rem 3rem;
  }
  .line-area h3 {
    margin-bottom: 2rem;
    line-height: 1.2941176471;
  }
  .line-area .point {
    margin-bottom: 2.5rem;
    display: block;
    text-align: center;
  }
  .line-area .point .label {
    margin-right: 0;
    display: inline-block;
  }
  .line-area .point p {
    margin-top: 0.8em;
    line-height: 1.3;
  }
  .line-area .line-detail {
    display: block;
  }
  .line-area .text-area {
    width: 100%;
  }
  .line-area .line-btn {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    padding-left: 4rem;
  }
  .line-area .line-btn::before {
    width: 2.2rem;
  }
  .line-area .line-btn::after {
    left: 2.8rem;
  }
  .line-add-button {
    width: 100%;
    height: 5.6rem;
    margin: 2rem auto 0;
    font-size: 1.8rem;
    font-weight: 700;
    color: #FFF;
    text-align: center;
    background-color: #00C100;
    background-image: url(../../images/home/line.svg);
    background-repeat: no-repeat;
    background-position: 1.6rem center;
    background-size: 4rem 3.8rem;
    border-radius: 1rem;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .sns-widget-area {
    width: 100%;
    height: 38rem;
    margin-top: 2rem;
  }
  .sns-link-banner .banner {
    width: 100%;
  }
  .sns-link-banner .banner + .banner {
    margin-top: 2rem;
  }
  .sns-link-banner .banner img {
    width: 100%;
  }
  .products-archive-list {
    margin-bottom: -3.2rem;
    display: block;
  }
  .products-archive-list .products-card {
    width: 100%;
    max-width: 100%;
    margin-right: 0;
    margin-bottom: 3.2rem;
  }
  #products-slider20.products-archive-list {
    margin-bottom: -5.2rem;
  }
  #products-slider20.products-archive-list .products-card {
    width: calc(50% - 1rem + 0px);
  	margin: 0 2rem 1rem 0;
  }
  #products-slider20.products-archive-list .products-card:nth-child(2n) {
  	margin-right: 0;
  }
  #products-slider20.products-card .eye-catch img {
    max-width: 100%;
  }
  .products-card .eye-catch img {
    width: 100%;
  }
  .home-about p {
    text-align: left;
  }
  .home-about .btn-more {
    margin-top: 4rem;
  }
  .about-archive-list {
    margin: 4rem 0 0;
  }
  .about-archive-list .slick-list {
    overflow: visible;
  }
  .about-archive-list .about-card {
    margin: 0 0.8rem;
  }
  .voice-archive-list {
    margin-bottom: -3.2rem;
  }
  .voice-archive-list .voice-card {
    width: 100%;
    max-width: 100%;
    margin-right: 0;
    margin-bottom: 3.2rem;
  }
  .voice-archive-list.sp_col2 {
    justify-content: space-between;
  }
  .voice-archive-list.sp_col2 .voice-card {
    width: 48.5%;
  }
  .voice-archive-list.sp_col2 .maker-name {
    font-size: 1.6rem;
  }
  .blog-archive-list {
    margin-bottom: -3.2rem;
    display: block;
  }
  .blog-archive-list .blog-card {
    width: 100%;
    max-width: 100%;
    margin-right: 0;
    margin-bottom: 3.2rem;
  }
  .blog-archive-list.carousel .blog-card {
    max-width: 100%;
  }
  .blog-column-wrapper .side-column {
    margin-top: 6rem;
    padding-top: 6rem;
    border-top: 1px solid #CCC;
  }
  .lower-headline {
    height: auto;
    margin-bottom: 1rem;
    padding-top: 11.3rem;
  }
  .lower-headline .pic {
    height: 11.3rem;
  }
  .lower-headline .headline-01 {
    margin-top: 2.4rem;
    color: #000;
  }
  .breadcrumbs {
    padding: 0 1.8rem;
    display: none;
  }
  .type-page > .section-wrap:first-of-type {
    padding-top: 3rem;
  }
  .page-navi-top .btn-more {
    width: 100%;
  }
  .reason-inner:not(:last-child) {
    margin-bottom: 2rem;
  }
  .slide-img-wrap .col-inner:not(:last-child) {
    margin-bottom: 1rem;
  }
  .slide-img-wrap img {
    width: 100%;
  }
  .cut-img-wrap .col-inner:not(:last-child) {
    margin-bottom: 1rem;
  }
  .cut-img-wrap img {
    width: 100%;
  }
  .brand-visual-lead {
    padding-right: 1.8rem;
    padding-left: 1.8rem;
  }
  .brand-visual-lead .logo {
    margin-bottom: 2rem;
  }
  .brand-visual-lead .logo img {
    width: calc(var(--logo-width) * 0.65);
  }
  .brand-visual-lead .catch {
    font-size: 2.4rem;
  }
  .brand-visual-lead p {
    font-size: 1.6rem;
  }
  .product-thumbnail .slick-slide {
    padding-bottom: 6.4rem;
  }
  .spec-list .inner + .inner dl:first-child {
    border-top: none;
  }
  .spec-list .inner + .inner dl:first-child dt::before {
    content: none;
  }
  .spec-list dt {
    width: 40%;
  }
  .spec-list .price-wrap > span {
    display: block;
  }
  .spec-list .price-wrap > span + span {
    margin-top: 0.5em;
    margin-left: 0;
  }
  .product-movie-block .inner + .inner {
    margin-top: 3.4rem;
  }
  .dl-table dd {
    padding-left: 0;
  }
  .dl-table.sp_col1 dl {
    display: block;
  }
  .dl-table.sp_col1 dl:first-child dt::before {
    content: none;
  }
  .dl-table.sp_col1 dt {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-top: 1.5em;
    padding-bottom: 0;
    text-align: left;
  }
  .dl-table.sp_col1 dt::after {
    top: -1px;
    bottom: auto;
  }
  .dl-table.sp_col1 dd {
    padding-bottom: 1.5em;
  }
  .service-detail .dl-table + .dl-table {
    margin-top: 0 !important;
  }
  .service-detail .dl-table + .dl-table dl:first-child {
    border-top: none;
  }
  .service-detail .dl-table dl:first-child dt::before {
    content: none;
  }
  .service-detail .dl-table dt {
    width: 100%;
    padding-bottom: 0.6em;
  }
  .service-detail .dl-table dt::after {
    content: none;
  }
  .service-detail .dl-table dd {
    padding-top: 0;
    padding-left: 0;
  }
  .voice-detail-block {
    margin-top: 3rem;
  }
  .pv-link.sp_col1 {
    display: block;
  }
  .pv-link.sp_col1 > a {
    margin: 0 auto;
  }
  .pv-link.sp_col1 > a + a {
    margin-top: 1em;
    margin-left: auto;
  }
  .column-type01,
  .column-type02,
  .column-type03,
  .column-type04 {
    display: block;
  }
  .column-type01 .image,
  .column-type02 .image,
  .column-type03 .image,
  .column-type04 .image {
    width: 100%;
    margin-bottom: 2rem;
    text-align: center;
  }
  .column-type01 .text,
  .column-type02 .text,
  .column-type03 .text,
  .column-type04 .text {
    width: 100%;
  }  
  .column-type01 .btn-more,
  .column-type02 .btn-more,
  .column-type03 .btn-more,
  .column-type04 .btn-more {
    margin: auto;
  }
  .services-nav .btn-more {
    font-size: 1.4rem;
  }
  .services-nav .btn {
    width: 100%;
  }
  .services-block:not(:last-child) {
    margin-bottom: 5rem;
  }
  .services-block .services-headline {
    font-size: 1.8rem;
  }
  .service-detail .title {
    font-size: 2rem;
  }
  .service-detail .dl-table dl {
    display: block;
  }
  .service-detail .dl-table dt {
    width: 100%;
  }
  .service-detail .dl-table dd {
    width: 100%;
  }
  .services-message span {
    margin-bottom: 2rem;
  }
  .services-btn {
    display: block;
  }
  .services-btn .btn + .btn {
    margin-left: auto;
    margin-top: 2rem;
  }
  .services-btn .btn-more {
    margin: auto;
  }
  .maintenance-wrap {
    margin-top: 4rem;
  }
  .flow-wrap .image figcaption {
    left: -1.5rem;
  }
  .flow-wrap h4 {
    margin-bottom: 1rem;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
    font-size: 2rem;
  }
  .about-fees-wrap {
    margin-bottom: 2rem;
    display: block;
  }
  .about-fees dt {
    margin-bottom: 0;
    font-size: 1.8rem;
  }
  .about-fees:first-child {
    margin-right: 0;
    margin-bottom: 2rem;
  }
  .service-add {
    font-size: 2rem;
  }
  .service-add span {
    font-size: 1.4rem;
  }
  .lower-line .line-area .text-area {
    width: 100%;
  }
  .greeting-wrap {
    display: block;
  }
  .greeting-wrap figure {
    width: 100%;
    margin-right: 0;
    margin-bottom: 2rem;
  }
  .greeting-text {
    width: 100%;
  }
  .line-method {
    display: block;
  }
  .line-method li {
    width: 100%;
    margin-right: 0;
  }
  .line-method li:not(:last-child) {
    margin-bottom: 6rem;
  }
  .line-method li:not(:last-child):after {
    width: 2rem;
    height: 3.4rem;
    margin-left: -1.4rem;
    transform: rotate(90deg);
    top: auto;
    left: 50%;
    bottom: -4.7rem;
  }
  .line-headline {
    font-size: 1.6rem;
  }
  .line-headline .green {
    margin-right: 0;
    font-size: 1.8rem;
    text-align: center;
    display: block;
  }
  .line-headline .big {
    font-size: 3.2rem;
  }
  .service-list {
    margin-top: 3rem;
    font-size: 1.6rem;
  }
  .service-list li:not(:last-child) {
    margin-bottom: 3rem;
  }
  .service-list .btn-group {
    margin-top: 1rem;
  }
  .service-list p {
    margin-bottom: 0;
  }
  .btn-more.wide {
    width: 100%;
    font-size: 1.4rem;
  }
  .contact-message {
    display: block;
  }
  .text-card {
    width: 100%;
  }
  .contact-form-area {
    padding: 3rem 1rem;
  }
}
@media (max-width: 833px) and (orientation: landscape) {
  html {
    font-size: 2vw;
  }
  .site-header {
    padding: 1rem 1.5rem 1rem 1.5rem;
  }
  .header-title a {
    width: 15rem;
  }
}

/* nail (site-id-3) */
.site-id-3 {
	color: #333333;	
}
.site-id-3 a {
	color: #333333;
}
.site-id-3 aside.widget-area h2,
.site-id-3 .blog-header h3.blog-title {
	border-bottom: 2px solid var(--color-primary);
}
.site-id-3 .main-column h2.rel-blog-title {
  margin: 80px 0px 30px 0px;
  padding-bottom: 0px;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif;
  font-size: 3rem;
  font-weight: 500;
  border-bottom: 2px solid var(--color-primary);
}
.site-id-3 .btn-more {  
  color: #333333;
  background-color: #ffffff;
  border: 1px solid #000000;
}
.site-id-3 .btn-more::before, 
.site-id-3 .btn-more::after {
  background-color: var(--color-primary);
}
.site-id-3 .sliderType-01 .slick-arrow {
	background-color: #000000;
}
.site-id-3 .sliderType-01 .slick-arrow::before, 
.site-id-3 .sliderType-01 .slick-arrow::after {
  background-color: var(--color-primary);
}
.site-id-3 .btn-search-list {
	width: 96%;
	margin: -5px auto 50px auto;
	padding: 0px 0px;
	display: flex;	
}
.site-id-3 .btn-search-list li {
	width: calc(23% + 0px);
	margin-right: 2.6%;
}
.site-id-3 .btn-search-list li:last-child {
	margin-right: 0%;
}
.site-id-3 .btn-search {
	width: 100%;
	padding: 12px 0px 12px 0px;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "Noto Serif JP", serif !important;
	font-size: 1.6rem;
	font-weight: bold;
	vertical-align: middle;
	text-align: center;
	border: 1px solid #000000;
	background-image: url(../../images/nail/ico_arrow_pink.png);
  	background-repeat: no-repeat;
  	background-position: 15px 50%;
  	background-size: auto;
	display: inline-block;
}
.site-id-3 .btn-search-black {
	color: #ffffff;
	background-color: #000000;
}
.site-id-3 .dl-table dl:first-child dt::before {
	background-color: #000000;
}
.site-id-3 .dl-table dt::after {
	background-color: #000000;
}
.site-id-3 .column-type04 {
  width: 31.7%;
  margin: 0px 2.4% 0px 0px !important;
  padding: 0px 0px 0px 0px;
  display: inline-block;
  vertical-align: top;
  justify-content: center;
}
.site-id-3 .column-type04:last-child {
	margin-right: -10px !important;
}
.site-id-3 .column-type04 .image20 img {
  width: 99%;
}
.site-id-3 .column-type04 .text {
  width: 95.85%;
  margin-left: 4.15%;
}
.site-id-3 .headline-01 .title {
    font-size: 4.8rem;
}
.site-id-3 .products-archive-list .products-card {
  width: 23%;
  max-width: 27.45rem;
  margin-right: 2.6%;
  margin-bottom: 8rem;
}
.site-id-3 .products-archive-list .products-card:nth-child(4n) {
  margin-right: 0;
}
.site-id-3 p.service-add {
  margin-top: -20px;
  padding-top: 0px;
  font-size: 2rem;
  line-height: 1.5;
}
.site-id-3 .service-add span {
  font-size: 1.3rem;
  line-height: 1.5;
}
.site-id-3 #productThumbnail {
	display: none;
}
.site-id-3 .hero-visual {
  height: 42rem;
}

.site-id-3 .site-footer .footer-navi {
	width: 66%;
	text-align: center;
}
.site-id-3 .footer-navi .menu > li {
  width: auto;
  margin-right: 3rem;
  margin-bottom: 2rem;
}
.site-id-3 .footer-navi .menu > li:last-child {
  margin-right: 0px;
}

@media screen and (min-width: 1460px) {
	
}

@media screen and (min-width: 1420px) {
	
}

@media screen and (min-width: 1120px) {
	
}

@media screen and (max-width: 1119px) {
	.site-id-3 .menu-header-menu-container a {
	    color: #FFF;
	}	
	.site-id-3 .product-slider .slick-prev {
	  margin-right: -0.2rem;
	}
	.site-id-3 .product-slider .slick-next {
	  margin-left: -0.2rem;
	}
	
}

@media (min-width: 835px) and (max-width: 1260px) {
	
}

@media screen and (min-width: 834px) {
	.site-id-3 .l-column.col2 .col-inner {
  		margin-bottom: 3.5%;
	}	
}

@media screen and (max-width: 833px) {
	/*.site-id-3 {
		font-size: 130%;
	}*/
	.site-id-3 .btn-search-list {
		width: 100%;
		margin: -5px auto 30px auto;
		padding: 0px 0px;
		display: flex;  
		flex-wrap: wrap;
	}
	.site-id-3 .btn-search-list li {
		width: 47%;
		margin-right: 6%;
		padding-bottom: 20px;
	}
	.site-id-3 .btn-search-list li:nth-child(even) {
		margin-right: 0%;
	}
	.site-id-3 .btn-search {
		width: 100%;
		padding: 12px 0px 12px 0px;
		font-size: 1.4rem;		
	  	background-position: 10px 50%;
	}
	.site-id-3 .column-type04 {
	  width: 100%;
	  margin: 0px auto 20px auto !important;
	  padding: 0px 0px 0px 0px;
	  vertical-align: top;
	  display: flex;
	}
	.site-id-3 .column-type04:last-child {
		margin: 0px auto 0px auto !important;
	}
	.site-id-3 .column-type04 .image20 {
	  width: 122px;
	  display: inline-block;
	}
	.site-id-3 .column-type04 .text {
	  width: calc(100% - 20px - 128px);
	  margin-left: 20px;
	  font-size: 14px;
	  display: inline-block;
	}
	.site-id-3 .l-column.col2 .col-inner:last-child {
  		margin-bottom: -20px;
	}
	.site-id-3 .headline-01 .title {
	    font-size: 3rem;
	}
  
	.site-id-3 .lower-headline {
		height: 11.3rem;
    	margin-bottom: 1.5rem;
    	padding-top: 0rem;
	}
	.site-id-3 .lower-headline .pic {
    	height: 100%;
  	}
	.site-id-3 .lower-headline .headline-01 {
    	margin-top: 0rem;
    	color: #ffffff;
  	}
  	.site-id-3 .headline-01 .caption {
		margin-top: 0.65em;
	}
	.site-id-3 .products-archive-list .products-card {
	  width: 46%;
	  margin-right: 6%;
	  margin-bottom: 3rem;
	  vertical-align: top;
	  display: inline-block;
	}
	.site-id-3 .products-archive-list .products-card:nth-child(2n) {
	  margin-right: 0;
	}
	.site-id-3 .products-archive-list .products-card h3.product-name {	
	  font-size: 14px;
	}
	.site-id-3 .user-information dt,
	.site-id-3 .spec-list dt {
		width: 35%;
	}
	.site-id-3 .user-information dd,
	.site-id-3 .spec-list dd {
		padding-left: 10px;
	}
	
	.site-id-3 p.service-add {
		margin-top: -20px;
		padding-top: 0px;
	    font-size: 1.6rem;
	 }
	 .site-id-3 .service-add span {
	    font-size: 1.15rem;
	 }
	 .site-id-3 .product-slider .slick-arrow {
		  width: 1.6rem;
		  height: 3.1rem;
		  margin-top: -1.55rem;
	}
	.site-id-3 .product-slider .slick-arrow::before, 
	.site-id-3 .product-slider .slick-arrow::after {
		  width: 2.1rem;
		  height: 0.2rem;
		  border-radius: 0.1rem;
	}
	.site-id-3 .hero-visual {
		height: 60vw;
		max-height: 30rem;
	}
	
	.site-id-3 .site-info {
    	border-top: none;
	}
	.site-id-3 .site-footer .footer-navi {
		width: 100%;
		padding: 2.8rem 0px 0px 0px;
		text-align: left;
	}
	.site-id-3 .footer-navi .menu > li {
		width: 50%;
		margin: 0 0;
		border-top: none;
	}
	.site-id-3 .footer-navi .menu > li:nth-child(odd) {		
		padding: 0px 1.5rem 1rem 3.5rem;
	}
	.site-id-3 .footer-navi .menu > li:nth-child(even) {		
		padding: 0px 1rem 1rem 0rem;
	}
	.site-id-3 .site-info .address {
		margin-top: 2.6rem;
		font-size: 1.4rem;
		text-align: center;
	}
	
}

@media (max-width: 833px) and (orientation: landscape) {
	
}
/* /nail (site-id-3) */