@charset "euc-jp";

html {
  scroll-behavior: smooth;
  animation: scrollseal 0s 2.5s both;
}
@keyframes scrollseal {
from { overflow: hidden }
to { overflow: visible }
}



/* ==============================================================================
  reset
============================================================================== */

:root {
  /* area */
  --max-width: 1490px;
  --main-color: #68C9F3;
  --sub-color: #E4006E;
  --accent-color: #4E74D5;
  --bg-color: #FFF9E4;
  --text-color: #070707;
  --gradation--color: rgba(255, 215, 140, 1), rgba(255, 248, 192, 1), rgba(255, 215, 140, 1);
  --text-size-48: 48px;
  --text-size-40: 40px;
  --text-size-24: 24px;
  --text-size-18: 18px;
  --text-size-14: 14px;
  --text-height: 1.6;
  --margin-120: 120px;
  --margin-80: 80px;
  --margin-56: 56px;
  --margin-48: 48px;
  --margin-40: 40px;
  --margin-32: 32px;
  --margin-24: 24px;
  --margin-16: 16px;
}

ol { list-style: none;}

.sp_only {
  display: none !important;
}

#templateWrap #templateFlame #headline *,
#templateWrap #templateFlame #bodyClump * {
  margin: 0;
  padding: 0;
  background: none;
}
#templateWrap #templateFlame #headline .area img,
#templateWrap #templateFlame #bodyClump .area img {
  width: 100%;
}

/* ==============================================================================
  templateFlame
============================================================================== */

#templateWrap {
  background: linear-gradient(70deg, var(--gradation--color));
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 900;
  font-style: normal;
}

#templateWrap #templateFlame {
  width: 100%;
  margin: 0;
  padding: 0;
  background: linear-gradient(70deg, rgba(255, 215, 140, 0.8), rgba(255, 248, 192, 0.8), rgba(255, 215, 140, 0.8), rgba(255, 248, 192, 0.8), rgba(255, 215, 140, 0.8), rgba(255, 248, 192, 0.8), rgba(255, 215, 140, 0.8), rgba(255, 248, 192, 0.8), rgba(255, 215, 140, 0.8), rgba(255, 248, 192, 0.8), rgba(255, 215, 140, 0.8), rgba(255, 248, 192, 0.8), rgba(255, 215, 140, 0.8), rgba(255, 248, 192, 0.8), rgba(255, 215, 140, 0.8), rgba(255, 248, 192, 0.8)), url("https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/bg-base-pattern.png") repeat top center / 5%;
  overflow: clip;
    -webkit-animation-name: fade;
          animation-name: fade;
  -webkit-animation-duration: 2s;
          animation-duration: 2s;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1; /* 回数指定 */
}

@-webkit-keyframes fade {
  0%{
    opacity: 0;
  }
  100%{
    opacity: 1;
  }
}
@keyframes fade {
  0%{
    opacity: 0;
  }
  100%{
    opacity: 1;
  }
}

#templateWrap #templateFlame * {
  box-sizing: border-box;
}

/* ==============================================================================
  headline
============================================================================== */

#templateWrap #templateFlame #headline {
  padding: 0 0 40%;
  overflow: hidden;
}

/* ==============================================================================
  scrolltext
============================================================================== */

#templateWrap #templateFlame #headline .scrollbox {
  position: relative;
}
#templateWrap #templateFlame #headline .scrolltext {
  font-size: var(--text-size-24);
  writing-mode: vertical-rl;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%) translateY(8%);
  color: #222;
  padding: 0 0 8%;
  margin: 4% 0;
}
#templateWrap #templateFlame #headline .scrolltext::after {
  content : '';
  display : inline-block;
  position : absolute;
  background-color: #222;
  right : 50%;
  bottom : 0;
  transform : translateX(-50%);
  width : 1px;
  height : 100px;
  animation: scroll 1.5s infinite;
}
@keyframes scroll {
0% {
  transform: scale(1, 0);
  transform-origin: 0 0;
}
50% {
  transform: scale(1, 1);
  transform-origin: 0 0;
}
50.1% {
  transform: scale(1, 1);
  transform-origin: 0 100%;
}
100% {
  transform: scale(1, 0);
  transform-origin: 0 100%;
}
}

