#rss {
  padding: 20.3vw 6.6% 0;
}
#rss h2 {
  font-family: var(--zcool);
  font-weight: 400;
  font-size: 13.3vw;
  line-height: 1.4em;
  margin-bottom: 3vw;
  color: #67806b;
  letter-spacing: 0.1em;
  position: relative;
  z-index: 1;
}
#rss h2::before {
  content: "";
  position: absolute;
  background: url(../img/index/rss_deco.png) repeat-x;
  background-position: center;
  background-size: auto 3.2vw;
  left: -50vw;
  right: 107.5%;
  top: 0;
  bottom: 0;
}
#rss .wrap-feed {
  padding: 9vw 15.4% 11.3vw;
  background: url(../img/shared/main_bg3.jpg) repeat;
}
#rss #feed {
  margin-bottom: 6.5vw;
}
#rss .row {
  color: #280d07;
}
#rss .row .photo {
  height: 60vw;
  margin-bottom: 3.8vw;
}
#rss .row .photo a {
  height: 100%;
  display: inline-block;
}
#rss .row .photo a span {
  height: 100% !important;
}
#rss .row .photo img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#rss .row .date {
  font-size: 2.7vw;
  font-weight: 400;
  font-family: var(--tenor);
  line-height: 1.6em;
  margin-bottom: 1.2vw;
  text-decoration: underline;
  text-underline-offset: 0.5vw;
  letter-spacing: 0.15em;
}
#rss .row .title {
  font-size: 3.5vw;
  font-family: var(--serif);
  font-weight: 400;
  line-height: 1.6em;
  letter-spacing: 0.15em;
}
#rss .btn-news {
  text-align: center;
}
#rss .btn-news a {
  color: #280d07;
  font-family: var(--tenor);
  text-decoration: none;
  font-size: 4.7vw;
  line-height: 1.6em;
  letter-spacing: 0.2em;
  text-align: center;
  position: relative;
  padding-right: 11.6vw;
  padding-bottom: 3vw;
  border-bottom: 1px solid #280d07;
}
#rss .btn-news a::before {
  content: "";
  position: absolute;
  background: url(../img/shared/arrow_style1.png) no-repeat;
  background-size: contain;
  width: 7.5vw;
  height: 7.5vw;
  right: 0;
  top: -1vw;
}

.en-all {
  text-transform: uppercase;
  font-size: 5.3vw;
  font-weight: 400;
  font-family: var(--zcool);
  color: #b1a46a;
  line-height: 1.6em;
  letter-spacing: 0.05em;
  margin-bottom: 1.7vw;
}

.h2-all {
  font-size: 9.3vw;
  font-weight: 400;
  color: #280d07;
  line-height: 1.4em;
  letter-spacing: 0.13em;
  margin-bottom: 8.3vw;
}

#sec1 {
  padding: 34.8vw 0 9vw;
  position: relative;
  z-index: 1;
}
#sec1::before,
#sec1::after {
  content: "";
  position: absolute;
  z-index: -1;
}
#sec1::before {
  background: url(../img/index/sec1_deco1.png) no-repeat;
  background-size: contain;
  aspect-ratio: 164/520;
  width: 23.3vw;
  height: auto;
  top: 0;
  right: 4.53%;
}
#sec1::after {
  background: url(../img/index/sec1_deco2.png) no-repeat;
  background-size: contain;
  aspect-ratio: 336/184;
  width: 44.8vw;
  height: auto;
  top: 6vw;
  left: -3.33%;
}
#sec1 .row .desc {
  margin-bottom: 4vw;
}
#sec1 .row .desc .txt {
  margin-bottom: 24px;
}
#sec1 .row .desc .txt:last-child {
  margin-bottom: 0;
}
#sec1 .row .img {
  display: flex;
  padding-bottom: 79vw;
  position: relative;
}
#sec1 .row .img::before,
#sec1 .row .img::after {
  content: "";
  position: absolute;
  z-index: -1;
}
#sec1 .row .img::before {
  background: url(../img/index/sec1_deco3.png) no-repeat;
  background-size: contain;
  aspect-ratio: 230/135;
  width: 32.8vw;
  height: auto;
  bottom: 83vw;
  right: -13.47%;
}
#sec1 .row .img::after {
  background: url(../img/index/sec1_deco4.png) no-repeat;
  background-size: contain;
  aspect-ratio: 705/231;
  width: 113.3vw;
  height: auto;
  bottom: -6vw;
  left: -1.33%;
}
#sec1 .row .img .photo img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#sec1 .row .img .photo1 {
  width: 50%;
  margin-top: 16vw;
  margin-right: 2%;
}
#sec1 .row .img .photo2 {
  width: 50%;
  height: 78.9vw;
}
#sec1 .row .img .photo3 {
  position: absolute;
  bottom: 0;
  left: 4.6%;
  width: 87.6vw;
}
#sec1 .row .img .photo3 img {
  object-fit: contain;
  width: 100%;
  height: auto;
}

