@charset "UTF-8";

@import "base.css";

@import "fonts.css";

/*@import url('https://fonts.googleapis.com/css2?family=Cormorant:wght@300;400;500&family=Shippori+Mincho:wght@400;500;600;700&display=swap');*/

@font-face {
  font-family: "Cormorant";
  src: url("../fonts/Cormorant-Light.eot");
  src: url("../fonts/Cormorant-Light.eot?#iefix") format("embedded-opentype"),
    url("../fonts/Cormorant-Light.woff2") format("woff2"),
    url("../fonts/Cormorant-Light.woff") format("woff"),
    url("../fonts/Cormorant-Light.ttf") format("truetype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Cormorant";
  src: url("../fonts/Cormorant-Regular.eot");
  src: url("../fonts/Cormorant-Regular.eot?#iefix") format("embedded-opentype"),
    url("../fonts/Cormorant-Regular.woff2") format("woff2"),
    url("../fonts/Cormorant-Regular.woff") format("woff"),
    url("../fonts/Cormorant-Regular.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Cormorant";
  src: url("../fonts/Cormorant-Medium.eot");
  src: url("../fonts/Cormorant-Medium.eot?#iefix") format("embedded-opentype"),
    url("../fonts/Cormorant-Medium.woff2") format("woff2"),
    url("../fonts/Cormorant-Medium.woff") format("woff"),
    url("../fonts/Cormorant-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Shippori Mincho";
  src: url("../fonts/ShipporiMincho-Regular.eot");
  src: url("../fonts/ShipporiMincho-Regular.eot?#iefix") format("embedded-opentype"),
    url("../fonts/ShipporiMincho-Regular.woff2") format("woff2"),
    url("../fonts/ShipporiMincho-Regular.woff") format("woff"),
    url("../fonts/ShipporiMincho-Regular.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Shippori Mincho";
  src: url("../fonts/ShipporiMincho-Medium.eot");
  src: url("../fonts/ShipporiMincho-Medium.eot?#iefix") format("embedded-opentype"),
    url("../fonts/ShipporiMincho-Medium.woff2") format("woff2"),
    url("../fonts/ShipporiMincho-Medium.woff") format("woff"),
    url("../fonts/ShipporiMincho-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Shippori Mincho";
  src: url("../fonts/ShipporiMincho-SemiBold.eot");
  src: url("../fonts/ShipporiMincho-SemiBold.eot?#iefix") format("embedded-opentype"),
    url("../fonts/ShipporiMincho-SemiBold.woff2") format("woff2"),
    url("../fonts/ShipporiMincho-SemiBold.woff") format("woff"),
    url("../fonts/ShipporiMincho-SemiBold.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Shippori Mincho";
  src: url("../fonts/ShipporiMincho-Bold.eot");
  src: url("../fonts/ShipporiMincho-Bold.eot?#iefix") format("embedded-opentype"),
    url("../fonts/ShipporiMincho-Bold.woff2") format("woff2"),
    url("../fonts/ShipporiMincho-Bold.woff") format("woff"),
    url("../fonts/ShipporiMincho-Bold.ttf") format("truetype");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}

/*==========================================================================*/

/*                                                                          */

/*    base.css  --> スタイルの初期設定を行うため、変更しないで下さい。      */

/*    fonts.css --> フォントの初期設定を行うため、変更しないで下さい。      */

/*                                                                          */

/*==========================================================================*/

/*==========================================================================*/

/*                           Common-Setting                                 */

/*==========================================================================*/

/* 基本タグのフォントサイズを指定（12px -> 120% or 1.2em ） */

h1,
h2,
h3,
h4,
h5,
h6,
input,
button,
textarea,
select,
p,
blockquote,
th,
td,
pre,
address,
li,
dt,
dd {
  font-size: 160%;

  -webkit-text-size-adjust: none;

  font-weight: 500;
}

html:focus-within {
  scroll-behavior: smooth;
}

img {
  vertical-align: middle;

  max-width: 100%;

  flex-shrink: 0;

  height: auto;
}

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

  outline: none;
}

select {
  visibility: visible !important;
}

a {
  transition: all ease 0.3s;

  text-decoration: none;

  color: var(--txt);
}

a[href^="tel:"] {
  word-break: keep-all;
}

/*==========================================================================*/

/*                               Container                                  */

/*==========================================================================*/

html {
  background: #fff;
}

body {
  color: var(--txt);

  -webkit-text-size-adjust: none;

  min-width: 320px;

  font-family: 'Noto Sans JP', sans-serif;
}

table {
  width: 100%;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  line-height: 1.333;
}

h3,
h4,
h5,
h6 {
  letter-spacing: 0.1em;
}

p,
dd,
dt,
li,
th,
td,
address {
  line-height: 2em;

  letter-spacing: 0.075em;
}

p {
  margin: 0 0 1.5em;
}

p:last-child {
  margin-bottom: 0;
}

.fixed {
  position: fixed;
}

.bold {
  font-weight: bold;
}

.left {
  text-align: left;
}

.auto {
  margin-left: auto;

  margin-right: auto;
}

.white {
  color: #fff;
}

.txt_line {
  text-decoration: underline;
}

.m0a {
  display: block;

  margin: 0 auto;
}

.f_big {
  font-size: 150%;
}

.f_sm {
  font-size: 80%;
}

:root {
  --font-main: "Shippori Mincho", serif;

  --txt: #333333;

  --black: #4c4c4c;

  --black02: url(../images/bg_bl02.jpg) repeat;

  --black03: url(../images/bg_bl.jpg) repeat;

  --mcolor: url(../images/bg_bl.jpg) repeat;

  --scolor: #f3f3f3;

  --site_size: 1310px;

  --gray: url(../images/bg_gray.jpg) repeat;

  --gray02: url(../images/bg_gray02.jpg) repeat;

  --brown: url(../images/bg_brown.jpg) repeat;

  --brown02: url(../images/bg_brown02.jpg) repeat;

  --green: #2e563b;
  --green02: #99be23;

  /*     --f-yuthic: "游ゴシック体", "Yu Gothic", YuGothic, sans-serif; */

  --f-en: "Cormorant", serif;
}

#wrapper {
  min-width: 1260px;

  overflow: hidden;

  margin: 0 auto;
}

.inner {
  width: var(--site_size);

  margin: 0 auto;

  position: relative;

  max-width: 100%;

  padding: 0 15px;
}

.container {
  width: 100%;

  max-width: 1920px;

  margin: 0 auto;

  position: relative;
}

/*==========================================================

                       H E A D E R  

==========================================================*/

header {
  position: relative;

  z-index: 13;
}

header.show .h_box {
  background-color: rgb(0 0 0 / 50%);

  box-shadow: 0 2px 20px rgb(0 0 0 / 20%);
}

#logo {
  padding: 30px 0 10px 50px;
  width: 250px;
  transition: all 0.5s ease;
}

#logo img {
  width: 100%;
}

.h_box {
  width: 100%;

  position: fixed;
  top: 0;
  background-color: transparent;
}

.h_box .tag_h1 {
  position: absolute;
  top: 3.5%;
  left: 2.5%;
  color: #fff;
  font-size: 120%;
  display: block ruby;
}

#header.show .h_box .tag_h1 {
  display: none;
}

.h_inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 100%;
  width: 100%;
  max-width: 1920px;
  position: relative;
  margin: 0 auto;
}

.h_contact {
  /* position: fixed;

  right: 0;

  bottom: 50px; */

  display: flex;

  /* flex-direction: column; */

  align-items: center;

  z-index: 13;

  transition: all 0.5s ease;
  margin-right: 110px;
}

.h_contact>p {
  margin-bottom: 0;
}

.h_contact>p:not(:last-child) {
  /* margin-bottom: 6px; */
  margin-right: 5px;
}

.h_contact a {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  box-shadow: 4px 4px 20px rgba(0, 0, 0, 0.2);
  transition: all 0.5s ease;
  padding: 0 20px;
  color: #40362c;
  font-weight: 600;
  min-height: 50px;
  min-width: 150px;
}

.h_contact .h_contact_chat a {
  background: url(../images/bg_brown.jpg) repeat;
}

.h_contact .h_contact_cal a {
  background: url(../images/bg_brown02.jpg) repeat;
}

.h_contact .h_contact_mail a {
  background: url(../images/bg_gray02.jpg) repeat;
}

.h_contact .h_contact_ins a {
  background: url(../images/bg_ins.jpg) repeat;
}