/* ==============================================================================
  area__main
============================================================================== */

#templateWrap #templateFlame #headline .area__main--inner {
  position: relative;
  z-index: 1;
}
#templateWrap #templateFlame #headline .area__main--inner .base_img {
  margin: 0 auto;
  width: 56%;
}
#templateWrap #templateFlame #headline .area__main--inner .logo {
  position: relative;
  width: 32%;
  margin: 0 auto;
  padding: 4% 0 2%;
  z-index: 1;
}
#templateWrap #templateFlame #headline .area__main--inner h1,
#templateWrap #templateFlame #headline .area__main--inner .period,
#templateWrap #templateFlame #headline .area__main--inner .character,
#templateWrap #templateFlame #headline .area__main--inner [class^="deco_"] {
  position: absolute;
}
#templateWrap #templateFlame #headline .area__main--inner h1 img,
#templateWrap #templateFlame #headline .area__main--inner .period img,
#templateWrap #templateFlame #headline .area__main--inner .character img,
#templateWrap #templateFlame #headline .area__main--inner [class^="deco_"] img {
  display: block;
}
#templateWrap #templateFlame #headline .area__main--inner .character {
  top: 18%;
  left: 1%;
  right: 0;
  width: 56%;
  margin: 0 auto;
  z-index: 3;
}
#templateWrap #templateFlame #headline .area__main--inner h1 {
  top: 70%;
  left: 0;
  right: 0;
  width: 40%;
  margin: 0 auto;
  z-index: 4;
}
#templateWrap #templateFlame #headline .area__main--inner .period {
  top: 99.6%;
  left: 0;
  right: 0;
  width: 24%;
  margin: 0 auto;
  z-index: 5;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_01 {
  top: 28%;
  right: 4%;
  z-index: 4;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_02 {
  top: 28%;
  left: 4%;
  z-index: 3;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_03 {
  width: 100%;
  top: 28%;
  left: 0;
  z-index: 2;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_03 .rooptext {
  width: 100%;
  height: 208px;
  background: url("https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/main-deco-03.png") repeat-x 0 0 / auto 100%;
  animation: bg-slider 90s linear infinite;
}
@keyframes bg-slider {
  from {
    background-position: 0 0;
  }
  to {
    background-position: -4050px 0;
  }
}

#templateWrap #templateFlame #headline .area__main--inner .deco_04_a {
  width: 22%;
  top: 28%;
  left: 0;
  z-index: 1;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_04_b { 
  width: 22%;
  top: 38%;
  right: 0;
  z-index: 3;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_05 {
  width: 48%;
  top: -5%;
  left: 0;
  z-index: -1;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_06 {
  width: 48%;
  top: -8%;
  right: 0;
  z-index: -1;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_07 {
  width: 56%;
  top: 75%;
  right: -6%;
  z-index: -1;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_08 {
  width: 48%;
  top: 11%;
  right: -5%;
  z-index: -1;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_09 {
  width: 40%;
  top: -1%;
  left: 0;
  z-index: -1;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_10 {
  top: 42%;
  right: 0;
  z-index: -1;
  width: 64%;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_11 {
  top: 71%;
  left: 0;
  z-index: -1;
  width: 48%;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_12 {
  top: 40%;
  left: 0;
  z-index: -1;
  width: 64%; 
}
#templateWrap #templateFlame #headline .area__main--inner .deco_13 {
  width: 50%;
  top: 44%;
  left: 0;
  z-index: -1;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_14 {
  width: 50%;
  top: 8%;
  left: 0;
  right: 0;
  margin: 0 auto;
  z-index: 0;
}
#templateWrap #templateFlame #headline .area__main--inner .deco_15 {
  top: 10%;
  left: 0;
  width: 40%;
  z-index: -1;
  transform: scale(-1, 1);
}
#templateWrap #templateFlame #headline .area__main--inner .deco_16 {
  top: 0;
  right: 0;
  width: 70%;
  z-index: -1;
  transform: scale(-1, 1);
}

/* ==============================================================================
  bodyClump
============================================================================== */

#templateWrap #templateFlame #bodyClump {
  margin: -59% 0 0 0;
}


/* ==============================================================================
  h-menu
============================================================================== */

#templateWrap #templateFlame #bodyClump #nav-floating {
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 999;
}
#templateWrap #templateFlame #bodyClump .h-menu {
  position: relative;
  padding: 24px 24px 88px 88px;
  background: url(https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/nav-base.png) no-repeat top right / 100%;
  box-sizing: border-box;
}
/*inputのcheckboxは非表示に*/
#templateWrap #templateFlame #bodyClump .h-menuCheckbox {
  display: none;
}

/*ハンバーガーメニュー*/
#templateWrap #templateFlame #bodyClump .h-menu_icon {
  display: inline-block;
  width: 38px;
  height: 38px;
  vertical-align: middle;
  cursor: pointer;
  position: relative;
  z-index: 100;
  padding: 32px;
}
/* #templateWrap #templateFlame #bodyClump .h-menu_icon::after {
  content: "MENU";
  font-size: 11px;
  position: absolute;
  bottom: -4px;
  color: #fff;
  letter-spacing: 0.05em;
} */

/*3本線*/
#templateWrap #templateFlame #bodyClump .hamburger-icon,
#templateWrap #templateFlame #bodyClump .hamburger-icon::before,
#templateWrap #templateFlame #bodyClump .hamburger-icon::after {
  content: '';
  display: block;
  position: absolute;
  z-index: 100;
  top: 24px;
  width: 38px;
  height: 3px;
  background: var(--text-color);
  cursor: pointer;
  border-radius: 1.5px;
  right: 12px;
}
#templateWrap #templateFlame #bodyClump .hamburger-icon:before {
  top: 16px;
  right: 0;
}
#templateWrap #templateFlame #bodyClump .hamburger-icon:after {
  top: 8px;
  right: 0;
}

/*メニュー以外を暗くする*/
#templateWrap #templateFlame #bodyClump #h-menu_black {
  display: none;
  position: fixed;
  z-index: 98;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: .3s ease-in-out;
  background-color: rgb(17, 17, 17);
}