#sec2 {
  padding: 19.5vw 0 41.5vw;
  position: relative;
  z-index: 1;
}
#sec2::before {
  content: "";
  position: absolute;
  background: url(../img/shared/main_bg5.jpg) repeat;
  top: 0;
  left: 0;
  right: 0;
  bottom: 93.5vw;
  z-index: -2;
}
#sec2::after {
  content: "";
  position: absolute;
  background: url(../img/index/sec2_deco1.png) no-repeat;
  background-size: contain;
  aspect-ratio: 281/65;
  width: 61.2vw;
  height: auto;
  bottom: 20.2vw;
  left: -6%;
  z-index: -1;
}
#sec2 .desc {
  padding: 0 3.33%;
  margin-bottom: 22vw;
}
#sec2 .desc .txt1 {
  margin-bottom: 24px;
}
#sec2 .desc .txt2 {
  margin-bottom: 11vw;
}
#sec2 .img {
  width: 90vw;
  height: 92.5vw;
}
#sec2 .img img {
  object-position: center right;
  object-fit: cover;
  width: 100%;
  height: 100%;
}

#sec3 {
  padding: 26.7vw 0 15vw;
  position: relative;
}
#sec3::before {
  content: "";
  position: absolute;
  background: url(../img/index/deco.png) repeat-x;
  background-size: contain;
  aspect-ratio: 73/31;
  width: 100%;
  height: 8vw;
  top: 0;
  left: 0;
  right: 0;
}
#sec3 .row .item {
  position: relative;
  margin-bottom: 42.1vw;
}
#sec3 .row .item:nth-child(2) .tit {
  color: #42230d;
}
#sec3 .row .item:last-child {
  margin-bottom: 0;
}
#sec3 .row .item .link {
  position: absolute;
  inset: 0;
  z-index: 2;
}
#sec3 .row .item .tit {
  text-shadow: 0 1.3vw 2vw rgba(0, 0, 0, 0.2);
  font-size: 22.7vw;
  font-weight: 400;
  line-height: 1em;
  letter-spacing: 0.1em;
  font-family: var(--zcool);
  color: #ee7948;
  position: absolute;
  top: 3vw;
  left: 5%;
  right: 0;
  text-align: center;
  z-index: 1;
}
#sec3 .row .item .img {
  height: 106.7vw;
}
#sec3 .row .item .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  border-radius: 13.3vw 0 13.3vw 0;
}
#sec3 .row .item .btn {
  width: 46.4vw;
  height: 44.7vw;
  text-align: center;
  position: absolute;
  z-index: 2;
  bottom: -27.4vw;
  left: 0;
  right: 0;
  margin: 0 auto;
}
#sec3 .row .item .btn a {
  color: #fff;
  display: inline-flex;
  align-items: center;
  flex-direction: column;
  text-align: center;
  font-size: 5.3vw;
  font-weight: 400;
  line-height: 1.3em;
  padding-top: 9.8vw;
  background: url(../img/index/btn_frame.png) no-repeat;
  background-size: contain;
  width: 100%;
  height: 100%;
  position: relative;
}
#sec3 .row .item .btn a .en {
  display: block;
  text-align: center;
  font-size: 4vw;
  font-weight: 400;
  font-family: var(--tenor);
  position: relative;
  margin-top: 9.1vw;
  letter-spacing: 0.2em;
}
#sec3 .row .item .btn a .en::before {
  content: "";
  position: absolute;
  background: url(../img/shared/arrow_style4.png) no-repeat;
  background-size: contain;
  top: -5vw;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 5.3vw;
  height: 2.1vw;
}

#sec4 {
  padding: 43.3vw 0 13.5vw;
  position: relative;
  z-index: 1;
}
#sec4::before {
  content: "";
  position: absolute;
  background: url(../img/index/sec4_deco_sp.png) no-repeat;
  background-size: contain;
  aspect-ratio: 750/1455;
  width: 100vw;
  height: auto;
  top: 63vw;
  right: 0;
  z-index: -1;
}
#sec4 h2 {
  width: 28.8vw;
  height: 103.7vw;
  margin: 0 auto;
  color: #280d07;
  font-size: 7.1vw;
  font-weight: 400;
  line-height: 2em;
  letter-spacing: 0.15em;
  text-align: right;
  position: relative;
  margin-bottom: 17vw;
}
#sec4 h2::before {
  content: "";
  position: absolute;
  background: url(../img/index/sec4_ttl_deco.png) no-repeat;
  background-size: contain;
  aspect-ratio: 151/122;
  width: 26.8vw;
  height: auto;
  top: -4vw;
  left: 30%;
}
#sec4 h2 .big {
  position: relative;
  font-size: 169.8113207547%;
  right: 1.5vw;
  top: 2vw;
}
#sec4 h2 .medium {
  position: relative;
  font-size: 109.4339622642%;
  top: 1.3vw;
  left: 2vw;
}
#sec4 h2 .pd {
  display: inline-block;
  margin-bottom: -8vw;
}
#sec4 .img {
  width: 106.7vw;
  margin-left: -10%;
  position: relative;
  z-index: 2;
}
#sec4 .img::before {
  content: "";
  position: absolute;
  background: url(../img/index/sec4_smoke.png) no-repeat;
  background-size: contain;
  aspect-ratio: 589/1173;
  width: 78.5vw;
  height: auto;
  bottom: 87%;
  right: -4.8%;
  z-index: 2;
}
#sec4 .img img {
  object-fit: contain;
  width: 100%;
  height: auto;
}

