@charset "UTF-8";
/* -----------------------------------------------------------
CSS Information

File name : style.css
---------------------------------------------------------- */
/* Reset
---------------------------------------------------- */
* {
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
  height: 100%;
}

html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, a, address, cite, em, img, small, dl, dt, dd, ol, ul, li, form, label, table, caption, tbody, tfoot, thead, tr, th, td, main, article, aside, canvas, figure, figcaption, footer, header, menu, nav, output, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

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

ol, ul {
  list-style: none;
}
.blockPc {
  display: block;
}
.blockSp {
  display: none;
}
.sp_block {
  display: none;
}

@media screen and (max-width: 750px) {
  .pc_block {
    display: none;
  }
  .sp_block {
    display: block;
  }
  .blockPc {
    display: none;
  }
  .blockSp {
    display: block;
  }
}

/* header
---------------------------------------------------- */
.l-header {
  color: #333;
}
.l-header .header-content {
  align-items: center;
  display: flex;
  justify-content: space-between;
  padding: 15px 40px;
  position: relative;
}

.l-header .header-content .logo {
  align-items: center;
  display: flex;
}

.l-header .header-content .logo img {
  width: 207px;
}

.l-header .header-content .l-sns {
  align-items: center;
  display: flex;
  height: 30px;
}

.l-header .header-content .l-sns .sns-list {
  font-size: 1.875rem;
}

.l-header .header-content .l-sns .sns-list.sns-list-ttl {
  font-size: 0.9rem;
}

.l-header .header-content .l-sns .sns-list:nth-child(n+2) {
  margin-left: 16px;
}

.l-sns .sns-list.sns-item--line {
  display: none;
  margin: 0;
}

.l-header .header-tit {
  font-size: 14px;
  padding-bottom: 25px;
}
.l-header .inner {
  box-sizing: border-box;
  max-width: 1020px;
}

@media screen and (max-width: 1040px) {
  .l-header .header-content .logo {
    padding-left: 2em;
    width: 150px;
  }
  .l-header .header-tit {
    font-size: 1.5686vw;
  }
}
@media screen and (max-width: 768px) {
  /* header
  ---------------------------------------------------- */
  .l-header .header-content {
    padding: 4vw 1.25rem 4vw 1.25rem;
  }
  .l-header .header-content .logo {
    padding-left: 0;
  }
  .l-header .header-content .logo img {
    width: 52.2667vw;
  }
  .l-header .header-content .l-sns {
    height: 7.3333vw;
  }
  .l-header .header-content .l-sns .sns-list {
    font-size: 1.6875rem;
  }
  .l-header .header-content .l-sns .sns-list:nth-child(n+2) {
    margin-left: 4.6667vw;
  }
  .l-sns .sns-list.sns-item--line {
    display: block;
  }
  .l-header .header-tit {
    display: none;
  }
}
/*SNSアイコン*/
@font-face {
  src: url(../fonts/icon.eot?1632808221);
  src: url(../fonts/icon.woff?1632808221) format("woff"), url(../fonts/icon.ttf?1632808221) format("truetype");
  font-family: icon;
}
.icon {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  align-items: center;
  color: #000;
  display: inline-flex;
  display: block;
  font-family: icon;
  font-style: normal;
  font-variant: normal;
  font-weight: 400;
  line-height: 1;
  text-decoration: none;
  text-rendering: auto;
  text-transform: none;
  vertical-align: middle;
}

.icon-facebook:before {
  content: "\ea03";
}

.icon-line:before {
  content: "\ea05";
}

.icon-twitter:before {
  content: "\ea06";
}

.icon-instagram:before {
  content: "\ea04";
}

body {
  font-family: yu-gothic-pr6n, sans-serif;
  font-style: normal;
}

p {
  font-size: 16px;
  line-height: 1.875;
}
@media screen and (max-width: 1020px) {
  p {
    font-size: 1.5686vw;
    line-height: 1.87;
  }
}
@media screen and (max-width: 750px) {
  p {
    font-size: 3.6vw;
    line-height: 1.6;
    letter-spacing: -0.012em;
  }
}

a {
  text-decoration: none;
  overflow: hidden;
  outline: none;
  transition: all 0.2s ease;
}
a:hover {
  opacity: 0.7;
}

img {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  vertical-align: bottom;
}

/* footer
---------------------------------------------------- */
.l-footer {
  border-top: 1px solid #000;
  padding: 60px 0;
  text-align: center;
  color: #333;
  position: relative;
}

.l-footer .logo img {
  width: 206px;
  margin: 60px auto 0;
}

.l-footer .inner .copyright {
  margin-top: 40px;
  font-size: 0.75rem;
}

.l-footer .inner .l-sns {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding: 60px 0 15px;
}

