@charset "UTF-8";
* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin: 0;
  padding: 0;
}

@-webkit-keyframes slide-b-t {
  0% {
    opacity: 0;
    -webkit-transform: translateY(50px);
            transform: translateY(50px);
  }
  100% {
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
    opacity: 1;
  }
}

@keyframes slide-b-t {
  0% {
    opacity: 0;
    -webkit-transform: translateY(50px);
            transform: translateY(50px);
  }
  100% {
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
    opacity: 1;
  }
}
@-webkit-keyframes expansion {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.8);
            transform: scale(0.8);
  }
  20% {
    opacity: 1;
    -webkit-transform: scale(1.02);
            transform: scale(1.02);
  }
  28% {
    opacity: 1;
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  36%, 100% {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@keyframes expansion {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.8);
            transform: scale(0.8);
  }
  20% {
    opacity: 1;
    -webkit-transform: scale(1.02);
            transform: scale(1.02);
  }
  28% {
    opacity: 1;
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  36%, 100% {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@-webkit-keyframes rotate {
  0% {
    rotate: 0;
    -webkit-perspective: 1;
            perspective: 1;
  }
  100% {
    rotate: -18.7deg;
    -webkit-perspective: 2;
            perspective: 2;
  }
}
@keyframes rotate {
  0% {
    rotate: 0;
    -webkit-perspective: 1;
            perspective: 1;
  }
  100% {
    rotate: -18.7deg;
    -webkit-perspective: 2;
            perspective: 2;
  }
}
@-webkit-keyframes clip-anime-center {
  0% {
    opacity: 1;
    clip-path: polygon(50% 0, 50% 0, 50% 100%, 50% 100%);
  }
  100% {
    opacity: 1;
    clip-path: polygon(100% 0, 0 0, 0 100%, 100% 100%);
  }
}
@keyframes clip-anime-center {
  0% {
    opacity: 1;
    clip-path: polygon(50% 0, 50% 0, 50% 100%, 50% 100%);
  }
  100% {
    opacity: 1;
    clip-path: polygon(100% 0, 0 0, 0 100%, 100% 100%);
  }
}
@-webkit-keyframes clip-anime-left-right {
  0% {
    opacity: 1;
    clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
  }
  100% {
    opacity: 1;
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  }
}
@keyframes clip-anime-left-right {
  0% {
    opacity: 1;
    clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
  }
  100% {
    opacity: 1;
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  }
}
@-webkit-keyframes clip-anime-left-right-hide {
  0% {
    opacity: 1;
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  }
  100% {
    opacity: 1;
    clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
  }
}
@keyframes clip-anime-left-right-hide {
  0% {
    opacity: 1;
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  }
  100% {
    opacity: 1;
    clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
  }
}
@-webkit-keyframes clip-anime-right-left {
  0% {
    opacity: 1;
    clip-path: polygon(100% 0, 100% 0, 100% 100%, 100% 100%);
  }
  100% {
    opacity: 1;
    clip-path: polygon(100% 0, 0 0, 0 100%, 100% 100%);
  }
}
@keyframes clip-anime-right-left {
  0% {
    opacity: 1;
    clip-path: polygon(100% 0, 100% 0, 100% 100%, 100% 100%);
  }
  100% {
    opacity: 1;
    clip-path: polygon(100% 0, 0 0, 0 100%, 100% 100%);
  }
}
@-webkit-keyframes clip-anime-right-left-hide {
  0% {
    opacity: 1;
    clip-path: polygon(100% 0, 0 0, 0 100%, 100% 100%);
  }
  100% {
    opacity: 1;
    clip-path: polygon(100% 0, 100% 0, 100% 100%, 100% 100%);
  }
}
@keyframes clip-anime-right-left-hide {
  0% {
    opacity: 1;
    clip-path: polygon(100% 0, 0 0, 0 100%, 100% 100%);
  }
  100% {
    opacity: 1;
    clip-path: polygon(100% 0, 100% 0, 100% 100%, 100% 100%);
  }
}
/***************************************************
 * Generated by SVG Artista on 4/7/2026, 5:02:08 PM
 * MIT license (https://opensource.org/licenses/MIT)
 * W. https://svgartista.net
 **************************************************/
@-webkit-keyframes animate-svg-fill-1 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
@keyframes animate-svg-fill-1 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
.svg-elem-1 {
  -webkit-animation: animate-svg-fill-1 0.1s ease 0s both;
  animation: animate-svg-fill-1 0.1s ease 0s both;
}

@-webkit-keyframes animate-svg-fill-2 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
@keyframes animate-svg-fill-2 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
.svg-elem-2 {
  -webkit-animation: animate-svg-fill-2 0.1s ease 0.1s both;
  animation: animate-svg-fill-2 0.1s ease 0.1s both;
}

@-webkit-keyframes animate-svg-fill-3 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
@keyframes animate-svg-fill-3 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
.svg-elem-3 {
  -webkit-animation: animate-svg-fill-3 0.1s ease 0.2s both;
  animation: animate-svg-fill-3 0.1s ease 0.2s both;
}

@-webkit-keyframes animate-svg-fill-4 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
@keyframes animate-svg-fill-4 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
.svg-elem-4 {
  -webkit-animation: animate-svg-fill-4 0.1s ease 0.3s both;
  animation: animate-svg-fill-4 0.1s ease 0.3s both;
}

@-webkit-keyframes animate-svg-fill-5 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
@keyframes animate-svg-fill-5 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
.svg-elem-5 {
  -webkit-animation: animate-svg-fill-5 0.1s ease 0.4s both;
  animation: animate-svg-fill-5 0.1s ease 0.4s both;
}

@-webkit-keyframes animate-svg-fill-6 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
@keyframes animate-svg-fill-6 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
.svg-elem-6 {
  -webkit-animation: animate-svg-fill-6 0.1s ease 0.5s both;
  animation: animate-svg-fill-6 0.1s ease 0.5s both;
}

@-webkit-keyframes animate-svg-fill-7 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
@keyframes animate-svg-fill-7 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
.svg-elem-7 {
  -webkit-animation: animate-svg-fill-7 0.1s ease 0.6s both;
  animation: animate-svg-fill-7 0.1s ease 0.6s both;
}

@-webkit-keyframes animate-svg-fill-8 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
@keyframes animate-svg-fill-8 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
.svg-elem-8 {
  -webkit-animation: animate-svg-fill-8 0.1s ease 0.7s both;
  animation: animate-svg-fill-8 0.1s ease 0.7s both;
}

@-webkit-keyframes animate-svg-fill-9 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
@keyframes animate-svg-fill-9 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(88, 65, 65);
  }
}
.svg-elem-9 {
  -webkit-animation: animate-svg-fill-9 0.1s ease 0.8s both;
  animation: animate-svg-fill-9 0.1s ease 0.8s both;
}

@-webkit-keyframes animate-svg-fill-10 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(116, 181, 103);
  }
}
@keyframes animate-svg-fill-10 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(116, 181, 103);
  }
}
.svg-elem-10 {
  -webkit-animation: animate-svg-fill-10 0.1s ease 0.9s both;
  animation: animate-svg-fill-10 0.1s ease 0.9s both;
}

@-webkit-keyframes animate-svg-fill-11 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(83, 150, 79);
  }
}
@keyframes animate-svg-fill-11 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(83, 150, 79);
  }
}
.svg-elem-11 {
  -webkit-animation: animate-svg-fill-11 0.1s ease 1s both;
  animation: animate-svg-fill-11 0.1s ease 1s both;
}

@-webkit-keyframes animate-svg-fill-12 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(116, 181, 103);
  }
}
@keyframes animate-svg-fill-12 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(116, 181, 103);
  }
}
.svg-elem-12 {
  -webkit-animation: animate-svg-fill-12 0.1s ease 1.1s both;
  animation: animate-svg-fill-12 0.1s ease 1.1s both;
}

@-webkit-keyframes animate-svg-fill-13 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(83, 150, 79);
  }
}
@keyframes animate-svg-fill-13 {
  0% {
    fill: transparent;
  }
  100% {
    fill: rgb(83, 150, 79);
  }
}
.svg-elem-13 {
  -webkit-animation: animate-svg-fill-13 0.1s ease 1.2s both;
  animation: animate-svg-fill-13 0.1s ease 1.2s both;
}