/*中身*/
#templateWrap #templateFlame #bodyClump #h-menu_content {
  transition: .1s ease-in-out;
  -webkit-transform: translateX(100vw);
  transform: translateX(100vw);
  position: fixed;
  top: 0;
  right: 0;
  z-index: 99;
  width: 400px;
  height: 100vh;
  overflow: auto;
  transition: .1s ease-in-out;
  box-sizing: border-box;
}

/*チェックボックスにチェックが入ったら表示*/
#templateWrap #templateFlame #bodyClump .h-menu input:checked ~ .h-menu_icon .hamburger-icon {
  background: transparent!important ;
  box-shadow: unset;
}
#templateWrap #templateFlame #bodyClump .h-menu input:checked ~ .h-menu_icon .hamburger-icon::before {
  /* background: #fff; */
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  top: 16px !important;
  z-index: 999;
  box-shadow: unset;
  background: #fff;
}
#templateWrap #templateFlame #bodyClump .h-menu input:checked ~ .h-menu_icon .hamburger-icon::after {
  /* background: #fff; */
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 16px !important;
  z-index: 999;
  box-shadow: unset;
  background: #fff;
}

/*カバーを表示*/
#templateWrap #templateFlame #bodyClump .h-menu input:checked ~ #h-menu_black { 
  display: block;
  opacity: .8;
}
#templateWrap #templateFlame #bodyClump #h-menu_checkbox:checked ~ #h-menu_content {
  -webkit-transform: translateX(0%);
  transform: translateX(0);
  /* box-shadow: -2px 0 20px rgba(0, 0, 0, .15); */
}
#templateWrap #templateFlame #bodyClump #h-menu_checkbox:checked ~ .h-menu_icon::after {
  display: none;
}
#templateWrap #templateFlame #bodyClump .h-menu_icon .hamburger-icon,
#templateWrap #templateFlame #bodyClump .h-menu_icon .hamburger-icon::before,
.h-menu_icon .hamburger-icon::after,
#h-menu_black,
#h-menu_content {
  -webkit-transition: all .4s;
  transition: all .3s;
}

