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

@keyframes chara {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes logo {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes opacity {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
#about.site-section-content .site-section-inner {
  padding: 80px 0px;
  margin: 0 auto;
}
@media screen and (max-width:650px) {
  #about.site-section-content .site-section-inner {
    padding: 80px 0px 40px;
    margin: 0 auto;
  }
}
#about.site-section-content .content-holder {
  text-align: center;
  position: relative;
  display: flex;
  margin: 0 16px;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width:650px) {
  #about.site-section-content .content-holder {
    margin: 0 8px;
  }
}
#about.site-section-content .content-holder h1 {
  margin-bottom: 16px;
  font-size: 24px;
}
@media screen and (max-width:650px) {
  #about.site-section-content .content-holder h1 {
    font-size: 18px;
  }
}
#about.site-section-content .btn-holder {
  display: flex;
  justify-content: center;
  margin-top: 80px;
  align-items: center;
  padding: 80px 0;
  background: rgba(0, 0, 0, 0.733);
}
@media screen and (max-width:650px) {
  #about.site-section-content .btn-holder {
    flex-direction: column;
    margin-top: 40px;
    align-items: center;
    padding: 40px 0;
    gap: 16px;
  }
}
#about.site-section-content .btn-holder .btn {
  width: 400px;
  height: 100px;
  margin: 24px;
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
@media screen and (max-width:650px) {
  #about.site-section-content .btn-holder .btn {
    width: calc(100% - 40px);
    margin: 0;
  }
}
@media (hover: hover) and (pointer: fine) {
  #about.site-section-content .btn-holder .btn:hover {
    transform: scale(1.1, 1.1);
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active) {
  #about.site-section-content .btn-holder .btn:hover {
    transform: scale(1.1, 1.1);
  }
}