.l-footer .inner .l-sns .sns-list {
  font-size: 3.125rem;
}

.l-footer .inner .l-sns .sns-list.sns-list-ttl {
  font-size: 1rem;
  margin-bottom: 35px;
  width: 100%;
}

.l-footer .inner .l-sns .sns-list:nth-child(n+3) {
  margin-left: 72px;
}

.l-footer .inner .l-sns .sns-item--instagram {
  display: none;
}

@media (max-width: 768px) {
  .l-footer {
    padding: 10.6667vw 0 12vw;
  }
  .l-footer .inner {
    padding: 0;
    width: 92vw;
  }
  .l-footer .logo img {
    width: 52.2667vw;
    margin-top: 9.33333vw;
  }
  .l-footer .inner .copyright {
    margin-top: 6.6667vw;
    font-size: 0.6875rem;
  }
  .l-footer .inner .l-sns {
    padding: 0 0 9.33333vw;
  }
  .l-footer .inner .l-sns .sns-list {
    font-size: 8.66667vw;
  }
  .l-footer .inner .l-sns .sns-list.sns-list-ttl {
    margin-bottom: 3.33333vw;
  }
  .l-footer .inner .l-sns .sns-list:nth-child(n+3) {
    margin-left: 10.66667vw;
  }
  .l-footer .inner .l-sns .sns-item--instagram {
    display: block;
  }
}