/* メニューの中身css  */
#templateWrap #templateFlame #bodyClump #h-menu_content ul li a {
  display: block;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  transition-duration: 0.2s;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre > ul {
  padding: 160px 0 0;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre > ul > li {
  margin: 0 0 16px;
  overflow: hidden;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre > ul > li > a {
  display: block;
  transition-duration: 0.3s;
  transition-property: all;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre > ul > li > a:hover {
  transform: translate(8px,0);
  filter: brightness(110%);
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre > ul > li > a img {
  width: 100%;
}
/* #templateWrap #templateFlame #bodyClump #h-menu_content .navgenre .onpage p {
  margin: 0 4vw;
  box-sizing: border-box;
  padding: 6vw 0 0;
  color: #fff;
  font-size: 3.5vw;
  font-size: min(3.5vw,16px);
  font-weight: bold;
  text-decoration: none;
  transition-duration: 0.2s;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre .onpage a {
  padding: 6vw 0 2vw;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre .onpage .navlist {
    margin: 0 0 6vw 0;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre .onpage .navlist li a {
  margin: 4vw;
  box-sizing: border-box;
  padding: 0 0 2vw;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre .onpage .navlist li a {
  position: relative;
  margin: 4vw 4vw;
  padding: 0 0 0 6vw;
  border: none;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre .onpage .navlist li a::after {
  display: block;
  content: "";
  width: 4vw;
  height: 0.2vw;
  background: #fff;
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: rotate(0);
  transform: rotate(0);
  margin-top: 0;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre .onpage .navlist li a::before {
  display: none;
} */



#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre > ul > li > a span {
  display: block;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre > ul > li > a span + span {
  margin: 4vw 0 0 0;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre > ul > li > a span + span img {
  max-width: 80%;
  max-height: 24vw;
}



#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre > ul > li .navlist {
  margin: 0 4vw 4vw;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre > ul > li .navlist a {
  padding: 0 3vw 4vw 5vw;
  position: relative;
}
#templateWrap #templateFlame #bodyClump #h-menu_content .navgenre > ul > li .navlist a::before {
  display: block;
  content: "";
  width: 2vw;
  height: 0.4vw;
  background: #fff;
  position: absolute;
  top: 2.6vw;
  left: 0;
}



/* ==============================================================================
  area__nav
============================================================================== */

#templateWrap #templateFlame #bodyClump .area__nav--inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 0 5% 12%;
}
#templateWrap #templateFlame #bodyClump .area__nav--inner ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 40%;
}
#templateWrap #templateFlame #bodyClump .area__nav--inner li {
  width: 50%;
  margin: 0 0 4%;
}
#templateWrap #templateFlame #bodyClump .area__nav--inner li:nth-child(2n) {
  transform: translate(-42%, 58%);
}
#templateWrap #templateFlame #bodyClump .area__nav--inner ul + ul {
  flex-direction: row-reverse;
  justify-content: flex-start;
}
#templateWrap #templateFlame #bodyClump .area__nav--inner ul + ul li:nth-child(2n) {
  transform: translate(42%, 58%);
}

/* ==============================================================================
  area__side
============================================================================== */

#templateWrap #templateFlame #bodyClump .area__side .area__side--inner {
  position: fixed;
  right: 0;
  bottom: 16px;
  z-index: 90;
  display: none;
  transition-duration: 0.3s;
  transition-property: all;
}
#templateWrap #templateFlame #bodyClump .area__side .area__side--inner.topbtn {
  width: 140px;
  right: 16px;
  bottom: -4px;
}
#templateWrap #templateFlame #bodyClump .area__side .area__side--inner.marathonbtn {
  right: 172px;
  bottom: -4px;
  width: 188px;
}
#templateWrap #templateFlame #bodyClump .area__side .area__side--inner a {
  display: block;
}

/* ==============================================================================
  area__contents
============================================================================== */