header {
  width: 100%;
  min-width: 1000px;
  margin: auto;
  max-width: 1920px;
  position: relative;
}
@media screen and (max-width:650px) {
  header {
    height: 800px;
    background-size: 300px;
    min-width: unset;
    min-height: unset;
    width: 100%;
  }
}
header h1 {
  display: none;
}
header .header-chara-wrapper {
  display: flex;
  width: 100%;
  height: min(56.25vw, 1080px);
  min-height: 565px;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper {
    flex-wrap: wrap;
    min-height: unset;
    height: 260px;
  }
}
header .header-chara-wrapper .header-chara {
  width: 100%;
  height: 100%;
  opacity: 0;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper .header-chara {
    width: 25%;
  }
}
header .header-chara-wrapper .header-chara.tanjiro {
  background: url("../img/sozai/header-tanjiro.webp") no-repeat center/contain;
  animation-delay: 0.2s;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper .header-chara.tanjiro {
    background: url("../img/sozai/header-tanjiro.webp") no-repeat top/cover;
    background-position: 0px -70px;
  }
}
header .header-chara-wrapper .header-chara.giyu {
  background: url("../img/sozai/header-giyu.webp") no-repeat center/contain;
  animation-delay: 0.2s;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper .header-chara.giyu {
    background: url("../img/sozai/header-giyu.webp") no-repeat top/cover;
    background-position: 0px -70px;
  }
}
header .header-chara-wrapper .header-chara.zenitsu {
  background: url("../img/sozai/header-zenitsu.webp") no-repeat center/contain;
  animation-delay: 0.4s;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper .header-chara.zenitsu {
    background: url("../img/sozai/header-zenitsu.webp") no-repeat top/cover;
    background-position: 0px -70px;
  }
}
header .header-chara-wrapper .header-chara.shinobu {
  background: url("../img/sozai/header-shinobu.webp") no-repeat center/contain;
  animation-delay: 0.4s;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper .header-chara.shinobu {
    background: url("../img/sozai/header-shinobu.webp") no-repeat top/cover;
    background-position: 0px -70px;
  }
}
header .header-chara-wrapper .header-chara.kanao {
  background: url("../img/sozai/header-kanao.webp") no-repeat center/contain;
  animation-delay: 0.6s;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper .header-chara.kanao {
    background: url("../img/sozai/header-kanao.webp") no-repeat top/cover;
    background-position: 0px -70px;
  }
}
header .header-chara-wrapper .header-chara.mitsuri {
  background: url("../img/sozai/header-mitsuri.webp") no-repeat center/contain;
  animation-delay: 0.6s;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper .header-chara.mitsuri {
    background: url("../img/sozai/header-mitsuri.webp") no-repeat top/cover;
    background-position: 0px -70px;
  }
}
header .header-chara-wrapper .header-chara.inosuke {
  background: url("../img/sozai/header-inosuke.webp") no-repeat center/contain;
  animation-delay: 0.8s;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper .header-chara.inosuke {
    background: url("../img/sozai/header-inosuke.webp") no-repeat top/cover;
    background-position: 0px -70px;
  }
}
header .header-chara-wrapper .header-chara.iguro {
  background: url("../img/sozai/header-iguro.webp") no-repeat center/contain;
  animation-delay: 0.8s;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper .header-chara.iguro {
    background: url("../img/sozai/header-iguro.webp") no-repeat top/cover;
    background-position: 0px -70px;
  }
}
header .header-chara-wrapper .header-chara.sanemi {
  background: url("../img/sozai/header-sanemi.webp") no-repeat center/contain;
  animation-delay: 1s;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper .header-chara.sanemi {
    background: url("../img/sozai/header-sanemi.webp") no-repeat top/cover;
    background-position: 0px -70px;
  }
}
header .header-chara-wrapper .header-chara.muichiro {
  background: url("../img/sozai/header-muichiro.webp") no-repeat center/contain;
  animation-delay: 1s;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper .header-chara.muichiro {
    background: url("../img/sozai/header-muichiro.webp") no-repeat top/cover;
    background-position: 0px -70px;
  }
}
header .header-chara-wrapper .header-chara.himejima {
  background: url("../img/sozai/header-himejima.webp") no-repeat center/contain;
  animation-delay: 1.2s;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper .header-chara.himejima {
    background: url("../img/sozai/header-himejima.webp") no-repeat top/cover;
    background-position: 0px -70px;
  }
}
header .header-chara-wrapper .header-chara.genya {
  background: url("../img/sozai/header-genya.webp") no-repeat center/contain;
  animation-delay: 1.2s;
}
@media screen and (max-width:650px) {
  header .header-chara-wrapper .header-chara.genya {
    background: url("../img/sozai/header-genya.webp") no-repeat top/cover;
    background-position: 0px -70px;
  }
}
header .animated {
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  animation-name: chara;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
  animation-timing-function: ease-in;
}
header .logo-wrapper {
  opacity: 0;
  display: flex;
  justify-content: center;
  position: absolute;
  bottom: 0;
  background: url("../img/logo/title-webshop2.webp"), linear-gradient(rgba(0, 0, 0, 0) 10%, rgba(0, 0, 0, 0.5) 20%, #000);
  background-position: bottom;
  background-repeat: no-repeat;
  background-size: contain;
  height: min(12.5vw, 240px);
  width: 100%;
  min-height: 110px;
}
header .logo-wrapper.animated {
  animation-name: logo;
  animation-duration: 0.3s;
  animation-fill-mode: forwards;
  animation-timing-function: ease-in;
  animation-delay: 2s;
}
@media screen and (max-width:450px) {
  header .logo-wrapper {
    background: url("../img/logo/title-webshop.webp"), linear-gradient(rgba(0, 0, 0, 0) 10%, rgba(0, 0, 0, 0.4) 30%, #000);
    background-position: bottom;
    background-repeat: no-repeat;
    background-size: contain;
    height: 120px;
    width: 100%;
  }
}

.site-footer-wrap {
  min-width: 1000px;
}
@media screen and (max-width:650px) {
  .site-footer-wrap {
    min-width: unset;
    width: 100%;
  }
}

#goods.site-section-content {
  padding: 0;
  width: 100%;
  overflow: hidden;
}
#goods.site-section-content .site-section-inner {
  padding: 0px;
  margin: 0 12px;
  position: relative;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .site-section-inner {
    padding: 40px 0;
  }
}
#goods.site-section-content .site-section-inner .tab-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 900px;
  margin: 0 auto 16px;
}
#goods.site-section-content .site-section-inner .tab-list .tab-item.tab-item-vol2 {
  background-color: rgba(55, 83, 146, 0.8);
}
#goods.site-section-content .site-section-inner .tab-list .tab-item.tab-item-vol3 {
  background-color: #8b651d;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .site-section-inner .tab-list {
    flex-direction: column;
  }
}
#goods.site-section-content .site-section-inner button {
  background: rgba(143, 64, 21, 0.7137254902);
  padding: 16px 16px;
  margin: 0 4px 8px;
  flex-grow: 1;
  color: #fff;
  border-radius: 45px;
  font-size: 20px;
  position: relative;
  font-weight: 500;
  filter: brightness(0.7);
}
@media screen and (max-width:650px) {
  #goods.site-section-content .site-section-inner button {
    font-size: 16px;
    padding: 8px 15px;
  }
}
@media screen and (max-width:450px) {
  #goods.site-section-content .site-section-inner button {
    font-size: 12px;
  }
}
#goods.site-section-content .site-section-inner button.active {
  border: 2px solid #fff;
  background: rgba(143, 64, 21, 0.7137254902);
  filter: brightness(1);
}
#goods.site-section-content .tab-content {
  display: none;
}
#goods.site-section-content .tab-content.vol2 .goods-card-wrapper .goods-card {
  background-color: rgba(55, 83, 146, 0.8);
}
#goods.site-section-content .tab-content.vol2 .goods-card-wrapper .goods-card .goods-info .webshop-btn a {
  background-color: #8b651d;
}
#goods.site-section-content .tab-content.vol2 .goods-card-wrapper .goods-card .goods-info .webshop-btn a:hover {
  background: #694e1b;
}
#goods.site-section-content .tab-content.vol3 .goods-card-wrapper .goods-card {
  background-color: #8b651d;
}
#goods.site-section-content .tab-content.vol3 .goods-card-wrapper .goods-card .goods-info .webshop-btn a {
  background: #8f4015;
}
#goods.site-section-content .tab-content.vol3 .goods-card-wrapper .goods-card .goods-info .webshop-btn a:hover {
  background: #70300d;
}
#goods.site-section-content .tab-content.active {
  display: block;
}
#goods.site-section-content .heading-h1 {
  margin: 0 auto 80px;
  line-height: 110px;
  font-size: 40px;
  text-align: center;
  color: #ffffff;
  position: relative;
  text-shadow: 0px 0px 6px rgba(83, 74, 66, 0.431372549);
  display: flex;
  justify-content: center;
  margin: 0;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .heading-h1 {
    width: 100%;
    margin: 40px auto 16px;
    line-height: 88px;
    font-size: 32px;
  }
}
@media screen and (max-width:450px) {
  #goods.site-section-content .heading-h1 {
    font-size: 24px;
    height: 80px;
    line-height: 64px;
  }
}
#goods.site-section-content .content-bg {
  padding: 0px;
  max-width: 900px;
  height: auto;
  margin: 0 auto;
  text-align: center;
  font-size: 24px;
  position: relative;
  border-radius: 12px;
  height: auto;
  margin: 0 auto 80px;
  text-align: center;
  font-size: 24px;
  position: relative;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .content-bg {
    width: 100%;
    padding: 0;
  }
}
#goods.site-section-content .content-bg .goods-detail {
  margin-bottom: 24px;
  padding: 0 80px;
  font-size: 16px;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .content-bg .goods-detail {
    padding: 0px;
  }
}
#goods.site-section-content .content-bg .goods-card-wrapper {
  display: flex;
  gap: 24px;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .content-bg .goods-card-wrapper {
    flex-direction: column;
    gap: 0px;
  }
}
#goods.site-section-content .content-bg .goods-card-wrapper.single {
  margin: 0 auto;
  justify-content: center;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .content-bg .goods-card-wrapper.single {
    width: 100%;
  }
}
#goods.site-section-content .content-bg .goods-card {
  position: relative;
  background: rgba(143, 64, 21, 0.7137254902);
  padding: 24px;
  margin-bottom: 24px;
  width: 50%;
  border-radius: 12px;
  color: #ffffff;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .content-bg .goods-card {
    width: 100%;
    margin-bottom: 16px;
    padding: 24px 16px;
  }
}
#goods.site-section-content .content-bg .goods-card .goods-name {
  font-size: 20px;
  margin: 12px 0;
  padding-bottom: 12px;
  border-bottom: 2px solid #ffffff;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .content-bg .goods-card .goods-name {
    font-size: 20px;
    padding-bottom: 8px;
    margin: 8px 0;
  }
}
#goods.site-section-content .content-bg .goods-card .goods-price {
  font-size: 20px;
  margin-bottom: 12px;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .content-bg .goods-card .goods-price {
    margin-bottom: 8px 0;
    font-size: 20px;
  }
}
#goods.site-section-content .content-bg .goods-card .goods-text,
#goods.site-section-content .content-bg .goods-card .goods-size,
#goods.site-section-content .content-bg .goods-card .goods-material {
  margin-bottom: 12px;
  font-size: 16px;
}
#goods.site-section-content .content-bg .webshop-btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 64px;
  text-align: center;
  text-shadow: 0px 0px 6px rgba(83, 74, 66, 0.431372549);
  border-radius: 50px;
  border: 4px solid #fff;
  color: #ffffff;
  background: #556fa8;
  font-size: 18px;
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  transition: 0.5s ease;
  position: relative;
  flex-direction: column;
  color: #fff;
}
#goods.site-section-content .content-bg .webshop-btn-zk {
  margin-bottom: 16px;
}
#goods.site-section-content .content-bg .webshop-btn-zk span {
  font-size: 10px;
}
#goods.site-section-content .content-bg .webshop-btn a:hover {
  background: #34476e;
}
#goods.site-section-content .content-bg .webshop-btn a:hover:before, #goods.site-section-content .content-bg .webshop-btn a:hover:after {
  display: block;
}
#goods.site-section-content .ctl-text {
  margin-bottom: 24px;
}
#goods.site-section-content .ctl-text span {
  color: #be1616;
  font-size: 18px;
  font-weight: bold;
  /* line-height: 25px; */
  background: #fff;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .ctl-text {
    font-size: 18px;
  }
}
#goods.site-section-content .ctlg .contains {
  display: flex;
  justify-content: center;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .ctlg .contains {
    height: 550px;
  }
}
#goods.site-section-content .ctlg .contains .button_move {
  background-color: #b63211;
}
#goods.site-section-content .ctlg .contains .scroll_button {
  border-color: #b63211;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .ctlg .contains .scroll_button {
    height: 20px;
    width: 20px;
  }
}
#goods.site-section-content .ctlg .contains .scroll_next {
  right: -15px;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .ctlg .contains .scroll_next {
    right: 10px;
  }
}
#goods.site-section-content .ctlg .contains .scroll_prev {
  left: -15px;
}
@media screen and (max-width:650px) {
  #goods.site-section-content .ctlg .contains .scroll_prev {
    left: 10px;
  }
}
#goods.site-section-content .ctlg-img {
  display: table-cell;
  height: 100%;
}