#sec5 {
  padding: 26.9vw 0 22vw;
}
#sec5 .bg {
  box-sizing: border-box;
  margin: 0 3.33% 15.3vw;
  min-height: 90.7vw;
  position: relative;
}
#sec5 .bg::before {
  content: "";
  position: absolute;
  inset: 1.5vw 1.8% 1.5vw;
  background-image: url(../img/shared/deco1.png), url(../img/shared/deco2.png),
    url(../img/shared/deco3.png), url(../img/shared/deco4.png);
  background-position: top left, top right, bottom right, bottom left;
  background-size: 8.8vw;
  background-repeat: no-repeat;
  z-index: 2;
}
#sec5 .img_parallax {
  position: absolute;
  inset: 0;
  clip: rect(0, auto, auto, 0);
  margin-bottom: 0;
}
#sec5 .img_parallax img {
  position: fixed;
  width: 100%;
  height: 100vh;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  object-fit: cover;
}
#sec5 .row1 {
  margin-bottom: 25.6vw;
  position: relative;
}
#sec5 .row1::before,
#sec5 .row1::after {
  content: "";
  position: absolute;
}
#sec5 .row1::before {
  background: url(../img/index/sec5_deco1.png) no-repeat;
  background-size: contain;
  aspect-ratio: 375/219;
  width: 49.7vw;
  height: auto;
  bottom: calc(100% + 105vw);
  left: -12%;
}
#sec5 .row1::after {
  background: url(../img/index/sec5_deco2.png) no-repeat;
  background-size: contain;
  aspect-ratio: 269/148;
  width: 35.7vw;
  height: auto;
  bottom: -18vw;
  right: 0;
}
#sec5 .row1 .desc .en-all {
  letter-spacing: 0.06em;
  margin-bottom: 4vw;
}
#sec5 .row1 .desc .h2-all {
  margin-bottom: 10vw;
}
#sec5 .row1 .desc .txt {
  margin-bottom: 24px;
}
#sec5 .row1 .desc .txt:last-child {
  margin-bottom: 0;
}
#sec5 .row2 .img-map {
  background: url(../img/shared/main_bg3.jpg) repeat;
  padding: 3.5vw 2.7vw;
  margin-bottom: 17.7vw;
  position: relative;
}
#sec5 .row2 .img-map::before {
  content: "";
  position: absolute;
  background: url(../img/index/sec5_deco3.png) no-repeat;
  background-size: contain;
  aspect-ratio: 172/297;
  width: 22.8vw;
  height: auto;
  top: 100%;
  right: 0;
}
#sec5 .row2 .slide {
  width: 100%;
}
#sec5 .row2 .slide .slick-list {
  height: 75.2vw;
}
#sec5 .row2 .slide .photo img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

#sec6 {
  padding-bottom: 11.5vw;
  position: relative;
}
#sec6::before {
  content: "";
  position: absolute;
  background: url(../img/index/sec6_deco1.png) no-repeat;
  background-size: contain;
  aspect-ratio: 521/171;
  width: 83.9vw;
  height: auto;
  bottom: -5.5vw;
  left: -10.13%;
}
#sec6 .tit {
  font-size: 8.7vw;
  font-weight: 400;
  letter-spacing: 0.85em;
  line-height: 1.6em;
  text-align: center;
  position: relative;
  left: 4%;
  color: #280d07;
  margin-bottom: 19.8vw;
  z-index: 1;
}
#sec6 .tit::before {
  content: "";
  position: absolute;
  background: url(../img/index/sec6_tit_bg.png) no-repeat;
  background-size: contain;
  background-position: center;
  aspect-ratio: 482/139;
  width: 85.6vw;
  height: auto;
  inset: 5vw 8% 0 0;
  margin: auto;
  z-index: 1;
}
#sec6 .row .stick {
  position: absolute;
  bottom: -65vw;
  right: -4%;
  width: 68.9vw;
  z-index: 3;
}
#sec6 .row .stick img {
  object-fit: contain;
  width: 100%;
  height: auto;
}
#sec6 .row .img-js {
  position: relative;
}
#sec6 .row .img-js .slick-list {
  overflow: visible;
}
#sec6 .row .img-js .img {
  height: 96vw;
  position: relative;
  z-index: 1;
}
#sec6 .row .img-js .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#sec6 .row .thumb-js {
  display: flex;
  margin-bottom: 4vw;
}
#sec6 .row .thumb-js .slick-track {
  display: flex;
  width: 100% !important;
}
#sec6 .row .thumb-js .slick-slide {
  width: 33.3333333333% !important;
  aspect-ratio: 1/1;
  height: auto;
  margin-right: 1.86%;
  transition: all 0.3s ease;
}
#sec6 .row .thumb-js .slick-slide:last-child {
  margin-right: 0;
}
#sec6 .row .thumb-js .slick-slide > div {
  height: 100%;
}
#sec6 .row .thumb-js .slick-slide:not(.slick-current):hover {
  opacity: 0.8;
}
#sec6 .row .thumb-js .slick-slide.slick-current .img {
  filter: unset;
}
#sec6 .row .thumb-js .slick-slide.slick-current .img::before {
  opacity: 1;
  visibility: visible;
}
#sec6 .row .thumb-js .img {
  cursor: pointer;
  width: 100%;
  height: 100%;
  position: relative;
  filter: grayscale(100%);
  transition: all 0.3s ease;
}
#sec6 .row .thumb-js .img::before {
  content: "";
  position: absolute;
  inset: 1.6vw;
  border: 1px solid #fff;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  z-index: 1;
}
#sec6 .row .thumb-js .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#sec6 .row .desc-js {
  top: -18vw;
  position: relative;
  margin: 0 -3.6%;
}
#sec6 .row .desc-js .slick-list {
  width: 100%;
  overflow: visible;
}
#sec6 .row .desc-js .desc {
  box-sizing: border-box;
  padding: 11.6vw 7% 13.2vw;
  position: relative;
}
#sec6 .row .desc-js .desc::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url(../img/shared/main_bg6.jpg) repeat;
  opacity: 0.8;
  z-index: -1;
}
#sec6 .row .desc-js .en {
  width: 100%;
  box-sizing: border-box;
  display: block;
}
#sec6 .row .desc-js .h2-all {
  margin-bottom: 5.4vw;
}