#about.site-section-content {
  padding: 0px;
  position: relative;
  margin: 120px 0px;
  margin-right: 380px;
}
@media (max-width:1200px) {
  #about.site-section-content {
    margin-right: 0px;
  }
}
@media (max-width: 767px) {
  #about.site-section-content {
    padding: 0px;
    margin: 190px 24px;
  }
}
#about.site-section-content .site-section-inner .content-holder {
  text-align: center;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#about.site-section-content .site-section-inner .content-holder h1 {
  max-width: 900px;
  margin: 0 auto;
}
@media (max-width: 767px) {
  #about.site-section-content .site-section-inner .content-holder h1 {
    font-size: 24px;
  }
}
#about.site-section-content #nav-menu2 {
  width: 100%;
}
#about.site-section-content #nav-menu2 .nav__list {
  margin: 0;
  padding: 120px 24px;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 30px;
}
@media (max-width: 767px) {
  #about.site-section-content #nav-menu2 .nav__list {
    padding: 100px 0 0;
    gap: 16px;
  }
}
#about.site-section-content #nav-menu2 .nav__item {
  display: table;
  width: 240px;
  height: 140px;
  z-index: 0;
}
@media (max-width: 767px) {
  #about.site-section-content #nav-menu2 .nav__item {
    margin-bottom: 0px;
    width: 46%;
    -o-object-fit: contain;
       object-fit: contain;
    aspect-ratio: 240/140;
    height: unset;
  }
}
#about.site-section-content #nav-menu2 .nav__link {
  display: table-cell;
  color: #ffffff;
  text-decoration: none;
  -webkit-transition: 0.5s ease;
  transition: 0.5s ease;
  position: relative;
}
#about.site-section-content #nav-menu2 .nav__link.event-gaiyou {
  background: url("../img/sozai/nav-bg-event-g.png") no-repeat center/contain;
  width: 100%;
  height: 100%;
}
#about.site-section-content #nav-menu2 .nav__link.event-gaiyou:before {
  content: "";
  background: url("../img/sozai/zenitsu-nav.webp") no-repeat center/contain;
  height: 120px;
  width: 130px;
  display: inline-block;
  position: absolute;
  top: 10px;
  left: 0;
  right: 0;
  margin: auto;
  z-index: -1;
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
@media (max-width: 767px) {
  #about.site-section-content #nav-menu2 .nav__link.event-gaiyou:before {
    display: none;
  }
}
#about.site-section-content #nav-menu2 .nav__link.event-gaiyou:hover:before {
  -webkit-transform: translateY(-70px);
          transform: translateY(-70px);
}
#about.site-section-content #nav-menu2 .nav__link.menu {
  background: url("../img/sozai/nav-bg-menu-g.png") no-repeat center/contain;
  width: 100%;
  height: 100%;
}
#about.site-section-content #nav-menu2 .nav__link.menu:before {
  content: "";
  background: url("../img/sozai/inosuke-nav.webp") no-repeat center/contain;
  height: 120px;
  width: 130px;
  display: inline-block;
  position: absolute;
  top: 10px;
  left: 0;
  right: 0;
  margin: auto;
  z-index: -1;
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
@media (max-width: 767px) {
  #about.site-section-content #nav-menu2 .nav__link.menu:before {
    display: none;
  }
}
#about.site-section-content #nav-menu2 .nav__link.menu:hover:before {
  -webkit-transform: translateY(-70px);
          transform: translateY(-70px);
}
#about.site-section-content #nav-menu2 .nav__link.goods {
  background: url("../img/sozai/nav-bg-goods-g.png") no-repeat center/contain;
  width: 100%;
  height: 100%;
}
#about.site-section-content #nav-menu2 .nav__link.goods:before {
  content: "";
  background: url("../img/sozai/murata-nav.webp") no-repeat center/contain;
  height: 120px;
  width: 130px;
  display: inline-block;
  position: absolute;
  top: 10px;
  left: 0;
  right: 0;
  margin: auto;
  z-index: -1;
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
@media (max-width: 767px) {
  #about.site-section-content #nav-menu2 .nav__link.goods:before {
    display: none;
  }
}
#about.site-section-content #nav-menu2 .nav__link.goods:hover:before {
  -webkit-transform: translateY(-70px);
          transform: translateY(-70px);
}
#about.site-section-content #nav-menu2 .nav__link.special {
  background: url("../img/sozai/nav-bg-special-g.png") no-repeat center/contain;
  width: 100%;
  height: 100%;
}
#about.site-section-content #nav-menu2 .nav__link.special:before {
  content: "";
  background: url("../img/sozai/nezuko-nav.webp") no-repeat center/contain;
  height: 110px;
  width: 130px;
  display: inline-block;
  position: absolute;
  top: 10px;
  left: 0;
  right: 0;
  margin: auto;
  z-index: -1;
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
@media (max-width: 767px) {
  #about.site-section-content #nav-menu2 .nav__link.special:before {
    display: none;
  }
}
#about.site-section-content #nav-menu2 .nav__link.special:hover:before {
  -webkit-transform: translateY(-70px);
          transform: translateY(-70px);
}