.hamburger {
  position: fixed;
  top: 8px;
  right: 15px;
  z-index: 101;
  width: 48px;
  height: 48px;
  border: none;
  background: transparent;
  cursor: pointer;
}

.hamburger__line {
  position: absolute;
  left: 3px;
  width: 42px;
  height: 4px;
  border-radius: 21px;
  background-color: #c2c0c0;
  transition: all 0.4s;
}

.hamburger__line:nth-of-type(1) {
  top: 14px;
}

.hamburger__line:nth-of-type(2) {
  top: 23px;
}

.hamburger__line:nth-of-type(3) {
  top: 32px;
}

/* メニューオープン時 */
.hamburger.active .hamburger__line:nth-of-type(1) {
  transform: translateY(9px) rotate(-45deg);
}

.hamburger.active .hamburger__line:nth-of-type(2) {
  opacity: 0;
}

.hamburger.active .hamburger__line:nth-of-type(3) {
  transform: translateY(-9px) rotate(45deg);
}

.nav {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 300px;
  background-color: rgba(0, 0, 0, 0.8705882353);
  box-shadow: 2px 0 4px rgba(0, 0, 0, 0.1);
  transform: translateY(-100%);
  transition: transform 0.4s;
  z-index: 100;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width:650px) {
  .nav {
    height: 100vh;
  }
}