.h_contact .h_contact_yt a {
  background: var(--black02);
  color: #fff;
}

.h_contact .h_contact_line a {
  background: #585858;
  color: #fff;
}

.h_contact .h_contact_chat a {
  color: #fff;
}

.h_contact a span {
  z-index: 2;
  font-size: 14px;
  display: inline-block;
  position: relative;
  line-height: 1em;
  transition: all 0.5s ease;
  padding-left: 30px;
}

.h_contact_chat a span::before {
  content: "";
  position: absolute;
  width: 24px;
  height: 24px;
  left: -3px;
  top: -2px;
  background: url(../images/ic_chat.png) no-repeat center / cover;
}

.h_contact_cal a span::before {
  content: "";
  position: absolute;
  width: 28px;
  height: 25px;
  left: -4px;
  top: -3px;
  background: url("../images/ic_calendar.png") no-repeat center / cover;
}

.h_contact_mail a span::before {
  content: "";
  position: absolute;
  width: 24px;
  height: 25px;
  left: -3px;
  top: -4px;
  background: url("../images/ic_h_mail.png") no-repeat center / cover;
  transition: all 0.5s ease;
}

.h_contact_ins a span::before {
  content: "";
  position: absolute;
  width: 26px;
  height: 26px;
  left: -3px;
  top: -4px;
  background: url(../images/ic_ins2.png) center / cover no-repeat;
}

.h_contact_yt a span::before {
  content: "";
  position: absolute;
  width: 30px;
  height: 30px;
  left: -5px;
  top: -5px;
  background: url(../images/ic_yt.svg) center / cover no-repeat;
}

.h_contact_line a span::before {
  content: "";
  position: absolute;
  width: 24px;
  height: 24px;
  left: -2px;
  top: -2px;
  background: url(../images/ic_line_top.png) center / cover no-repeat;
}

/* 
.h_contact a {

    color: #40362c;

    font-weight: 600;

    text-align: center;

    display: flex;

    justify-content: center;

    align-items: flex-end;

    width: 130px;

    height: 120px;

    padding-bottom: 20px;
    box-shadow: 4px 4px 20px rgba(0, 0, 0, 0.2);
    transition: all .5s ease;
}

.h_contact a span {

    z-index: 2;

    font-size: 16px;

    display: inline-block;

    position: relative;

    padding-top: 38px;

    line-height: 1.375em;

    min-height: 82px;

    display: flex;

    flex-direction: column;
    transition: all .5s ease;

    justify-content: flex-end;

}

.h_contact_chat a span::before {

    content: '';

    position: absolute;

    width: 30px;
    height: 29px;
    left: calc(50% - 15px);

    top: 0;

    background: url('../images/ic_chat.png') no-repeat center /cover;

}

.h_contact_cal a span::before {

    content: '';

    position: absolute;

    width: 37px;

    height: 33px;

    left: calc(50% - 19px);

    top: 0;

    background: url('../images/ic_calendar.png') no-repeat center /cover;

}

.h_contact_mail a span::before {

    content: '';

    position: absolute;

    width: 32px;

    height: 34px;

    left: calc(50% - 16px);

    top: 0;

    background: url('../images/ic_h_mail.png') no-repeat center /cover;
    transition: all .5s ease;

}

.h_contact_ins a span::before {
    content: '';
    position: absolute;
    width: 36px;
    height: 36px;
    left: calc(50% - 18px);
    top: 0;
    background: url(../images/ic_ins2.png) center / cover no-repeat;
}

.h_contact_line a span::before,
.h_contact_yt a span::before {
    content: '';
    position: absolute;
    width: 36px;
    height: 36px;
    left: calc(50% - 18px);
    top: 0;
    background: url(../images/ic_yt.svg) center / cover no-repeat;
}

.h_contact_line a span::before {
    background: url(../images/ic_line.png) center / cover no-repeat;
} */

.h_contact_tel .time {
  font-size: 12px;

  display: block;

  line-height: 1.6;

  text-align: right;
}

/*  nav_new */
.nav_new {
  transition: all 0.3s ease;
  margin-top: 10px;
}

.nav_new .nav_new_list {
  display: flex;
  background: rgb(51 51 51 / 80%);
  position: relative;
}

.nav_new .nav_new_list>li {
  width: 20%;
  height: 50px;
  position: static;
  transition: all 0.3s ease;
}

.nav_new .nav_new_list>li>a {
  font-size: 14px;
  color: #fff;
  font-weight: bold;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  width: 100%;
  padding: 18px 0 18px;
  line-height: 1;
}

.nav_new .nav_new_list>li:not(:last-child)>a:before {
  content: "";
  position: absolute;
  right: 0;
  top: 10px;
  width: 1px;
  height: calc(100% - 20px);
  background-color: #fff;
}

.nav_new .nav_new_list>li.parent>a {
  cursor: default;
}

.nav_new .nav_new_list>li.parent>a::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 6px;
  transform: translateX(-50%);
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 4px 0 4px;
  border-color: #fff transparent transparent transparent;
}

.nav_new .nav_new_list>li.parent:hover .nav_new_sub {
  display: flex;
}

.nav_new .nav_new_list>li.parent.item_center .nav_new_sub {
  justify-content: center;
}

.nav_new_sub {
  width: 100%;
  position: absolute;
  top: 50px;
  left: 0;
  background-color: #fff;
  transition: all 0.3s ease;
  padding: 15px 10px;
  background-color: rgb(243 243 243 / 70%);
  display: none;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
}

.nav_new_list>li.is05 .nav_new_sub {
  justify-content: flex-end;
}

.nav_new_sub>li {
  width: 20%;
  background-color: #fff;
  position: relative;
  transition: all 0.3s ease;
}

.nav_new_list>li.is04 .nav_new_sub>li {
  margin-left: calc(40% + 10px);
}

.nav_new_sub>li.dif {
  width: 24%;
}

.nav_new_sub>li:not(:last-child) {
  border-right: 1px solid var(--txt);
}

.nav_new_sub>li a {
  z-index: 1;
}

.nav_new_sub>li .pic {
  margin: 0;
  height: 130px;
}

.nav_new_sub>li .pic img {
  aspect-ratio: 16 / 9;
  width: 100%;
  height: 100% !important;
  object-fit: cover;
}

.nav_new_sub>li .txt {
  padding: 10px 0;
}

.nav_new_sub>li .txt .en {
  font-size: 15px;
  text-transform: uppercase;
  font-weight: 500;
  letter-spacing: 0;
  margin: 0;
  color: #928169;
}

.nav_new_sub>li .txt .ja {
  position: relative;
  font-weight: bold;
  margin-top: 0px;
  letter-spacing: 0em;
  font-size: 14px;
  padding: 0 5px 0 15px;
}

.nav_new_sub>li .txt .ja .ja_dif {
  margin-left: -7px;
}

.nav_new_sub>li .txt .ja::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 11px;
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 6px;
  border-color: transparent transparent transparent #ff671f;
}

/* HAMBUGER BUTTON */

.hamburger {
  font: inherit;

  display: block;

  overflow: visible;

  margin: 0;

  padding: 10px 8px 5px;

  cursor: pointer;

  transition-timing-function: linear;

  transition-duration: 0.15s;

  transition-property: opacity, filter, top;

  text-transform: none;

  color: inherit;

  border: 0;

  position: absolute;

  top: 20px;

  right: 29px;

  z-index: 3;
}

.hamburger-box {
  position: relative;

  display: inline-block;

  width: 38px;

  height: 24px;
}

.hamburger-inner {
  top: 50%;

  display: block;

  margin-top: -2px;
}

.hamburger-inner,
.hamburger-inner::after,
.hamburger-inner::before {
  position: absolute;

  width: 38px;

  height: 2px;

  transition-timing-function: ease;

  transition-duration: 0.15s;

  transition-property: transform;

  border-radius: 4px;

  background-color: #fff;
}

.hamburger-inner {
  background-color: transparent;
}

.hamburger-inner::after,
.hamburger-inner::before {
  display: block;

  content: "";
}

.hamburger-inner::before {
  top: 0;
}

.hamburger-inner::after {
  bottom: -8px;
}

.hamburger--3dxy .hamburger-box {
  perspective: 80px;
}

.hamburger--3dxy .hamburger-inner {
  transition: transform 0.15s cubic-bezier(0.645, 0.045, 0.355, 1),
    background-color 0 cubic-bezier(0.645, 0.045, 0.355, 1) 0.1s;
}