header {
  padding-bottom: 65.045833%;
  width: 100%;
  position: relative;
  height: 100%;
  z-index: 999;
  background-color: #fdd876;
}
@media (max-width: 767px) {
  header {
    padding-bottom: 208%;
  }
}
header .header-wrapper {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
header .kimetsu-logo {
  position: absolute;
  top: 44%;
  right: 30%;
  width: min(15.625vw, 300px);
  height: min(8.3333333333vw, 160px);
  z-index: 99;
  opacity: 0;
}
header .kimetsu-logo.animated {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  opacity: 1;
  position: absolute;
  background: url("../img/logo/logo-kimetsu.webp") no-repeat center/contain;
}
@media (max-width: 767px) {
  header .kimetsu-logo {
    top: 42%;
    right: 15%;
    width: 200px;
    height: 200px;
    width: min(26.075619296vw, 200px);
    height: min(26.075619296vw, 200px);
  }
}
header .event-logo-wrapper {
  position: absolute;
  top: 38%;
  left: 35%;
  width: min(22.3958333333vw, 430px);
  height: min(15.625vw, 300px);
  z-index: 99;
}
@media (max-width: 767px) {
  header .event-logo-wrapper {
    top: 40%;
    left: 9%;
    width: min(52.1512385919vw, 400px);
    height: min(33.8983050847vw, 260px);
    z-index: 99;
  }
}
header .event-logo-wrapper .event-logo-parts-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
}
header .event-logo-wrapper .event-logo-parts-wrapper .header-animation {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  pointer-events: none;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
header .event-logo-wrapper .event-logo-parts-wrapper .header-animation.eventlogo-bg {
  position: absolute;
}
header .event-logo-wrapper .event-logo-parts-wrapper .header-animation.eventlogo-bg.animated {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  opacity: 1;
  position: absolute;
  background: url("../img/logo/event-logo-bg.png") no-repeat center/contain;
}
header .event-logo-wrapper .event-logo-parts-wrapper .header-animation.eventlogo-text {
  background: url("../img/logo/event-logo-text.png") no-repeat center/contain;
}
header .event-logo-wrapper .event-logo-parts-wrapper .header-animation.eventlogo-text.animated {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  position: absolute;
  -webkit-animation: expansion 1.2s forwards;
          animation: expansion 1.2s forwards;
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}
header .event-logo-wrapper .event-logo-parts-wrapper .header-animation.eventlogo-line-top {
  background: url("../img/logo/event-logo-line-top.png") no-repeat center/contain;
}
header .event-logo-wrapper .event-logo-parts-wrapper .header-animation.eventlogo-line-top.animated {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  -webkit-animation: clip-anime-left-right 1s forwards;
          animation: clip-anime-left-right 1s forwards;
  -webkit-animation-delay: 0.4s;
          animation-delay: 0.4s;
}
header .event-logo-wrapper .event-logo-parts-wrapper .header-animation.eventlogo-line-btm {
  background: url("../img/logo/event-logo-line-btm.png") no-repeat center/contain;
}
header .event-logo-wrapper .event-logo-parts-wrapper .header-animation.eventlogo-line-btm.animated {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  -webkit-animation: clip-anime-left-right 0.9s forwards;
          animation: clip-anime-left-right 0.9s forwards;
  -webkit-animation-delay: 0.6s;
          animation-delay: 0.6s;
}
header .event-logo-wrapper .event-logo-parts-wrapper .header-animation.eventlogo-needle {
  background: url("../img/logo/event-logo-needle.png") no-repeat center/contain;
}
header .event-logo-wrapper .event-logo-parts-wrapper .header-animation.eventlogo-needle.animated {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  -webkit-animation: slide-b-t 0.5s forwards;
          animation: slide-b-t 0.5s forwards;
  -webkit-animation-delay: 1.3s;
          animation-delay: 1.3s;
}
header .header-wrapper .header-animation {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  pointer-events: none;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
header .header-wrapper .header-animation.header-middle {
  position: absolute;
}
header .header-wrapper .header-animation.header-middle.animated {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  -webkit-animation: clip-anime-center 0.4s forwards;
          animation: clip-anime-center 0.4s forwards;
  position: absolute;
  background: url("../img/sozai/obi-pc.webp") no-repeat center/contain;
}
@media (max-width: 767px) {
  header .header-wrapper .header-animation.header-middle.animated {
    background: url("../img/sozai/obi-sp.webp") no-repeat left top/contain;
  }
}
header .header-wrapper .header-animation.header-top-y {
  position: absolute;
}
header .header-wrapper .header-animation.header-top-y.animated {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  -webkit-animation: clip-anime-left-right 1s forwards;
          animation: clip-anime-left-right 1s forwards;
  position: absolute;
  opacity: 1;
  background: url("../img/sozai/header-pc-top-yellow.webp") no-repeat top/contain;
}
header .header-wrapper .header-animation.header-top-y.animated.deactive {
  -webkit-animation: clip-anime-right-left-hide 1s forwards;
          animation: clip-anime-right-left-hide 1s forwards;
  z-index: 3;
}
header .header-wrapper .header-animation.header-top-y.animated.active {
  z-index: 2;
}
@media (max-width: 767px) {
  header .header-wrapper .header-animation.header-top-y.animated {
    background: url("../img/sozai/header-sp-top-yellow.webp") no-repeat left top/contain;
  }
  header .header-wrapper .header-animation.header-top-y.animated.deactive {
    -webkit-animation: clip-anime-right-left-hide 1s forwards;
            animation: clip-anime-right-left-hide 1s forwards;
    z-index: 3;
  }
  header .header-wrapper .header-animation.header-top-y.animated.active {
    z-index: 2;
  }
}
header .header-wrapper .header-animation.header-top-g {
  position: absolute;
}
header .header-wrapper .header-animation.header-top-g.animated {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  -webkit-animation: clip-anime-left-right 1s forwards;
          animation: clip-anime-left-right 1s forwards;
  position: absolute;
  opacity: 1;
  background: url("../img/sozai/header-pc-top-green.webp") no-repeat top/contain;
}
header .header-wrapper .header-animation.header-top-g.animated.deactive {
  -webkit-animation: clip-anime-right-left-hide 1s forwards;
          animation: clip-anime-right-left-hide 1s forwards;
  z-index: 3;
}
header .header-wrapper .header-animation.header-top-g.animated.active {
  z-index: 2;
}
@media (max-width: 767px) {
  header .header-wrapper .header-animation.header-top-g.animated {
    background: url("../img/sozai/header-sp-top-green.webp") no-repeat left top/contain;
  }
  header .header-wrapper .header-animation.header-top-g.animated.deactive {
    -webkit-animation: clip-anime-right-left-hide 1s forwards;
            animation: clip-anime-right-left-hide 1s forwards;
    z-index: 3;
  }
  header .header-wrapper .header-animation.header-top-g.animated.active {
    z-index: 2;
  }
}
header .header-wrapper .header-animation.header-bottom-g {
  position: absolute;
}
header .header-wrapper .header-animation.header-bottom-g.animated {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  -webkit-animation: clip-anime-right-left 1s forwards;
          animation: clip-anime-right-left 1s forwards;
  position: absolute;
  opacity: 1;
  background: url("../img/sozai/header-pc-bottom-green.webp") no-repeat top/contain;
}
header .header-wrapper .header-animation.header-bottom-g.animated.deactive {
  -webkit-animation: clip-anime-left-right-hide 1s forwards;
          animation: clip-anime-left-right-hide 1s forwards;
  z-index: 3;
}
header .header-wrapper .header-animation.header-bottom-g.animated.active {
  z-index: 2;
}
@media (max-width: 767px) {
  header .header-wrapper .header-animation.header-bottom-g.animated {
    background: url("../img/sozai/header-sp-bottom-green.webp") no-repeat left top/contain;
  }
  header .header-wrapper .header-animation.header-bottom-g.animated.deactive {
    -webkit-animation: clip-anime-left-right-hide 1s forwards;
            animation: clip-anime-left-right-hide 1s forwards;
    z-index: 3;
  }
  header .header-wrapper .header-animation.header-bottom-g.animated.active {
    z-index: 2;
  }
}
header .header-wrapper .header-animation.header-bottom-y {
  position: absolute;
}
header .header-wrapper .header-animation.header-bottom-y.animated {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  -webkit-animation: clip-anime-right-left 1s forwards;
          animation: clip-anime-right-left 1s forwards;
  position: absolute;
  opacity: 1;
  background: url("../img/sozai/header-pc-bottom-yellow.webp") no-repeat top/contain;
}
header .header-wrapper .header-animation.header-bottom-y.animated.deactive {
  -webkit-animation: clip-anime-left-right-hide 1s forwards;
          animation: clip-anime-left-right-hide 1s forwards;
  z-index: 3;
}
header .header-wrapper .header-animation.header-bottom-y.animated.active {
  z-index: 2;
}
@media (max-width: 767px) {
  header .header-wrapper .header-animation.header-bottom-y.animated {
    background: url("../img/sozai/header-sp-bottom-yellow.webp") no-repeat left top/contain;
  }
  header .header-wrapper .header-animation.header-bottom-y.animated.deactive {
    -webkit-animation: clip-anime-left-right-hide 1s forwards;
            animation: clip-anime-left-right-hide 1s forwards;
    z-index: 3;
  }
  header .header-wrapper .header-animation.header-bottom-y.animated.active {
    z-index: 2;
  }
}

.site-footer-wrap {
  margin-right: 240px;
}
@media (max-width:1200px) {
  .site-footer-wrap {
    margin-right: 0px;
  }
}

#goods-circle {
  margin-right: 380px;
}
@media (max-width:1200px) {
  #goods-circle {
    margin-right: 0px;
  }
}
#goods-circle #circle-section {
  display: block;
  position: relative;
  padding-top: 14.3055555556vw;
  overflow: clip;
  height: 100%;
  background: #fdd876;
}
#goods-circle #circle-section:before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 95%;
  background: #fdd876;
  background: url("../img/sozai/bg-pattern3.png"), #96c673;
  background-size: 500px;
}
@media (max-width: 767px) {
  #goods-circle #circle-section:before {
    height: 98%;
  }
}
@media (max-width: 767px) {
  #goods-circle #circle-section {
    padding-top: 22.3055555556vw;
  }
}
#goods-circle #circle-section .circle-bg {
  clip-path: polygon(0 0, 100% 0, 100% 50%, 0 50%);
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform-origin: top center;
          transform-origin: top center;
  width: 214.3916666667vw;
  aspect-ratio: 1;
  pointer-events: none;
  translate: -50% 0.1%;
}
#goods-circle #circle-section .circle-bg:before {
  clip-path: circle(50% at 50% 50%);
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #96c673;
  background: #fdd876;
  background: url("../img/sozai/bg-pattern3.png"), #96c673;
  background-size: 500px;
}
#goods-circle #circle-section .circle-bg svg {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 105.7142857143%;
  -webkit-animation: rotate 16s linear 0s both infinite;
          animation: rotate 16s linear 0s both infinite;
  -webkit-animation-duration: 13.25s;
          animation-duration: 13.25s;
  -webkit-animation-duration: 30s;
          animation-duration: 30s;
  isolation: isolate;
  will-change: translate, width, rotate;
  translate: -50% calc(-50% + 11.1805555556vw);
}