.nav.active {
  transform: translateY(0);
}

.nav__list {
  margin: 0;
  list-style: none;
  font-size: 24px;
}

.nav__item {
  padding: 0 20px;
}

.nav__link {
  display: block;
  padding: 4px 0;
  margin-bottom: 16px;
  color: #ffffff;
  text-decoration: none;
  transition: 0.5s ease;
  position: relative;
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
.nav__link::after {
  position: absolute;
  bottom: -4px;
  left: 0;
  content: "";
  width: 100%;
  height: 1px;
  background: rgba(255, 255, 255, 0.4196078431);
  transform: scale(0, 1);
  transform-origin: center top;
  transition: transform 0.3s;
}
.nav__link:hover::after {
  transform: scale(1, 1);
}

*,
*::before,
*::after {
  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;
  user-select: none;
  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;
  touch-action: manipulation;
}

body {
  -webkit-overflow-scrolling: touch;
  color: #ffffff;
  font-family: "Zen Old Mincho", serif;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
  position: relative;
}

h1 {
  font-weight: 500;
}

.site-content-wrapper {
  overflow-x: hidden;
  position: relative;
  min-width: 1000px;
  background: url("../img/sozai/bg.webp"), #000;
  background-attachment: fixed;
  background-size: cover;
  background-repeat: no-repeat;
}
@media screen and (max-width:650px) {
  .site-content-wrapper {
    min-width: initial;
  }
}

.red-bold {
  color: rgb(180, 37, 37);
  font-weight: bold;
}
.red-bold.small {
  font-size: 18px;
}

body::-webkit-scrollbar {
  width: 24px;
}

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

body::-webkit-scrollbar-thumb {
  background-color: #8f4015;
  border-radius: 4px;
  height: 80px;
}

.z-index {
  z-index: 10;
}

#illustration {
  /* 画像コンテナ */
  /* 画像 */
  /* 画像を表示するためのクラス */
  /* ナビゲーションコンテナ */
  /* 新しく作成したボタンに追加するクラス */
  /* ボタンの色を変えるためのクラス */
}
#illustration .site-section-inner {
  padding: 120px 0px;
  margin: 0 auto;
  min-width: 1000px;
  height: 1380px;
  background: rgba(12, 12, 12, 0.521);
  background-repeat: repeat;
  padding: 120px 0px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-content: center;
  align-items: center;
}
@media screen and (max-width:650px) {
  #illustration .site-section-inner {
    padding: 40px 0px;
    margin: 0 auto;
    min-width: unset;
    padding: 0 12px;
  }
}
@media screen and (max-width:550px) {
  #illustration .site-section-inner {
    height: 1380px;
  }
}
@media screen and (max-width:450px) {
  #illustration .site-section-inner {
    height: 1200px;
  }
}
#illustration .heading-h1 {
  margin: 0 auto 80px;
  line-height: 110px;
  font-size: 40px;
  text-align: center;
  color: #ffffff;
  position: relative;
  text-shadow: 0px 0px 6px rgba(83, 74, 66, 0.431372549);
  display: flex;
  justify-content: center;
  margin: 0;
}
@media screen and (max-width:650px) {
  #illustration .heading-h1 {
    width: 100%;
    margin: 40px auto 16px;
    font-size: 32px;
    line-height: 88px;
  }
}
@media screen and (max-width:450px) {
  #illustration .heading-h1 {
    font-size: 24px;
    line-height: 64px;
  }
}
#illustration .text {
  text-align: center;
  margin-bottom: 24px;
  font-size: 24px;
}
@media screen and (max-width:650px) {
  #illustration .text {
    font-size: 20px;
  }
}
@media screen and (max-width:450px) {
  #illustration .text {
    font-size: 16px;
  }
}
#illustration .slider-container {
  position: relative;
  display: flex;
  width: 700px;
  height: 1000px;
  align-content: center;
  align-items: center;
  justify-content: flex-end;
}
@media screen and (max-width:650px) {
  #illustration .slider-container {
    height: 860px;
    width: 100%;
    align-content: center;
    align-items: flex-end;
  }
}
@media screen and (max-width:550px) {
  #illustration .slider-container {
    height: 746px;
  }
}
@media screen and (max-width:500px) {
  #illustration .slider-container {
    height: 677px;
  }
}
@media screen and (max-width:450px) {
  #illustration .slider-container {
    height: 604px;
  }
}
@media screen and (max-width:400px) {
  #illustration .slider-container {
    height: 530px;
  }
}
#illustration .image-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
#illustration img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  opacity: 0; /* 透明（非表示）*/
  transition: opacity 0.5s;
}
#illustration img.image-active {
  opacity: 1; /* 不透明（表示）*/
  transition: opacity 0.5s;
}
#illustration .nav-container {
  position: absolute;
  /* bottom: 0; */
  width: 120px;
  right: -135px;
  height: 600px;
  flex-wrap: wrap;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  flex-direction: column;
}
@media screen and (max-width:650px) {
  #illustration .nav-container {
    right: unset;
    position: absolute;
    /* bottom: 0; */
    width: 100%;
    /* right: -135px; */
    /* height: 10%; */
    justify-content: center;
    align-items: flex-end;
    flex-direction: row;
    justify-content: space-evenly;
    bottom: -90px;
    height: 80px;
    /* margin-top: 80px; */
  }
}
#illustration .nav-btn {
  width: 120px;
  height: 80px;
  display: inline-block;
  border: none;
  filter: grayscale(1);
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  cursor: pointer;
}
#illustration .nav-btn.tanjiro-btn {
  background: url("../img/sozai/tanjiro-thumb.webp") no-repeat center/cover;
}
#illustration .nav-btn.zenitsu-btn {
  background: url("../img/sozai/zenitsu-thumb.webp") no-repeat center/cover;
}
#illustration .nav-btn.giyu-btn {
  background: url("../img/sozai/giyu-thumb.webp") no-repeat center/cover;
}
#illustration .nav-btn.shinobu-btn {
  background: url("../img/sozai/shinobu-thumb.webp") no-repeat center/cover;
}
#illustration .nav-btn.inosuke-btn {
  background: url("../img/sozai/inosuke-thumb.webp") no-repeat center/cover;
}
#illustration .nav-btn.kanao-btn {
  background: url("../img/sozai/kanao-thumb.webp") no-repeat center/cover;
}
#illustration .nav-btn.genya-btn {
  background: url("../img/sozai/genya-thumb.webp") no-repeat center/cover;
}
#illustration .nav-btn.muichiro-btn {
  background: url("../img/sozai/muichiro-thumb.webp") no-repeat center/cover;
}
#illustration .nav-btn.mitsuri-btn {
  background: url("../img/sozai/mitsuri-thumb.webp") no-repeat center/cover;
}
#illustration .nav-btn.iguro-btn {
  background: url("../img/sozai/iguro-thumb.webp") no-repeat center/cover;
}
#illustration .nav-btn.sanemi-btn {
  background: url("../img/sozai/sanemi-thumb.webp") no-repeat center/cover;
}
#illustration .nav-btn.himejima-btn {
  background: url("../img/sozai/himejima-thumb.webp") no-repeat center/cover;
}
#illustration .nav-btn.btn-active {
  filter: grayscale(0);
}
#illustration .nav-btn:hover {
  filter: grayscale(0);
}