.hamburger--3dxy .hamburger-inner::after,
.hamburger--3dxy .hamburger-inner::before {
  transition: transform 0 cubic-bezier(0.645, 0.045, 0.355, 1) 0.1s;
}

.hamburger--3dxy.is_active .hamburger-inner {
  transform: rotateX(180deg) rotateY(180deg);

  background-color: transparent !important;
}

.hamburger--3dxy.is_active .hamburger-inner::before {
  transform: translate3d(0, 0px, 0) rotate(45deg);
}

.hamburger--3dxy.is_active .hamburger-inner::after {
  transform: translate3d(0, -8px, 0) rotate(-45deg);
}

/*==========================================================

                  M A I N    V I S U A L

==========================================================*/

main {
  position: relative;

  z-index: 2;
}

.mv {
  position: relative;
  background: #DCDDDD;
  padding: 0;
}

.mv_bg {
  position: relative;

  overflow: hidden;
  /* 
  opacity: 0; */

  transition: all 0.3s;
}

/* .mv_bg.init {

  opacity: 1
} */

.main_slider {
  position: absolute;

  top: 0;

  left: 0;

  width: 100%;

  height: 100%;

  z-index: 1;
}

.mv_bg,
.main_slider .slide_item {
  width: 100%;

  height: 100vh;
}

/* 
.main_slider .slide_item .bg {

  position: absolute;

  width: 100%;

  height: 100%;

  z-index: 0;

  top: 0;

  left: 0;

  background-size: cover;

  background-position: center
}



.main_slider .slide_item.zoomed .bg {

  animation-name: zoomImg;

  animation-duration: 6s;

  animation-timing-function: linear;

  animation-fill-mode: forwards
} */

.main_slider .sub_slider {
  display: flex;
  position: relative;
  background: #DCDDDD;
  padding-left: 471px;
  height: 100%;
  z-index: -1;
}

.main_slider .sub_slider .box {
  width: 100%;
  max-width: 640px;
  height: 100%;
  position: relative;
}

.main_slider .sub_slider .box:last-child {
  margin-left: 40px;
}

.main_slider .sub_slider .mv_list {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.main_slider .sub_slider .mv_list .slick-list {
  flex: 1;
}

.main_slider .sub_slider .mv_list li {
  margin-bottom: 20px;
  width: 100%;
  border: 0;
  position: relative;
}

.main_slider .sub_slider .mv_list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgb(0 0 0 / 32%);
  z-index: 1;
}

.mv_list.is02 {
  transform: rotate(180deg);
}

.mv_list.is02 li {
  transform: rotate(-180deg);
}

.mv_txt {
  position: absolute;

  z-index: 2;

  top: 50%;

  left: 50%;

  transform: translate(-50%, -50%);

  width: 100%;

  height: auto;
}

.mv_txt .txt {
  font-size: 60px;

  font-weight: 400;

  letter-spacing: 0.075em;

  color: #fff;

  position: relative;

  padding: 0 0 140px 103px;

  line-height: 1.333;

  display: inline-block;
}

.slide_item.is02 .mv_txt .txt {
  padding: 0 0 0px 8px;
}

.mv_txt .txt .pic {
  position: absolute;

  right: 19px;
  bottom: 14px;
}

.slide_item.is02 .mv_txt .txt .pic {
  position: absolute;
  right: -168px;
  bottom: -109px;
}

.mv_txt .txt .aos_txt {
  display: block;

  overflow: hidden;

  overflow-y: hidden;
}

/* .mv_badge {
    position: absolute;
    width: 200px;
    height: 200px;
    bottom: 30px;
    right: 50px;
    border-radius: 50%;
    background-color: #fafae0;
    margin: 0;
    color: var(--txt);
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    font-size: 20px;
    transform: rotate(13deg);
    font-weight: bold;
    line-height: 1.6;
    text-align: center;
    box-shadow: 6px 6px 4px rgb(211 211 127 / 84%);
    background: url(../images/bg_green.jpg) repeat;
} */

.mv_badge {
  position: fixed;
  width: 197px;
  height: 134px;
  bottom: 110px;
  right: 20px;
  margin: 0;
  z-index: 999;
  color: transparent;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  font-size: 20px;
  line-height: 1.6;
  text-align: center;
  /* box-shadow: 7px 5px 1px rgb(216 216 169); */
}

/* 
.mv_badge::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 300px;
    height: 300px;
    background: url(../images/badge_top.png) center / cover no-repeat;
}
 */

@keyframes zoomImg {
  0% {
    transform: scale(1.2);
  }

  100% {
    transform: scale(1);
  }
}

.box_news {
  /* org  width: 740px; */
  width: 76%;
  /* 2024.4.30 modified. */

  /* height: 60px; */

  background: url(../images/bg_news.png) repeat;

  display: flex;

  align-items: center;

  justify-content: space-between;

  padding: 10px 20px;

  position: absolute;

  left: 0;

  bottom: 0;

  z-index: 1;

  opacity: 0;

  transition: opacity 1s;
}

.box_news .news_list {
  width: calc(100% - 195px);
  /* height: 30px; */
  overflow: hidden;
}

.box_news .news_list .slick-track {
  display: flex;
  align-items: center;
}

.box_news.--init {
  opacity: 1;
}

.box_news .wrap_txt {
  display: flex;

  align-items: center;

  width: 100%;
}

.box_news .txt,
.box_news .news_btn a {
  font-family: 'Noto Sans JP', sans-serif;

  font-size: 14px;

  letter-spacing: 0.075em;

  font-weight: 500;

  padding-left: 30px;

  margin-bottom: 0;
}

.box_news .txt {
  line-height: 1.2;
}

.box_news .txt a {
  display: block;
}

.box_news .txt.time {
  font-weight: bold;

  padding-left: 0;
}

.box_news .news_btn {
  padding-left: 22px;
  border-left: 1px solid #a6a6a6;
}

.box_news .news_btn a {
  position: relative;

  display: block;

  padding: 0 33px 0 0px;

  height: 28px;

  display: flex;

  justify-content: center;

  align-items: center;
}

.box_news .news_btn a::before {
  content: "";

  position: absolute;

  right: -2px;

  top: calc(50% - 12px);

  width: 24px;

  height: 24px;

  background: url(../images/ic_op_bl.png) center / cover no-repeat;
}

/*==========================================================

                M A I N    C O N T E N T

==========================================================*/

/* DEFAULT TITLE */

.limit_txt {
  text-overflow: ellipsis;

  overflow: hidden;

  white-space: nowrap;
}

.ttl {
  font-weight: 600;

  position: relative;
}

.ttl span {
  display: block;
}

.en {
  font-family:"Playfair Display",sans-serif;
}

.en.big {
  font-family:"Playfair Display",sans-serif;

  font-size: 200px;

  letter-spacing: 0;

  font-weight: 300;

  line-height: 1;

  position: absolute;

  color: #ececec;

  z-index: -1;
}

.f_yt {
  font-family: 'Noto Sans JP', sans-serif;
}

.ttl .en {
  font-size: 70px;

  font-weight: 400;

  letter-spacing: 0;
  line-height: 1.3;
}

.ttl .ja {
  font-size: 24px;
}

.link_wrap {
  position: absolute;

  left: 0;

  top: 0;

  width: 100%;

  height: 100%;
  z-index: 1;
}

.hv_01 a.link_wrap::before{
  background-color: transparent;
}

.dect {
  font-family: 'Noto Sans JP', sans-serif;
}

/* DEFAUTL NAME BUTTON */

.btn a {
  width: 262px;

  height: 66px;

  display: flex;

  justify-content: center;

  align-items: center;

  font-size: 18px;

  text-decoration: none;

  font-weight: 600;

  letter-spacing: 0.1em;

  border: 2px solid #808080;

  position: relative;
  text-align: center;
  line-height: 1.4;
}

.btn a::before {
  content: "";

  position: absolute;

  right: -23px;

  top: calc(50% - 4px);

  width: 42px;

  height: 8px;

  background: url(../images/ic_arrow_bl.png) center / cover no-repeat;
}

.btn.black a {
  color: #fff;

  background: var(--txt);

  border-color: var(--txt);
}

.btn.black a::before {
  background-image: url(../images/ic_arrow_dif.png);

  top: calc(50% - 8px);
}