#goods.site-section-content {
  padding: 0;
  width: 100%;
  margin: 0 auto;
}
#goods.site-section-content .site-section-inner {
  padding: 0 0 240px;
  margin: 0 24px;
  position: relative;
}
@media (max-width:1200px) {
  #goods.site-section-content .site-section-inner {
    padding: 0 0 400px;
  }
}
#goods.site-section-content .site-section-inner .heading-h1 {
  margin: 0 auto 32px;
  text-align: center;
  color: #ffffff;
  position: relative;
  font-size: 64px;
}
@media (max-width: 767px) {
  #goods.site-section-content .site-section-inner .heading-h1 {
    margin: 24px auto;
    font-size: 40px;
  }
}
#goods.site-section-content .goods-wrapper {
  display: -webkit-box;
  display: flex;
  justify-content: center;
  gap: 24px;
  flex-wrap: wrap;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 24px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: auto;
  max-width: 900px;
}
@media (max-width: 767px) {
  #goods.site-section-content .goods-wrapper {
    padding: 0px;
  }
}
#goods.site-section-content .goods-wrapper .goods-card {
  position: relative;
  padding: 24px;
  background: #faecd4;
  border-radius: 24px;
  width: calc(50% - 10px);
  max-width: 400px;
  text-align: center;
  -webkit-box-shadow: 0px 0px 15px -5px rgba(114, 111, 100, 0.568627451);
          box-shadow: 0px 0px 15px -5px rgba(114, 111, 100, 0.568627451);
  display: none;
}
#goods.site-section-content .goods-wrapper .goods-card.active {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding: 24px;
  border-radius: 24px;
  text-align: center;
}
@media (max-width: 767px) {
  #goods.site-section-content .goods-wrapper .goods-card {
    width: 100%;
    padding: 24px 16px;
    max-width: unset;
  }
}
#goods.site-section-content .goods-wrapper .goods-card .goods-name {
  font-size: 24px;
  margin: 12px 0;
  padding-bottom: 12px;
  border-bottom: 2px solid #594242;
}
@media (max-width: 767px) {
  #goods.site-section-content .goods-wrapper .goods-card .goods-name {
    padding-bottom: 8px;
    margin: 8px 0;
  }
}
#goods.site-section-content .goods-wrapper .goods-card .goods-price {
  font-size: 24px;
  margin-bottom: 12px;
}
@media (max-width: 767px) {
  #goods.site-section-content .goods-wrapper .goods-card .goods-price {
    margin: 16px;
  }
}
#goods.site-section-content .goods-wrapper .goods-card .goods-date {
  font-size: 18px;
}
#goods.site-section-content .goods-wrapper .goods-card .goods-desc {
  margin-bottom: 12px;
  font-size: 18px;
}
#goods.site-section-content .goods-wrapper .webshop-btn a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 64px;
  text-align: center;
  background: #96c673;
  padding: 10px 15px;
  margin: 0 4px 8px;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  color: #594242;
  font-size: 16px;
  border-radius: 50px;
  -webkit-transition: 0.5s ease;
  transition: 0.5s ease;
  position: relative;
  margin-top: 12px;
}
#goods.site-section-content .goods-wrapper .webshop-btn a:before {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  content: "";
  display: inline-block;
  width: 30px;
  height: 30px;
  background-image: url("../img/sozai/btn-deco1.png");
  background-position: center;
  background-size: contain;
  position: absolute;
  left: 8px;
  top: 17px;
  -webkit-transform: rotate(0deg) scale(0.7);
          transform: rotate(0deg) scale(0.7);
}
@media (max-width: 500px) {
  #goods.site-section-content .goods-wrapper .webshop-btn a:before {
    width: 24px;
    left: 3px;
    top: 20px;
    height: 24px;
  }
}
#goods.site-section-content .goods-wrapper .webshop-btn a:after {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  content: "";
  display: inline-block;
  width: 30px;
  height: 30px;
  background-image: url("../img/sozai/btn-deco1.png");
  background-position: center;
  background-size: contain;
  position: absolute;
  right: 8px;
  top: 17px;
  -webkit-transform: rotate(0deg) scale(0.7);
          transform: rotate(0deg) scale(0.7);
}
@media (max-width: 500px) {
  #goods.site-section-content .goods-wrapper .webshop-btn a:after {
    width: 24px;
    right: 3px;
    top: 20px;
    height: 24px;
  }
}
#goods.site-section-content .goods-wrapper .webshop-btn a:hover {
  background: #a3d87b;
}
#goods.site-section-content .goods-wrapper .webshop-btn a:hover:before, #goods.site-section-content .goods-wrapper .webshop-btn a:hover:after {
  -webkit-transform: rotate(180deg) scale(1);
          transform: rotate(180deg) scale(1);
}
#goods.site-section-content .goods-nav {
  margin: 24px auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 1000px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 8px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#goods.site-section-content .goods-nav button {
  background-color: #fdd876;
  width: 220px;
  border-radius: 16px;
  padding: 8px 16px;
}
@media (max-width: 767px) {
  #goods.site-section-content .goods-nav button {
    width: 46%;
    padding: 8px;
  }
}
#goods.site-section-content .goods-nav button.active {
  background-color: #e2b63c;
}
#goods.site-section-content .back-to-top {
  background: url("../img/sozai/goods-top.png") no-repeat center/contain;
  width: 100px;
  height: 100px;
  position: absolute;
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  bottom: 290px;
  right: 1rem;
  display: table;
}
#goods.site-section-content .back-to-top:hover {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
@media (max-width: 767px) {
  #goods.site-section-content .back-to-top {
    width: 80px;
    height: 80px;
    right: 0rem;
  }
}
#goods.site-section-content .side-pictures-sp {
  display: none;
  background: url("../img/sozai/bg-side-sp-goods.webp");
  background-position: bottom left;
  background-size: cover;
  -webkit-animation: bg-slider-sp 80s linear infinite;
  animation: bg-slider-sp 80s linear infinite;
  width: 100%;
  height: 290px;
  position: absolute;
  bottom: 0;
  right: 0px;
  z-index: 99;
}
@media (max-width:1200px) {
  #goods.site-section-content .side-pictures-sp {
    display: inline-block;
  }
}
@-webkit-keyframes bg-slider-sp {
  from {
    background-position: 2196px 0;
  }
  to {
    background-position: 0;
  }
}
@keyframes bg-slider-sp {
  from {
    background-position: 2196px 0;
  }
  to {
    background-position: 0;
  }
}

#info-circle {
  margin-right: 380px;
}
@media (max-width:1200px) {
  #info-circle {
    margin-right: 0px;
  }
}
#info-circle #circle-section {
  display: block;
  position: relative;
  padding-top: 14.3055555556vw;
  overflow: clip;
  height: 100%;
}
#info-circle #circle-section:before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 75%;
  background: url("../img/sozai/bg-clover.png"), #96c673;
  background-size: 500px;
}
@media (max-width: 767px) {
  #info-circle #circle-section {
    padding-top: 22.3055555556vw;
  }
}
#info-circle #circle-section .circle-bg {
  clip-path: polygon(0 0, 100% 0, 100% 50%, 0 50%);
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform-origin: top center;
          transform-origin: top center;
  width: 214.3916666667vw;
  aspect-ratio: 1;
  pointer-events: none;
  translate: -50% 0.1%;
}
#info-circle #circle-section .circle-bg:before {
  clip-path: circle(50% at 50% 50%);
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #96c673;
  background: url("../img/sozai/bg-clover.png"), #96c673;
  background-size: 500px;
}
#info-circle #circle-section .circle-bg svg {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 105.7142857143%;
  -webkit-animation: rotate 16s linear 0s both infinite;
          animation: rotate 16s linear 0s both infinite;
  -webkit-animation-duration: 13.25s;
          animation-duration: 13.25s;
  -webkit-animation-duration: 30s;
          animation-duration: 30s;
  isolation: isolate;
  will-change: translate, width, rotate;
  translate: -50% calc(-50% + 11.1805555556vw);
}

#info {
  width: 100%;
  overflow: hidden;
  height: 100%;
}
#info.site-section-content {
  width: 100%;
  position: relative;
}
#info.site-section-content .site-section-inner {
  padding: 0 0 240px;
  margin: 0 24px;
  position: relative;
}
@media (max-width:1200px) {
  #info.site-section-content .site-section-inner {
    padding: 0 0 300px;
  }
}
#info .content-bg {
  max-width: 800px;
  height: auto;
  margin: 0 auto;
  position: relative;
  text-align: center;
}
@media (max-width: 767px) {
  #info .content-bg {
    width: 100%;
    padding: 0;
  }
}
#info .heading-h1 {
  margin: 0 auto 32px;
  text-align: center;
  color: #ffffff;
  position: relative;
  font-size: 64px;
}
@media (max-width: 767px) {
  #info .heading-h1 {
    margin: 24px auto;
    font-size: 40px;
  }
}
#info table {
  width: 100%;
  width: calc(100% - 0px);
  background-color: #e2b63c;
  font-size: 16px;
  -webkit-box-shadow: 0px 0px 15px -5px rgba(114, 111, 100, 0.568627451);
          box-shadow: 0px 0px 15px -5px rgba(114, 111, 100, 0.568627451);
}
@media (max-width: 767px) {
  #info table {
    width: calc(100% - 0px);
    margin-bottom: 40px;
  }
}
#info th {
  width: 30%;
  padding: 40px;
  background: #fdd876;
  color: #594242;
  font-weight: 500;
  vertical-align: middle;
}
@media (max-width: 767px) {
  #info th {
    display: block;
    width: 100%;
    padding: 24px;
  }
}
#info td {
  padding: 40px;
  background: #ffffff;
  background-attachment: fixed;
  background-size: 400px;
  background-repeat: repeat;
}
@media (max-width: 767px) {
  #info td {
    display: block;
    padding: 24px;
  }
}
#info td a {
  border-bottom: 1px dashed #594242;
  color: #594242;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
#info td a:hover {
  opacity: 0.7;
}
#info .side-pictures-sp {
  display: none;
  background: url("../img/sozai/bg-side-sp-info.webp");
  background-position: bottom left;
  background-size: cover;
  -webkit-animation: bg-slider-sp 80s linear infinite;
  animation: bg-slider-sp 80s linear infinite;
  width: 100%;
  height: 290px;
  position: absolute;
  bottom: 0;
  right: 0px;
  z-index: 99;
}
@media (max-width:1200px) {
  #info .side-pictures-sp {
    display: inline-block;
  }
}
@keyframes bg-slider-sp {
  from {
    background-position: 2196px 0;
  }
  to {
    background-position: 0;
  }
}