#shopinfo {
  padding-bottom: 29.2vw;
}
#shopinfo .bg {
  box-sizing: border-box;
  margin: 0 3.33% 14vw;
  min-height: 90.7vw;
  position: relative;
}
#shopinfo .bg::before {
  content: "";
  position: absolute;
  inset: 1.5vw 1.8% 1.5vw;
  background-image: url(../img/shared/deco1.png), url(../img/shared/deco2.png),
    url(../img/shared/deco3.png), url(../img/shared/deco4.png);
  background-position: top left, top right, bottom right, bottom left;
  background-size: 8.8vw;
  background-repeat: no-repeat;
  z-index: 2;
}
#shopinfo .img_parallax {
  position: absolute;
  inset: 0;
  clip: rect(0, auto, auto, 0);
  margin-bottom: 0;
}
#shopinfo .img_parallax img {
  position: fixed;
  width: 100%;
  height: 100vh;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  object-fit: cover;
}
#shopinfo .row {
  padding: 0 3.33%;
  display: flex;
  flex-direction: column-reverse;
}
#shopinfo .row .list .btn-map {
  margin-bottom: 3.3vw;
}
#shopinfo .row .list .btn-map a {
  font-family: var(--kaku);
  font-size: 15px;
  height: 75px;
  letter-spacing: 0.05em;
  padding-left: 19px;
  box-sizing: border-box;
}
#shopinfo .row .list .btn-map a::before {
  content: none;
}
#shopinfo .row .list .btn-map a .ic {
  position: relative;
}
#shopinfo .row .list .btn-map a .ic::before {
  content: "";
  width: 14px;
  background-image: url(../img/shared/icon_map2.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 50%;
  position: absolute;
  top: 0;
  bottom: 0;
  left: -37px;
}
#shopinfo .row .list .btn {
  text-align: center;
}
#shopinfo .row .list .btn a {
  font-size: 12px;
  font-weight: 400;
  text-align: center;
  text-decoration: none;
  color: #000;
  position: relative;
  padding-right: 20px;
  letter-spacing: normal;
}
#shopinfo .row .list .btn a::before {
  content: "";
  width: 13px;
  background-image: url(../img/shared/icon_copy.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 50%;
  position: absolute;
  top: 2px;
  bottom: 0;
  right: 0;
}
#shopinfo .row .left iframe {
  width: 100%;
  height: 80.3vw;
  margin-bottom: 8.9vw;
}
#shopinfo .row .right {
  margin-bottom: 26vw;
}
#shopinfo .row .right .shopinfo-logo {
  width: 68.8vw;
  margin: 0px auto 7.7vw;
}
#shopinfo .row .right .slg {
  font-size: 3.5vw;
  text-align: center;
  line-height: 1.4em;
  letter-spacing: 0.05em;
  margin-bottom: 7.5vw;
}
#shopinfo .row .right .tel-info {
  width: 100%;
  text-align: center;
  position: relative;
  border: 1px solid #67806b;
  padding: 4.5vw 0 6.8vw;
  box-sizing: border-box;
  margin-bottom: 7.6vw;
}
#shopinfo .row .right .tel-info::before {
  content: "";
  position: absolute;
  inset: 1.5vw 1.5%;
  background-image: url(../img/shared/deco1.png), url(../img/shared/deco2.png),
    url(../img/shared/deco3.png), url(../img/shared/deco4.png);
  background-position: top left, top right, bottom right, bottom left;
  background-size: 5.7vw;
  background-repeat: no-repeat;
  z-index: 2;
}
#shopinfo .row .right .tel-info dt {
  font-size: 3.5vw;
  font-family: var(--tenor);
  font-weight: 400;
  line-height: 1.75em;
  margin-bottom: 0.9vw;
}
#shopinfo .row .right .tel-info dt .tit {
  font-family: var(--serif);
  font-size: 76.9230769231%;
  font-weight: 500;
}
#shopinfo .row .right .tel-info dt .tel-icon {
  font-size: 192.3076923077%;
  letter-spacing: 0.1em;
  padding-left: 2vw;
}
#shopinfo .row .right .tel-info dd {
  font-size: 2.7vw;
  font-weight: 600;
  line-height: 1.6em;
}
#shopinfo .row .right .btn-web {
  margin-bottom: 12.9vw;
}
#shopinfo .row .right .info {
  margin-bottom: 16vw;
}
#shopinfo .row .right .info dl {
  padding: 9px 0 10px 5px;
  display: flex;
  border-bottom: 1px dotted #c3c3bb;
  font-size: 13px;
  line-height: 1.55em;
}
#shopinfo .row .right .info dl dt {
  letter-spacing: normal;
  text-align: left;
  flex-shrink: 0;
  width: 88px;
}
#shopinfo .row .right .info dl dd {
  letter-spacing: normal;
}
#shopinfo .row .right .info dl dd span {
  padding-left: 20px;
}
#shopinfo .row .right .info dl dd .equal {
  display: inline-block;
  width: 77px;
  padding-left: 0;
}
#shopinfo .row .right .info dl dd .cus {
  padding-left: 0;
  letter-spacing: -0.05em;
}
#shopinfo .row .right .box {
  padding: 10vw 5%;
  margin-bottom: 19.2vw;
  position: relative;
  z-index: 1;
}
#shopinfo .row .right .box::before {
  content: "";
  position: absolute;
  inset: 0;
  border: 3vw solid #bbc3a4;
  mix-blend-mode: multiply;
  opacity: 0.35;
  z-index: -1;
}
#shopinfo .row .right .box::after {
  content: "";
  position: absolute;
  inset: 0;
  background: #bbc3a4;
  mix-blend-mode: multiply;
  opacity: 0.35;
  z-index: -2;
}
#shopinfo .row .right .box .tit {
  font-size: 5.3vw;
  color: #280d07;
  line-height: 1.6em;
  text-align: center;
  margin-bottom: 6vw;
  padding-bottom: 5.6vw;
  position: relative;
}
#shopinfo .row .right .box .tit::before {
  content: "";
  position: absolute;
  left: 6%;
  right: 6%;
  bottom: 0;
  height: 1px;
  border-bottom: 1px dashed #c3c3bb;
}
#shopinfo .row .right .box .txt {
  color: #280d07;
  font-size: 3.5vw;
  text-align: center;
  line-height: 1.9em;
  letter-spacing: -0.01em;
}
#shopinfo .row .right .desc {
  margin-bottom: 6.5vw;
}
#shopinfo .row .right .desc .en-all {
  text-align: center;
  font-size: 4vw;
}
#shopinfo .row .right .desc .h2-all {
  text-align: center;
  font-size: 6.7vw;
  margin-bottom: 9vw;
}
#shopinfo .row .right .img-js .img img {
  border-radius: 9.3vw 0 9.3vw 0;
}