.btn.center a {
  margin-left: auto;

  margin-right: auto;
}

section {
  padding: 40px 0 0;
}

.tmp_slick .slick-prev,
.tmp_slick .slick-next {
  width: 80px;

  height: 80px;

  border: 1px solid var(--txt);

  border-radius: 50%;

  top: 180px;

  transition: all 0.3s ease;

  transform: none;
}

.tmp_slick .slick-prev {
  right: calc(100% + 330px);

  left: inherit;
}

.tmp_slick .slick-next {
  right: calc(100% + 230px);
}

.tmp_slick .slick-prev::before,
.tmp_slick .slick-next::before {
  content: "";

  opacity: 1;

  -webkit-font-smoothing: none;

  -moz-osx-font-smoothing: none;

  width: 25px;

  height: 6px;

  top: calc(50% - 2px);

  left: calc(50% - 13px);

  display: block;

  position: absolute;

  transition: all 0.3s ease;
}

.tmp_slick .slick-prev::before {
  background: url(../images/prev.png) center / cover no-repeat;
}

.tmp_slick .slick-next::before {
  background: url(../images/next.png) center / cover no-repeat;
}

/* use private */

/*==================== SEC01 ===================*/

.sec01 {
  padding-top: 60px;
  /* padding-bottom: 120px; */
  color: #575757;
  background: #DCDDDD;
}

.sec01.movie_sc {
  padding-bottom: 0;
}

.sec01.bottom {
  padding-bottom: 0;
  padding-top: 0;
}

.sec01_top {
  width: auto;
  margin-left: 62px;
  padding-top: 40px;
  border-top: 1px solid #575757;
  display: flex;
  flex-wrap: wrap;
}

#contact_note {
  text-align: center;
  font-size: 20px;
  margin: 50px auto 0;
  background-color: #fffd63;
  padding: 5px;
  width: 75%;
}

.contact_first {
  margin-top: 61px;
}

.sec01_top.topin {
  padding-bottom: 60px;
  margin-bottom: 0;
  border-bottom: 1px solid #575757;
}

.sec01_top.topin.blog_tp {
  padding-bottom: 60px;
  margin-bottom: 0px;
  padding-top: 60px;
  margin-top: 0px;
  border-bottom: 1px solid #575757;
}

.sec01_top .ttl .ja {
  letter-spacing: 0.1em;
}

.sec01 .btn a {
  background-color: #fff;
}

.sec01 .btn_box {
  width: 100%;
}

.sec01_list {
  display: flex;
  margin-left: 50px;
}

.sec01_list .slick-list {
  width: 100%;
}

.sec01_list li {
  position: relative;

  z-index: 1;

  margin: 10px;
  width: calc(100% / 3 - 20px);
}

.sec07_list li .pic,
.sec01_list li .pic,
.sec09_list li .pic {
  margin-bottom: 30px;
  height: 400px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #e5e5e5;
}

.sec01_list li .pic {
  height: auto;
  max-height: 300px;
  overflow: hidden;
  background-color: transparent;
}

.sec01_list li .pic img {
  width: 100%;
  object-fit: cover;
  aspect-ratio: 16 / 9;
}

.sec01_list li .wrap_txt {
  margin-top: 34px;

  max-width: 600px;
}

.sec01_list li .wrap_txt p:not(:last-child) {
  margin-bottom: 20px;
}

.sec01_list li .wrap_txt .time {
  font-size: 14px;

  font-weight: bold;

  padding-left: 0;

  line-height: 1;

  position: relative;

  letter-spacing: 0.1em;
}

.sec01_list li .wrap_txt .time::before {
  content: "";
  display: none;
  position: absolute;

  left: 2px;

  top: calc(50% - 1px);

  width: 80px;

  height: 1px;

  background-color: #fff;
}

.sec01_list li .wrap_txt .txt {
  font-size: 20px;

  font-weight: 600;

  letter-spacing: 0.1em;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  height: 80px;
}

.sec01_list .slick-prev,
.sec01_list .slick-next {
  border-color: #fff;
}

.sec01_list .slick-prev {
  right: calc(100% + 280px);
  left: inherit;
}

.sec01_list .slick-next {
  right: calc(100% + 380px);
}

.sec01_list .slick-next::before {
  background-image: url(../images/prev_wh.png);
}

.sec01_list .slick-prev::before {
  background-image: url(../images/next_wh.png);
}

.sec01_box_movie .movie_list {
  margin-left: 50px;
  opacity: 0;
}

.sec01_box_movie .movie_list.slick-initialized {
  opacity: 1;
}

.sec01_box_movie .movie_list li {
  position: relative;
}

.sec01_box_movie .movie_list .icon-play {
  width: 68px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  pointer-events: none;
}

/* .sec01_box_movie .movie_list li iframe {
    width: 100%;
    aspect-ratio: 16/9;
    height: auto;
} */

.sec01 .sec01_box_movie .btn_box {
  margin-top: -60px;
}

/*==================== SEC02 ===================*/

.sec02 {
  padding: 70px 0;
}

.sec02 .container {
  z-index: 2;
}

/* .sec02 .container::before {

  content: "";

  position: absolute;

  left: -8px;

  bottom: 190px;

  width: 1600px;

  height: 1306px;

  background: url(../images/bg_gray03.jpg) repeat;

  z-index: -1;

} */

.line_check {
  width: auto;
  margin: 0px 65px 0px 65px;
  padding-top: 80px;
  border-top: 1px solid #575757;
}

.sec02_top .ttl {
  padding-left: 0;
  position: relative;
  color: #fff;
}

.sec02_top .pic {
  position: absolute;

  z-index: -1;

  margin-bottom: 0;

  z-index: 1;
  width: 750px;
}

.sec02_top .pic.is01 {
  top: 170px;

  left: 15px;
}

.sec02_top .pic.is02 {
  top: 21px;

  right: 15px;
}

.sec02_top .txt {
  margin-top: 220px;
  margin-bottom: 220px;

  position: relative;

  left: 0;
  padding-left: 30px;
  font-size: 56px;

  letter-spacing: 0.025em;

  color: #fff;

  font-weight: 400;

  line-height: 1.5;

  z-index: 2;
}

.sec02_bottom {
  display: flex;
  justify-content: space-between;
  position: relative;
}

.sec02_bottom .box_left {
  margin-right: 50px;
}

.sec02_bottom .dect {
  font-size: 16px;

  font-family: 'Noto Sans JP', sans-serif;

  letter-spacing: 0.1em;
  margin-bottom: 23px;
  color: #575757;
}

.sec02_bottom .dect:last-child {
  margin-bottom: 0;
}

/* .sec02_bottom .box_right {

    width: 700px;

    height: 386px;

    position: absolute;

    right: -150px;

    top: 13px;

} */

/* .sec02_bottom .box_right iframe {
    width: 100%;
    height: 100%;
} */

.sec02_bottom .btn {
  width: 100%;

  display: flex;

  justify-content: flex-end;
}

.sec02_bottom .btn a {
  color: #575757;
  border-color: #575757;
}

.sec02_bottom .btn a::before {
  background-image: url(../images/ic_arrow_wh.png);
}

.sec02 .box_link {
  padding-left: 0;
}

.sec02 .box_link::before {
  background: #636364;
}

.sec02 .box_link .txt {
  color: #fff;
}
 
.sec02 .box_list_btn {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin-top: 80px;
  justify-content: space-between;
  padding-right: 20px;
  padding-left: 20px;
}

.sec02 .box_list_btn li {
  font-family: 'Noto Sans JP', sans-serif;
  width: fit-content;
  margin: 0 0 30px;
  font-size: 24px;
  font-weight: 600;
  line-height: 1.5em;
  letter-spacing: 0;
  text-align: center;
}

.sec02 .box_list_btn li:not(:last-child) {
  margin-right: 20px;
}

.sec02 .box_list_btn li a {
  position: relative;
  padding-right: 40px;
  display: inline-block;
  transition: all ease 0.3s;
  color: #fff;
}

.sec02 .box_list_btn li a::before {
  content: "";
  position: absolute;
  right: 0;
  top: calc(50% - 18px);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: url(../images/ic_arrow_bl.png) no-repeat right 11px center / 11px #fff;
}

/*==================== SEC03 ===================*/

.sec03 {
  padding-top: 55px;
  color: #575757;
  padding-bottom: 70px;
}

.sec03_block {
  z-index: 2;
}