.nav-wrapper .hamburger {
  background: url("../img/sozai/nav-menu.png") no-repeat center/contain;
  position: fixed;
  top: 70px;
  width: 169px;
  height: 85px;
  width: min(8.8020833333vw, 169px);
  height: min(4.4270833333vw, 85px);
  top: min(3.6458333333vw, 70px);
  left: min(0vw, 0px);
  cursor: pointer;
  z-index: 999;
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
.nav-wrapper .hamburger.active {
  background: url("../img/sozai/nav-close.png") no-repeat center/contain;
}
@media (max-width: 767px) {
  .nav-wrapper .hamburger {
    width: 112px;
    height: 65px;
    width: 160px;
    height: 80px;
    width: min(20.8604954368vw, 160px);
    height: min(10.4302477184vw, 80px);
    top: 70px;
  }
}
.nav-wrapper .nav {
  position: fixed;
  top: 0;
  left: 0;
  width: 500px;
  height: 100vh;
  background-color: #96c673;
  background: url("../img/sozai/bg-clover.png"), #96c673;
  background-size: 500px;
  -webkit-box-shadow: 2px 0 4px rgba(0, 0, 0, 0.1);
          box-shadow: 2px 0 4px rgba(0, 0, 0, 0.1);
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
  z-index: 100;
  text-align: center;
}
@media (max-width: 767px) {
  .nav-wrapper .nav {
    width: 100%;
  }
}
.nav-wrapper .nav.active {
  -webkit-transform: translateX(0);
          transform: translateX(0);
}
.nav-wrapper .nav__list {
  margin: 0;
  padding: 240px 0 0;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media (max-width: 767px) {
  .nav-wrapper .nav__list {
    padding: 100px 0 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.nav-wrapper .nav__item {
  display: table;
  width: 50%;
  height: 120px;
  margin-bottom: 90px;
}
@media (max-width: 767px) {
  .nav-wrapper .nav__item {
    margin-bottom: 40px;
    width: 100%;
  }
}
.nav-wrapper .nav__link {
  display: table-cell;
  color: #594242;
  text-decoration: none;
  -webkit-transition: 0.5s ease;
  transition: 0.5s ease;
  position: relative;
}
.nav-wrapper .nav__link.event-gaiyou {
  background: url("../img/sozai/nav-bg-event-y.png") no-repeat center/contain;
  height: 120px;
  width: 100%;
}
.nav-wrapper .nav__link.event-gaiyou:before {
  content: "";
  background: url("../img/sozai/himejima-nav.webp") no-repeat center/contain;
  height: 120px;
  width: 130px;
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: -1;
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
.nav-wrapper .nav__link.event-gaiyou:hover:before {
  -webkit-transform: translateY(-70px);
          transform: translateY(-70px);
}
@media (max-width: 767px) {
  .nav-wrapper .nav__link.event-gaiyou:hover:before {
    display: none;
  }
}
.nav-wrapper .nav__link.menu {
  background: url("../img/sozai/nav-bg-menu-y.png") no-repeat center/contain;
  height: 120px;
  width: 100%;
}
.nav-wrapper .nav__link.menu:before {
  content: "";
  background: url("../img/sozai/aoi-nav.webp") no-repeat center/contain;
  height: 120px;
  width: 130px;
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: -1;
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
.nav-wrapper .nav__link.menu:hover:before {
  -webkit-transform: translateY(-70px);
          transform: translateY(-70px);
}
@media (max-width: 767px) {
  .nav-wrapper .nav__link.menu:hover:before {
    display: none;
  }
}
.nav-wrapper .nav__link.goods {
  background: url("../img/sozai/nav-bg-goods-y.png") no-repeat center/contain;
  height: 120px;
  width: 100%;
}
.nav-wrapper .nav__link.goods:before {
  content: "";
  background: url("../img/sozai/uzui-nav.webp") no-repeat center/contain;
  height: 120px;
  width: 130px;
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: -1;
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
.nav-wrapper .nav__link.goods:hover:before {
  -webkit-transform: translateY(-70px);
          transform: translateY(-70px);
}
@media (max-width: 767px) {
  .nav-wrapper .nav__link.goods:hover:before {
    display: none;
  }
}
.nav-wrapper .nav__link.special {
  background: url("../img/sozai/nav-bg-special-y.png") no-repeat center/contain;
  height: 120px;
  width: 100%;
}
.nav-wrapper .nav__link.special:before {
  content: "";
  background: url("../img/sozai/nezuko-nav.webp") no-repeat center/contain;
  height: 110px;
  width: 130px;
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: -1;
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
.nav-wrapper .nav__link.special:hover:before {
  -webkit-transform: translateY(-70px);
          transform: translateY(-70px);
}
@media (max-width: 767px) {
  .nav-wrapper .nav__link.special:hover:before {
    display: none;
  }
}
.nav-wrapper .tenpo-link .nav__item {
  height: 0;
  margin: 0;
  width: 100%;
  font-size: 20px;
  margin-bottom: 20px;
}

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

img,
video,
object {
  display: block;
  width: 100%;
  height: auto;
  border: 0;
  pointer-events: none;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-touch-callout: none;
  -moz-user-select: none;
  -ms-user-select: none;
      user-select: none;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}

a {
  text-decoration: none;
  cursor: pointer;
}

ul,
li {
  margin: 0;
  padding: 0;
  text-decoration: none;
}

html {
  -webkit-overflow-scrolling: touch;
  height: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizelegibility;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  scroll-behavior: smooth;
  -ms-touch-action: manipulation;
      touch-action: manipulation;
}

body {
  -webkit-overflow-scrolling: touch;
  color: #594242;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.5;
}

.site-content-wrapper {
  overflow-y: hidden;
  overflow-x: hidden;
  background: #fdd876;
  position: relative;
}

.site-header-logoarea {
  z-index: 999;
  position: relative;
}

.side-pictures {
  background: url("../img/sozai/bg-side-pc.webp"), #fff8ec;
  background-position: top center;
  background-size: 100%;
  -webkit-animation: bg-slider 200s linear infinite;
          animation: bg-slider 200s linear infinite;
  width: 380px;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0px;
  z-index: 99;
}
@media (max-width:1200px) {
  .side-pictures {
    display: none;
  }
}

@-webkit-keyframes bg-slider {
  from {
    background-position: 0 -6415px;
  }
  to {
    background-position: 0;
  }
}

@keyframes bg-slider {
  from {
    background-position: 0 -6415px;
  }
  to {
    background-position: 0;
  }
}
body::-webkit-scrollbar {
  width: 24px;
}
@media (max-width: 767px) {
  body::-webkit-scrollbar {
    width: 0px;
  }
}

body::-webkit-scrollbar-track {
  background-color: #594242;
}

body::-webkit-scrollbar-thumb {
  background-color: #faecd4;
  border-radius: 12px;
  height: 80px;
}

#menu-circle {
  margin-right: 380px;
}
@media (max-width:1200px) {
  #menu-circle {
    margin-right: 0px;
  }
}
#menu-circle #circle-section {
  display: block;
  position: relative;
  padding-top: 14.3055555556vw;
  overflow: clip;
  height: 100%;
  background: url("../img/sozai/bg-clover.png"), #96c673;
  background-size: contain;
}
#menu-circle #circle-section:before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 89%;
  background: #fdd876;
}
@media (max-width: 767px) {
  #menu-circle #circle-section {
    padding-top: 22.3055555556vw;
  }
}
#menu-circle #circle-section .circle-bg {
  clip-path: polygon(0 0, 100% 0, 100% 50%, 0 50%);
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform-origin: top center;
          transform-origin: top center;
  width: 214.3916666667vw;
  aspect-ratio: 1;
  pointer-events: none;
  translate: -50% 0.1%;
}
#menu-circle #circle-section .circle-bg:before {
  clip-path: circle(50% at 50% 50%);
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #96c673;
  background: #fdd876;
}
#menu-circle #circle-section .circle-bg svg {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 105.7142857143%;
  -webkit-animation: rotate 16s linear 0s both infinite;
          animation: rotate 16s linear 0s both infinite;
  -webkit-animation-duration: 13.25s;
          animation-duration: 13.25s;
  -webkit-animation-duration: 30s;
          animation-duration: 30s;
  isolation: isolate;
  will-change: translate, width, rotate;
  translate: -50% calc(-50% + 11.1805555556vw);
}