@media only screen and (min-width: 768px) {
  #rss {
    padding: 105px 0 0;
  }
  #rss h2 {
    font-size: 80px;
    margin-bottom: 24px;
    margin-left: -8px;
  }
  #rss h2::before {
    background-size: auto 19px;
    right: calc(100% + 21px);
  }
  #rss .wrap-feed {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
    padding: 72px 0 83px;
    position: relative;
    background: transparent;
    z-index: 1;
  }
  #rss .wrap-feed::before {
    content: "";
    position: absolute;
    width: 1300px;
    left: 50%;
    top: 0;
    bottom: 0;
    transform: translateX(-50%);
    background: url(../img/shared/main_bg3.jpg) repeat;
    z-index: -1;
  }
  #rss #feed {
    margin-bottom: 0;
    display: flex;
    gap: 57px;
  }
  #rss .row {
    width: 33.3333333333%;
  }
  #rss .row .photo {
    height: 261px;
    margin-bottom: 22px;
  }
  #rss .row .photo a:hover {
    opacity: 0.8;
  }
  #rss .row dl {
    padding: 0 10px;
  }
  #rss .row .date {
    font-size: 16px;
    margin-bottom: 9px;
    text-underline-offset: 2px;
  }
  #rss .row .title {
    font-size: 16px;
  }
  #rss .row .title a:hover {
    text-decoration: underline;
  }
  #rss .btn-news {
    position: absolute;
    top: 110px;
    left: 276px;
    text-align: left;
    z-index: 2;
  }
  #rss .btn-news a {
    font-size: 20px;
    padding-right: 43px;
    padding-bottom: 13px;
    transition: all 0.3s ease;
  }
  #rss .btn-news a:hover {
    opacity: 0.7;
  }
  #rss .btn-news a::before {
    width: 30px;
    height: 30px;
    top: -4px;
  }
  .en-all {
    font-size: 30px;
    margin-bottom: 7px;
  }
  .h2-all {
    font-size: 60px;
    line-height: 1.4em;
    margin-bottom: 66px;
  }
  #sec1 {
    padding: 167px 0 522px;
  }
  #sec1::before {
    width: 164px;
    right: calc(50% + 544px);
  }
  #sec1::after {
    width: 336px;
    top: 69px;
    left: calc(50% + 141px);
  }
  #sec1 .row {
    margin: 0 -250px 0 -100px;
    display: flex;
  }
  #sec1 .row .desc {
    flex-shrink: 0;
    margin-bottom: 0;
    margin-right: 58px;
    margin-top: 61px;
  }
  #sec1 .row .desc .txt {
    margin-bottom: 42px;
  }
  #sec1 .row .img {
    align-items: flex-start;
    padding-bottom: 0;
  }
  #sec1 .row .img::before {
    width: 230px;
    bottom: -154px;
    right: 1249px;
  }
  #sec1 .row .img::after {
    width: 705px;
    bottom: -489px;
    left: 120px;
  }
  #sec1 .row .img .photo1 {
    width: 382px;
    margin-top: 135px;
    margin-right: 16px;
  }
  #sec1 .row .img .photo2 {
    width: 352px;
    height: auto;
  }
  #sec1 .row .img .photo3 {
    bottom: -446px;
    left: -250px;
    width: 517px;
  }
  #sec2 {
    padding: 138px 0 181px;
  }
  #sec2::before {
    top: 0;
    left: calc(50% - 350px);
    right: 0;
    bottom: 69px;
  }
  #sec2::after {
    width: 281px;
    bottom: 327px;
    left: unset;
    right: calc(50% + 437px);
  }
  #sec2 .row {
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    flex-direction: row-reverse;
  }
  #sec2 .desc {
    flex-shrink: 0;
    padding: 85px 0 0;
    margin-bottom: 0;
    margin-right: -62px;
    margin-left: 104px;
    display: flex;
    flex-direction: row-reverse;
    align-items: flex-start;
    position: relative;
    z-index: 2;
  }
  #sec2 .desc .en-all {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    text-align: right;
  }
  #sec2 .desc .h2-all {
    width: 168px;
    height: 475px;
    margin-bottom: 0;
    margin-left: 45px;
  }
  #sec2 .desc .ct {
    display: flex;
    flex-direction: row-reverse;
    width: 351px;
    height: 555px;
    margin-top: 78px;
  }
  #sec2 .desc .txt {
    width: 100%;
    height: 100%;
    margin-bottom: 0;
  }
  #sec2 .desc .txt1 {
    margin-left: 42px;
  }
  #sec2 .desc .btn-all {
    position: absolute;
    bottom: 21px;
    left: -544px;
  }
  #sec2 .img {
    left: calc(50% - 50vw);
    right: calc(50% + 56px);
    position: absolute;
    width: unset;
    height: 695px;
    top: -83px;
    z-index: 1;
  }
  #sec3 {
    padding: 95px 0 130px;
  }
  #sec3::before {
    height: 31px;
  }
  #sec3 .row {
    display: flex;
  }
  #sec3 .row .item {
    margin-bottom: 0;
    width: 100%;
    flex: 1;
    transition: 0.5s all ease-in-out;
    z-index: 1;
  }
  #sec3 .row .item::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    opacity: 0.5;
    background-color: #291000;
    transition: 0.5s all ease-in-out;
    opacity: 0;
    visibility: hidden;
  }
  #sec3 .row .item:hover {
    flex: 0.75;
  }
  #sec3 .row .item:nth-child(1) .img img {
    border-radius: 100px 0 0 0;
  }
  #sec3 .row .item:nth-child(2) .img img {
    border-radius: 0 0 100px 0;
  }
  #sec3 .row .item .tit {
    text-shadow: 0 9.75px 15px rgba(0, 0, 0, 0.2);
    font-size: 170px;
    top: 23px;
    left: 16px;
    transition: 0.5s all ease-in-out;
  }
  #sec3 .row .item .img {
    height: 800px;
  }
  #sec3 .row .item .img img {
    transition: 0.5s all ease-in-out;
    border-radius: 100px 0 100px 0;
  }
  #sec3 .row .item .btn {
    width: 269px;
    height: 259px;
    bottom: -130px;
    transition: 0.5s all ease-in-out;
  }
  #sec3 .row .item .btn a {
    font-size: 30px;
    padding-top: 55px;
    transition: 0.5s all ease-in-out;
  }
  #sec3 .row .item .btn a:hover {
    opacity: 0.8;
  }
  #sec3 .row .item .btn a .en {
    font-size: 25px;
    margin-top: 56px;
  }
  #sec3 .row .item .btn a .en::before {
    top: -28px;
    width: 31px;
    height: 13px;
  }
  #sec3 .row:has(.item:hover) .item:not(:hover) {
    flex: 0.25;
  }
  #sec3 .row:has(.item:hover) .item:not(:hover)::before {
    opacity: 0.5;
    visibility: visible;
  }
  #sec3 .row:has(.item:hover) .item:not(:hover) .tit {
    opacity: 0;
  }
  #sec3 .row:has(.item:hover) .item:not(:hover) .btn {
    opacity: 0;
  }
  #sec3 .row:has(.item:hover) .item:not(:hover) .img img {
    border-radius: 0;
  }
  #sec4 {
    padding: 48px 0 146px;
    position: relative;
    z-index: 1;
  }
  #sec4::before {
    background-image: url(../img/index/sec4_deco.png);
    width: 1659px;
    height: 354px;
    top: 399px;
    right: calc(50% - 796px);
  }
  #sec4 h2 {
    width: 160px;
    height: 611px;
    font-size: 40px;
    margin-bottom: 28px;
  }
  #sec4 h2::before {
    width: 151px;
    top: 0;
    left: 48px;
  }
  #sec4 h2 .big {
    font-size: 67px;
    right: 12px;
    top: 35px;
  }
  #sec4 h2 .medium {
    padding-bottom: 29px;
    font-size: 43px;
    top: 31px;
    left: 7px;
  }
  #sec4 h2 .pd {
    margin-bottom: -39px;
  }
  #sec4 .img {
    width: 806px;
    margin-left: 81px;
  }
  #sec4 .img::before {
    width: 589px;
    bottom: 36%;
    right: -76px;
  }
  #sec5 {
    padding: 0 0 193px;
  }
  #sec5 .bg {
    margin: 0 18px 160px;
    min-height: 680px;
  }
  #sec5 .bg::before {
    inset: 17px 15px;
    background-size: 96px;
  }
  #sec5 .row1 {
    margin: 0 -71px -21px -100px;
    display: flex;
    justify-content: space-between;
  }
  #sec5 .row1::before {
    width: 375px;
    bottom: 83%;
    left: -85px;
  }
  #sec5 .row1::after {
    width: 269px;
    bottom: 57px;
    right: -207px;
  }
  #sec5 .row1 .img {
    margin-top: 81px;
    height: 770px;
  }
  #sec5 .row1 .img img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }
  #sec5 .row1 .desc {
    flex-shrink: 0;
    margin-left: 60px;
    width: 552px;
  }
  #sec5 .row1 .desc .en-all {
    margin-bottom: 16px;
  }
  #sec5 .row1 .desc .h2-all {
    margin-bottom: 53px;
  }
  #sec5 .row1 .desc .txt {
    width: 100%;
    margin-bottom: 42px;
  }
  #sec5 .row2 {
    display: flex;
    align-items: flex-start;
    flex-direction: row-reverse;
    margin: 0 -135px 0 -100px;
  }
  #sec5 .row2 .img-map {
    background: transparent;
    position: relative;
    z-index: 2;
    box-sizing: border-box;
    padding: 36px 36px;
    margin-bottom: 0;
    margin-left: -93px;
  }
  #sec5 .row2 .img-map::before {
    width: 172px;
    top: 100%;
    right: 59px;
  }
  #sec5 .row2 .img-map::after {
    content: "";
    position: absolute;
    z-index: -1;
    inset: 0;
    background: #bbc3a4;
    opacity: 0.35;
  }
  #sec5 .row2 .img {
    margin-top: 259px;
    position: relative;
    z-index: 1;
  }
  #sec6 {
    padding-bottom: 216px;
  }
  #sec6::before {
    width: 521px;
    top: 5px;
    right: calc(50% + 301px);
    left: unset;
    bottom: unset;
  }
  #sec6::after {
    content: "";
    position: absolute;
    background: url(../img/index/sec6_deco3.png) no-repeat;
    background-size: contain;
    width: 281px;
    height: 65px;
    bottom: 215px;
    right: calc(50% + 148px);
  }
  #sec6 .tit {
    font-size: 50px;
    letter-spacing: 0.8em;
    left: 20px;
    margin-bottom: 137px;
  }
  #sec6 .tit::before {
    width: 482px;
    inset: 33px 44px 0 0;
  }
  #sec6 .row {
    margin: 0 0 0 -180px;
    display: flex;
    position: relative;
  }
  #sec6 .row .stick {
    top: -158px;
    right: unset;
    bottom: unset;
    left: -48px;
    width: 515px;
  }
  #sec6 .row .img-js {
    width: 1177px;
    height: 813px;
  }
  #sec6 .row .img-js .img {
    height: 100%;
  }
  #sec6 .row .thumb-js {
    width: 580px;
    position: absolute;
    bottom: 110px;
    left: 0;
    margin-bottom: 0;
  }
  #sec6 .row .thumb-js .slick-slide {
    margin-right: 12px;
  }
  #sec6 .row .thumb-js .img::before {
    inset: 10px;
  }
  #sec6 .row .desc-js {
    top: 0;
    margin: 584px 0 0 -575px;
    flex-shrink: 0;
    width: 818px;
  }
  #sec6 .row .desc-js::before {
    content: "";
    position: absolute;
    background: url(../img/index/sec6_deco2.png) no-repeat;
    background-size: contain;
    width: 157px;
    height: 376px;
    bottom: 100%;
    right: 28px;
  }
  #sec6 .row .desc-js .desc {
    padding: 100px 40px 111px 126px;
  }
  #sec6 .row .desc-js .en-all {
    margin-bottom: 17px;
  }
  #sec6 .row .desc-js .h2-all {
    margin-bottom: 41px;
  }
  #sec6 .row .desc-js .txt {
    width: 100%;
  }
  #shopinfo {
    padding-bottom: 26px;
  }
  #shopinfo .bg {
    margin: 0 18px;
    min-height: 680px;
  }
  #shopinfo .bg::before {
    inset: 17px 15px;
    background-size: 96px;
  }
  #shopinfo .row {
    padding: 0 25px;
    flex-direction: row;
    position: relative;
  }
  #shopinfo .row .list {
    margin-bottom: 59px;
  }
  #shopinfo .row .list .btn-map {
    margin-bottom: 11px;
  }
  #shopinfo .row .list .btn-map a {
    font-size: 20px;
    height: 91px;
    width: 362px;
    padding-left: 48px;
  }
  #shopinfo .row .list .btn a {
    font-size: 14px;
    padding-right: 28px;
  }
  #shopinfo .row .list .btn a:hover {
    text-decoration: underline;
  }
  #shopinfo .row .list .btn a::before {
    width: 16px;
  }
  #shopinfo .row .left {
    width: calc(50% - 18px);
    position: absolute;
    top: 0;
    left: 18px;
    margin: 0;
    height: 100vh;
  }
  #shopinfo .row .left iframe {
    height: 100%;
    margin-bottom: 0;
  }
  #shopinfo .row .right {
    flex-shrink: 0;
    width: 50%;
    min-width: 620px;
    margin: 0 0 0 auto;
    padding: 152px 37px 186px 78px;
    box-sizing: border-box;
  }
  #shopinfo .row .right .shopinfo-logo {
    width: 433px;
    margin: 0px auto 29px;
  }
  #shopinfo .row .right .slg {
    font-size: 16px;
    margin-bottom: 51px;
  }
  #shopinfo .row .right .tel-info {
    margin: 0 auto 44px;
    max-width: 526px;
    padding: 22px 10px 34px;
  }
  #shopinfo .row .right .tel-info::before {
    inset: 10px;
    background-size: 32px;
  }
  #shopinfo .row .right .tel-info dt {
    font-size: 20px;
    line-height: 1.75em;
    margin-bottom: -5px;
  }
  #shopinfo .row .right .tel-info dt .tit {
    font-size: 16px;
  }
  #shopinfo .row .right .tel-info dt .tel-icon {
    font-size: 35px;
    padding-left: 30px;
  }
  #shopinfo .row .right .tel-info dd {
    font-size: 14px;
  }
  #shopinfo .row .right .btn-web {
    margin-bottom: 57px;
  }
  #shopinfo .row .right .btn-web a {
    width: 362px;
    padding-left: 21px;
    padding-bottom: 5px;
  }
  #shopinfo .row .right .btn-web a::before {
    right: 29px;
  }
  #shopinfo .row .right .info {
    margin-bottom: 66px;
    margin-left: 23px;
  }
  #shopinfo .row .right .info dl {
    padding: 14px 0 13px 5px;
    font-size: 16px;
    line-height: 1.55em;
  }
  #shopinfo .row .right .info dl dt {
    letter-spacing: normal;
    width: 148px;
  }
  #shopinfo .row .right .info dl dd {
    flex-shrink: 0;
    letter-spacing: normal;
    width: calc(100% - 148px);
  }
  #shopinfo .row .right .info dl dd span {
    padding-left: 25px;
  }
  #shopinfo .row .right .info dl dd .equal {
    padding-left: 0;
    width: 105px;
  }
  #shopinfo .row .right .info dl dd .cus {
    letter-spacing: -0.05em;
  }
  #shopinfo .row .right .box {
    max-width: 565px;
    box-sizing: border-box;
    padding: 51px 58px 54px;
    margin: 0 auto 91px;
  }
  #shopinfo .row .right .box::before {
    border-width: 15px;
  }
  #shopinfo .row .right .box .tit {
    font-size: 25px;
    margin-bottom: 17px;
    padding-bottom: 23px;
  }
  #shopinfo .row .right .box .tit::before {
    left: 0;
    right: 0;
  }
  #shopinfo .row .right .box .txt {
    font-size: 16px;
    line-height: 1.9em;
    letter-spacing: -0.01em;
  }
  #shopinfo .row .right .desc {
    margin-bottom: 58px;
  }
  #shopinfo .row .right .desc .en-all {
    font-size: 20px;
    margin-bottom: 19px;
  }
  #shopinfo .row .right .desc .h2-all {
    font-size: 30px;
    margin-bottom: 47px;
  }
  #shopinfo .row .right .desc .txt {
    width: 480px;
    margin: 0 auto;
    line-height: 1.9em;
  }
  #shopinfo .row .right .img-js {
    width: 539px;
    margin: 0 auto;
    left: -11px;
  }
  #shopinfo .row .right .img-js .img img {
    border-radius: 70px 0 70px 0;
  }
}
@media screen and (min-width: 768px) and (max-width: 1440px) {
  #sec3 .row .item .tit {
    font-size: 140px;
  }
  #sec6 .row .desc-js .desc {
    padding: 100px 40px 111px 90px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  #sec1 .row {
    margin: 0 -90px 0 -20px;
  }
  #sec1 .row .img .photo1 {
    width: 50%;
    height: 657px;
  }
  #sec1 .row .desc {
    margin-right: 20px;
  }
  #sec1 .row .img .photo2 {
    width: 50%;
    height: 657px;
  }
  #sec2 .desc {
    margin-right: 10px;
    margin-left: 30px;
  }
  #sec2 .desc .btn-all {
    left: -490px;
  }
  #sec3 .row .item .tit {
    font-size: 120px;
  }
  #sec5 .row1 {
    margin: 0 -20px -21px -100px;
  }
  #sec5 .row2 {
    margin: 0 -20px 0 -60px;
  }
  #sec6 .row .desc-js .desc {
    padding-left: 40px;
  }
  #sec6 .row {
    margin-left: -40px;
  }
  #sec6 .row .desc-js {
    margin-left: -760px;
  }
  #sec6 .row .thumb-js {
    width: 400px;
  }
  #shopinfo .row .left {
    width: calc(100% - 620px - 18px);
  }
}