.sec03_block .en.big {
  left: -275px;

  top: -90px;
  letter-spacing: 0.01em;
}

.sec03_top .ttl {
  position: relative;
  text-align: center;
}

/* .sec03_top .ttl::before {

    left: -59px;
    top: -21px;
    height: 180px;
    background-color: #fff;
} */

.sec03_top .dect {
  margin: 63px 0 0 3px;

  max-width: 896px;

  letter-spacing: 0.085em;
}

.sec03_list {
  margin: 40px auto 70px;
  width: 100%;
}

.sec03_list li {
  position: relative;

  border-bottom: 1px solid #575757;

  display: flex;

  align-items: center;

  /* padding-left: 50px; */

  min-height: 180px;

  transition: 0.3s cubic-bezier(0.4, 0.4, 0, 1);
}

.sec03_list li .link_wrap {
  z-index: 1;
}

.sec03_list li:first-child {
  border-top: 1px solid #575757;
}

.sec03_list li .img_hv {
  position: absolute;

  top: -141px;

  right: 100px;

  transform: translate(0px, 14px) skew(0deg, 1deg);

  opacity: 0;

  transition: 0.3s cubic-bezier(0.4, 0.4, 0, 1);

  z-index: 1;
}

.sec03_list li::after {
  content: "";

  position: absolute;

  right: 20px;

  top: calc(50% - 30px);

  width: 60px;

  height: 60px;

  border-radius: 50%;

  background: url(../images/next.png) no-repeat right 20px center / 19px #fff;
}

.sec03_list li h4 {
  padding: 15px 20px;
  min-width: 300px;
  text-align: center;
}


.sec03_list li .txt {
  max-width: 724px;

  margin-left: 10px;
}

/*==================== SEC04 ===================*/

.sec04 {
  background: #fff;
  padding: 0;
}

.sec04 .container {
  min-height: 800px;

  z-index: 1;

  padding-top: 321px;

  padding-left: 88px;

  transition: all 0.3s ease;
}

.sec04 .container .link_wrap {
  z-index: 1;
}

/* .sec04 .container .link_wrap::before {
  content: "";
  position: absolute;
  right: 310px;
  top: 386px;
  width: 340px;
  height: 580px;
  background: url(../images/sec05_img01.jpg) center / cover no-repeat;
} */

.sec04 .container::before {
  content: "";

  position: absolute;

  left: 0;

  top: 0;

  width: 100%;

  height: 100%;

  background: url(../images/sec04_img01.jpg) center / cover no-repeat;

  z-index: -1;
}

.sec04 .ttl {
  color: #fff;

  position: relative;

  display: inline-block;
}

.sec04 .ttl::before {
  content: "";

  position: absolute;

  left: -62px;

  bottom: 2px;

  width: 201px;

  height: 85px;

  background: url(../images/txt_sec04.png) center / cover no-repeat;
}

.sec04 .ttl::after {
  content: "";

  position: absolute;

  right: -113px;

  top: calc(50% - 45px);

  width: 80px;

  height: 80px;

  border-radius: 50%;

  background: url(../images/next.png) no-repeat right 27px center / 26px #fff;
}

.sec04 .ttl .en {
  font-size: 120px;
}

.sec04 .ttl .ja {
  text-align: right;

  position: relative;

  top: -7px;

  right: 5px;
}

.sec04 .dect {
  margin-top: 130px;

  color: #fff;

  max-width: 797px;
}

/*==================== SEC05 ===================*/

.sec05 {
  /* position: relative; */
  padding-top: 0;
  padding-bottom: 0px;
  /* background: url(../images/bg_mv.jpg) repeat; */
}

.sec05_video {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -10;
  background: #DCDDDD;
}

.sec05_video::before {
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.8);
  position: absolute;
  z-index: 2;
  content: "";
}

.sec05_video video {
  position: absolute;
  top: -10vh;
  left: -10vw;
  width: 120vw;
  height: 120vh;
  z-index: 1;
}

.sec05 .container {
  z-index: 1;

  padding-top: 73px;
}

.sec05 .container::before {
  content: "";
  position: absolute;
  right: -9px;
  top: -191px;
  width: 800px;
  height: 1702px;
  background: url(../images/sec05_img07.jpg) center / cover no-repeat;
  display: none;
}

.sec05 .container::after {
  display: none;

  content: "";

  position: absolute;

  left: -8px;
  top: -191px;
  width: 800px;
  height: 1464px;

  background:#DCDDDD;
}

.sec05 .container .en.big {
  left: 21px;

  top: -12px;
  color: #f1ece5;
  z-index: 1;

  white-space: nowrap;

  letter-spacing: 0;
}

.sec05_list {
  max-width: 100%;

  margin: 0 auto;
}

.sec05_list li {
  position: relative;

  z-index: 2;
}

.sec05_list li.is01 .ttl {
  color: #fff;
  text-align: center;
}

.sec05_list li .link_wrap::after {
  content: "";

  position: absolute;

  background: url(../images/sec05_img01.jpg) center / cover no-repeat;
}

.sec05_list h4.ttl {
  z-index: -1;
}

.sec05_list .it_big h4.ttl .en {
  font-size: 120px;

  font-weight: 300;
}

.sec05_list .it_sm .ttl .en {
  font-size: 100px;

  line-height: 1em;
  color: #27241f;
}

.sec05_list li h4.ttl .ja {
  font-size: 28px;

  font-weight: 400;

  letter-spacing: 0.1em;
}

.sec05_list .it_big h4.ttl .ja {
  margin-top: 13px;

  margin-left: 5px;
}

.sec05_list .is01 {
  margin-bottom: 70px;
}

.sec05_list .is01 .dect {
  max-width: 846px;

  margin-top: 65px;
}

.sec05_list li.is01 .link_wrap::after {
  width: 340px;

  height: 580px;

  right: 0;

  top: -287px;
  display: none;
}

.sec05_list li:not(.is01) {
  width: 100%;
  min-height: 200px;
  position: relative;
  margin: 0 auto 50px;
  display: flex;
  align-items: center;
  z-index: 1;
  transition: all 0.3s ease;
  padding: 10px;
  background-color: #fff;
  color: #fff;
}

.sec05_list li:not(.is01) a::before {
  z-index: -2;
}

.sec05_list li:not(.is01) a::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 5px;
  width: calc(100% - 10px);
  height: calc(100% - 10px);
  background: url(../images/sec05_img02.jpg) center / cover no-repeat;
  z-index: -2;
}

.sec05_list li.is03 a::after {
  background-image: url(../images/sec05_img03.jpg);
}

.sec05_list li.is04 a::after {
  background-image: url(../images/sec05_img04.jpg);
}

.sec05_list li.is05 a::after {
  background-image: url(../images/sec05_img05.jpg);
}

.sec05_list li.is06 a::after {
  background-image: url(../images/sec05_img08.jpg);
}

.sec05_list li:not(.is01) .ttl {
  z-index: 1;
  padding: 0 0 0px 50px;
  margin: 0 -5px;
  width: calc(100% + 10px);
}

.sec05_list li:not(.is01)::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 5px;
  width: calc(100% - 10px);
  height: calc(100% - 10px);
  background-color: rgb(0 0 0 / 30%);
}

.sec05_list li:not(.is01)::after {
  content: "";
  position: absolute;
  right: 50px;
  top: calc(50% - 25px);
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: url(../images/ic_arrow_bl.png) no-repeat right 13px center / 20px #fff;
  z-index: 1;
}

.box_link {
  width: 100%;

  margin: 76px auto 0;

  background: #DCDDDD;

  min-height: 386px;

  position: relative;

  z-index: 1;

  padding-left: 140px;

  display: flex;

  flex-direction: column;

  padding-top: 78px;

  transition: all 0.3s ease;
}

.box_link::before {
  content: "";

  position: absolute;

  left: 0;

  top: 0;

  width: 100%;
  height: 100%;

  background: #DCDDDD;
}

.box_link .link_wrap {
  z-index: 2;
}

.box_link .pic {
  position: absolute;

  right: 0;

  top: calc(50% - 193px);

  margin: 0;
}

.box_link .bg_flow {
  position: absolute;

  left: 0;

  top: 0;

  width: 100%;

  height: 100%;
}

.box_link .bg_flow::before {
  content: "";

  position: absolute;

  left: 0;

  top: 0;

  width: 240px;

  height: 100%;

  background: url(../images/bg_flow.png) repeat;
}