#menu.site-section-content {
  padding: 0;
  width: 100%;
  overflow: hidden;
  height: 100%;
}
#menu.site-section-content .site-section-inner {
  padding: 0 0 240px;
  margin: 0 24px;
  position: relative;
}
@media (max-width:1200px) {
  #menu.site-section-content .site-section-inner {
    padding: 0 0 300px;
  }
}
#menu.site-section-content .site-section-inner .heading-h1 {
  margin: 0 auto 32px;
  text-align: center;
  color: #ffffff;
  position: relative;
  font-size: 64px;
  color: #594242;
}
@media (max-width: 767px) {
  #menu.site-section-content .site-section-inner .heading-h1 {
    margin: 24px auto;
    font-size: 40px;
  }
}
#menu.site-section-content .site-section-inner .content-bg {
  padding: 40px;
  max-width: 800px;
  height: auto;
  margin: 0 auto;
  text-align: center;
  font-size: 24px;
  position: relative;
  color: #594242;
  background: #faecd4;
  border-radius: 24px;
  -webkit-box-shadow: 0px 0px 10px rgb(185.4375, 125.0625, 21.5625);
          box-shadow: 0px 0px 10px rgb(185.4375, 125.0625, 21.5625);
  height: auto;
  color: #594242;
  margin: 0 auto 24px;
  text-align: center;
  font-size: 24px;
  border-radius: 10px;
  background: url("../img/sozai/bg-pattern2.png"), #96c673;
  background-size: cover;
  -webkit-box-shadow: 0px 0px 15px -5px rgba(114, 111, 100, 0.568627451);
          box-shadow: 0px 0px 15px -5px rgba(114, 111, 100, 0.568627451);
}
@media (max-width: 767px) {
  #menu.site-section-content .site-section-inner .content-bg {
    width: 100%;
    padding: 32px 16px;
  }
}
#menu.site-section-content .site-section-inner .content-bg .heading-h2,
#menu.site-section-content .site-section-inner .content-bg .heading-h3 {
  margin: 24px;
  position: relative;
  font-size: 32px;
}
@media (max-width: 767px) {
  #menu.site-section-content .site-section-inner .content-bg .heading-h2,
  #menu.site-section-content .site-section-inner .content-bg .heading-h3 {
    font-size: 24px;
    margin: 16px;
  }
}
@media (max-width: 767px) {
  #menu.site-section-content .site-section-inner .content-bg .heading-h3 {
    font-size: 20px;
  }
}
#menu.site-section-content .site-section-inner .content-bg h4 {
  font-size: 18px;
  margin-bottom: 4px;
}
#menu.site-section-content .site-section-inner .content-bg .drink-date {
  font-size: 40px;
}
@media (max-width: 767px) {
  #menu.site-section-content .site-section-inner .content-bg .drink-date {
    font-size: 24px;
  }
}
#menu.site-section-content .site-section-inner .content-bg .menu-price {
  font-size: 32px;
  margin-bottom: 24px;
}
@media (max-width: 767px) {
  #menu.site-section-content .site-section-inner .content-bg .menu-price {
    font-size: 24px;
    margin: 16px 0;
  }
}
#menu.site-section-content .site-section-inner .content-bg .menu-detail,
#menu.site-section-content .site-section-inner .content-bg .novelty-detail {
  background-color: #ffffff;
  font-size: 16px;
  padding: 24px;
  line-height: 1.5rem;
  color: #594242;
}
@media (max-width: 767px) {
  #menu.site-section-content .site-section-inner .content-bg .menu-detail,
  #menu.site-section-content .site-section-inner .content-bg .novelty-detail {
    padding: 16px;
  }
}
#menu.site-section-content .site-section-inner .content-bg .drink-detail {
  font-size: 32px;
  padding: 24px;
  color: #ffffff;
}
@media (max-width: 767px) {
  #menu.site-section-content .site-section-inner .content-bg .drink-detail {
    padding: 16px;
    font-size: 16px;
  }
}
#menu.site-section-content .site-section-inner .content-bg .drink-sub-title {
  font-size: 24px;
  margin-bottom: 24px;
}
@media (max-width: 767px) {
  #menu.site-section-content .site-section-inner .content-bg .drink-sub-title {
    font-size: 18px;
  }
}
#menu.site-section-content .site-section-inner .content-bg .drink-title {
  margin-bottom: 16px;
  font-size: 32px;
}
@media (max-width: 767px) {
  #menu.site-section-content .site-section-inner .content-bg .drink-title {
    font-size: 24px;
  }
}
#menu.site-section-content .site-section-inner .content-bg .novelty-detail {
  line-height: unset;
}
#menu.site-section-content .site-section-inner .content-bg .note_1 {
  font-size: 14px;
  margin: 8px 0 0;
}
#menu.site-section-content .site-section-inner .content-bg .novelty-photo {
  margin: auto auto 16px;
}
@media (max-width: 767px) {
  #menu.site-section-content .site-section-inner .content-bg .novelty-photo {
    height: 100%;
    width: 100%;
  }
}
#menu.site-section-content .side-pictures-sp {
  display: none;
  background: url("../img/sozai/bg-side-sp-menu.webp");
  background-position: bottom left;
  background-size: cover;
  -webkit-animation: bg-slider-sp 80s linear infinite;
  animation: bg-slider-sp 80s linear infinite;
  width: 100%;
  height: 290px;
  position: absolute;
  bottom: 0;
  right: 0px;
  z-index: 99;
}
@media (max-width:1200px) {
  #menu.site-section-content .side-pictures-sp {
    display: inline-block;
  }
}
@keyframes bg-slider-sp {
  from {
    background-position: 2196px 0;
  }
  to {
    background-position: 0;
  }
}

#loading {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  height: 100%;
  background: #faecd4;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #594242;
}
#loading:before {
  width: 100%;
  height: 5%;
  content: "";
  background: url("../img/sozai/loading-bg.png") repeat-x top/contain;
}
#loading:after {
  width: 100%;
  height: 5%;
  content: "";
  background: url("../img/sozai/loading-bg.png") repeat-x bottom/contain;
  -webkit-transform: scale(1, -1);
          transform: scale(1, -1);
}
#loading .loading-title-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  opacity: 1;
  width: 100%;
  height: 100vh;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  max-width: 500px;
  display: flex;
  justify-content: center;
  align-items: center;
}
#loading .loading-svg {
  width: 80%;
}

#official-circle {
  margin-right: 380px;
}
@media (max-width:1200px) {
  #official-circle {
    margin-right: 0px;
  }
}
#official-circle #circle-section {
  display: block;
  position: relative;
  padding-top: 14.3055555556vw;
  overflow: clip;
  height: 100%;
  background: url("../img/sozai/bg-clover.png"), #96c673;
  background-size: contain;
}
#official-circle #circle-section:before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 75%;
  background: #fdd876;
}
@media (max-width: 767px) {
  #official-circle #circle-section {
    padding-top: 22.3055555556vw;
  }
}
#official-circle #circle-section .circle-bg {
  clip-path: polygon(0 0, 100% 0, 100% 50%, 0 50%);
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform-origin: top center;
          transform-origin: top center;
  width: 214.3916666667vw;
  aspect-ratio: 1;
  pointer-events: none;
  translate: -50% 0.1%;
}
#official-circle #circle-section .circle-bg:before {
  clip-path: circle(50% at 50% 50%);
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #96c673;
  background: #fdd876;
}
#official-circle #circle-section .circle-bg svg {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 105.7142857143%;
  -webkit-animation: rotate 16s linear 0s both infinite;
          animation: rotate 16s linear 0s both infinite;
  -webkit-animation-duration: 13.25s;
          animation-duration: 13.25s;
  -webkit-animation-duration: 30s;
          animation-duration: 30s;
  isolation: isolate;
  will-change: translate, width, rotate;
  translate: -50% calc(-50% + 11.1805555556vw);
}