/* mainの中のcss */
.main {
  font-family: 'Zen Old Mincho', serif;
  font-weight: 500;
  color: #000;
  /* overflow: hidden; */
  position: relative;
  z-index: 1;
}
.noto {
  font-family: 'Noto Sans JP', sans-serif;
  font-feature-settings: "palt";
}
picture {
  line-height: 0;
}
.main p {
  font-size: inherit;
  text-align: justify;
}
.main a:hover {
  opacity: 1;
}
@media (min-width: 1280px) {
  .main {
        font-size: 1px;
    }
}
@media (max-width: 1279px) and (min-width: 751px) {
  .main {
    font-size: calc(100/1279*1vw);
  }
}
@media (max-width: 750px) {
  .main {
        font-size: 10px;
        font-size: 2.66666vw;
        font-size: calc((100/375)*0.5vw);
    }
}
/* PC・SPの出し分け */
@media screen and (min-width: 769px) {
  .sp_only {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .pc_only {
    display: none !important;
  }
}
/*inner*/
.inner {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
}
@media screen and (min-width: 751px) {
  .main .inner {
    max-width: 1280em;
    width: 100%;
    padding: 0 40em;
    margin: 0 auto;
    box-sizing: border-box;
  }
}
@media screen and (max-width: 750px) {
  .inner {
    width: calc(100% - 80em);
  }
}
/* sup */
@media screen and (min-width: 751px) {
  sup {
    font-size: 0.66em;
  }
}
/* section_ttl */
.section_ttl {
  color: #674506;
  text-align: center;
}
.section_ttl_s {
  letter-spacing: -0.06em;
}
.section_ttl_l {
  letter-spacing: -0.06em;
}
.section_ttl_ll {
  letter-spacing: -0.06em;
  line-height: 1;
}
@media (min-width: 751px) {
  .section_ttl_s {
    font-size: 40em;
    line-height: 1.5;
  }
  .section_ttl_l {
    font-size: 48em;
    line-height: 1.25;
  }
  .section_ttl_ll {
    font-size: 64em;
  }  
}
@media (max-width: 750px) {
  .section_ttl_s {
    font-size: 48em;
    line-height: 1.5;
  }
  .section_ttl_l {
    font-size: 58em;
    line-height: 1.24;
  }
  .section_ttl_ll {
    font-size: 80em;
  }
}
/* btn */
.btn {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  overflow: hidden;
  margin-inline: auto;
  color: #fff;
  text-align: center;
}
.btn_txt {
  position: relative;
  z-index: 1;
}
.btn_txt_l,
.btn_txt_s {
  letter-spacing: -0.06em;
}
@media (min-width: 751px) {
  .btn {
    width: 594em;
    height: 130em;
    background: url(../img/btn_bg.jpg) no-repeat center / contain;
  }
  .btn_txt {
    line-height: 1.4;
  }
  .btn_txt_l {
    font-size: 26em;
  }
  .btn_txt_s {
    font-size: 20em;
  }
}
@media (max-width: 750px) {
  .btn {
    width: 100%;
    height: 168em;
    background: url(../img/btn_bg_sp.jpg) no-repeat center / contain;
  }
  .btn_txt {
    line-height: 1.5;
  }
  .btn_txt_l {
    font-size: 36em;
  }
  .btn_txt_s {
    font-size: 28em;
  }
}
@media (min-width: 751px) {
  @media (hover: hover) {
    .btn::before {
      content: '';
      position: absolute;
      top: 0;
      left: -75%;
      width: 50%;
      height: 100%;
      background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,.3) 100%);
      transform: skewX(-25deg);
    }
    .btn:hover::before {
      animation: shine 0.7s;
    }
    @keyframes shine {
      100% {
        left: 125%;
      }
    }
  }
}
/* 共通アニメーション */
.animation_ready .fadein {
  opacity: 0;
  will-change: opacity;
  transition: transform 0.8s ease-in, opacity 0.8s ease-in;
}
.animation_load .fadein.is_animated {
  opacity: 1;
}
/* mv */
.mv {
  width: 100%;
  position: relative;
  overflow: hidden;
}
.mv .inner {
  height: 100%;
  position: relative;
}
.mv_txt1 {
  font-weight: 700;
  line-height: 1;
}
.mv_txt1_inner {
  letter-spacing: -0.06em;
}
.mv_ttl {
  color: #fffcd1;
  line-height: 1;
}
.mv_copy {
  color: #fffcd1;
}
.mv_copy_inner {
  letter-spacing: -0.08em;
}
.mv_txt2 {
  color: #fff;
}
.mv_item {
  position: absolute;
}
.mv_pr {
  position: absolute;
  top: 0;
  background-color: #fff;
  color: #000;
  display: flex;
  justify-content: center;
  align-items: center;
}
.mv_pr_txt {
  font-size: 16em;
}
@media (min-width: 751px) {
  .mv {
    height: 723em;
    background: url(../img/mv.jpg) no-repeat center / auto 100%;
  }
  .mv_txt_area {
    position: absolute;
    top: 87em;
    right: 40em;
  }
  .mv_txt1_inner {
    font-size: 26em;
  }
  .mv_ttl {
    margin-top: 29em;
  }
  .mv_ttl_l {
    font-size: 42em;
  }
  .mv_ttl_m {
    font-size: 40em;
  }
  .mv_ttl_s {
    font-size: 32em;
  }
  .mv_copy {
    line-height: 1.116;
    margin-top: 16em;
  }
  .mv_copy_inner {
    font-size: 86em;
  }
  .mv_txt2 {
    line-height: 1.5;
    margin: 30em 0 0 26em;
    text-shadow: 0px 4em 19em rgba(93, 104, 104, 1), 0px -4em 19em rgba(93, 104, 104, 1);
  }
  .mv_txt2_inner {
    font-size: 18em;
  }
  .mv_item {
    width: 446em;
    bottom: -46em;
    right: -71em;
  }
  .mv_pr {
    right: 0;
    width: 52em;
    height: 28em;
  }
  .mv_pr_txt {
    font-size: 16em;
  }
}
@media (max-width: 750px) {
  .mv {
    height: 1416em;
    background: url(../img/mv_sp.jpg) no-repeat center / cover;
  }
  .mv_txt_area {
    padding-top: 46em;
  }
  .mv_txt1 {
    color: #fff;
  }
  .mv_txt1_inner {
    font-size: 28em;
  }
  .mv_ttl {
    margin-top: 23em;
  }
  .mv_ttl_l {
    font-size: 46em;
  }
  .mv_ttl_m {
    font-size: 46em;
  }
  .mv_ttl_s {
    font-size: 36em;
  }
  .mv_copy {
    line-height: 1.133;
    margin-top: 12em;
  }
  .mv_copy_inner {
    font-size: 90em;
  }
  .mv_txt2 {
    margin-top: 726em;
    color: #000;
  }
  .mv_txt2_inner {
    line-height: 1.5;
    font-size: 28em;
    letter-spacing: -0.04em;
  }
  .mv_item {
    width: 374em;
    top: 656em;
    right: -40em;
  }
  .mv_pr {
    right: -41em;
    width: 56em;
    height: 32em;
  }
  .mv_pr_txt {
    font-size: 20em;
  }
}
/* nav */
.nav {
  background-color: #543b28;
  width: 100%;
}
.nav_list li {
  display: flex;
  justify-content: center;
  align-items: center;
  background: linear-gradient(-120deg, #be9b68, #fff, #b47649);
}
.nav_list a {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #543b28;
  color: #fff;
  text-align: center;
  position: relative;
}
.nav_list a::after {
  content: "";
  display: block;
  background: url(../img/nav_btn_arrow.png) no-repeat center / contain;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto 0;
}
@media (min-width: 751px) {
  .nav {
    padding: 40em 0;
  }
  .nav_list {
    display: flex;
    justify-content: center;
    gap: 20em;
  }
  .nav_list li {
    height: 104em;
    width: 388em;
  }
  .nav_list a {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
  }
  .nav_list a::after {
    width: 21em;
    height: 15em;
    right: 24em;
  }
  .nav_link_txt_s {
    font-size: 18em;
    line-height: 1.5;
  }
  .nav_link_txt_l {
    font-size: 22em;
    line-height: 1.27;
  }  
}
@media (max-width: 750px) {
  .nav {
    padding: 40em;
  }
  .nav_list li {
    height: 120em;
    width: 100%;
  }
  .nav_list li + li {
    margin-top: 16em;
  }
  .nav_list a {
    width: calc(100% - 2px);
    height: calc(100% - 2px);
  }
  .nav_list a::after {
    width: 33em;
    height: 20em;
    right: 27em;
  }
  .nav_link_txt_s {
    font-size: 28em;
    line-height: 1.5;
  }
  .nav_link_txt_l {
    font-size: 32em;
    line-height: 1.3125;
  }
}
@media (min-width: 751px) {
  @media (hover: hover) {
    .nav_list li {
      transition: box-shadow 0.3s;
    }
    .nav_list li:hover {
      box-shadow: 0px 0px 30em 0px rgba(130, 101, 56, 1);
    }  
  }
}
/* mainte */
.mainte_sub_ttl {
  font-weight: 700;
  text-align: center;
}
.mainte_item_wrap {
  width: 100%;
}
.mainte_item_txt_copy {
  font-weight: 700;
}
.mainte_item_note {
  color: #6e6e6e;
  padding-left: 1em;
  text-indent: -1em;
}
.mainte_profile_msg {
  color: #530000;
}
.mainte_profile_msg_inner {
  letter-spacing: -0.06em;
}
.mainte_profile_msg_name {
  line-height: 1;
}
.main .mainte_profile_msg_name {
  text-align: right;
}
.mainte_profile_msg_name_l {
  letter-spacing: -0.1em;
}
.mainte_profile_msg_name_s {
  letter-spacing: -0.06em;
}
.mainte_profile_detail_name {
  line-height: 1;
}
.mainte_profile_detail_name_l {
  letter-spacing: -0.06em;
}
.mainte_profile_detail_name_s {
  letter-spacing: -0.06em;
}
.main .mainte_profile_price {
  line-height: 1;
  text-align: right;
}  

@media (min-width: 751px) {
  .mainte {
    padding: 148em 0 0;
  }
  .mainte_sub_ttl {
    margin-top: 73em;
  }
  .mainte_sub_ttl_inner {
    font-size: 26em;
  }
  .mainte_txt {
    width: 920em;
    margin: 32em auto 0;
    line-height: 1.7;
  }
  .mainte_txt_inner {
    font-size: 18em;
  }
  .mainte_item_wrap {
    margin-top: 68em;
    height: 770em;
    background: url(../img/mainte_img.jpg) no-repeat center / auto 100%;
  }
  .mainte_item_wrap .inner {
    height: 100%;
    position: relative;
  }
  .mainte_item_txt_box {
    position: absolute;
  }
  .mainte_item_txt_box1 {
    top: 122em;
    left: 119em;
    width: 234em;
  }
  .mainte_item_txt_box2 {
    top: 76em;
    left: 429em;
    width: 278em;
  }
  .mainte_item_txt_box3 {
    top: 704em;
    left: 153em;
    width: 385em;
  }
  .mainte_item_txt_box4 {
    top: 677em;
    left: 692em;
    width: 220em;
  }
  .mainte_item_txt_box5 {
    top: 677em;
    left: 953em;
    width: 223em;
  }
  .mainte_item_txt_copy {
    line-height: 1.3;
  }
  .mainte_item_txt_copy_inner {
    font-size: 18em;
  }
  .mainte_item_txt {
    line-height: 1.5;
    margin-top: 6em;
  }
  .mainte_item_txt_inner {
    font-size: 16em;
  }
  .mainte_item_note {
    position: absolute;
    top: 922em;
    left: 40em;
    line-height: 1.5;
    width: 407em;
  }
  .mainte_item_note_inner {
    font-size: 12em;
  }
  .mainte_item_bottom_txt {
    margin: 273em auto 0;
    width: 920em;
    line-height: 1.7;
  }
  .mainte_item_bottom_txt_inner {
    font-size: 18em;
  }
  .mainte_profile {
    margin-top: 110em;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 80em;
  }
  .mainte_profile_img {
    width: 440em;
  }
  .mainte_profile_txt_area {
    width: 560em;
  }
  .mainte_profile_msg {
    line-height: 1.5;
  }
  .mainte_profile_msg_inner {
    font-size: 32em;
  }
  .mainte_profile_msg_name {
    margin-top: 15em;
  }
  .mainte_profile_msg_name_l {
    font-size: 24em;
  }
  .mainte_profile_msg_name_s {
    font-size: 20em;
  }
  .mainte_profile_detail_wrap {
    margin-top: 113em;
  }
  .mainte_profile_detail_name_l {
    font-size: 22em;
  }
  .mainte_profile_detail_name_s {
    font-size: 18em;
  }
  .mainte_profile_detail_txt {
    margin-top: 20em;
    line-height: 1.5;
  }
  .mainte_profile_detail_txt_inner {
    font-size: 16em;
  }
  .mainte_btn {
    margin-top: 120em;
  }
  .mainte_profile_price {
    margin: 20em 0 0 52em;
    width: 440em;
  }
  .mainte_profile_price_inner {
    font-size: 12em;
  }
}
@media (max-width: 750px) {
  .mainte {
    padding: 148em 0 0;
  }
  .mainte_sub_ttl {
    margin-top: 62em;
  }
  .mainte_sub_ttl_inner {
    font-size: 40em;
  }
  .mainte_txt {
    width: 100%;
    margin-top: 45em;
  }
  .mainte_txt_inner {
    font-size: 28em;
    line-height: 1.5;
  }
  .mainte_item_wrap {
    margin-top: 57em;
    width: 100%;
    height: 466em;
    background: url(../img/mainte_img_sp.jpg) no-repeat top center / cover;
  }
  .mainte_item_wrap .inner {
    padding: 0;
  }
  .mainte_item_bottom_txt {
    margin: 57em auto 0;
    width: 100%;
  }
  .mainte_item_bottom_txt_inner {
    font-size: 28em;
    line-height: 1.5;
  }
  .mainte_profile {
    margin: 113em 0 0;
  }
  .mainte_profile_img {
    width: 440em;
    margin: 0 auto;
  }
  .mainte_profile_txt_area {
    margin-top: 55em;
    width: 100%;
  }
  .mainte_profile_msg {
    display: flex;
    justify-content: center;
  }
  .mainte_profile_msg_inner {
    font-size: 38em;
    line-height: 1.47;
  }
  .mainte_profile_msg_name {
    margin-top: 22em;
  }
  .mainte_profile_msg_name_l {
    font-size: 28em;
  }
  .mainte_profile_msg_name_s {
    font-size: 28em;
  }
  .mainte_profile_detail_name {
    width: 600em;
    margin-inline: auto;
  }
  .mainte_profile_detail_name_l {
    font-size: 30em;
  }
  .mainte_profile_detail_name_s {
    font-size: 28em;
  }
  .mainte_profile_detail_txt {
    margin: 28em auto 0;
    width: 600em;
  }
  .mainte_profile_detail_txt_inner {
    font-size: 24em;
    line-height: 1.5;
  }
  .mainte_item_txt_box_wrap + .mainte_item_txt_box_wrap {
    margin-top: 74em;
  }
  .mainte_item_sp_img {
    line-height: 0;
    margin-bottom: -61em;
  }
  .mainte_item_txt_box + .mainte_item_txt_box {
    margin-top: 54em;
  }
  .mainte_item_txt_copy_inner {
    font-size: 28em;
    line-height: 1.5;
  }
  .mainte_item_txt {
    line-height: 1.5;
    margin-top: 10em;
  }
  .mainte_item_txt_inner {
    font-size: 24em;
  }
  .mainte_item_note {
    line-height: 1.5;
    margin-top: 48em;
  }
  .mainte_item_note_inner {
    font-size: 20em;
  }
  .mainte_btn {
    margin-top: 155em;
  }
  .main .mainte_profile_price {
    margin: 25em 0 108em;
    color: #6e6e6e;
  }
  .mainte_profile_price_inner {
    font-size: 20em;
  }
}
/* commit */
.commit {
  overflow: hidden;
}
.commit_swiper_wrap {
  overflow: hidden;
  position: relative;
}
.commit_swiper_wrap::before,
.commit_swiper_wrap::after {
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  top: 0;
  z-index: 5;
  pointer-events: none;
}
.commit_swiper_wrap::before {
  left: 0;
}
.commit_swiper_wrap::after {
  right: 0;
}
.commit_swiper {
  margin: 0 auto;
}
.commit_navigation {
  display: flex;
  justify-content: space-between;
  position: absolute;
  top: 0;
  z-index: 10;
}
.commit_pagination {
  position: relative;
  color: transparent;
  top: 0;
  bottom: 0;
  display: flex;
  justify-content: center;
}
.swiper-pagination-current {
  color: #674506;
}
.swiper-pagination-total {
  color: rgba(103, 69, 6, 0.3);
}
.commit_pagination::after {
  content: "";
  display: block;
  background-color: rgba(103, 69, 6, 0.3);
  rotate: 0 0 1 45deg;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
.commit_next,
.commit_prev {
  display: block;
}
.commit_next {
  rotate: 0 0 1 180deg;
}
.commit_img {
  position: relative;
  line-height: 0;
}
.commit_img_txt_area {
  position: absolute;
}
.main .commit_img2_txt_area .commit_img_txt_num,
.main .commit_img2_txt_area .commit_img_txt,
.main .commit_img3_txt_area .commit_img_txt_num,
.main .commit_img3_txt_area .commit_img_txt {
  text-align: right;
}
.commit_img_txt_num {
  color: #674506;
}
.commit_img_txt_num_inner {
  letter-spacing: -0.06em;
  line-height: 1;
}
.commit_img_txt_inner {
  letter-spacing: -0.06em;
}
@media (min-width: 751px) {
  .commit {
    margin-top: 154em;
  }
  .commit_swiper_wrap {
    width: 1482em;
    left: 50%;
    translate: -50% 0;
    padding-top: 97em;
    margin-top: -49em;
  }
  .commit_swiper_wrap::before,
  .commit_swiper_wrap::after {
    width: 361em;
  }
  .commit_swiper_wrap::before {
    background: linear-gradient(to right, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) 24%, rgba(255, 255, 255, 0) 100%);
  }
  .commit_swiper_wrap::after {
    background: linear-gradient(to left, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) 24%, rgba(255, 255, 255, 0) 100%);
  }
  .commit_swiper {
    width: 502em;
  }
  .commit_swiper .swiper-slide {
    padding: 0 12em;
  }
  .commit_swiper_txt {
    padding: 36em 48em 0;
  }
  .commit_swiper_txt + .commit_swiper_txt {
    margin-top: -12em;
  }
  .commit_swiper_txt_inner {
    font-size: 16em;
    line-height: 1.5;
  }
  .commit_navigation {
    align-items: center;
    width: 200em;
    right: 50%;
    translate: 600em 0;
  }
  .commit_pagination {
    gap: 9em;
  }
  .swiper-pagination-current {
    font-size: 32em;
    margin-top: -0.4em;
  }
  .swiper-pagination-total {
    font-size: 24em;
    margin-top: 0.3em;
  }
  .commit_pagination::after {
    height: 31em;
    width: 1em;
    top: 10em;
  }
  .commit_next,
  .commit_prev {
    min-width: 35em;
    height: 31em;
    background: url(../img/commit_navigation_arrow.svg) no-repeat center / contain;
    cursor: pointer;
  }
  .commit_img1_txt_area {
    left: 48em;
    bottom: 34em;
  }
  .commit_img2_txt_area {
    right: 48em;
    top: 40em;
  }
  .commit_img3_txt_area {
    right: 48em;
    bottom: 34em;
  }
  .commit_img4_txt_area {
    left: 48em;
    top: 40em;
  }
  .commit_img_txt_num_inner {
    font-size: 40em;
  }
  .commit_img_txt {
    margin-top: 6em;
  }
  .commit_img_txt_inner {
    font-size: 24em;
    line-height: 1.5;
  }  
}
@media (max-width: 750px) {
  .commit {
    margin-top: 154em;
  }
  .commit_swiper_wrap {
    width: 100%;
    padding-top: 83em;
    margin-top: 72em;
  }
  .commit_swiper_wrap::before,
  .commit_swiper_wrap::after {
    width: 89em;
  }
  .commit_swiper_wrap::before {
    background: linear-gradient(to right, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
  }
  .commit_swiper_wrap::after {
    background: linear-gradient(to left, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
  }
  .commit_swiper {
    width: 604em;
  }
  .commit_swiper .swiper-slide {
    padding: 0 16em;
  }
  .commit_swiper_txt {
    padding: 42em 15em 0;
  }
  .commit_swiper_txt + .commit_swiper_txt {
    margin-top: -22em;
  }
  .commit_swiper_txt_inner {
    font-size: 24em;
    line-height: 1.5;
  }
  .commit_navigation {
    align-items: flex-end;
    width: 284em;
    right: 0;
    left: 0;
    margin: 0 auto;
  }
  .commit_pagination {
    gap: 12em;
    align-items: flex-end;
    line-height: 1;
  }
  .swiper-pagination-current {
    font-size: 44em;
    translate: 0 -0.2em;
  }
  .swiper-pagination-total {
    font-size: 34em;
  }
  .commit_pagination::after {
    height: 44em;
    width: 1px;
    top: 18em;
    left: 5em;
  }
  .commit_next,
  .commit_prev {
    min-width: 49em;
    height: 43em;
    background: url(../img/commit_navigation_arrow.svg) no-repeat center / contain;
  }
  .commit_img1_txt_area {
    left: 40em;
    bottom: 34em;
  }
  .commit_img2_txt_area {
    right: 40em;
    top: 40em;
  }
  .commit_img3_txt_area {
    right: 40em;
    bottom: 34em;
  }
  .commit_img4_txt_area {
    left: 40em;
    top: 40em;
  }
  .commit_img_txt_num_inner {
    font-size: 48em;
  }
  .commit_img_txt {
    margin-top: 6em;
  }
  .commit_img_txt_inner {
    font-size: 30em;
    line-height: 1.5;
  }
}
/* msg */
.msg {
  width: 100%;
  color: #fff;
}
.msg_copy_inner {
  letter-spacing: -0.06em;
}
.main .msg_name {
  text-align: right;
}
.msg_name_l {
  letter-spacing: -0.1em;
  line-height: 1;
}
.msg_name_s {
  letter-spacing: -0.06em;
  line-height: 1;
}
.main .msg_note {
  color: #ccc;
}
@media (min-width: 751px) {
  .msg {
    background: url(../img/msg_bg.jpg) no-repeat center / auto 100%;
    margin-top: 156em;
  }
  .msg_content {
    padding: 148em 0 61em;
    display: flex;
    justify-content: flex-end;
  }
  .msg_copy_inner {
    line-height: 1.5;
    font-size: 40em;
  }
  .main .msg_name {
    margin-top: 14em;
  }
  .msg_name_l {
    font-size: 24em;
  }
  .msg_name_s {
    font-size: 20em;
  }
  .msg_main {
    width: 582em;
    margin: 57em 38em 0 auto;
  }
  .msg_main_inner {
    font-size: 18em;
    line-height: 1.7;
  }
  .main .msg_note {
    margin-top: 52em;
    text-align: right;
  }
  .msg_note_inner {
    font-size: 12em;
    line-height: 1.5;
  }
}
@media (max-width: 750px) {
  .msg {
    background: url(../img/msg_bg_sp.jpg) no-repeat top center / 100% auto;
    margin-top: 156em;
  }
  .msg_content {
    padding: 90em 0 0;
  }
  .msg_copy_wrap {
    display: flex;
    justify-content: flex-end;
    position: relative;
    z-index: 1;
  }
  .msg_copy {
    writing-mode:vertical-rl;
    order: 1;
    padding-bottom: 16em;
    white-space: nowrap;
  }
  .msg_copy_inner {
    line-height: 1.5;
    font-size: 56em;
  }
  .main .msg_name {
    writing-mode:vertical-rl;
    margin-right: 26em;
  }
  .msg_name_l {
    font-size: 34em;
  }
  .msg_name_s {
    font-size: 28em;
  }
  .msg_main_wrap {
    width: 100%;
    margin: -306em 0 0 40em;
    padding: 373em 80em 112em;
    background-color: #101322;
  }
  .msg_main_inner {
    font-size: 28em;
    line-height: 1.5;
  }
  .msg_note {
    margin-top: 12em;
  }
  .msg_note_inner {
    font-size: 20em;
    line-height: 1.5;
  }
}
/* eye_cream */
.eye_cream_content {
  position: relative;
}
.eye_cream_txt_box1_copy_inner {
  font-weight: 700;
}
.eye_cream_txt_box2_copy_inner {
  font-weight: 700;
}
.eye_cream_txt_box2_note {
  color: #6e6e6e;
}
@media (min-width: 751px) {
  .eye_cream {
    padding: 184em 0 155em;
  }
  .eye_cream_content {
    margin-top: 54em;
    padding-top: 136em;
  }
  .eye_cream_txt_box1_wrap {
    display: flex;
    justify-content: flex-end;
  }
  .eye_cream_txt_box1 {
    width: 622em;
  }
  .eye_cream_txt_box1_copy_inner {
    font-size: 26em;
    line-height: 1.5;
  }
  .eye_cream_txt_box1_txt {
    margin-top: 26em;
  }
  .eye_cream_txt_box1_txt_inner {
    font-size: 18em;
    line-height: 1.7;
  }
  .eye_cream_img {
    position: absolute;
    top: 0;
    left: -120em;
    width: 787em;
    z-index: -1;
  }
  .eye_cream_txt_box2_wrap {
    margin-top: 80em;
  }
  .eye_cream_txt_box2_copy_inner {
    font-size: 18em;
    line-height: 1.3;
  }
  .eye_cream_txt_box2_txt {
    margin-top: 8em;
    width: 548em;
  }
  .eye_cream_txt_box2_txt_inner {
    font-size: 16em;
    line-height: 1.5;
  }
  .eye_cream_txt_box2_note {
    margin-top: 8em;
  }
  .eye_cream_txt_box2_note_inner {
    font-size: 12em;
    line-height: 1;
  }
}
@media (max-width: 750px) {
  .eye_cream .section_ttl_l {
    line-height: 1.35;
  }
  .eye_cream {
    padding: 148em 0 120em;
  }
  .eye_cream_content {
    margin-top: 60em;
  }
  .eye_cream_txt_box1 {
    width: 100%;
  }
  .eye_cream_txt_box1_copy_inner {
    font-size: 40em;
    line-height: 1.5;
  }
  .eye_cream_txt_box1_txt {
    margin-top: 25em;
  }
  .eye_cream_txt_box1_txt_inner {
    font-size: 28em;
    line-height: 1.5;
  }
  .eye_cream_img {
    width: 100%;
  }
  .eye_cream_txt_box2_wrap {
    margin-top: 66em;
    width: calc(100% + 40em);
    position: relative;
  }
  .eye_cream_txt_box2 {
    position: absolute;
    bottom: 0;
    left: 0;
    padding: 0 40em 75em;
  }
  .eye_cream_txt_box2_copy_inner {
    font-size: 28em;
    line-height: 1.5;
  }
  .eye_cream_txt_box2_txt {
    margin-top: 18em;
  }
  .eye_cream_txt_box2_txt_inner {
    font-size: 24em;
    line-height: 1.5;
  }
  .eye_cream_txt_box2_note {
    margin-top: 9em;
  }
  .eye_cream_txt_box2_note_inner {
    font-size: 20em;
    line-height: 1.5;
  }
}
/* info */
.main .info_contact {
  text-align: center;
}
.info_contact a {
  color: #000;
  text-decoration: underline;
}
.main .info_note {
  text-align: center;
  color: #6e6e6e;
}
.main .info_bottom_txt {
  text-align: center;
}
@media (min-width: 751px) {
  .info {
    padding-bottom: 40em;
  }
  .info_btn_area .btn + .btn {
    margin-top: 32em;
  }
  .main .info_contact {
    margin-top: 60em;
  }
  .info_contact_l {
    font-size: 16em;
    line-height: 1.5;
  }
  .info_contact_s {
    font-size: 14em;
  }
  .main .info_note {
    margin-top: 36em;
  }
  .info_note_inner {
    font-size: 12em;
    line-height: 1;
  }
  .main .info_bottom_txt {
    margin-top: 116em;
  }
  .info_bottom_txt_inner {
    font-size: 12em;
    line-height: 1.5;
  }  
}
@media (max-width: 750px) {
  .info {
    padding-bottom: 34em;
  }
  .info_btn_area .btn + .btn {
    margin-top: 40em;
  }
  .main .info_contact {
    margin-top: 74em;
  }
  .info_contact_l {
    font-size: 24em;
    line-height: 1.5;
  }
  .info_contact_s {
    font-size: 22em;
  }
  .main .info_note {
    margin-top: 64em;
  }
  .info_note_inner {
    font-size: 20em;
    line-height: 1;
  }
  .main .info_bottom_txt {
    margin-top: 75em;
  }
  .info_bottom_txt_inner {
    font-size: 20em;
    line-height: 1.5;
  }
}
/* page_top */
.page_top_wrap {
  position: relative;
  display: block;
}
.page_top_btn {
  position: absolute;
  bottom:0;
  right:0;
  background: url(../img/page_top_btn.png) no-repeat center / contain;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 100;
}
.page_top_btn_arrow {
  display: block;
  margin-inline: auto;
}
.page_top_txt {
  text-align: center;
  color: #674506;
  display: block;
}
.page_top_txt_inner {
  line-height: 1;
}
/* 共通で透過するスタイルが当たっていたので打ち消し */
.page_top_btn:hover {
  opacity: 1;
}
@media (min-width: 751px) {
  .page_top_btn {
    position: fixed;
    bottom: 40em;
    right: 40em;
    width: 96em;
    height: 96em;
  }
  .page_top_btn_arrow {
    width: 25em;
  }
  .page_top_txt {
    margin-top: 12em;
  }
  .page_top_txt_inner {
    font-size: 18em;
  }
  @media (hover: hover) {
    .page_top_btn_arrow {
      transition: translate 0.3s;
    }
    .page_top_btn:hover .page_top_btn_arrow {
      translate: 0 -5em
    }
  }
}
@media (max-width: 750px) {
  .page_top {
    position: absolute;
    right: 40em;
    bottom: -384em;
    width: 117em;
    height: 117em;
  }
  .page_top_btn {
    width: 117em;
    height: 117em;
    transition: none;
    margin-bottom: 40em;
  }
  .is_floating .page_top_btn {
    position: fixed;
    right: 40em;
  }
  .page_top_btn_arrow {
    width: 27em;
  }
  .page_top_txt {
    margin-top: 19em;
  }
  .page_top_txt_inner {
    font-size: 26em;
  }
}

/* window_height_dvh */
.window_height_dvh {
  position: fixed;
  top: 0;
  left: 0;
  width: 0;
  height: 100vh;
  height: 100dvh;
  transition: none;
}