.box_link .txt {
  font-size: 36px;
  color: #575757;
  position: relative;
  font-weight: 500;
  line-height: 1;
  padding: 15px 36px 19px 37px;
  width: fit-content;
  margin: 0 auto;
  letter-spacing: 0.075em;
}

.box_link .txt::before {
  content: "";

  position: absolute;

  right: -179px;

  top: 22px;

  width: 203px;

  height: 75px;

  background: url(../images/txt_sec05.png) center / cover no-repeat;
}

.box_link .dect {
  margin-top: 41px;

  max-width: 675px;

  color: #fff;

  position: relative;
}

/*==================== SEC06 ===================*/

.sec06 {
  background: #DCDDDD;
  color: #fff;
  padding-top: 60px;
}

.sec06 .container {
  padding: 0;
}

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

/* .sec06_block .content,
.sec07_block .content {
    display: flex;
    align-items: flex-end;
} */

.sec06_block .dect {
  margin: 0 0 0 110px;
}

.sec06 .btn a {
  background-color: #fff;
}

.sec06_block .wrap_txt {
  margin: 64px 0 0 3px;

  display: flex;

  align-items: center;

  justify-content: flex-end;
}

.sec06_block .wrap_txt .dect {
  max-width: 840px;
}

.sec06_block .wrap_txt .btn {
  margin: -9px 22px 0 0;
}

.sec06_list {
  margin-top: 40px;

  width: 100%;

  display: flex;

  flex-wrap: wrap;
}

.sec06_list li {
  width: calc(100% / 3);

  margin-bottom: 42px;

  position: relative;

  z-index: 1;

  transition: all 0.3s ease;
}

.sec06_list li .pic {
  margin-bottom: 30px;

  height: 440px;

  display: flex;

  justify-content: center;

  align-items: center;
  background-color: #e5e5e5;
}

.sec06_list li .pic img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sec06_list li .content {
  display: flex;
  padding-left: 15px;
  flex-wrap: wrap;
}

.sec06_list li .content .sub_txt {
  position: relative;

  font-size: 14px;

  font-weight: 600;
  padding-left: 25px;
  margin-bottom: 6px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
}

.sec06_list li .content .sub_txt::before {
  content: "";

  position: absolute;

  left: 0;

  top: calc(50% - 10px);

  width: 15px;

  height: 20px;

  background: url(../images/ic_map_wh.png) center / cover no-repeat;
}

.sec06_list li .content .txt_case {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-weight: bold;
  background: #beb098;
  color: #575757;
  margin-right: 10px;
  width: 72px;
  margin: 0 10px 0 0;
  flex-shrink: 0;
  height: 72px;
}



.sec06_list li .content .txt_case span.is01 {
  font-size: 12px;
  font-weight: 400;
  line-height: 1;
}

.sec06_list li .content .txt_case span.is02 {
  font-size: 24px;
  line-height: 1.3;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  display: block;
  width: 100%;
  text-align: center;
}

.sec06_list li .content .txt {
  color: #575757;
}

.sec06_list li .two_txt {
  height: 43px;
  margin-top: 10px;
  padding-left: 15px;
  width: 100%;
  color: #575757;
}

.sec06_list li .two_txt span {
  font-size: 16px;
  display: inline-block;
  padding: 0 20px;
  border-left: 1px solid #575757;
  max-width: 50%;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}

.sec06_list li .two_txt span.is01 {
  border-left: 0;
  padding-left: 0;
}

.sec06_list li .two_txt span:last-child {
  padding-right: 0;
}

.sec06_list li .content .txt {
  font-size: 18px;
  height: 72px;
  display: flex;
  align-items: center;
  width: calc(100% - 88px);
  margin-bottom: 0;
  line-height: 1.5;
}

.sec06_list li .content .txt span {
  overflow: hidden;

  text-overflow: ellipsis;

  display: -webkit-box;

  -webkit-line-clamp: 3;

  line-clamp: 3;

  -webkit-box-orient: vertical;
}

/*==================== SEC07 ===================*/

.sec07 {
  padding-top: 50px;
  background: #DCDCDC;
  padding-bottom: 60px;
}

.sec07 .container {
  padding-bottom: 0;
}

/* .sec07 .container::before {

  content: "";

  position: absolute;

  right: -9px;

  bottom: 0;

  height: 1364px;

  width: 800px;

  background: url(../images/bg_brown03.jpg) repeat;

  z-index: -1;

}
 */

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

.sec07_block .dect {
  /* margin-top: 62px; */
  margin: 0 0 0 110px;
}

.sec07_list {
  margin-top: 50px;

  display: flex;
}

.sec07_list.tmp_slick .slick-prev,
.sec07_list.tmp_slick .slick-next {
  background-color: var(--txt);
  top: -100px;
}

.sec07_list.tmp_slick .slick-prev {
  right: 400px;
}

.sec07_list.tmp_slick .slick-next {
  right: 310px;
}

.sec07_list.tmp_slick .slick-prev::before {
  background-image: url(../images/prev_wh.png);
}

.sec07_list.tmp_slick .slick-next::before {
  background-image: url(../images/next_wh.png);
}

.sec07_list li {
  width: calc(100% / 3 - 20px);


  /* max-width: 400px; */

  margin: 30px 10px 20px 10px;

  position: relative;

  transition: all 0.3s ease;
}

.sec07_list li .pic img {
  width: 100%;
  height: 100%;
  max-height: 100%;
  object-fit: cover;
}

.sec07_list li .sub_txt,
.sec09_list li .sub_txt {
  font-size: 16px;

  padding-left: 96px;

  position: relative;

  line-height: 1.5;

  margin-bottom: 22px;

  font-weight: bold;
}

.sec09_list li .sub_txt::before,
.sec07_list li .sub_txt::before {
  content: "";

  position: absolute;

  left: 2px;

  top: calc(50% - -2px);

  width: 80px;

  height: 1px;

  background-color: var(--txt);
}

.sec07_list li .txt,
.sec09_list li .txt {
  font-size: 20px;

  font-weight: 600;

  letter-spacing: 0.1em;
}

.sec07_list li .txt {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  min-height: 80px;
  max-height: 120px;
}


.sec07 .btn {
  margin-top: 30px;
}

/*==================== SEC08 ===================*/

.sec08 {
  padding: 0;
  background: url(../images/sec08_img01.jpg) center / cover no-repeat fixed;
}

.sec08 .container {
  min-height: 740px;

  padding: 190px 0 199px;
}

.sec08.top_sale .container {
  padding-top: 100px;
  padding-bottom: 100px;
  min-height: 670px;
}

.sec08_bl_under {
  color: #fff;
  margin-bottom: 50px;
}

.sec08.top_sale .ttl {
  left: 0;
}

.sec08_bl_under h4 {
  font-size: 40px;
  position: relative;
  font-weight: 500;
  text-align: center;
  border-bottom: 1px #fff solid;
  padding-bottom: 23px;
  margin-bottom: 65px;
}

.sec08_bl_under h4::before {
  content: "";
  position: absolute;
  width: 4px;
  height: 25px;
  background-color: var(--mcolor);
  left: 0;
  top: 3px;
}

.sec08_bl_under .btn_line a::before {
  width: 40px;
  height: 40px;
  background: url(../images/ic_line.png) center / cover no-repeat;
  left: inherit;
  top: inherit;
  position: relative;
  display: inline-block;
  margin-right: 10px;
  content: "";
}

.sec08_bl_under .btn_line a {
  background: #00b900;
  color: #fff;
  font-size: 24px;
  font-family: 'Noto Sans JP', sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 600px;
  max-width: 100%;
  margin: 0 auto;
  height: 100px;
}

/* .sec08 .container::before {

  content: "";

  position: absolute;

  left: 0;

  top: 0;

  width: 1920px;

  height: 740px;

  background: url(../images/sec08_img01.jpg) center / cover no-repeat;

} */

.sec08_block {
  display: flex;

  align-items: center;
}

.sec08_block .ttl {
  position: absolute;

  color: #fff;

  left: -209px;

  top: 71px;
  z-index: 1;
}

.sec08_block .ttl .en {
  font-weight: 300;
}

.sec08_block .ttl .ja {
  text-align: right;

  margin-top: -7px;
}

.sec08_block .ttl::before {
  content: "";

  position: absolute;

  left: -60px;

  bottom: -11px;

  width: 280px;

  height: 92px;

  background: url(../images/txt_sec08.png) center / cover no-repeat;
  z-index: -1;
}