#goods {
  /* カルーセル内容 */
  /* スライド切り換え用ラジオボタンは常に非表示 */
  /* 各スライド */
  /* 前へ次へボタン */
  /* ホバー時にボタンを強調 */
  /* 前へボタン */
  /* 次へボタン */
  /* スライド移動ボタンエリア */
  /* スライド移動の各ボタン */
  /* スライド移動ボタンの色 */
  /* 1番目のスライド選択時 */
  /* 1番目のスライドの透明度を0にして表示する */
  /* 1番目のスライドの前へ次へボタンの領域を */
}
#goods .carousel {
  /* 水平方向中央寄せ */
  display: flex;
  justify-content: center;
}
#goods .contains {
  width: 100%;
  /* height: 100%; */
  position: relative;
  padding: 0;
  aspect-ratio: 1/1;
  list-style: none;
}
#goods .slide_select {
  display: none;
}
#goods .slide {
  max-width: 100%;
  height: 100%;
  position: absolute;
  /* スライドの初期値は選択されていないので透明にしておく */
  opacity: 0;
}
#goods .scroll_button {
  position: absolute;
  display: block;
  height: 30px;
  width: 30px;
  /* 縦中央から20px上の位置 */
  top: 50%;
  margin-top: -20px;
  /* 上辺と右辺のみ幅5pxの枠線 */
  border-width: 5px 5px 0 0;
  border-style: solid;
  border-color: #b63211;
  cursor: pointer;
  /* 普段はボタンはやや薄くする */
  opacity: 0.7;
  /* スライドよりも前面にする */
  z-index: 3;
}
@media screen and (max-width:650px) {
  #goods .scroll_button {
    height: 24px;
    width: 24px;
  }
}
#goods .vol3 .scroll_button {
  border-color: #b63211;
}
#goods .scroll_button:hover {
  opacity: 1;
}
#goods .scroll_prev {
  left: 15px;
  transform: rotate(-135deg);
}
@media screen and (max-width:650px) {
  #goods .scroll_prev {
    left: 10px;
  }
}
#goods .scroll_next {
  right: 15px;
  transform: rotate(45deg);
}
@media screen and (max-width:650px) {
  #goods .scroll_next {
    right: 10px;
  }
}
#goods .move_controler {
  position: absolute;
  bottom: 0px;
  width: 100%;
  text-align: center;
}
#goods .button_move {
  display: inline-block;
  height: 12px;
  width: 12px;
  margin: 0 2px;
  border-radius: 100%;
  cursor: pointer;
  opacity: 0.5;
  z-index: 2;
}
#goods .button_move:hover {
  opacity: 0.75;
}
#goods .button_move {
  background-color: #b63211;
}
#goods .vol3 .button_move {
  background-color: #b63211;
}
#goods .slide_select:nth-of-type(1):checked ~ .slide:nth-of-type(1) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(1):checked ~ .move_controler .button_move:nth-of-type(1) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(2):checked ~ .slide:nth-of-type(2) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(2):checked ~ .move_controler .button_move:nth-of-type(2) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(3):checked ~ .slide:nth-of-type(3) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(3):checked ~ .move_controler .button_move:nth-of-type(3) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(4):checked ~ .slide:nth-of-type(4) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(4):checked ~ .move_controler .button_move:nth-of-type(4) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(5):checked ~ .slide:nth-of-type(5) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(5):checked ~ .move_controler .button_move:nth-of-type(5) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(6):checked ~ .slide:nth-of-type(6) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(6):checked ~ .move_controler .button_move:nth-of-type(6) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(7):checked ~ .slide:nth-of-type(7) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(7):checked ~ .move_controler .button_move:nth-of-type(7) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(8):checked ~ .slide:nth-of-type(8) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(8):checked ~ .move_controler .button_move:nth-of-type(8) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(9):checked ~ .slide:nth-of-type(9) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(9):checked ~ .move_controler .button_move:nth-of-type(9) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(10):checked ~ .slide:nth-of-type(10) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(10):checked ~ .move_controler .button_move:nth-of-type(10) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(11):checked ~ .slide:nth-of-type(11) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(11):checked ~ .move_controler .button_move:nth-of-type(11) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(12):checked ~ .slide:nth-of-type(12) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(12):checked ~ .move_controler .button_move:nth-of-type(12) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(13):checked ~ .slide:nth-of-type(13) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(13):checked ~ .move_controler .button_move:nth-of-type(13) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(14):checked ~ .slide:nth-of-type(14) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(14):checked ~ .move_controler .button_move:nth-of-type(14) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(15):checked ~ .slide:nth-of-type(15) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(15):checked ~ .move_controler .button_move:nth-of-type(15) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(16):checked ~ .slide:nth-of-type(16) {
  opacity: 1;
}
#goods .slide_select:nth-of-type(16):checked ~ .move_controler .button_move:nth-of-type(16) {
  opacity: 1;
}