#templateWrap #templateFlame #bodyClump [class^="area__contents"] {
  margin: 0 0 16%;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] .sticky-element {
  position: sticky;
  top: 0;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  /* align-items: center; */
  position: relative;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"].rev {
  flex-direction: row-reverse;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"]::after {
  display: block;
  content: "";
  background: url(https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/main-deco-13.png) no-repeat top center / 100%;
  width: 100%;
  height: 100%;
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_01 {
  width: 30%;
  z-index: 2;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_01 .lead {
  position: absolute;
  z-index: -1;
  width: 50%;
  left: 5%;
  top: 22%;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"].rev .box_01 .lead {
  left: 42%;
  top: 22%;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_01 .main-character {
  position: relative;
  transform: translate(23%,-12%);
  width: 100%;
  z-index: 1;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"].rev .box_01 .main-character {
  transform: translate(-38%,-10%);
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_01 h2 {
  width: 108%;
  transform: translate(8%,26%) rotate(-5deg);
  z-index: 3;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"].rev .box_01 h2 {
  transform: translate(-26%,26%) rotate(5deg);
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_01 .period {
  background: url(https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/period-base.png) no-repeat top left / 100%;
  padding: 9% 4% 24%;
  transform: translate(0,-41%);
  width: 110%;
  font-size: 1.3vw;
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  position: absolute;
  top: 100%;
  left: 0;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"].rev .box_01 .period {
  background: url(https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/period-base-02.png) no-repeat top left / 100%;
  transform: translate(-9%,-41%);
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_01 .period dt {
  background: #f5e7bd;
  text-align: center;
  padding: 2.4% 4% 2%;
  border-radius: 30px;
  margin: 0 4% 0 0;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_01 .period dd {
  color: #fff;
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 {
  background: var(--bg-color);
  position: relative;
  width: 70%;
  padding: 6% 6% 6% 8%;
  border-radius: 80px 0 0 80px;
  box-shadow: 0 8px 32px 0 rgba(0,0,0,0.1);
  z-index: 1;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"].rev .box_02 {
  background-position: top left;
  border-radius: 0 80px 80px 0;
  padding: 6% 8% 6% 6%;
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .bg-image-loop {
  position: absolute;
  top: 0;
  right: 0;
	height: 100%;
	width: 280px; /* 画像の高さを指定 */
	background: url(https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/pattern-01.png) repeat-y 0 0;
	background-size: 100% auto;
	animation: bg-slider-02 23s linear infinite; /* 23sの部分背景画像の約数だとスムーズ */
	padding: 0;
  z-index: 1;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"].rev .box_02 .bg-image-loop {
  right: unset;
  left: 0;
}
@keyframes bg-slider-02 {
	from { background-position: 0 0; }
    to { background-position: 0 844px; } /* 1518pxとは使用した背景画像の長さ */
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 h3 {
  font-size: clamp(1.75rem, 0.845rem + 1.52vw, 2.75rem);
  line-height: var(--text-height);
  text-align: center;
  padding: 0 0 8%;
  letter-spacing: -0.1rem;
  position: relative;
  z-index: 2;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 h3 span {
  font-size: 1.6rem;
  display: block;
  margin: 0;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item .text-box h4 {
  font-weight: 700;
  font-size: clamp(1.375rem, 1.149rem + 0.38vw, 1.625rem);
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item .text-box h4 span {
  font-size: 80%;
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: left;
  position: relative;
  z-index: 2;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 ul li {
  position: relative;
  width: 46%;
  background: url(https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/item-base.png) no-repeat center / 100%;
  margin: 2%;
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item {
  position: relative;
  background: url(https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/item-base-02.png) no-repeat top center / contain;
  padding: 0 4%;
  margin: 0 4%;
  z-index: 2;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item + .item {
  margin-top: 8%;
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item .item-img {
  margin: -3% auto 0;
  width: 80%;
}
#templateWrap #templateFlame #bodyClump .area__contents04 [class$="--inner"] .box_02 .item .item-img {
  width: 64%;
  margin: 0 auto;
}
#templateWrap #templateFlame #bodyClump .area__contents05 [class$="--inner"] .box_02 .item .item-img {
  width: 72%;
  margin: 0% auto;
  padding: 16% 0 0 0;
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item .item-name {
  padding-top: 8%;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item .group-name {
  position: absolute;
  top: 0;
  left: 0;
  padding: 8% 0 0 0;
}
/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item .text-box {
  width: 100%;
  text-align: center;
  padding: 4%;
  background: #FFFBEF;
  border-radius: 40px;
  font-size: var(--text-size-18);
  color: #333;
  line-height: var(--text-height);
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item div + .small-text + .text-box {
  margin-top: -6%;
}

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item .text-box p {
  background: #685B32;
  color: #fff;
  margin: 2% 0;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item .text-box .detailanchor {
  width: 230px;
  margin: 2% auto 3%;
  background: none;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item .text-box .detailanchor a {
  display: block;
  padding: 0.5% 1% 1%;
  border-radius: 23px;
  font-size: 14px;
  background: #f4e7bd;
  text-decoration: none;
  color: #685b32;
  transition-duration: 0.3s;
  transition-property: all;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item .text-box .detailanchor a:hover {
  background: #685b32;
  color: #f4e7bd;
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item-button {
  position: absolute;
  right: 0;
  bottom: -5%;
  width: 34%;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item .item-button {
  width: 28%;
  right: 0;
  bottom: 0;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .item-button a {
  display: block;
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .comingsoon {
  margin: 8% 8% 0;
  position: relative;
  z-index: 2;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item + .comingsoon {
  margin-top: 8%;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] h3 + .comingsoon {
  margin-top: 0;
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .small-text {
  font-size: var(--text-size-14);
  font-size: clamp(0.75rem, 0.524rem + 0.38vw, 1rem);
  font-weight: 500;
  line-height: 1.4;
  color: #333;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 ul + .small-text {
  margin-top: 4%;
  text-align: center;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item div + .small-text {
  padding: 4% 0 10%;
  text-align: center;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .item .text-box .small-text {
  background: none;
  font-size: var(--text-size-14);
  color: #685B32;
  text-align: left;
}

#templateWrap #templateFlame #bodyClump .area__contents07 [class$="--inner"] .small-text {
  text-align: center;
  margin: 8% 0 0;
}
#templateWrap #templateFlame #bodyClump .area__contents07 [class$="--inner"] .box_02 .item .item-img {
  padding: 3% 0 16%;
  width: 100%;
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .end-campaign {
  margin: 8% 8% 0;
  position: relative;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_02 .end-campaign::after {
  display: block;
  content: "";
  width: 100%;
  height: 100%;
  background: url(https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250726/campaign-end-text.png) no-repeat center / 50% rgba(0,0,0,0.65);
  position: absolute;
  top: -4%;
  left: 0;
  padding: 4% 0;
  z-index: 3;
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .deco_05 {
  position: absolute;
  z-index: 0;
  top: -440px;
  left: -2%;
  width: 72%;
  padding: 4% 0;
}
#templateWrap #templateFlame #bodyClump .area__contents02 [class$="--inner"] .deco_05,
#templateWrap #templateFlame #bodyClump .area__contents04 [class$="--inner"] .deco_05,
#templateWrap #templateFlame #bodyClump .area__contents06 [class$="--inner"] .deco_05,
#templateWrap #templateFlame #bodyClump .area__contents08 [class$="--inner"] .deco_05  {
  top: -460px;
}

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .deco_07 {
  position: absolute;
  z-index: 0;
  top: -420px;
  right: 0;
  width: 64%;
}
#templateWrap #templateFlame #bodyClump .area__contents02 [class$="--inner"] .deco_07,
#templateWrap #templateFlame #bodyClump .area__contents04 [class$="--inner"] .deco_07,
#templateWrap #templateFlame #bodyClump .area__contents06 [class$="--inner"] .deco_07,
#templateWrap #templateFlame #bodyClump .area__contents08 [class$="--inner"] .deco_07  {
  top: -360px;
  width: 72%;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .deco_12 {
  position: absolute;
  z-index: 0;
  top: -440px;
  width: 100%;
  left: 0;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .deco_13 {
  position: absolute;
  z-index: 0;
  top: -540px;
  right: 0;
  width: 100%;
  opacity: 0.8;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .deco_13 img {
  transform: scale(-1, 1);
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump .area__contents_ct [class$="--inner"] .deco_05 {
  top: -24%;
  width: 56%;
  padding: 0;
}
#templateWrap #templateFlame #bodyClump .area__contents_ct [class$="--inner"] .deco_07 {
  top: -140%;
  width: 72%;
}
#templateWrap #templateFlame #bodyClump .area__contents_ct [class$="--inner"] .deco_13 {
  top: -173%;
  left: 190px;
  right: unset;
  width: 80%; 
}

/*==================================================================*/

#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .box_03 {
  position: absolute;
  top: 0;
  right: 0;
  width: 70%;
  z-index: 0;
}

/* ==============================================================================
  area__movie
============================================================================== */

#templateWrap #templateFlame #bodyClump .area__movie {
  background: url(https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/movie-deco-01.png) no-repeat top right / auto 100%, url(https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/movie-deco-02.png) no-repeat top left / auto 100%, #171717;
}
#templateWrap #templateFlame #bodyClump .area__movie--inner {
  background: url(https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/movie-deco-03.png) no-repeat center / 100%;
  padding: 12% 8%;
}
#templateWrap #templateFlame #bodyClump .area__movie--inner .flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
#templateWrap #templateFlame #bodyClump .area__movie--inner .flex .box_01 {
  width: 35%;
  padding: 0 8% 0 0;
}
#templateWrap #templateFlame #bodyClump .area__movie--inner .flex .box_02 {
  width: 65%;
}
#templateWrap #templateFlame #bodyClump .area__movie--inner .flex .box_02 .movie {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}
#templateWrap #templateFlame #bodyClump .area__movie--inner .flex .box_02 .movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#templateWrap #templateFlame #bodyClump .area__movie--inner h2 {
  margin-bottom: 8%;
}

/* ==============================================================================
  area__banner
============================================================================== */

#templateWrap #templateFlame #bodyClump .area__banner {
  background: #0c0c0c;
  padding: 12% 8%;
}
#templateWrap #templateFlame #bodyClump .area__banner--inner {
  max-width: 1200px;
  margin: 0 auto;
}
#templateWrap #templateFlame #bodyClump .area__banner li {
  text-align: center;
}
#templateWrap #templateFlame #bodyClump .area__banner a {
  display: inline-block;
  -webkit-transform: scale(1) rotate(0deg);
  transform: scale(1) rotate(0deg);
  transition-duration: 0.3s;
  transition-property: all;
}
#templateWrap #templateFlame #bodyClump .area__banner a:hover {
  -webkit-transform: scale(1.05) rotate(0deg);
  transform: scale(1.05) rotate(0deg);
  filter: brightness(110%);
}
#templateWrap #templateFlame #bodyClump .area__banner img {
  max-width: max-content;
}

/* ==============================================================================
  area__panda
============================================================================== */

#templateWrap #templateFlame #bodyClump .area__panda {
  background: #E8FAFF;
}
#templateWrap #templateFlame #bodyClump .area__panda--inner {
  position: relative;
  padding: 8% 16%;
  margin: 0 auto;
}
/* #templateWrap #templateFlame #bodyClump .area__panda--inner::after {
  display: block;
  content: "";
  width: 40.6%;
  height: 75%;
  position: absolute;
  top: 22%;
  left: 3%;
  background: #D2F6FF;
  border-radius: 50%;
  z-index: 1;
} */
#templateWrap #templateFlame #bodyClump .area__panda--inner h2 {
  position: relative;
  width: 535px;
  margin: 4% auto -4%;
  z-index: 3;
}
#templateWrap #templateFlame #bodyClump .area__panda--inner .flex {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  z-index: 2;
}
#templateWrap #templateFlame #bodyClump .area__panda--inner .flex .box_01 {
  width: 40%;
  background: #D2F6FF;
  padding: 6%;
  border-radius: 50%;
}
#templateWrap #templateFlame #bodyClump .area__panda--inner .flex .box_02 {
  width: 60%;
  background: #fff;
  border-radius: 40px;
  padding: 4%;
  border: 8px solid #6BDCFB;
  line-height: var(--text-height);
  font-size: var(--text-size-14);
  color: #333;
  transform: translate(-7%,0);
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .item-button a {
  -webkit-transform: scale(1) rotate(0deg);
  transform: scale(1) rotate(0deg);
    transition-duration: 0.3s;
    transition-property: all;
}
#templateWrap #templateFlame #bodyClump [class^="area__contents"] [class$="--inner"] .item-button a:hover {
  -webkit-transform: scale(1.05) rotate(0deg);
  transform: scale(1.05) rotate(0deg);
  filter: brightness(110%);
}

/* ==============================================================================
  area__campaign
============================================================================== */

#templateWrap #templateFlame #bodyClump .area__campaign {
  background: #fff;
  padding: 0 80px;
}
#templateWrap #templateFlame #bodyClump .area__campaign--inner {
  max-width: 1490px;
  margin: 0 auto;
  padding: 80px;
  line-height: 1.6;
}
#templateWrap #templateFlame #bodyClump .area .area__comingsoon .area__comingsoon--inner p {
  font-size: 32px;
  line-height: 1.4;
}

#templateWrap #templateFlame #bodyClump .area__campaign--inner .rbcomp__campaign__h2.bw.reverse {
  padding: 24px;
  color: #ffffff;
  font-size: 100%;
  text-align: center;
  border: none;
  box-sizing: border-box;
  background: #312c2b;
  margin: 0;
  font-family: unset;
}
#templateWrap #templateFlame #bodyClump .area__campaign--inner .rbcomp__campaign__h2::after {
  display: none;
}
#templateWrap #templateFlame #bodyClump .area__campaign--inner .rbcomp__campaign__h3-accordion {
  display: flex;
  flex-wrap: wrap;
  justify-content: left;
  align-items: center;
  padding: 32px 0;
  border-bottom: 1px solid #aeaeae;
}
#templateWrap #templateFlame #bodyClump .area__campaign--inner .rbcomp-acc-title {
  width: 30%;
  background: none;
  color: #333333;
  font-weight: bold;
}
#templateWrap #templateFlame #bodyClump .area__campaign--inner .rbcomp-acc-title h3 {
  font-size: 14px;
  color: #312c2b;
  padding: 0 32px;
    font-family: unset;
  text-align: left;
  margin: 0;
}
#templateWrap #templateFlame #bodyClump .area__campaign--inner .rbcomp-acc-content {
  width: 70%;
  color: #333333;
  padding: 0 32px;
  box-sizing: border-box;
}
#templateWrap #templateFlame #bodyClump .area__campaign--inner .rbcomp-acc-content .rbcomp__campaign__h3-accordion-txt {
  font-size: 14px;
  color: #333;
  font-weight: 500;
}

/* ==============================================================================
  add css
============================================================================== */

#templateWrap #templateFlame #bodyClump .area__nav--inner li a {
  display: block;
  transition-duration: 0.3s;
  transition-property: all;
}
#templateWrap #templateFlame #bodyClump .area__nav--inner li img {
  cursor: pointer;
}
#templateWrap #templateFlame #bodyClump .area__nav--inner li a:hover {
  -webkit-transform: scale(1.05) rotate(0deg);
  transform: scale(1.05) rotate(0deg);
  filter: brightness(110%);
}