.sec08_block .ttl .en {
  font-size: 120px;
  color: #fff;
}

.sec08_block .ttl .ja {
  font-size: 24px;
  color: #fff;
}

.sec08_list {
  margin-left: 217px;

  display: flex;
}

.sec08_list li {
  width: 351px;

  height: 351px;

  position: relative;

  display: flex;

  justify-content: center;

  padding-top: 71px;

  box-shadow: 4px 4px 20px rgb(2 2 2 / 20%);

  transition: all 0.3s ease;
}

.sec08_list li.it01 {
  background: url(../images/sec08_img02.png) center top / cover repeat;
}

.sec08_list li.it02 {
  background: url(../images/sec08_img03.png) center top / cover repeat;
}

.sec08_list li.it02.top_sale {
  display: none;
}

.sec08_list li.it03 {
  background: url(../images/sec08_img04.png) center top / cover repeat;
}

.sec08_list li.it04 {
  background: #00b900;
}

.sec08_list li .link_wrap {
  z-index: 2;
}

.sec08_list li::before {
  content: "";
  position: absolute;
  left: calc(50% - 21px);
  bottom: 20px;
  width: 42px;
  height: 42px;
  border: 1px solid #443a30;
  border-radius: 50%;
  background: url(../images/ic_arrow_bl.png) no-repeat right 10px center / 19px;
}

.sec08_list li.it01::before {
  border-color: #fff;
  background: url(../images/ic_arrow_wh.png) no-repeat right 10px center / 19px;
}

.sec08_list li:not(:last-child) {
  margin-right: 5px;
}

.sec08_list li .wrap_txt {
  color: #40362c;

  padding-top: 84px;

  position: relative;

  text-align: center;

  line-height: 1.5em;
}

.sec08_list li.it01 .wrap_txt {
  color: #fff;
}

.sec08_list li .wrap_txt::before {
  content: "";

  position: absolute;

  left: calc(50% - 25px);

  top: 9px;

  width: 53px;

  height: 52px;

  background: url(../images/ic_chat.png) center / cover no-repeat;
}

.sec08_list li.it02 .wrap_txt::before {
  width: 54px;

  height: 50px;

  left: calc(50% - 26px);

  top: 9px;

  background-image: url(../images/ic_calendar.png);
}

.sec08_list li.it03 .wrap_txt::before {
  width: 48px;

  height: 51px;

  left: calc(50% - 22px);

  top: 10px;

  background-image: url(../images/ic_h_mail.png);
}

.sec08_list li .wrap_txt .txt {
  font-size: 24px;

  margin-bottom: 0;

  font-weight: 600;

  line-height: 1.5;

  letter-spacing: 0;
  font-family: 'Noto Sans JP', sans-serif;
}

.sec08_list li .wrap_txt .en {
  font-size: 20px;

  margin-bottom: 0;

  font-weight: 500;

  letter-spacing: 0.05em;
}

.sec08_list li.it01 .wrap_txt .en {
  color: #fff;
}
.sec08_list li.it04 {
  padding: 0;
}

.sec08_list li.it04::before {
  display: none;
}

.sec08_list li.it04 .wrap_txt {
  color: #fff;
  padding: 0;
  display: flex;
  align-items: center;
}

.sec08_list li.it04 .wrap_txt::before {
  width: 40px;
  height: 40px;
  background: url("../images/ic_line.png") center / cover no-repeat;
  left: inherit;
  top: inherit;
  position: relative;
  display: inline-block;
  margin-right: 10px;
}

/*==================== SEC09 ===================*/
.sec09 {
  padding: 0;
}

.sec09 .container {
  padding-bottom: 86px;
}

/* .sec09 .container::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: url(../images/sec09_img01.jpg) center / cover no-repeat;
  z-index: -1;
} */

.sec09_block {
  color: #fff;
}

.sec09_block .ttl {
  padding-top: 70px;
  text-align: center;
}

.sec09_list {
  display: flex;
  margin-top: 46px;
  justify-content: center;
}

.sec09_list li {
  width: 100%;
  max-width: 300px;
  margin: 30px 20px 20px;
  position: relative;
  transition: all 0.3s ease;
}

.sec09_list li .link_wrap {
  z-index: 1;
}

.sec09_list li .pic {
  height: 428px;
  /* background-color: #8c8c8c; */
  background-color: transparent;
  overflow: hidden;
}

.sec09_list li .sub_txt {
  height: 48px;
  margin-bottom: 0;
  display: flex;
  align-items: center;
}

.sec09_list li .sub_txt::before {
  background-color: #575757;
}

.sec09_list li .sub_txt,
.sec09_list li .txt {
  color: #575757;
}

/*==================== SEC10 ===================*/
.sec10 {
  padding: 40px 0 120px;
}

.sec10 .box_link {
  margin-top: 0;
  padding: 0 0 0px 580px;
  justify-content: center;
  min-height: 250px;
}

.sec10 .box_link .txt {
  color: #fff;
}

.sec10 .box_link .link_wrap::before {
  content: "";
  position: absolute;
  right: 25px;
  top: calc(50% - 15px);
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: url(../images/next.png) no-repeat right 15px center / 20px #fff;
}

.sec10 .bg_flow::before {
  left: calc(100% - 240px);
  background-image: url(../images/bg_flow2.png);
}

.sec10 .box_link .pic {
  left: 0;
  top: 0;
  height: 100%;
}

.sec10 .box_link .pic img {
  max-height: 250px;
}

.sec10 .box_link .pic::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgb(0 0 0 / 55%);
}

.sec10 .box_link .dect {
  max-width: 687px;
}

.sec10 .box_link .txt {
  margin-left: 0;
}

.sec10 .box_link .txt::before {
  width: 339px;
  height: 102px;
  right: -80px;
  top: 38px;
  background-image: url(../images/txt_sec07.png);
}

/*==========================================================

                        F O O T E R

==========================================================*/

footer {
  background: #DCDDDD;

  position: relative;

  z-index: 3;

  padding: 0 0 120px;
}

.ft_top {
  padding: 120px 0 118px;
}

/* FOOTER INFORMATION */

.ft_info {
  display: flex;

  align-items: center;

  color: #575757;
}

.ft_info p {
  margin-bottom: 0;
}

.ft_info .wrap_txt {
  display: flex;

  align-items: flex-end;
}

.ft_info_tel {
  margin-left: 80px;

  display: flex;

  flex-direction: column;
}

.ft_info_tel .time {
  font-size: 24px;

  letter-spacing: 0;

  line-height: 1em;

  font-weight: 400;

  margin-bottom: 21px;
}

.ft_info_tel a {
  font-size: 40px;

  color: #575757;

  font-weight: 400;

  padding-left: 35px;

  position: relative;

  line-height: 1;

  display: block;

  letter-spacing: 0.1em;
}

.ft_info_tel a::before {
  content: "";

  position: absolute;

  left: 0;

  top: calc(50% - 15px);

  width: 18px;

  height: 33px;

  background: url(../images/ic_phone.png) center / cover no-repeat;
}

.ft_info_tel.-black a::before {
  background: url(../images/ic_phone_black.png) center / cover no-repeat;
}

.ft_info_add {
  margin-left: 73px;
}

.ft_info_add p {
  font-size: 18px;
}

.ft_info_add .txt {
  margin-bottom: 9px;

  line-height: 1.5em;

  font-weight: 400;

  letter-spacing: 0.1em;
}

.ft_info_add .txt.is02 {
  display: flex;

  justify-content: space-between;

  margin-bottom: 0;
}

/* FOOTER LINK */

.ft_link {
  color: #575757;

  margin-top: 74px;

  padding-left: 185px;
}

.ft_link .content {
  display: flex;
}

.ft_link .content:not(:last-child) {
  margin-bottom: 91px;
}

.ft_link .content ul:not(:last-child) {
  margin-right: 100px;
}

.ft_link .content ul {
  padding-bottom: 35px;

  min-width: 400px;

  border-bottom: 1px solid #595959;
}

.ft_link .content ul li {
  font-weight: 400;
}

.ft_link .content ul li p {
  font-size: 20px;

  font-weight: 500;

  line-height: 1.8em;

  padding-bottom: 12px;

  margin-bottom: 27px;

  border-bottom: 1px solid #595959;

  letter-spacing: 0.1em;
}