#official.site-section-content {
  padding: 0;
  width: 100%;
  overflow: hidden;
  color: #ffffff;
}
#official.site-section-content .heading-wrap {
  text-align: center;
}
@media (max-width: 767px) {
  #official.site-section-content .heading-wrap {
    width: 100%;
  }
}
#official.site-section-content .heading-h1 {
  margin: 0 auto 32px;
  text-align: center;
  color: #ffffff;
  position: relative;
  font-size: 64px;
  color: #594242;
}
@media (max-width: 767px) {
  #official.site-section-content .heading-h1 {
    margin: 24px auto;
    font-size: 40px;
  }
}
#official.site-section-content .heading-h2 {
  font-weight: 500;
  margin: 24px 0;
  font-size: 24px;
}
#official.site-section-content .site-section-inner {
  padding: 0 0 80px;
  margin: 0 24px;
  position: relative;
}
#official.site-section-content .site-section-inner .back-to-top {
  background: url("../img/sozai/top.png") no-repeat center/contain;
  width: 100px;
  height: 100px;
  position: absolute;
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  bottom: 30px;
  right: 1rem;
  display: table;
}
#official.site-section-content .site-section-inner .back-to-top:hover {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
@media (max-width: 767px) {
  #official.site-section-content .site-section-inner .back-to-top {
    width: 80px;
    height: 80px;
    bottom: 24px;
    right: 0rem;
  }
}
#official.site-section-content .site-section-inner .content-bg {
  padding: 60px;
  max-width: 800px;
  height: auto;
  margin: 0 auto;
  text-align: center;
  font-size: 24px;
  position: relative;
  color: #594242;
  background: #faecd4;
  border-radius: 24px;
  -webkit-box-shadow: 0px 0px 10px rgb(185.4375, 125.0625, 21.5625);
          box-shadow: 0px 0px 10px rgb(185.4375, 125.0625, 21.5625);
  height: auto;
  margin: 0 auto 40px;
  text-align: center;
  font-size: 24px;
  background: url(../img/sozai/bg-pattern2.png), #96c673;
  background-size: cover;
}
@media (max-width: 767px) {
  #official.site-section-content .site-section-inner .content-bg {
    width: 100%;
    padding: 32px 16px 72px;
  }
}
#official.site-section-content .site-section-inner .social-account-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
#official.site-section-content .site-section-inner .social-account-wrap .social-account {
  margin: 0 8px;
  list-style: none;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media (max-width: 767px) {
  #official.site-section-content .site-section-inner .social-account-wrap .social-account {
    margin: 0 4px;
  }
}
#official.site-section-content .site-section-inner .social-account-wrap .social-account a {
  display: inline-block;
  -webkit-transition: 0.7s;
  transition: 0.7s;
}
#official.site-section-content .site-section-inner .social-account-wrap .social-account.x {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
@media (hover: hover) and (pointer: fine) {
  #official.site-section-content .site-section-inner .social-account-wrap .social-account.x:hover {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active) {
  #official.site-section-content .site-section-inner .social-account-wrap .social-account.x:hover {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
#official.site-section-content .site-section-inner .social-account-wrap .social-account.facebook {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
@media (hover: hover) and (pointer: fine) {
  #official.site-section-content .site-section-inner .social-account-wrap .social-account.facebook:hover {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active) {
  #official.site-section-content .site-section-inner .social-account-wrap .social-account.facebook:hover {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
#official.site-section-content .site-section-inner .social-account-wrap .social-account.instagram {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
@media (hover: hover) and (pointer: fine) {
  #official.site-section-content .site-section-inner .social-account-wrap .social-account.instagram:hover {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active) {
  #official.site-section-content .site-section-inner .social-account-wrap .social-account.instagram:hover {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
#official.site-section-content .site-section-inner .social-account-wrap .social-account.youtube {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
@media (hover: hover) and (pointer: fine) {
  #official.site-section-content .site-section-inner .social-account-wrap .social-account.youtube:hover {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active) {
  #official.site-section-content .site-section-inner .social-account-wrap .social-account.youtube:hover {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}

#store-circle {
  margin-right: 380px;
}
@media (max-width:1200px) {
  #store-circle {
    margin-right: 0px;
  }
}
#store-circle #circle-section {
  display: block;
  position: relative;
  padding-top: 14.3055555556vw;
  overflow: clip;
  height: 100%;
  background: #fdd876;
}
#store-circle #circle-section:before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 88%;
  background: #fdd876;
  background: url("../img/sozai/bg-clover.png"), #96c673;
  background-size: 500px;
}
@media (max-width: 767px) {
  #store-circle #circle-section {
    padding-top: 22.3055555556vw;
    height: 97%;
  }
}
#store-circle #circle-section .circle-bg {
  clip-path: polygon(0 0, 100% 0, 100% 50%, 0 50%);
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform-origin: top center;
          transform-origin: top center;
  width: 214.3916666667vw;
  aspect-ratio: 1;
  pointer-events: none;
  translate: -50% 0.1%;
}
#store-circle #circle-section .circle-bg:before {
  clip-path: circle(50% at 50% 50%);
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #96c673;
  background: #fdd876;
  background: url("../img/sozai/bg-clover.png"), #96c673;
  background-size: 500px;
}
#store-circle #circle-section .circle-bg svg {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 105.7142857143%;
  -webkit-animation: rotate 16s linear 0s both infinite;
          animation: rotate 16s linear 0s both infinite;
  -webkit-animation-duration: 13.25s;
          animation-duration: 13.25s;
  -webkit-animation-duration: 30s;
          animation-duration: 30s;
  isolation: isolate;
  will-change: translate, width, rotate;
  translate: -50% calc(-50% + 11.1805555556vw);
}

#store.site-section-content {
  padding: 0;
  width: 100%;
  overflow: hidden;
  color: #594242;
}
#store.site-section-content .heading-h2 {
  font-weight: 500;
  margin: 32px;
  font-size: 24px;
}
@media (max-width: 767px) {
  #store.site-section-content .heading-h2 {
    margin: 24px 0;
  }
}
#store.site-section-content .site-section-inner {
  position: relative;
  padding: 0 0 40px;
  margin: 0 24px;
  position: relative;
}
#store.site-section-content .site-section-inner .heading-h1 {
  margin: 0 auto 32px;
  text-align: center;
  color: #ffffff;
  position: relative;
  font-size: 64px;
}
@media (max-width: 767px) {
  #store.site-section-content .site-section-inner .heading-h1 {
    margin: 24px auto;
    font-size: 40px;
  }
}
#store.site-section-content .site-section-inner .content-bg {
  padding: 60px;
  max-width: 800px;
  height: auto;
  margin: 0 auto;
  text-align: center;
  font-size: 24px;
  position: relative;
  color: #594242;
  background: #faecd4;
  border-radius: 24px;
  -webkit-box-shadow: 0px 0px 10px rgb(185.4375, 125.0625, 21.5625);
          box-shadow: 0px 0px 10px rgb(185.4375, 125.0625, 21.5625);
  height: auto;
  margin: 0 auto 40px;
  text-align: center;
  font-size: 24px;
  color: #594242;
  -webkit-box-shadow: 0px 0px 15px -5px rgba(114, 111, 100, 0.568627451);
          box-shadow: 0px 0px 15px -5px rgba(114, 111, 100, 0.568627451);
}
@media (max-width: 767px) {
  #store.site-section-content .site-section-inner .content-bg {
    width: 100%;
    padding: 16px 16px 72px;
  }
}
#store.site-section-content .site-section-inner .content-bg .store-cards {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 16px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
#store.site-section-content .site-section-inner .content-bg .store-card {
  border-radius: 12px;
  width: 200px;
  height: 200px;
  position: relative;
  -webkit-box-shadow: 0px 0px 8px rgba(158, 116, 116, 0.5058823529);
          box-shadow: 0px 0px 8px rgba(158, 116, 116, 0.5058823529);
}
@media (max-width: 767px) {
  #store.site-section-content .site-section-inner .content-bg .store-card {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    width: 100%;
    height: 80px;
  }
}
#store.site-section-content .site-section-inner .content-bg .store-card.uct {
  background: url("../img/sozai/x_uct.webp");
  background-size: 400px;
  background-position: center;
  background-repeat: repeat;
}
#store.site-section-content .site-section-inner .content-bg .store-card.mct {
  background: url("../img/sozai/x_uct.webp");
  background-size: 400px;
  background-position: center;
  background-repeat: repeat;
}
#store.site-section-content .site-section-inner .content-bg .store-card.mcn {
  background: url("../img/sozai/x_ufn_mcn.webp");
  background-size: 400px;
  background-position: center;
  background-repeat: repeat;
}
#store.site-section-content .site-section-inner .content-bg .store-card.mco {
  background: url("../img/sozai/x_ufo_mco.webp");
  background-size: 400px;
  background-position: center;
  background-repeat: repeat;
}
#store.site-section-content .site-section-inner .content-bg .store-card.uctk {
  background: url("../img/sozai/x_uft.webp");
  background-size: 400px;
  background-position: center;
  background-repeat: repeat;
}
#store.site-section-content .site-section-inner .content-bg .store-card.mcb {
  background: url("../img/sozai/x_mcb.webp");
  background-size: 400px;
  background-position: center;
  background-repeat: repeat;
}
#store.site-section-content .site-section-inner .content-bg .store-card.mck {
  background: url("../img/sozai/x_mck.webp");
  background-size: 400px;
  background-position: center;
  background-repeat: repeat;
}
#store.site-section-content .site-section-inner .content-bg .store-card.togo {
  background: url("../img/sozai/x_togo.webp");
  background-size: 400px;
  background-position: center;
  background-repeat: repeat;
}
#store.site-section-content .site-section-inner .content-bg .store-card .white-content {
  background-color: rgba(0, 0, 0, 0.6352941176);
  border-radius: 12px;
  height: 100%;
  display: table;
  width: 100%;
}
#store.site-section-content .site-section-inner .content-bg .store-card a {
  display: table-cell;
  width: 100%;
  height: 100%;
  color: #ffffff;
  vertical-align: middle;
  text-align: center;
  font-size: 16px;
  border-radius: 12px;
  text-shadow: 0 0 6px #000;
  padding: 12px;
  -webkit-transition: 0.7s;
  transition: 0.7s;
}
@media (max-width: 767px) {
  #store.site-section-content .site-section-inner .content-bg .store-card a {
    font-size: 18px;
    padding: 8px;
    height: 80px;
  }
}
@media (hover: hover) and (pointer: fine) {
  #store.site-section-content .site-section-inner .content-bg .store-card a:hover {
    background-color: rgba(255, 255, 255, 0.3764705882);
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active) {
  #store.site-section-content .site-section-inner .content-bg .store-card a:hover {
    background-color: rgba(255, 255, 255, 0.3764705882);
  }
}