/* ==============================================================================
  add css
============================================================================== */



#templateWrap #templateFlame #bodyClump [class^="area__contents"] {
  background: url(https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/main-deco-12.png) no-repeat top 80% left / 70%;
}
#templateWrap #templateFlame #bodyClump .area__contents02,
#templateWrap #templateFlame #bodyClump .area__contents04,
#templateWrap #templateFlame #bodyClump .area__contents06,
#templateWrap #templateFlame #bodyClump .area__contents08 {
  background: url(https://image.books.rakuten.co.jp/books/img/event/all/kimetsu/20250714/img/main-deco-10.png) no-repeat top 40% right / 70%;
}




/* ==============================================================================
  area__contents_ct
============================================================================== */

#templateWrap #templateFlame #bodyClump .area__contents_ct {
  position: relative;
  margin: 0;
}
#templateWrap #templateFlame #bodyClump .area__contents_ct,
#templateWrap #templateFlame #bodyClump .area__contents_ct--inner {
  background: none;
}
#templateWrap #templateFlame #bodyClump .area__contents_ct--inner {
  margin: 0;
}
#templateWrap #templateFlame #bodyClump .area__contents_ct p {
  text-align: center;
  font-size: 12px;
  font-weight: 400;
  margin: -3% auto 19%;
  color: #484848;
  position: relative;
  z-index: 1;
}