.ft_link .content ul li a {
  line-height: 2.25em;

  font-size: 16px;

  letter-spacing: 0.1em;

  color: #575757;

  padding-left: 22px;
}

.ft_map {
  width: 100%;
}

.ft_map_iframe {
  width: 100%;

  height: 335px;
}

.ft_map_iframe iframe {
  width: 100%;

  height: 100%;

  border: none;

  outline: none;
}

.ft_map .gg_link::before {
  background: url("../images/ic_map.png") center / cover no-repeat;

  width: 12px;

  height: 16px;

  content: "";

  display: inline-block;

  margin-right: 5px;

  position: relative;

  top: 2px;
}

/* ft_bottom */

.ft_bottom {
  padding-top: 100px;
}

.ft_bottom .inner {
  display: flex;

  justify-content: space-between;

  align-items: flex-end;
}

.ft_bottom .content {
  position: relative;

  width: 100%;

  max-width: 944px;

  transition: all 0.3s ease;
  padding-right: 90px;
}

.ft_bottom .content .link_wrap::before {
  content: "";

  position: absolute;

  right: -94px;

  bottom: -47px;

  width: 326px;

  height: 119px;

  background: url(../images/txt_ft.png) center / cover no-repeat;
}

.ft_bottom .content .link_wrap::after {
  content: "";
  position: absolute;
  right: 0;
  top: calc(50% - 15px);
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: 1px solid #575757;
  background: url(../images/next_wh.png) no-repeat right 15px center / 20px;
}

.ft_bottom .content .link_wrap.-black::after {
  background: url(../images/next_black.png) no-repeat right 15px center / 20px;
}

.ft_bottom .content .box1 {
  display: flex;

  justify-content: space-between;

  align-items: center;
}

.ft_bottom .content .box1 .img {
  position: relative;
  top: 5px;
}
.ft_bottom .content .box1 img{
  max-width: 156px;
}

.ft_bottom .btn_find {
  width: 260px;

  height: 46px;

  display: flex;

  align-items: center;

  position: relative;

  font-size: 20px;

  letter-spacing: 0.1em;

  border: 1px solid #575757;

  color: #575757;

  padding: 0 0 5px 15px;
  z-index: -1;
}

.ft_bottom .btn_find::before {
  content: "";

  position: absolute;

  top: calc(50% - 11px);

  right: 11px;

  width: 22px;

  height: 22px;

  background: url(../images/ic_search.png) center / cover no-repeat;
}

.ft_bottom .btn_find.-black::before {
  background: url(../images/ic_search_black.png) center / cover no-repeat;
}

.ft_bottom_list {
  margin-top: 20px;

  display: flex;
}

.ft_bottom_list li:not(:last-child) {
  margin-right: 4px;
}

address {
  text-align: right;

  color: #575757;

  font-size: 16px;

  letter-spacing: 0.1em;

  line-height: 1em;
  font-weight: 400;
}

/* BACK TO TOP */

.to_top {
  position: fixed;

  z-index: 9;

  width: 60px;

  height: 60px;

  bottom: 70px;

  right: 20px;

  cursor: pointer;

  transition: all 0.2s;

  opacity: 0;

  visibility: hidden;

  border: 1px solid #fff;
}

.to_top.show {
  transform: scale(1);

  opacity: 1;

  visibility: visible;
}

.leFadeInBottom span {
  animation-name: leFadeInBottom;
}

@keyframes leFadeInBottom {
  from {
    opacity: 0;
    transform: translateY(100%);
  }

  to {
    opacity: 1;
  }
}

.slide_content {
  -webkit-clip-path: polygon(0% 100%, 100% 100%, 0% 100%, 100% 100%);
  clip-path: polygon(0% 100%, 100% 100%, 0% 100%, 100% 100%);
  transition: -webkit-clip-path 0s cubic-bezier(0.645, 0.045, 0.355, 1) 2s;
  transition: clip-path 0s cubic-bezier(0.645, 0.045, 0.355, 1) 2s;
  transition: clip-path 0s cubic-bezier(0.645, 0.045, 0.355, 1) 2s,
    -webkit-clip-path 2s cubic-bezier(0.645, 0.045, 0.355, 1) 2s;
}

.slide_content.active {
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}

.blog .max_w1k h2 {
  color: #000;
}

#header img {
  max-width: 100%;
  height: auto;
}

#header img.img01 {
  width: 100%;
}

#header img.img02 {
  width: 160px;
}


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

.flex_box_end {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: flex-start;
}

.flex_box_end .item {
  width: 48%;
  margin: 0;
}

.title_bold {
  font-weight: bold;
  font-size: 22px;
  margin-bottom: 15px;
}

.title_h3_bold {
  font-size: 24px;
  font-weight: bold;
}

.blue {
  color: #18909d;
}

.orange {
  color: orangered;
}

.list_flex {
  display: flex;
  justify-content: center;
  gap: 80px;
  margin-bottom: 20px;
}

.fs30 {
  font-size: 30px;
}

.note_sm {
  font-size: 14px;
}

.box_border {
  border: 1px solid;
  padding: 15px;
}

.yelow {
  color: #d5993e;
}

.green {
  color: #74a556;
}

.flex_end {
  display: flex;
  align-items: flex-end;
}

.relative_img {
  position: relative;
}

.abs_img {
  position: absolute;
  top: -150px;
  right: 0;
  max-width: 300px;
}

.algn_cen {
  align-items: center;
}

.pickup {
  background: var(--brown02);
  padding: 60px 30px 60px 30px !important;
  margin-bottom: 115px !important;
  position: relative;
}

.pickup_abs {
  position: absolute;
  left: -35px;
  top: -10px;
  max-width: 250px;
}

.flex_end {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  gap: 20px;
}

.basis-img {
  margin: 0 5px;
}

.basis-img-tt {
  margin: 0 5px;
}

/* .list_flex li{
  font-size: 20px;
} */

.wrap_line {
  background-color: #00B900;
  text-align: center;
  padding: 5px 20px 20px;
  max-width: 800px;
  cursor: pointer;
  margin: -50px auto 50px;
}

.sec_line_logo {
  display: flex;
  align-items: center;
  justify-content: center;
}

.wrap_line img {
  vertical-align: middle;
}

.wrap_line .main-text {
  color: white;
  font-size: 24px;
  font-weight: bold;
  vertical-align: middle;
}

.wrap_line .sub-text {
  /* background-color: #06c355; */
  color: white;
  font-size: 24px;
  padding: 5px 10px;
  display: inline-block;
}

.btn-modal {
  text-align: center;
  padding: 7px 13px;
  background: #3e3e3e;
  color: #fff;
  font-size: 15px;
  width: 50px;
  cursor: pointer;
}

.modal {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, .5);
  opacity: 0;
  visibility: hidden;
  transform: scale(1.1);
  transition: visibility 0s linear 0.25s, opacity 0.25s 0s, transform 0.25s;
  z-index: 2;
}

.modal-content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  padding: 2rem;
}

.modal img {
  border: 1px solid #06c755;
}

.btn-close {
  text-align: right
}

.close-button {
  width: 1.5rem;
  line-height: 1.5rem;
  text-align: center;
  cursor: pointer;
  border-radius: 0.25rem;
  background-color: #333;
  padding: 5px 10px;
  color: #fff
}

.show-modal {
  opacity: 1;
  visibility: visible;
  transform: scale(1.0);
  transition: visibility 0s linear 0s, opacity 0.25s 0s, transform 0.25s;
}


.swiper-slide.swiper-slide-active .caption_title {
  display: block;
}

.swiper-slide:not(.swiper-slide-active) .caption_title {
  display: none;
}

.under main table.clhite th {
  border-top: 2px wheat solid;
  border-bottom: 2px wheat solid;
  color: wheat;
}

.under main table.clhite td {
  border-top: 2px #ffffff solid;
  border-bottom: 2px #ffffff solid;
  color: white;
}

p,a{ 
  font-family: 'Noto Sans JP', sans-serif;
}
.sec02_bottom .dect {
  font-family: 'Noto Sans JP', sans-serif;
}
.sec08_list li .wrap_txt .txt {
  font-family: 'Noto Sans JP', sans-serif;
}

.en,.ja {
  font-family:"Playfair Display",sans-serif;
  color:#575757;
}
h1,h2,h3,h4,h5,h6{
  font-family:"Playfair Display",sans-serif;
  color:#575757;
}

.en.-white,
.ja.-white {
  color:#fff;
}