#loading {
  position: fixed;
  inset: 0;
  z-index: 9999;
  place-items: center;
  height: 100%;
  background-color: black;
}

.loading-area {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  align-items: center;
  position: relative;
}
.loading-area .logo-movie {
  background: url("../img/logo/logo-movie.webp") no-repeat center/contain;
  width: 480px;
  height: 400px;
  margin-bottom: 24px;
  animation-name: opacity;
  animation-duration: 0.5s;
  animation-delay: 2s;
  animation-fill-mode: forwards;
  animation-timing-function: ease-in;
}
@media screen and (max-width:650px) {
  .loading-area .logo-movie {
    width: 240px;
    height: 240px;
    margin-bottom: 0px;
  }
}

h1 {
  font-size: 40px;
  text-align: center;
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
  animation-name: opacity;
  animation-duration: 0.5s;
  animation-delay: 2s;
  animation-fill-mode: forwards;
  animation-timing-function: ease-in;
}
@media screen and (max-width:650px) {
  h1 {
    font-size: 20px;
  }
}

#link {
  padding: 160px 0px;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
}
@media screen and (max-width:650px) {
  #link {
    padding: 80px 12px;
  }
}
#link .btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 64px;
  text-align: center;
  text-shadow: 0px 0px 6px rgba(83, 74, 66, 0.431372549);
  border-radius: 50px;
  border: 4px solid #fff;
  color: #ffffff;
  background: #556fa8;
  font-size: 18px;
  margin-top: 50px;
  width: 500px;
  height: 100px;
  display: table;
  position: relative;
  transition: 0.7s cubic-bezier(0.4, 0.4, 0, 1);
}
@media screen and (max-width:650px) {
  #link .btn {
    width: 100%;
  }
}
@media (hover: hover) and (pointer: fine) {
  #link .btn:hover {
    background-color: #8b651d;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active) {
  #link .btn:hover {
    background-color: #8b651d;
  }
}
#link .btn a {
  color: #ffffff;
  display: table-cell;
  vertical-align: middle;
  text-align: center;
}
#link p {
  text-align: center;
}/*# sourceMappingURL=style.css.map */