#special-circle {
  margin-right: 380px;
}
@media (max-width:1200px) {
  #special-circle {
    margin-right: 0px;
  }
}
#special-circle #circle-section {
  display: block;
  position: relative;
  padding-top: 14.3055555556vw;
  overflow: clip;
  height: 100%;
  background: url("../img/sozai/bg-pattern3.png"), #96c673;
  background-size: 500px;
}
#special-circle #circle-section:before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 96%;
  background: #fdd876;
  background-size: contain;
}
@media (max-width: 767px) {
  #special-circle #circle-section {
    padding-top: 22.3055555556vw;
  }
}
#special-circle #circle-section .circle-bg {
  clip-path: polygon(0 0, 100% 0, 100% 50%, 0 50%);
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform-origin: top center;
          transform-origin: top center;
  width: 214.3916666667vw;
  aspect-ratio: 1;
  pointer-events: none;
  translate: -50% 0.1%;
}
#special-circle #circle-section .circle-bg:before {
  clip-path: circle(50% at 50% 50%);
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fdd876;
}
#special-circle #circle-section .circle-bg svg {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 105.7142857143%;
  -webkit-animation: rotate 16s linear 0s both infinite;
          animation: rotate 16s linear 0s both infinite;
  -webkit-animation-duration: 13.25s;
          animation-duration: 13.25s;
  -webkit-animation-duration: 30s;
          animation-duration: 30s;
  isolation: isolate;
  will-change: translate, width, rotate;
  translate: -50% calc(-50% + 11.1805555556vw);
}

#special.site-section-content {
  padding: 0;
  width: 100%;
  overflow: hidden;
  height: 100%;
}
#special.site-section-content .site-section-inner {
  padding: 0 0 40px;
  margin: 0 24px;
  position: relative;
}
#special.site-section-content .site-section-inner .heading-h1 {
  margin: 0 auto 32px;
  text-align: center;
  color: #ffffff;
  position: relative;
  font-size: 64px;
  color: #594242;
  font-size: 52px;
}
@media (max-width: 767px) {
  #special.site-section-content .site-section-inner .heading-h1 {
    margin: 24px auto;
    font-size: 28px;
  }
}
#special.site-section-content .site-section-inner .content-bg {
  padding: 24px;
  max-width: 800px;
  height: auto;
  margin: 0 auto;
  text-align: center;
  font-size: 24px;
  position: relative;
  color: #594242;
  background: #faecd4;
  border-radius: 24px;
  -webkit-box-shadow: 0px 0px 10px rgb(185.4375, 125.0625, 21.5625);
          box-shadow: 0px 0px 10px rgb(185.4375, 125.0625, 21.5625);
  height: auto;
  color: #594242;
  margin: 0 auto 24px;
  text-align: center;
  font-size: 24px;
  border-radius: 10px;
  background: url("../img/sozai/bg-lighter.png"), #a5d680;
  background-size: contain;
  -webkit-box-shadow: 0px 0px 15px -5px rgba(114, 111, 100, 0.568627451);
          box-shadow: 0px 0px 15px -5px rgba(114, 111, 100, 0.568627451);
}
@media (max-width: 767px) {
  #special.site-section-content .site-section-inner .content-bg {
    width: 100%;
    padding: 32px 16px;
  }
}
#special.site-section-content .site-section-inner .content-bg img {
  margin: auto;
  position: relative;
}
#special.site-section-content .site-section-inner .content-bg .heading-h2 {
  position: relative;
  font-size: 16px;
  padding: 0 16px;
  margin: 24px 0;
  background: #fff8ec;
  margin: 24px 0;
  padding: 24px;
}
#special.site-section-content .site-section-inner .content-bg .side-pictures-sp {
  display: none;
  background: url("../img/sozai/bg-side-sp-special.webp");
  background-position: bottom left;
  background-size: cover;
  -webkit-animation: bg-slider-sp 80s linear infinite;
  animation: bg-slider-sp 80s linear infinite;
  width: 100%;
  height: 290px;
  position: absolute;
  bottom: 0;
  right: 0px;
  z-index: 99;
}
@media (max-width:1200px) {
  #special.site-section-content .site-section-inner .content-bg .side-pictures-sp {
    display: inline-block;
  }
}
@keyframes bg-slider-sp {
  from {
    background-position: 2196px 0;
  }
  to {
    background-position: 0;
  }
}
#special.site-section-content .site-section-inner .content-bg .special-info {
  width: 100%;
  width: calc(100% - 0px);
  background-color: #e2b63c;
  font-size: 16px;
  -webkit-box-shadow: 0px 0px 15px -5px rgba(114, 111, 100, 0.568627451);
          box-shadow: 0px 0px 15px -5px rgba(114, 111, 100, 0.568627451);
}
@media (max-width: 767px) {
  #special.site-section-content .site-section-inner .content-bg .special-info {
    width: calc(100% - 0px);
  }
}
#special.site-section-content .site-section-inner .content-bg .special-info th {
  width: 20%;
  padding: 16px;
  background: #fdd876;
  color: #594242;
  vertical-align: middle;
}
@media (max-width: 767px) {
  #special.site-section-content .site-section-inner .content-bg .special-info th {
    display: block;
    width: 100%;
    padding: 16px;
  }
}
#special.site-section-content .site-section-inner .content-bg .special-info .special-info-title {
  background-color: #594242;
  color: #faecd4;
}
#special.site-section-content .site-section-inner .content-bg .special-info td {
  padding: 16px;
  background: #ffffff;
}
@media (max-width: 767px) {
  #special.site-section-content .site-section-inner .content-bg .special-info td {
    display: block;
    padding: 16px;
  }
}
#special.site-section-content .site-section-inner .content-bg .special-info td a {
  border-bottom: 1px dashed #594242;
  color: #594242;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
#special.site-section-content .site-section-inner .content-bg .special-info td a:hover {
  opacity: 0.7;
}
#special.site-section-content .site-section-inner .content-bg button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 64px;
  text-align: center;
  background: #96c673;
  padding: 10px 15px;
  margin: 0 4px 8px;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  color: #594242;
  font-size: 16px;
  border-radius: 50px;
  background-color: #594242;
  -webkit-transition: 0.5s ease;
  transition: 0.5s ease;
  position: relative;
  margin: 32px 0;
  color: #faecd4;
  font-size: 24px;
}
#special.site-section-content .site-section-inner .content-bg button:before {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  content: "";
  display: inline-block;
  width: 30px;
  height: 30px;
  background-image: url("../img/sozai/btn-deco1.png");
  background-position: center;
  background-size: contain;
  position: absolute;
  left: 8px;
  top: 17px;
  -webkit-transform: rotate(0deg) scale(0.7);
          transform: rotate(0deg) scale(0.7);
}
#special.site-section-content .site-section-inner .content-bg button:after {
  -webkit-transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  content: "";
  display: inline-block;
  width: 30px;
  height: 30px;
  background-image: url("../img/sozai/btn-deco1.png");
  background-position: center;
  background-size: contain;
  position: absolute;
  right: 8px;
  top: 17px;
  -webkit-transform: rotate(0deg) scale(0.7);
          transform: rotate(0deg) scale(0.7);
}
#special.site-section-content .site-section-inner .content-bg button:hover {
  background: #faecd4;
  color: #594242;
}
#special.site-section-content .site-section-inner .content-bg button:hover:before, #special.site-section-content .site-section-inner .content-bg button:hover:after {
  -webkit-transform: rotate(180deg) scale(1);
          transform: rotate(180deg) scale(1);
}
#special.site-section-content .site-section-inner .content-bg .item-img-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 8px;
}
#special.site-section-content .site-section-inner .content-bg .item-img-wrapper img {
  width: 48%;
}
@media (max-width: 767px) {
  #special.site-section-content .site-section-inner .content-bg .item-img-wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  #special.site-section-content .site-section-inner .content-bg .item-img-wrapper img {
    width: 100%;
  }
}
#special.site-section-content .site-section-inner .content-bg .special-table {
  width: calc(100% - 0px);
  font-size: 18px;
  text-align: left;
  font-weight: normal;
  border-collapse: separate;
  margin-bottom: 24px;
  color: #594242;
  background-color: #594242;
}
#special.site-section-content .site-section-inner .content-bg .special-table th {
  width: 100%;
  color: #594242;
  padding: 20px;
  vertical-align: middle;
  text-align: center;
  font-size: 16px;
}
#special.site-section-content .site-section-inner .content-bg .special-table tr:nth-child(odd) {
  background-color: #fdd876;
}
#special.site-section-content .site-section-inner .content-bg .special-table tr {
  background-color: #ffffff;
}
#special.site-section-content .site-section-inner .content-bg .special-table .special-caution .special-caution-item {
  text-align: left;
  list-style: none;
  color: #594242;
  font-size: 14px;
  text-indent: -1em;
  padding-left: 0.5em;
}
#special.site-section-content .site-section-inner .content-bg .special-table .special-caution .special-caution-item:before {
  content: "・";
}
#special.site-section-content .site-section-inner .content-bg .special-table .special-caution .special-caution-item.important {
  font-size: 18px;
  color: rgb(179, 21, 21);
}
#special.site-section-content .site-section-inner .content-bg .workshop {
  margin: 24px 0;
}