@charset "UTF-8";

/* zannen na ikimono jiten LP 2024*/

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p,
blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike,
strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody,
tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section,
summary, time, mark, audio, video{
  margin: 0;
  padding: 0;
  border: 0;
  font-family: 'Yu Gothic', YuGothic, 'Hiragino Kaku Gothic Pro', 'YuGothic', 'Meiryo', verdana, 'Osaka', 'MS PGothic', Sans-Serif;
  font-size: 100%;
  vertical-align: top;
  color: #1c1a1a;
}

html {
  line-height: 1
}

html, body {
  font-size: 16px;
  font-weight: 400;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  color: #000;
  -webkit-text-size-adjust: 100%
}

main.contents_zannen{
  overflow: hidden;
}



 @media (hover:hover){
  header#header a,
main.contents_zannen,
main.contents_zannen a,
.cartjs_cart_in a input{
  /*cursor: pointer;*/
  cursor: none;
}

#custom-cursor{
  position: fixed;
  pointer-events: none;
  z-index: 9999;
}
      }

@media (hover:none){
  header#header a,
  main.contents_zannen,
  main.contents_zannen a,
  .cartjs_cart_in a input{
  cursor: pointer;
}

#custom-cursor{
  display: none;
}
      }

ol, ul {
  list-style: none
}

table {
  border-collapse: collapse;
  border-spacing: 0
}

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle
}

q, blockquote {
  quotes: none
}

q:before, q:after, blockquote:before, blockquote:after {
  content: "";
  content: none
}

img{
  max-width: 100%;
}

a img {
  border: none
}

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block
}

p {
  font-size: 16px;
  line-height: 27px;
  padding-bottom: 15px;
}

h1 {
  font-size: 45px;
  font-weight: 300;
  line-height: 68px
}

h2 {
  font-size: 36px;
  font-weight: 300;
  color: #fff
}

h3 {
  font-size: 20px;
  line-height: 32px;
  margin-bottom: 20px;
}

h4 {
  font-size: 16px;
}

h5 {
  font-size: 13px;
  font-weight: 600;
  display: inline-block;
}

ruby rt{
  letter-spacing:-.05em;
}

ruby rt.mini{
  letter-spacing:-.35em;
}

.modal_btn{
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-weight: bold;
}

ul.modal_btn  li{
  color: #fff;
}

.btn.primary {
  display: inline-block;
  font-size: 16px;
  letter-spacing: 1px;
  color: #fff;
  background-color: #ea5432;
  padding: 10px;
  text-decoration: none;
  line-height: 1.5;
  border-radius: 20px;
  font-weight: 600;
}

a.btn.primary{
   color: #fff;
}
.btn.primary:hover {
  background-color: #f38066
}

.view-more {
  margin-top: 70px
}

.has-padding {
  padding: 60px 0 120px;/*padding: 40px 0*/
}
@media screen and (min-width:641px) and ( max-width:769px) {
.has-padding {
  padding: 60px 0 90px;/*padding: 40px 0*/
}
}
@media screen and (max-width: 640px) {
  .has-padding {
    padding: 30px 0 30px/* padding: 30px 0*/
  }
}

.group:after {
  display: table;
  clear: both;
  content: ''
}
.no-padding {
  padding: 0
}
.no-margin {
  margin: 0
}
a {
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-duration: 200ms;
  transition-duration: 200ms;
  color: #e97106/*color: #7AE2DE*/
}
a:hover {
  text-decoration: none;
  color: #ea9448/*color: #71D5D2*/
}
ul, ol {
  margin: 0;
  padding: 0
}
ul li {
  list-style: none
}
input, textarea {
  outline: none
}
.bold {
  font-weight: 600
}
.wp1, .wp2, .wp3, .wp4, .wp5, .wp6, .wp7, .wp8, .wp9, .wp10 {
  visibility: hidden
}
.wp1 {
  -webkit-animation-delay: .5s;
  animation-delay: .5s
}
.wp2 {
  -webkit-animation-delay: .8s;
  animation-delay: .8s;
  text-align: center;
}
.wp3 {
  -webkit-animation-delay: 1s;
  animation-delay: 1s
}
.wp4 {
  -webkit-animation-delay: 1s;
  animation-delay: 1s
}
.wp7 {
  -webkit-animation-delay: .5s;
  animation-delay: .5s
}
.wp8 {
  -webkit-animation-delay: 1s;
  animation-delay: 1s;
}
.bounceInLeft, .bounceInRight, .fadeInUp, .fadeInUpDelay, .fadeInDown, .fadeInUpD, .fadeInLeft, .fadeInRight, .bounceInDown, .fadeIn {
  visibility: visible
}

.fixed {
  position: fixed;
  z-index: 999
}

/* GLOBAL MENU グローバルメニュー keep #d81718
------------------------------*/
.header-nav-wrapper {
  position: relative;
  background: #ea619f;
}
.header-nav-wrapper .logo {
  display: inline-block;
  max-width: 340px;
  padding: 0px 0;
  text-align: center;
}
.header-nav-wrapper .primary-nav-wrapper {
  float: right;
  height: 100%;
  -webkit-transition: all 300ms;
  transition: all 300ms;
}


.primary-nav li:nth-child(1){
    background-color: transparent;/**/
}
.primary-nav li:nth-child(2){
    background-color: #f9fbed; /*ガチャポン*/
}
.primary-nav li:nth-child(3){
    background-color: #ffe9f3 ; /*登場トップ15*/
}
.primary-nav li:nth-child(4){
    background-color: #d2f2f7; /*zannen_howto 読み方*/
}
.primary-nav li:nth-child(5){
  background: #eaf1c0; /*news ニュース*/
}
.primary-nav li:nth-child(6){
    background-color: #ffe100; /*ためしよみ＆本の購入はこちら*/
}


.header-nav-wrapper nav {
  display: inline-block;
  margin-right: 0px;
  padding: 0px 0 0px;
}
.header-nav-wrapper nav ul {
  display: inline-block
}
.header-nav-wrapper nav ul li {
  display: inline-block;
  padding: 11px 3px;/
  letter-spacing: 1px;
}
.header-nav-wrapper nav ul li:last-child {
  border-right:none;
}
.header-nav-wrapper nav ul li a {
  font-weight: 600;
  position: relative;
  padding: 5px 0;
  text-decoration: none;
}
.header-nav-wrapper nav ul li a:hover {
  opacity: .6;
}

.header-nav-wrapper .is-visible {
  visibility: visible;
  opacity: 1
}

.nav-toggle {
  position: absolute;
  z-index: 999999;
  top: 40%;
  left: 50%;
  padding: 10px 35px 16px 0;
  cursor: pointer;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%)
}
.nav-toggle:focus {
  outline: none
}
.nav-toggle span, .nav-toggle span:before, .nav-toggle span:after {
  position: absolute;
  display: block;
  width: 35px;
  height: 3px;
  content: '';
  cursor: pointer;
  border-radius: 1px;
  background: #fff;
}
.nav-toggle span:before {
  top: -10px
}
.nav-toggle span:after {
  bottom: -10px
}
.nav-toggle span, .nav-toggle span:before, .nav-toggle span:after {
  -webkit-transition: all 300ms ease-in-out;
  transition: all 300ms ease-in-out
}
.nav-toggle.active span {
  background-color: transparent
}
.nav-toggle.active span:before, .nav-toggle.active span:after {
  top: 0
}
.nav-toggle.active span:before {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg)
}
.nav-toggle.active span:after {
  top: 10px;
  -webkit-transform: translatey(-10px) rotate(-45deg);
  transform: translatey(-10px) rotate(-45deg)
}
.navicon {
  position: absolute;
  top: 0;
  right: 0;
  visibility: hidden;
  width: 25px;
  height: 26px;
  padding: 36px 52px;
  z-index: 999;
}

.navicon::after {
    display: block;
    content: "もくじ";
    position: relative;
    top: 10px;
    color: #fff;
    font-size: 12px;
    letter-spacing: 1px;
    width: 60px;
    left: -18px;
    font-weight: 600;
}

.secondary-nav-wrapper {
  display: inline-block;
  padding: 16px 0px;
  vertical-align: top;
}
.secondary-nav-wrapper ul.secondary-nav li {
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase
}
.secondary-nav-wrapper ul.secondary-nav li.subscribe {
  position: relative;
  padding: 10px 20px 10px 0;
  border-right: solid 1px #505c66
}
.secondary-nav-wrapper ul.secondary-nav li.subscribe a {
  position: relative;
  padding-bottom: 10px;
  text-decoration: none
}
.secondary-nav-wrapper ul.secondary-nav li.subscribe a:before {
  position: absolute;
  bottom: 0;
  left: 0;
  visibility: hidden;
  width: 100%;
  height: 2px;
  content: '';
  -webkit-transition: all .3s ease-in-out 0s;
  transition: all .3s ease-in-out 0s;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  background-color:#7AE2DE;
}
.secondary-nav-wrapper ul.secondary-nav li.subscribe a:hover:before {
  visibility: visible;
  -webkit-transform: scaleX(1);
  transform: scaleX(1)
}
.secondary-nav-wrapper ul.secondary-nav li.subscribe:after {
  position: absolute;
  top: 0;
  right: 0;
  height: 34px;
  content: ' ';
  border-right: 1px solid #323940;
}
.secondary-nav-wrapper ul.secondary-nav li.search {
  margin-left: 20px
}
.secondary-nav-wrapper ul.secondary-nav li.search a {
  font-size: 16px;
  color: #fff
}
.secondary-nav-wrapper ul {
  display: inline-block
}
.secondary-nav-wrapper ul li {
  display: inline-block
}

ul.primary-nav li .gmenu{
width: 150px;
}

.primary-nav-wrapper.open {
  visibility: visible;
  opacity: 1
}

.pc_menu{display: block;}

.sp_menu{display: none;}

@media screen and (max-width: 1200px) {
  .header-nav-wrapper nav {
    margin-right: 10px
  }
  .header-nav-wrapper .logo {
    width: 280px
  }

  ul.primary-nav li .gmenu{
    width: 247px;
    margin-left: 0px;
    padding: 10px 0 10px;
  }

  ul.primary-nav li .gmenu:nth-child(1){
    width: 247px;
    margin-left: 0px;
    padding: 10px 0 10px;
  }

.primary-nav li:nth-child(1){
    background-color: transparent;
}
.primary-nav li:nth-child(2){
    /*background-color: transparent;*/
    background-image: url(../img/g-menu_02_bg.png);
    background-repeat: no-repeat;
    background-position: center left;
}
.primary-nav li:nth-child(3){
     /*background-color: transparent;*/
    background-image: url(../img/g-menu_03_bg.png);
    background-repeat: no-repeat;
    background-position: center left;
  }
.primary-nav li:nth-child(4){
     /*background-color: transparent;*/
    background-image: url(../img/g-menu_04_bg.png);
    background-repeat: no-repeat;
    background-position: center left;
    background-size: auto;
}
.primary-nav li:nth-child(5){
     /*background-color: transparent;*/
    background-image: url(../img/g-menu_05_bg.png);
    background-repeat: no-repeat;
    background-position: center left;
}
.primary-nav li:nth-child(6){
     /*background-color: transparent;*/
    background-image: url(../img/g-menu_06_bg.png);
    background-repeat: no-repeat;
    background-position: center left;
}

.pc_menu{display: none;}

.sp_menu{display: inline;}

}

@media screen and (max-width: 1200px) {
.header-nav-wrapper nav {
    width: 100%;
    padding: 10px 0 0;
    text-align: center
  }
  .header-nav-wrapper nav ul {
    display: block
  }
  .header-nav-wrapper nav ul li,.header-nav-wrapper nav ul li:last-child  {
    display: block;
    padding: 0px;
    border-right: none
  }
  .header-nav-wrapper nav ul li a {
    display: block;
    color: #fff;
    border-bottom: solid 1px #fff;
  }
  .header-nav-wrapper nav ul li a:before {
    display: none
  }
  .primary-nav-wrapper {
    position: fixed;
    z-index: 99;
    top: 0;
    left: 0;
    visibility: hidden;
    width: 100%;
    height: 100%;
    opacity: 0;
    background-color: #ea619f;
  }
  .navicon {
    visibility: visible
  }
  .secondary-nav-wrapper ul.secondary-nav li {
    font-size: 30px
  }
  .secondary-nav-wrapper {
    display: block;
    padding: 0;
    text-align: center;
    background-color: transparent;
    padding: 10px 0;
  }
  .secondary-nav-wrapper ul {
    display: block
  }
  .secondary-nav-wrapper li a:before {
    display: none
  }
  .secondary-nav-wrapper ul li.subscribe a {
    font-weight: 600;
    display: block;
    color: #fff
  }
  .secondary-nav-wrapper ul li.subscribe a:hover {
    color: #7AE2DE
  }
  .secondary-nav-wrapper ul.secondary-nav li.subscribe {
    display: block;
    padding: 10px 0;
    border-right: none
  }
  .secondary-nav-wrapper ul.secondary-nav li.search i {
    display: none
  }
  .secondary-nav-wrapper ul.secondary-nav li.subscribe:after {
    display: none
  }
}

@media screen and (max-width: 480px) {
  .header-nav-wrapper .logo {
    width: 250px
  }
  .navicon {
    padding: 36px 35px;
    background-color: transparent
  }
  .header-nav-wrapper .logo {
    border-bottom: none
  }
  .header-nav-wrapper nav {
    width: 100%;
    padding: 10px 5px 0;
    text-align: center
  }
}

/* hero 出だし
------------------------------*/
.hero {
  width:100%;
  height: 650px;
  position: relative;
  background: #ffe100 repeating-conic-gradient(transparent,transparent 6deg,#fff 6deg 12deg);
}/**/

.hero-bg{
  position: relative;
  bottom:6%;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  max-width: 1080px;
  margin: 0px auto 0px;
  z-index:3;
}

.hero img.logo{
  max-width: 430px;
  z-index: 11;
  margin: 0 auto;
  position: absolute;
  top: 47%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.hero img.toha{
  width: 160px;
  z-index: 12;
  margin: 0 auto;
  position: absolute;
  bottom: 1%;
  left: 50%;
  transform: translateX(-50%);
}

.hero .modaal_btn_area{
  z-index: 12;
  margin: 0 auto;
  position: absolute;
  bottom: 1%;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  justify-content: center;
  gap: 0px 0px;
  width: 80%;
}

.hero img.b26{
  width: 160px;/**/
  transform: scale(1);
  transition: transform 0.3s ease;
}

.hero img.b26:hover{
  transform: scale(0.95);
}

img.old_zan{
  position: absolute;
  top: 50%;
  right: 30%;
  transform: translateY(-50%);
  width: 82px;
  z-index: 13;
}

img.now_zan{
  position: absolute;
  top: 50%;
  left: 30%;
  transform: translateY(-50%);
  width: 84px;
  z-index: 13;
}

.main_kv{
  max-width:555px;
  margin : 0 auto;
  padding: 35px 0 0;
  animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

@keyframes zoomIn {
  0% {
    transform: scale(0.8);
    opacity: 0;
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

/*いきものたちのアニメ*/

@keyframes yurayura {
  0% , 100%{
      transform: rotate(10deg);
  }
  50%{
      transform: rotate(-10deg);
  }
}

@keyframes fuwafuwa {
  0% {
    transform:translate(0, 0) rotate(-7deg);
  }
  50% {
    transform:translate(0, -7px) rotate(0deg);
  }
  100% {
    transform:translate(0, 0) rotate(7deg);
  }
}

@keyframes poyooon {
  0%   { transform: scale(1.0, 1.0) translate(0%, 0%); }
  10%  { transform: scale(1.1, 0.9) translate(0%, 5%); }
  40%  { transform: scale(1.2, 0.8) translate(0%, 15%); }
  50%  { transform: scale(1.0, 1.0) translate(0%, 0%); }
  60%  { transform: scale(0.9, 1.2) translate(0%, -100%); }
  75%  { transform: scale(0.9, 1.2) translate(0%, -20%); }
  85%  { transform: scale(1.2, 0.8) translate(0%, 15%); }
  100% { transform: scale(1.0, 1.0) translate(0%, 0%); }
}

.purun {
  animation: purun 0.8s linear 0s infinite;
}

@keyframes purun {
  0%   { transform: scale(1.0, 1.0) translate(0%, 0%); }
  15%  { transform: scale(0.9, 0.9) translate(0%, 5%); }
  30%  { transform: scale(1.0, 0.8) translate(0%, 10%); }
  50%  { transform: scale(0.8, 1.0) translate(0%, -10%); }
  70%  { transform: scale(1.1, 0.9) translate(0%, 5%); }
  100% { transform: scale(1.0, 1.0) translate(0%, 0%); }
}

.purupuru {
  animation: purupuru 0.8s linear 0s 1;
}

@keyframes purupuru {
  0%   { transform: scale(1.0, 1.0) translate(0%, 0%); }
  20%  { transform: scale(1.0, 1.06) translate(-5%, -4%) skew(6deg, 0deg); }
  50%  { transform: scale(1.0, 0.94) translate(5%, 4%) skew(-6deg, 0deg); }
  65%  { transform: scale(1.0, 1.03) translate(2%, -2%) skew(-3deg, 0deg); }
  80%  { transform: scale(1.0, 0.97) translate(-2%, 2%) skew(3deg, 0deg); }
  100% { transform: scale(1.0, 1.0) translate(0%, 0%); }
}

/* 2022 出だし */
.rotate-center {
  -webkit-animation: rotate-center 0.6s ease-in-out both;
          animation: rotate-center 0.6s ease-in-out both;
}

/* ----------------------------------------------
 * Generated by Animista on 2022-3-6 10:49:16
 * Licensed under FreeBSD License.
 * See http://animista.net/license for more info.
 * w: http://animista.net, t: @cssanimista
 * ---------------------------------------------- */
/**
 * ----------------------------------------
 * animation rotate-center
 * ----------------------------------------
 */
@-webkit-keyframes rotate-center {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@keyframes rotate-center {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}


@media screen and (min-width:1225px) and ( max-width:1500px) {
img.old_zan{
  right: 25%;
  width: 82px;
}

img.now_zan{
  left: 25%;
  width: 84px;
}
}

@media screen and (min-width:1025px) and ( max-width:1224px) {
img.old_zan{
  right: 20%;
  width: 72px;
}

img.now_zan{
  left: 20%;
  width: 74px;
}
}

@media screen and (min-width:541px) and ( max-width:1024px) {
  .hero {
  height: 530px;
}

.main_kv{
  max-width:440px;
  padding: 10px 0 0;
}

.min_max{
  max-width: 100%;
  position: relative;
  display: block;
  z-index:1;
  margin: 0 auto;
  bottom:0px;
  top: 30px;
}

.hero img.logo{
  max-width: 320px;
  top: 43%;
}

.hero img.toha{
  width: 150px;
  bottom: 1%;
  left: 50%;
}

img.old_zan{
  right: 15%;
  width: 62px;
}

img.now_zan{
  left: 15%;
  width: 64px;
}

}

@media screen and (max-width: 540px) {
  .hero {
  height: 530px;
}

.main_kv{
  max-width:440px;
  padding: 20px 0 0;
}

.hero img.logo{
  max-width: 320px;
  top: 43%;
}

.hero img.toha{
  width: 150px;
  bottom: 1%;
  left: 50%;
}


img.old_zan{
  right: 3%;
  width: 48px;
}

img.now_zan{
  left: 3%;
  width: 48px;
}

}

@media screen and (max-width: 375px) {
  .hero {
  height: 530px;
}

.main_kv{
  max-width:440px;
  padding: 20px 0 0;
}

.hero img.logo{
  max-width: 280px;
  top: 38%;
}

.hero img.toha{
  width: 150px;
  bottom: 1%;
  left: 50%;
}

}



/* bnrArea_1 バナーエリア １つ目
------------------------------*/
.bnrArea_1{
  background-color: #f9fbed;
}

.bnrArea_1 .container {
  width: auto !important;
  padding: 0;
}

@media screen and (max-width: 480px) {
  .roop {
    background-size:cover;
  }
}

.bnr_list {
  position: relative;
  margin: 25px auto 30px;
  padding: 1px 0;
  opacity: 0;
}

.bnr_list-slide {
  margin: 0 -50px;
}
@media screen and (max-width: 768px) {
  .bnr_list-slide {
    margin: 0;
    padding: 0 15px;
  }
  .bnr_list-slide .swiper-wrapper {
    display: block;
  }
}

.bnr_list.swiper-container {
  width: 100%;
  height: 100%;
  overflow: visible;
  z-index: 1;
}

.bnr_list .swiper-slide {
  width: 50%;
  padding: 0 10px;
  box-sizing: border-box;
}
@media screen and (max-width: 768px) {
  .bnr_list .swiper-slide {
    width: 100% !important;
    margin-top: 15px;
    padding: 0;
  }
  .bnr_list .swiper-slide:first-child {
    margin-top: 0;
  }
  .bnr_list .swiper-slide img {
    width: 100%;
  }
}

.bnr_list .swiper-slide a {
  transition: opacity .23s ease-in;
}

.bnr_list .swiper-slide a:hover {
  opacity: .6;
}

.bnr_list-swiper-pagination {
  display: none;
  position: absolute;
  z-index: 1;
  left: 50%;
  bottom: -32px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}

.bnr_list.active-slider .bnr_list-swiper-pagination {
  display: block;
}

.bnr_list .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  margin: 0 5px;
  background: #d2d2d2;
  border-radius: 50px;
  opacity: 1;
}

.bnr_list .swiper-pagination-bullet-active {
  background: #62b896;
}

.bnr_list .swiper-button-next,
.bnr_list .swiper-button-prev {
  display: none;
  top: 50%;
  right: 10px;
  width: 36px;
  height: 90px;
  margin-top: -45px;
  padding: 0;
  border-radius: 5px;
  background: url(../../common/img/book/arw_slide_r.svg) no-repeat center rgba(33, 33, 33, 0.5);
  background-size: 12px 22px;
  transition: background-color .1s linear;
}

.bnr_list.active-slider .swiper-button-next,
.bnr_list.active-slider .swiper-button-prev {
  display: block;
}

.bnr_list .swiper-button-next:hover,
.bnr_list .swiper-button-prev:hover {
  background-color: #212121;
}

.bnr_list .swiper-button-prev {
  left: 10px;
  background: url(../../common/img/book/arw_slide_l.svg) no-repeat center rgba(33, 33, 33, 0.5);
  background-size: 12px 22px;
}

.bnr_list-slide {
  overflow: hidden;
}


/* title_area 共通見出しエリア
------------------------------*/
.title_area{
  position: relative;
  min-height: 1px;
  padding: 0;
}


/* zannen_top15 登場トップ15
------------------------------*/
.zannen_top15{
  background-color: #ffe9f3;
}

.zannen_top15 .pict_list{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  max-width: 900px;
  margin:1rem auto;
  gap: 10px;
}

.zannen_top15 .pict{
  width: calc((100% - 50px) / 5);
}

.zannen_top15 .pict {
  padding: 0;
}

.zannen_top15 .pict a {
  width: calc((100% - 5px) / 5);
  padding: 0;
}

.zannen_top15 .pict{
  position: relative;
  background-color: #fff8fb;
  border-radius: 12px;
  padding: 0 0 2px;
}

.zannen_top15 .pict .active {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  transition: 0.5s;
}
.zannen_top15 .pict:hover .active {
  opacity: 1;
}

h2.top15_title{
  text-align:center;
  font-size:18px;
  padding:0px 0 0;
  color: #231815;
  font-weight:600;
}

.top15_contents{
position:relative;
}

.neta_list .howto_mdl_ikimono{
  position: absolute;
  bottom: 0px;
  right: 0px;
}

.neta_list .howto_mdl_ikimono_Left{
  position: absolute;
  bottom: 0px;
  left: 0px;
}

span.animal_name{
  font-size: 24px;
  color:rgba(230, 0, 18, 1);vertical-align:middle;
}

table.neta_list {
  margin: 5px 10px 20px;
}

.neta_list tr{
   border: solid 1px #ccc;
}

.neta_list th {
  background: #dfeed9;
  font-weight:600;
  padding: 20px 10px;
  width:60%;
  vertical-align: top;
  position:relative;
}

.neta_list th.yellow {
  background: #faeed1;
  font-weight:600;
  padding: 20px 10px;
  width:60%;
  vertical-align: top;
  position:relative;
  text-align:right;
}

.neta_list th.yellow2 {
  background: #faf6bc;
  font-weight:600;
  padding: 20px 10px;
  width:60%;
  vertical-align: top;
  position:relative;
  text-align:right;
}

.neta_list th.orange {
  background: #fcdaa7;
  font-weight:600;
  padding: 20px 10px;
  width:60%;
  vertical-align: top;
  position:relative;
  text-align:right;
}

.neta_list th.orange2 {
  background: #fcdaa7;
  font-weight:600;
  padding: 20px 10px;
  width:60%;
  vertical-align: top;
  position:relative;
}


.neta_list th.pink {
  background: #f2e4ea;
  font-weight:600;
  padding: 20px 10px;
  width:60%;
  vertical-align: top;
  position:relative;
  text-align:right;
}

.neta_list th.pink2 {
  background: #f2e4ea;
  font-weight:600;
  padding: 20px 10px;
  width:60%;
  vertical-align: top;
  position:relative;
}

.neta_list th.blue_1 {
  background: #ceebfc;
  font-weight:600;
  padding: 20px 10px;
  width:60%;
  vertical-align: top;
  position:relative;
}

.neta_list th.blue_2 {
  background: #afdefa;
  font-weight:600;
  padding: 20px 10px;
  width:60%;
  vertical-align: top;
  position:relative;
  text-align:right;
}

.neta_list th.blue_3 {
  background: #ceebfc;
  font-weight:600;
  padding: 20px 10px;
  width:60%;
  vertical-align: top;
  position:relative;
  text-align:right;
}

.neta_list th.hada {
  background: #f4e0d0;
  font-weight:600;
  padding: 20px 10px;
  width:60%;
  vertical-align: top;
  position:relative;
  text-align:right;
}

.neta_list th.blue_3 {
  background: #c5e7fa;
  font-weight:600;
  padding: 20px 10px;
  width:60%;
  vertical-align: top;
  position:relative;
}

.neta_list th.gray_1 {
  background: #c8d3d8;
  font-weight:600;
  padding: 20px 10px;
  width:60%;
  vertical-align: top;
  position:relative;
}



.neta_list td {
  padding: 5px;
  width:40%;
  margin: auto;
}

.neta_list td a{
  display:flex;
  align-items:center;
  font-weight:600;
}

.neta_list td a .mdl_book{
  width:30%;
  position:relative;
}

.neta_list td a .mdl_book .icon_buy{
  width:75%;
  position:absolute;
  bottom:-2%;
  right:62%;
}

.neta_list td a .mdl_text{
  width:70%;
  padding:0 5px 0;
  margin:0;
  vertical-align:middle;
  text-align:center;
  position:relative;
}

/*.neta_list td a .mdl_text::first-letter {
  font-size: 30px;
  color:rgba(230, 0, 18, 1);vertical-align:middle;
}*/

.neta_list td a .mdl_text span.vol-10digits {
  font-size: 30px;
  color:rgba(230, 0, 18, 1);vertical-align:middle;
}

.neta_list td a .mdl_text span {
  font-size: 14px;
  /*color:rgba(230, 0, 18, 1);*/
}

.neta_list td a img{
}


@media screen and (max-width: 640px) {

.zannen_top15 .pict_list {
    gap: 5px;
}

.zannen_top15 .pict{
  width: calc((100% - 15px) / 3);
}
.neta_list td {
  padding: 5px;
}
.neta_list td a{
  display:flex;
  flex-flow: column;
  text-align:center;
  font-size:12px;
}
.neta_list td a .mdl_book{
  width:80%;
}

.neta_list td a .mdl_text{
  width:100%;
  padding:5px 0px 0px;
}

.neta_list td a .mdl_text span.vol-10digits {
  font-size: 18px;
}

.neta_list td a .mdl_book .icon_buy{
  width:65%;
  position:absolute;
  bottom:-3%;
  right:-15%;
}

}

/* zannen_howto 読み方
------------------------------*/
.zannen_howto{
  /*background: linear-gradient(0deg, #c5e7ed 50%, #d2f2f7 50%);*/
  background-size: 20px 20px;
  background-image: linear-gradient(135deg, #c5e7ed 25%, transparent 25%), linear-gradient(225deg, #c5e7ed 25%, transparent 25%), linear-gradient(45deg, #c5e7ed 25%, transparent 25%), linear-gradient(315deg, #c5e7ed 25%, #d2f2f7 25%);
  background-position: 20px 0, 20px 0, 0 0, 0 0;

  background-repeat: repeat;
}

.zannen_howto .book_page{
  max-width:720px;
  margin:auto auto;
  position: relative;
}

.modaal-content-container .howto_title {
    position: relative;
    text-align: center;
    padding-bottom:10px;
}

.modal_page{
  filter: drop-shadow(1px 8px 8px rgba(0, 0, 0, 0.2));
  z-index:1;
  position: relative;
}

/*== 無限に波紋が広がる ==*/

/* 手下向き */
.btnripple1{
  position: relative;
  display:inline-block;
  background:rgba(230, 0, 18, .5);
  width:50px;/*width:70px;*/
  height:50px;/*height:70px;*/
  border-radius: 50%;
  color:#ccc;
  outline: none;
  transition: all .3s;
  z-index:2;
}

/*hoverした際の背景色の設定*/
.btnripple1:hover{
  background:rgba(230, 0, 18, 1);
}

/*波形を2つ設定*/
.btnripple1::after,
.btnripple1::before {
    content: '';
    /*絶対配置で波形の位置を決める*/
    position: absolute;
    left: -25%;
    top: -25%;
    /*波形の形状*/
    border: 1px solid rgba(230, 0, 18, .5);
    width: 150%;
    height: 150%;
    border-radius: 50%;
    /*はじめは不透明*/
    opacity: 1;
    /*ループするアニメーションの設定*/
    animation:1s circleanime linear infinite;
}

/*波形の2つ目は0.5秒遅らせてアニメーション*/
.btnripple1::before {
    animation-delay:.5s;
}

/*真ん中の手*/
.btnripple1 span::after {
    content: url(../img/icon_click_bottom.png);
    position: absolute;
    top: 56%;
    left: 54%;
    transform: translate(-56%, -54%);
    -webkit-transform: translate(-56%, -54%);
    -ms-transform: translate(-56%, -54%);
    color:#fff;
    font-size: 12px;
}

/* 手下向き */


/* 手上向き */
.btnripple2{
  position: relative;
  display:inline-block;
  background:rgba(230, 0, 18, .5);
  width:50px;/*width:70px;*/
  height:50px;/*height:70px;*/
  border-radius: 50%;
  color:#ccc;
  outline: none;
  transition: all .3s;
  z-index:2;
}

/*hoverした際の背景色の設定*/
.btnripple2:hover{
  background:rgba(230, 0, 18, 1);
}

/*波形を2つ設定*/
.btnripple2::after,
.btnripple2::before {
    content: '';
    /*絶対配置で波形の位置を決める*/
    position: absolute;
    left: -25%;
    top: -25%;
    /*波形の形状*/
    border: 1px solid rgba(230, 0, 18, .5);
    width: 150%;
    height: 150%;
    border-radius: 50%;
    /*はじめは不透明*/
    opacity: 1;
    /*ループするアニメーションの設定*/
    animation:1s circleanime linear infinite;
}

/*波形の2つ目は0.5秒遅らせてアニメーション*/
.btnripple2::before {
    animation-delay:.5s;
}

/*真ん中の手*/
.btnripple2 span::after {
    content: url(../img/icon_click.png);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    color:#fff;
    font-size: 12px;
}
/* 手上向き */

/* 手左向き */
.btnripple3{
  position: relative;
  display:inline-block;
  background:rgba(230, 0, 18, .5);
  width:50px;/*width:70px;*/
  height:50px;/*height:70px;*/
  border-radius: 50%;
  color:#ccc;
  outline: none;
  transition: all .3s;
  z-index:2;
}

/*hoverした際の背景色の設定*/
.btnripple3:hover{
  background:rgba(230, 0, 18, 1);
}

/*波形を2つ設定*/
.btnripple3::after,
.btnripple3::before {
    content: '';
    /*絶対配置で波形の位置を決める*/
    position: absolute;
    left: -25%;
    top: -25%;
    /*波形の形状*/
    border: 1px solid rgba(230, 0, 18, .5);
    width: 150%;
    height: 150%;
    border-radius: 50%;
    /*はじめは不透明*/
    opacity: 1;
    /*ループするアニメーションの設定*/
    animation:1s circleanime linear infinite;
}

/*波形の2つ目は0.5秒遅らせてアニメーション*/
.btnripple3::before {
    animation-delay:.5s;
}

/*真ん中の手*/
.btnripple3 span::after {
    content: url(../img/icon_click_left.png);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    color:#fff;
    font-size: 12px;
}
/* 手左向き */


/* 手右向き */
.btnripple4{
  position: relative;
  display:inline-block;
  background:rgba(230, 0, 18, .5);
  width:50px;/*width:70px;*/
  height:50px;/*height:70px;*/
  border-radius: 50%;
  color:#ccc;
  outline: none;
  transition: all .3s;
  z-index:2;
}

/*hoverした際の背景色の設定*/
.btnripple4:hover{
  background:rgba(230, 0, 18, 1);
}

/*波形を2つ設定*/
.btnripple4::after,
.btnripple4::before {
    content: '';
    /*絶対配置で波形の位置を決める*/
    position: absolute;
    left: -25%;
    top: -25%;
    /*波形の形状*/
    border: 1px solid rgba(230, 0, 18, .5);
    width: 150%;
    height: 150%;
    border-radius: 50%;
    /*はじめは不透明*/
    opacity: 1;
    /*ループするアニメーションの設定*/
    animation:1s circleanime linear infinite;
}

/*波形の2つ目は0.5秒遅らせてアニメーション*/
.btnripple4::before {
    animation-delay:.5s;
}

/*真ん中の手*/
.btnripple4 span::after {
    content: url(../img/icon_click_right.png);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    color:#fff;
    font-size: 12px;
}
/* 手右向き */


/*波形のアニメーション*/
@keyframes circleanime{
  0%{
    transform: scale(0.68);
  }
  100%{
    transform: scale(1.2);
    opacity: 0;
  }
}
/*== 無限に波紋が広がる */

/* 進化ネタ */
.zannen_howto .btn_1{
  position: absolute;
  top: 25%;
  left: -2%;
}
/* 進化ネタ */

/* ものしりネタ */
.zannen_howto .btn_2{
  position: absolute;
  bottom: 6%;
  left: 44%;
}
/* ものしりネタ */

/*ざんねんネタ*/
.zannen_howto .btn_3{
  position: absolute;
  top: 65%;
  right: 42%;
}
/*ざんねんネタ*/

/* ざんねんポイント */
.zannen_howto .btn_4{
  position: absolute;
  top: 11%;
  right: 42.5%;
}
/* ざんねんポイント */

/* 今と昔のざんねん対決 */
.zannen_howto .btn_5{
  position: absolute;
  top: 2%;
  right: 7%;
}
/* 今と昔のざんねん対決 */


@media screen and (max-width: 480px) {
  .btnripple1,.btnripple2,.btnripple3,.btnripple4{
  width:40px;
  height:40px;
}


/*手下向き*/
.btnripple1 span::after {
    content:'';
    position: absolute;
    top: 50%;
    left: 56%;
    transform: translate(-44%, -50%);
    -webkit-transform: translate(-44%, -50%);
    -ms-transform: translate(-44%, -50%);
    background:url(../img/icon_click_bottom.png) no-repeat;
    width: 30px;/*画像の幅*/
    height: 30px;/*画像の高さ*/
    background-size: contain;
    vertical-align: middle;
}

/*手上向き*/
.btnripple2 span::after {
    content:'';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    background:url(../img/icon_click.png) no-repeat;
    width: 30px;/*画像の幅*/
    height: 30px;/*画像の高さ*/
    background-size: contain;
    vertical-align: middle;
}

/*手左向き*/
.btnripple3 span::after {
    content:'';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    background:url(../img/icon_click_left.png) no-repeat;
    width: 30px;/*画像の幅*/
    height: 30px;/*画像の高さ*/
    background-size: contain;
    vertical-align: middle;
}

/*手右向き*/
.btnripple4 span::after {
    content:'';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    background:url(../img/icon_click_right.png) no-repeat;
    width: 30px;/*画像の幅*/
    height: 30px;/*画像の高さ*/
    background-size: contain;
    vertical-align: middle;
}


/* 進化ネタ */
.zannen_howto .btn_1{
  bottom: 6%;
  right: -1%;
}
/* 進化ネタ */

/* ものしりネタ */
.zannen_howto .btn_2{
  bottom: 3%;
}
/* ものしりネタ */

/*ざんねんネタ*/
.zannen_howto .btn_3{
  top: 55%;
  right: 42%;
}
/*ざんねんネタ*/

/* ざんねんポイント */
.zannen_howto .btn_4{
  top: 8%;
  right: 43%;
}
/* ざんねんポイント */

/* 今と昔のざんねん対決 */
.zannen_howto .btn_5{
  top: 1%;
  right: 0%;
}
/* 今と昔のざんねん対決 */

}












/* news ニュース
------------------------------*/
.news{
  background: #eaf1c0;
  /*background: linear-gradient(0deg, #e2ebaa 50%, #eaf1c0 50%);
  background-size: 20px 20px;*/
}

.news .title{
  position:relative;
  text-align: center;
  padding-bottom: 20px;
}
.news .title h4{
  position: absolute;
  top: 0;
  left:50%;
  filter: drop-shadow(2px 2px 5px rgb(0, 0, 0, .2));
}
.news .title h4 img{
  animation: buruburu 0.5s infinite linear alternate;
}

@keyframes buruburu {
  0% {
    transform: translate(-3px, 0) rotate(-5deg);
  }
  50% {
    transform: translate(0, -2px) rotate(0deg);
  }
  100% {
    transform: translate(-3px, 0)　rotate(5deg);
  }
}

.news__list{
  background: #fff;
  padding: 10px 10px;
  border-radius: 10px;
}

.news__list--item {
    font-weight: bold;
    display: -webkit-box;
    display: flex;
    padding: 17px 10px;
    border-bottom: 1px solid #dadada;
}
.news__list--item:nth-last-of-type(1){
  border-bottom:none;
}

.news__list--item dt {
    font-size: 16px;
    margin-right: 50px;/*margin-right: 50px;*/
    color: #231815;/*color: #e97106;*/
}

@media screen and (max-width: 480px) {
.news__list--item {
    display: block;
}
}

.news__list--button {
  text-align:center;
  margin-top: 0px;
}
.news__list--button a{
  text-align:center;
  margin-top: -35px;
}

.news__list--button a:hover{
  opacity: 1;
}/**/

/*タブ切り替え全体のスタイル*/
.tabs {
    padding-bottom: 40px;
    margin: 10px auto 0;
    filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.1));
}

.tabs p{
  display: none;
}

/*タブのエリア*/
.tab_area{
  display: flex;

}
/*タブのスタイル*/
.tab_item {
  width: 100%;
  height: 50px;
  font-size: 22px;
  text-align: center;
  color: #231815;
  font-weight: bold;
  transition: all 0.2s ease;
  border-radius: 20px 20px 0 0;
}

.tab_item{
  display: flex;
  align-items: center;
  justify-content: center;
}

.tab_item img{
  padding-right: 5px;
  padding-bottom: 6px;
  vertical-align: middle;
  filter: drop-shadow(5px 5px 5px rgba(0, 0, 0, 0.2));
  animation: yurayura 2s linear infinite;
}

@media screen and (max-width: 614px) {
  .tab_item {
  height: 40px;
}

  .tab_item img{
  width: 50px;
  padding-bottom: 5px;
}
  }

.tab_item.info {
  border-bottom: 3px solid #3a9126;
}

.tab_item.anime {
  border-bottom: 3px solid #d92628;
  background-color: #fea26b;
  display:none;
}

.tab_item.goods {
  border-bottom: 3px solid #d92628;
  background-color: #f5ce65;
  display:none;
}

@media screen and (max-width: 719px) {
.tab_item {
  font-size: 18px;
}
}

@media screen and (min-width: 481px) and (max-width: 578px) {
.tab_item.anime {
  font-size: 10px;
}
}
@media screen and (max-width: 480px) {
  .tab_item.anime{
  line-height: 1.2;
  font-size: 14px;
}
}

.tab_item:hover {
  opacity: 1;
}

/*ラジオボタンを全て消す*/
input[name="tab_item"] {
  display: none;
}

/*タブ切り替えの中身のスタイル*/
.tab_content {
  display: none;
  padding: 40px 40px 20px;
  clear: both;
  overflow: hidden;
  background-color: #fff;
}

@media screen and (max-width: 480px) {
  .tab_content {
  padding: 0px 0px 0;
}
}

/*選択されているタブのコンテンツのみを表示*/
#all:checked ~ #all_content,
#anime_event:checked ~ #anime_event_content,
#goods:checked ~ #goods_content {
  display: block;
}

/*選択されているタブのスタイルを変える*/
.tabs input:checked + .tab_item {
  background-color: #3a9126;
  color: #fff;
}

/* select_book ガチャ gacha
------------------------------*/

.select_book{
  background-image: linear-gradient(45deg, #ffe188 25%, transparent 25%), linear-gradient(315deg, #ffe188 25%, #fff3d2 25%);
    background-position: 10px 0, 20px 0, 0 0, 0 0;
    background-size: 20px 20px;
    background-repeat: repeat;
    padding: 20px 0 50px;
}

.gacha_wrap{
  display: flex;
  max-width: 900px;
  margin: 0px auto;
  justify-content: center;
  padding: 0 20px;
  text-align: center;
  align-items: stretch;
  flex-wrap: wrap;
}

.gacha_guide_area{
  position: relative;
  width:35%;
}

.gacha_guide-title {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    width: 100%;
}

.gacha_guide_area .inner{
    background-color: #fff;
    padding: 60px 8px 10px;
    max-width: 600px;
    margin: 17% auto 0px;
    border: solid 1px #a18b65;
    outline: solid 3px #a18b65;
    outline-offset: 2px;
    overflow: hidden;
    border-radius: 30px;
}

.gacha_area{
  position: relative;
  width:65%;
}

.gacha_area .inner{
  position: relative;
  padding: 0 60px;
}

.btn_gacha{
  position: absolute;
  top: 47%;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}

.btn_gacha .img_btn_gacha {
  display: block;
  position: relative;
  z-index: 3;
  cursor: pointer;
  filter: drop-shadow(5px 5px 5px #afaeae);
  width: 88%;
  margin: auto;
}

.btn_gacha .img_btn_gacha{
  transform: scale(1);
  transition: transform 0.3s ease;
}

.btn_gacha .img_btn_gacha:hover{
  transform: scale(0.9);
}


@media screen and (max-width: 767px) {
.gacha_guide_area{
  position: relative;
  width:100%;
}

.gacha_area{
  position: relative;
  width:100%;
}

.gacha_area .inner{
  position: relative;
  padding: 30px 0px 0;
}

}

@media screen and (max-width: 480px) {
  .select_book{
    background: linear-gradient(135deg, #fee086 25%, transparent 25%) -10px 0/ 20px 20px,
    linear-gradient(225deg, #fdecbb 25%, transparent 25%) -10px 0/ 20px 20px,
    linear-gradient(315deg, #fee086 25%, transparent 25%) 0px 0/ 20px 20px,
    linear-gradient(45deg, #fdecbb 25%, #f9fbed 25%) 0px 0/ 20px 20px;/**/
}
}

@media screen and (max-width: 281px) {

}


/*モーダルの中身*/
.modal_contents{
  margin:auto auto;
  position:relative;
  width:100%;
  height:100%;
}

.modal_contents_flex_box{
  display:flex;
  justify-content:center;
  text-align:center;
  flex-wrap:wrap;
  padding:20px 20px 0;
  align-items: center;
}

.modal_contents_flex_box .book{
  width:60%;
  padding:0 10px;
}

.modal_contents_flex_box .book img{
  filter: drop-shadow(6px 6px 6px rgba(0, 0, 0, 0.2));
}

.modal_contents_flex_box .book_guide{
  width:40%;
  /*background-color: #fffef3;*/
  padding:20px 0;
  filter: drop-shadow(6px 6px 6px rgba(0,0,0,0.2));
}

.modal_contents_flex_box .book_guide h3{
  color:#000;
  font-weight:600;
  font-size: 16px;
  line-height: 1.5;
  margin-bottom: 20px;
}

.modal_contents_flex_box h2{
  color:#000;
  font-weight:600;
  font-size: 30px;
  line-height:1;
  padding: 0;
  display: inline-block;
  /*border-top: solid;
  border-bottom: solid;*/
  position:relative;
}

.vol_1{
  position:absolute;
  top: -70%;
  left: 0%;
  width:20%;
}

.vol_9{
  position:absolute;
  top: -70%;
  left: 0%;
  width:20%;
}

.modal_contents_flex_box .book_guide h2 span.sub{
  font-size: 18px;
}

span.madamada{
  color: #e50050;
  font-size: 24px;
}

.modal_contents_flex_box .book_guide p.guide{
  color:#000;
  font-weight:600;
  margin: 10px 0;
}

.modal_contents_flex_box .tit_select_book_zannen_01{
  width:60%;
  margin:0px 0 0px;
}

.modal_contents_flex_box .tit_select_book_zannen_02{
  width:50%;
  margin:0px 0 0px;
}

@media screen and (max-width: 540px) {

.modal_contents_flex_box{
  padding:20px 10px 0;
}

  .modal_contents_flex_box .book{
  width:100%;
  margin:0 auto;
  padding:0 0px;
}

.modal_contents_flex_box .book_guide{
  width:100%;
  margin: 0px 5px 0;
  padding: 5px 3px;
}

.modal_contents_flex_box h2{
  color:#000;
  font-weight:600;
  font-size:24px;
}

.modal_contents_flex_box .tit_select_book_zannen_01{
  width:65%;
  margin:0px 0 0px;
}
.modal_contents_flex_box .tit_select_book_zannen_02{
  width:70%;
  margin:0px 0 0px;
}
}

@media screen and (max-width: 376px) {

.modal_contents_flex_box{
  padding:20px 10px 0;
}
  .modal_contents_flex_box .book{
  width:100%;
}
 .modal_contents_flex_box .goto_takahashi_web {
    padding: 0px 0!important;
    margin: 0px 0 0!important;
}
}

@media screen and (max-width: 300px) {
.vol_1{
  position:absolute;
  top: -45%;
  left: -5%;
  width:20%;
}
.vol_9{
  position:absolute;
  top: -35%;
  left: -5%;
  width:20%;
}

}

/* ---------- 吹き出し：共通 ---------- */

.block-baloon{
  display:flex;
  align-items:center;
  justify-content: center;
}

.fukidashi_animal{
  width:70px;
  height:89px;
  animation: yurayura 2s linear infinite;
}

.fukidashi_animal_1{
  width:70px;
  height:89px;
  animation: purun 1s linear 0s 1;
}

.block-baloon-right, .block-baloon-left {
  display: table;
  padding: .5em;
  margin: 1em 0;
  position: relative;
  background-color: #fff;
  border: 1px solid #222;
  border-radius: 30px;
}

.block-baloon-right:before, .block-baloon-right:after,
.block-baloon-left:before, .block-baloon-left:after {
  content: '';
  position: absolute;
}

.block-baloon-right h3,
.block-baloon-left h3{
  font-size:18px;
  color: #000;
  line-height: 1.5;
  margin:0 0 10px;
}

.block-baloon-right p,
.block-baloon-left p{
  font-size:16px;
  color: #000;
  line-height: 1.5;
  padding:0;
  font-weight:600;
}

/* ---------- 吹き出し：右 ---------- */
.block-baloon-right {
  margin-right: 1.5em;
  max-width: calc( 100% - 1.5em );
}

.block-baloon-right:before,
.block-baloon-right:after{
  top: 50%;
  transform: translateY(-50%);
  right: -1.5em;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 1.5em solid #222;
}

.block-baloon-right:after {
  right: calc( 2px - 1.5em );
  border-left: solid 1.5em #fff;
}

/* ---------- 吹き出し：左 ---------- */
.block-baloon-left  {
  margin-left: 1.5em;
  max-width: calc( 100% - 1.5em );
}
.block-baloon-left:before, .block-baloon-left:after {
  top: 50%;
  transform: translateY( -50% );
  left: -1.5em;
  border-top: 10px solid transparent;
  border-right: 1.5em solid #222;
  border-bottom: 10px solid transparent;
}
.block-baloon-left:after  {
  left: calc( 2px - 1.5em );
  border-right: solid 1.5em #fff;
}

@media screen and (max-width:539px) {
  .subsc_img{
  width:100%;
}
}
/* ---------- 吹き出し ---------- */

/* ↓こちらのお店でご購入ください↓ */
.modal_contents_flex_box .lineup__list--btns {
    width: 100%;
    display: flex;
    margin: 10px auto 0;
}

.modal_contents_flex_box .lineup__list--btns li{
  width: 33.33%;
  padding: 0 3px;
}

.modal_contents_flex_box .lineup__list--btns li a {
  display: block;
  background-color: #fff;
  border: 1px solid #d1d1d1;
  width: 100%;
  height: 47px;
  position: relative;
  border-radius: 3px;
  box-shadow: 0 4px 3px -1px #dddddd;
}

.modal_contents_flex_box .lineup__list--btns li a img:hover{
  opacity: .6;
}

.modal_contents_flex_box .lineup__list--btns li a img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  padding: 25px;
}

@media screen and (max-width: 480px) {
.modal_contents_flex_box .lineup__list--btns li a img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  padding: 10px;
}

.block-baloon-right p, .block-baloon-left p {
    font-size: 14px;
}

}

@media screen and (max-width: 376px) {

.block-baloon-right, .block-baloon-left {
    margin-top:10px;
    margin-bottom:10px;
}


}

/**************************\
  Basic Modal Styles
\**************************/
.select_book .flex_box button{
  border:none;
  background:none;
  padding:0;
}

.modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0,0,0,0.6);
  display: flex;
  justify-content: center;
  align-items: center;
}

.modal__container {
  background-image: linear-gradient(45deg, #ffe188 25%, transparent 25%), linear-gradient(315deg, #ffe188 25%, #fff3d2 25%);
    background-position: 10px 0, 20px 0, 0 0, 0 0;
    background-size: 20px 20px;
    background-repeat: repeat;
    
  /*background:linear-gradient(135deg, #fee086 25%, transparent 25%) -20px 0/ 40px 40px,
linear-gradient(225deg, #fdecbb 25%, transparent 25%) -20px 0/ 40px 40px,
linear-gradient(315deg, #fee086 25%, transparent 25%) 0px 0/ 40px 40px,
linear-gradient(45deg, #fdecbb 25%, #f9fbed 25%) 0px 0/ 40px 40px;*/
  padding: 0px;
  max-width: 900px;/**/
  max-height: 100vh;
  border-radius: 4px;
  overflow-y: auto;/**/
  box-sizing: border-box;
}

@media screen and (max-width: 541px) {
.modal__container {
  max-height: 90vh;
  max-width: 450px;
}
}

@media screen and (max-width: 480px) {
.modal__container {
  max-height: 96vh;
  max-width: 350px;
}
}

.modal__header {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding:5px 0px;
  }


.modal__close {
  background: transparent;
  border: 0;
  margin-top:5px;
}

.modal__header .modal__close:before {
  content: "\2715";
  border-radius: 50%;
  padding: 5px 9px;
  border: solid 1px;
  background-color:#fff;
}

.modal__content {
  margin-top: 2rem;
  margin-bottom: 2rem;
  line-height: 1.5;
  color: rgba(0,0,0,.8);
  padding: 0 20px;
}

.modal__btn {
    background: #ea5432;
    color: #fff;
    border-radius: 10px;
    padding: 5px 7px;
    display: inline;
    cursor: pointer;
    border: none;
}

.modal__btn:focus, .modal__btn:hover {
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
}

.modal__footer{
  text-align:center;
  padding:20px 20px;
}

@media screen and (max-width: 480px) {
.modal__footer{
  text-align: center;
  padding: 5px 20px 20px;
  position: relative;
  z-index: 100;
}
}


/* 新刊　試し読み追加 */
.new_book .guide .guide_flex{
  display: flex;
  align-items: center;
  justify-content: center;
}

.new_book .guide .btn {
  width: 100px;
  padding: 0;
}

.new_book .guide .btn a {
  width: 100px;
  padding: 0;
}

.new_book .guide .btn{
  position: relative;
}
.new_book .guide .active {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  transition: 0.5s;
}
.new_book .guide .btn:hover .active {
  opacity: 1;
}


@media screen and (min-width:481px) and ( max-width:1024px) {
  .kodomonohon .guide .lineup__list--btns li a img {
  display: block;
  position: absolute;
  top: 6px;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  padding: 5px;
}
.new_book .new_book_about .newbook:after {
  position: absolute;
  top: -55px;
  right: -45px;
  display: block;
  width: 100px;
  height: 90px;
  content: '';
  background: url(../img/new.png) no-repeat center center;
  background-size: contain;
}
}

@media screen and (max-width: 480px) {
.new_book .new_book_about{
  display: block;
}
.new_book .new_book_about .title{
  width: 100%;
  padding-bottom: 30px;
}

.new_book .new_book_about .newbook{
  width: 100%;
  text-align: center;
}
.new_book .new_book_about .newbook:after {
  position: absolute;
  top: -30px;
  right: -5px;
  display: block;
  width: 100px;
  height: 90px;
  content: '';
  background: url(../img/newnew.png) no-repeat center center;
  background-size: contain;
}

.new_book .new_book_about .kodomonohon{
  width: 100%;
}
.new_book .new_book_about .kodomonohon .sousenkyo{
  padding:20px 0 0;
}

.new_book .new_book_about .kodomonohon .guide{
  width: 100%;
}
.kodomonohon .guide .lineup__list--btns li a img {
  display: block;
  position: absolute;
  top: 6px;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  padding: 5px;
}
}


/* #lineup ためしよみ＆本の購入はこちら！
------------------------------*/
/* lineup_01 ざんなんないきもの事典 */

.lineup_01 {
  background-image: radial-gradient(#ffe100 2px, #fff4d3 2px);
  background-size: 20px 20px;
}

/*.lineup_01 {
    background: linear-gradient(135deg, #f5dfa1 25%, transparent 25%) -20px 0 / 40px 40px,
    linear-gradient(225deg, #f9e9bb 25%, transparent 25%) -20px 0 / 40px 40px,
    linear-gradient(315deg, #f5dfa1 25%, transparent 25%) 0px 0 / 40px 40px,
    linear-gradient(45deg, #f9e9bb 25%, #f9fbed 25%) 0px 0 / 40px 40px;
}*/

.lineup_01 .title{
  position:relative;
  text-align: center;
  margin-bottom: 40px;
}
.lineup_01 .title h4{
  position: absolute;
  top: 12px;
  left:53%;
  filter: drop-shadow(2px 2px 5px rgb(0, 0, 0, .2));
}
@media screen and (max-width: 480px) {
  .lineup_01 .title h4{
  position: absolute;
  top: 12px;
  left:59%;
}
.lineup_01 .title{
  margin-bottom: 10px;
}
  }

.lineup_01 .title h4 img{
  animation: fuwafuwa 0.7s infinite linear alternate;
}

@keyframes fuwafuwa {
  0% {
        transform: translate(0px, 0);
    }
    100% {
        transform: translate(10px, 0);
    }
}

.lineup_01 .lineup__list{
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  padding-top: 0px;
}

.lineup_01 .lineup__list:first-child{
  padding-top: 50px;
}

.lineup_01 .lineup__list:last-child{
  background-color: rgba(255, 255, 255, 0.7);
  max-width: 660px;
  margin: auto;
  padding: 20px;
}

.lineup_01 .lineup__list .lineup__list--item{
  width: calc((100% - 30px) / 3);
  min-height: 250px;
  margin: 0 0 20px;
  padding: 1rem 1rem 1.5rem;
  position: relative; 
 }

 .lineup_01 .lineup__list .lineup__list--item.new,
 .lineup_01 .lineup__list .lineup__list--item.second{
  width: auto;
  /*width: calc((100% - 30px) / 2);*/
  min-height: 250px;
  margin: 0 40px 20px;
  padding: 1rem 0rem 1.5rem;
  position: relative;
 }

 .lineup_01 .lineup__list .lineup__list--item.set10{
  width: calc((100% - 10px) / 1);/**/
  min-height: 250px;
  margin: 0 auto;
  padding: 0 40px 20px;
  position: relative;
  }

 .lineup_01 .lineup__list .lineup__list--item.set10 h3{
  font-size: 20px;
    line-height: 22px;
    margin-bottom: 10px;
    font-weight: 600;
 }

 .lineup_01 .lineup__list .lineup__list--item.new .lineup__list--img,
 .lineup_01 .lineup__list .lineup__list--item.second .lineup__list--img,
 .lineup_01 .lineup__list .lineup__list--item.set10 .lineup__list--img {
  max-width: 100%;
  margin: 0 auto;
  box-shadow: 2px 5px 10px 2px rgba(0, 0, 0, 0.2);
  position: relative;
  text-align: center;
}

.lineup__list--img a{
  max-width: 100%;
  margin: 0 auto;
}

 .lineup_01 .lineup__list .lineup__list--item.new .lineup__list--img:hover,
 .lineup_01 .lineup__list .lineup__list--item.second .lineup__list--img:hover,
  .lineup_01 .lineup__list .lineup__list--item.set10 .lineup__list--img:hover{
  box-shadow: unset;
  transform: translateY(4px);
}

.lineup__list--item.new:after {
    position: absolute;
    top: -19px;
    left: 0px;
    display: block;
    width: 110px;
    height: 90px;
    content: '';
    background: url(../img/newnew.png) no-repeat center center;
    background-size: contain;
}

.lineup_01 .lineup__list .lineup__list--item .icon_vol{
  position: absolute;
  top: -45px;
  right: -30px;
  display: block;
  width: 100px;
  height: 100px;
  z-index:2;
}

.lineup__list--img {
  max-width: 80%;
  margin: 0 auto;
  box-shadow: 2px 5px 10px 2px rgba(0, 0, 0, 0.2);
  position: relative;
  text-align: center;
}

.lineup__list--img a{
  max-width: 100%;
  margin: 0 auto;
}

.lineup__list--img:hover{
  box-shadow: unset;
  transform: translateY(4px);
}

.lineup__list--img .goto_takahashi_site{
  text-align: center;
  font-weight: 600;
  padding: 3px 0;
  margin: 10px 0 0;
  background: #ee1c25;
  color: #fff;
  border-radius: 10px;
  position: relative;
}

.lineup__list--img .goto_takahashi_site:before {
    content: "";
    display:inline-block;
    width: 0;
    height: 0;
    border-top: solid 6px transparent;
    border-right: solid 6px transparent;
    border-bottom: solid 6px transparent;
    border-left: solid 6px #fff;
    position: absolute;
    top: 50%;
    right:20px;
    margin-top:-6px;
}

.goto_takahashi_web{
  color: #ee1c25;
  padding: 0px 0;
  margin: 0px 0 0;
  font-size: 14px;
  text-align: center;
  font-weight: 600;
  text-decoration: underline;
}

.lineup__list--img .goto_takahashi_site{
  text-align: center;
  font-weight: 600;
  padding: 3px 0;
  margin: 10px 0 0;
  background: #ee1c25;
  color: #fff;
  border-radius: 10px;
  position: relative;
}

.lineup__list--img .goto_takahashi_site:before {
    content: "";
    display:inline-block;
    width: 0;
    height: 0;
    border-top: solid 6px transparent;
    border-right: solid 6px transparent;
    border-bottom: solid 6px transparent;
    border-left: solid 6px #fff;
    position: absolute;
    top: 50%;
    right:20px;
    margin-top:-6px;
}

.lineup_01 .lineup__list--detail {
  display: -webkit-box;
  display: flex;
  padding: 20px 0 5px;
  border-bottom: 1px solid #b2a6ba;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  justify-content: space-between;
}

.lineup_01 .lineup__list .lineup__list--item.new .lineup__list--detail {
    display: -webkit-box;
    display: flex;
    padding: 20px 0 5px;
    border-bottom: 1px solid #b2a6ba;
    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    justify-content: space-between;
}

.lineup__list--detail dl {
  font-size: 14px;
  line-height: 1.4;
  -webkit-box-flex: 1;
  flex: 1;
}

.lineup__list--detail dt {
  font-weight: bold;
  float: left;
  clear: both;
  width: 5em;
}
.lineup__list--detail dd{
  font-weight: bold;
}


.lineup__list--detail .btn {
  width: 100px;
  padding: 0;
}

.lineup__list--detail .btn a {
  width: 100px;
  padding: 0;
}
/*.lineup__list--detail .btn a:hover{
  opacity: .7;
}*/


.lineup__list--detail .btn{
  position: relative;
}
.lineup__list--detail .btn .active {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  transition: 0.5s;
}
.lineup__list--detail .btn:hover .active {
  opacity: 1;
}

.lineup__list--price {
  font-family: 'Hiragino Kaku Gothic ProN','メイリオ', sans-serif;
  font-size: 14px;
  font-weight: bold;
  text-align: right;
}

p.shop_guide{
  font-size: 16px;
    line-height: 27px;
     padding-bottom: 0px;
    color: #222;
    font-weight: 600;
    padding-top: 15px;
    text-align: center;
 }
.lineup__list--price .num {
  font-size: 18px;
  vertical-align: baseline;
}

.lineup__list--btns {
  width: 100%;
  display: flex;
  flex-wrap:wrap;
  margin: 20px -3px 0;
}

.lineup_01 .lineup__list--btns li{
  width:50%!important;
  padding:0 5px 10px;
  /*width: 33.33%;
  padding: 0 3px;*/
}

.lineup__list--btns li a {
  display: block;
  background-color: #fff;
  border: 1px solid #d1d1d1;
  width: 100%;
  height: 47px;
  position: relative;
  border-radius: 3px;
  box-shadow: 0 4px 3px -1px #dddddd;
}


.lineup__list--btns li a.takahashi_official {
  display: block;
  background-color: #fff;
  border: 2px solid #0033a1;
  color:#0033a1;
  font-weight: bold;
  line-height:1.2;
  text-align:center;
  width: 100%;
  height: 47px;
  position: relative;
  border-radius: 3px;
  box-shadow: 0 4px 3px -1px #dddddd;
  padding:3px 0;
}

.lineup__list--btns li.takahashi_official {
  display: block;
  background-color: #fff;
  border: 2px solid #0033a1;
  color:#0033a1;
  font-weight: bold;
  line-height:1.2;
  text-align:center;
  width: 100%;
  height: 47px;
  position: relative;
  border-radius: 3px;
  box-shadow: 0 4px 3px -1px #dddddd;
  padding:3px 0;
}

.lineup__list--btns li a.other_shop {
  display: block;
  background-color: #0033a1;
  border: 2px solid #0033a1;
  color:#fff;
  font-weight: bold;
  line-height:37px;
  text-align:center;
  width: 100%;
  height: 47px;
  position: relative;
  border-radius: 3px;
  box-shadow: 0 4px 3px -1px #dddddd;
  padding:3px 0;
}

.lineup__list--btns li a:hover{
  opacity: .6;
}

.lineup__list--btns li a img:hover{
  opacity: .6;
}

.lineup_01 .lineup__list--btns li a img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  padding: 40px;
}

@media screen and (min-width:769px) and ( max-width:1199px) {
  .lineup_01 .lineup__list--btns li a img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  padding: 40px;
}
}

@media screen and (min-width:768px) and ( max-width:820px) {
  .lineup_01 .lineup__list .lineup__list--item.new,
  .lineup_01 .lineup__list .lineup__list--item.second{
    width: calc((100% - 100px) / 2);
    min-height: 250px;
    margin: 0 20px 20px;
    padding: 1rem 0rem 1.5rem;
    position: relative;
}
}

@media screen and (min-width:481px) and ( max-width:768px) {
.lineup_01 .lineup__list .lineup__list--item{
  width: calc((100% - 10px) / 2);
  min-height: 250px;
  margin: 0 auto 20px;
  padding: 1rem 1rem 1.5rem;
  position: relative;
  display: flex;
  flex-direction: column;
 }

 .lineup_01 .lineup__list--btns li a img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  padding: 40px;
}
}

@media screen and (max-width: 480px) {
  .lineup_01 .lineup__list{
  display: block;
  justify-content: center;
  flex-wrap: wrap;
  padding-top: 0px;
}

.lineup_01 .lineup__list:first-child{
  padding-top: 50px;
}

.lineup_01 .lineup__list:last-child {
    background-color: rgba(255, 255, 255, 0.7);
    max-width: 728px;
    margin: auto 10px;
    padding: 10px;
}

.lineup_01 .lineup__list .lineup__list--item.new {
   width: auto;
   min-height: 250px;
   margin: 0 40px 20px;
   padding: 1rem 0rem 1.5rem;
   position: relative;
 }

 .lineup_01 .lineup__list .lineup__list--item {
    width: calc((100% - 30px) / 1);
    min-height: 250px;
    margin: 0 auto 20px;
    padding: 1rem 1rem 1.5rem;
    position: relative;
}

.lineup_01 .lineup__list .lineup__list--item.set10 {
    width: calc((100% - 30px) / 1);
    min-height: 250px;
    margin: 0 auto 20px;
    padding: 1rem 0rem 1.5rem;
    position: relative;
}

 .lineup_01 .lineup__list--btns li a img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  padding: 40px;
}
}

@media screen and (max-width: 300px) {
   .lineup_01 .lineup__list--btns li a img {
  padding: 20px;
}
}

/* lineup_02 オススメのいきものシリーズ */
.lineup_02{
  background-color: #e7f6e1;
  padding: 40px 0 15px;
}

.lineup_02 .title{
  text-align: center;
}
.lineup_02 .title p{
  font-weight: 600;
}

.lineup_02 .lineup__list{
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.lineup_02 .lineup__list .lineup__list--item{
  width: calc((100% - 10px) / 4);
  min-height: 250px;
  margin: 0 0 20px;
  padding: 1rem 1rem 1.5rem;
  position: relative;
  display: flex;
  flex-direction: column;
 }

 .lineup_02 .lineup__list--detail {
  display: -webkit-box;
  display: block;
  padding: 10px 0 5px;
  border-bottom: none;
  -webkit-box-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  justify-content: space-between;
  text-align: center;
}

 .lineup_02 .lineup__list--btns {
  width: 100%;
  display: flex;
  margin: auto -3px 0;
}

.lineup_02 .lineup__list--btns li {
  width: 33.33%;
  padding: 0 3px;
}

 .lineup_02 .lineup__list--btns li a img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  padding: 15px;
}
@media screen and (min-width:770px) and ( max-width:1199px) {
  .lineup_02 .lineup__list--btns li a img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  padding: 5px;
}
}
@media screen and (min-width:481px) and ( max-width:769px) {
.lineup_02 .lineup__list .lineup__list--item{
  width: calc((100% - 10px) / 2);
  min-height: 250px;
  margin: 0 auto 20px;
  padding: 1rem 1rem 1.5rem;
  position: relative;
  display: flex;
  flex-direction: column;
 }
  .lineup_02 .lineup__list--btns li a img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  padding: 15px;
}
}

@media screen and (max-width: 480px) {
  .lineup_02 .lineup__list{
  display: block;
  justify-content: center;
  flex-wrap: wrap;
}

.lineup_02 .lineup__list .lineup__list--item{
  width: calc((100% - 10px) / 1);
  min-height: 250px;
  margin: 0 auto 20px;
  padding: 1rem 1rem 1.5rem;
  position: relative;
  display: flex;
  flex-direction: column;
 }
}

/* pagetop ページのTOPへ戻る
------------------------------*/

#page-top {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 10;
}

#page-top a {
  width: 60px;
  padding: 28px 5px;
  text-align: center;
  display: block;
  transition: all .3s ease;
  z-index: 11;
  position: relative;

}

#page-top a:hover {
  text-decoration: none;
  /*opacity: .5;*/
}

@media screen and (max-width: 480px) {
  #page-top {
  bottom: 0px;
  right: 0px;
}
}


/* footer フッター
------------------------------*/
footer.zannen_footer{
  text-align:center;
  padding: 0px 0;
}

footer ul.sns_list{
  display: flex;
  justify-content: center;
}

footer ul.sns_list li{
  padding: 20px 20px;
}

footer ul.sns_list li p{
  padding: 8px 0 0;
  font-size: 12px;
}

footer p.copyright {
  font-size: 14px;
}
.is-open {
  top: -20px;
  opacity: 1
}

.pc_only{
  display:block;
}
.sp_only{
  display:none;
}

.pc_br{
  display: block;
}
.pc_inline{
    display: inline;
  }
.sp_br{
    display: none;
  }
.sp_inline{
    display: none;
  }

.sp-tablet_only{
  display: none!important;
}

@media screen and (max-width: 1200px) {
.sp-tablet_only{
  display: block!important;
}
  }

@media screen and (max-width: 767px) {
  .pc_only{
  display:none;
}
.sp_only{
  display:block;
}
}

@media screen and (max-width: 480px) {
  .pc_br{
  display: none;
}
.pc_inline{
    display: none;
  }
  .sp_br{
    display: block;
  }
  .sp_inline{
    display: inline;
  }
}


/* .modaal-content-container */
.modaal-container{
  border-radius: 12px;
  max-width:600px;
}

.modaal-content-container{
  border-radius: 12px;
  padding: 10px 10px 10px;
}
.modaal-content-container p.lead{
  font-size: 18px;
  font-weight: 600;
  text-align: center;
  line-height: 1.8;
  margin-top: 40px;
}
.modaal-content-container p.lead br{
  display: block;
}

.modaal-content-container p.book{
  text-align:center;
  padding:0 10px 10px;
}

.modaal-content-container .center_btn{
  text-align: center;
}
.modaal-content-container .close_btn{
  background: #d81718;
  color:#fff;
  border-radius: 10px;
  padding: 5px 7px;
  display: inline;
  cursor: pointer;
}
.modaal-content-container .close_btn a{
  color:#fff;
  }

@media screen and (max-width: 480px) {
  .modaal-content-container p.lead{
  font-size: 14px;
}
.modaal-content-container p.lead br{
  display: none;
}
.modaal-content-container {
    padding: 10px;
}
  }

/*何？*/
.modaal-content-container .inline1_title{
  position: relative;
  text-align: center;
}
.modaal-content-container .inline1_title h1,
.modaal-content-container .inline1_title h2{
  position: absolute;
  z-index: 10;
}
.modaal-content-container .inline1_title img.z-index1{
  z-index: 9;
}
.modaal-content-container .inline1_title h1{
  top: 30%;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  width: 90%;
}
.modaal-content-container .inline1_title h2{
  top: 80%;
  width: 90%;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}

/**/
header {
    position: fixed;
    width: 100%;
    z-index: 25;
}

main.contents_zannen {
    overflow: hidden;
    padding-top: 65px;
    z-index: 1;
}

/* 202203 zannen_contents スライダー */
.zannen_contents_slider{
  width: calc((100% - 10px) / 2);
  margin: 2em auto;
  padding: 2em;
  position: relative;
}

.zannen_contents_slider .swiper-container {
    padding-bottom: 68px;
}

.zannen_contents_slider .swiper-slide{
  text-align: center;
}

.zannen_contents_slider .swiper-slide img{
  max-width: 100%;
  margin: auto;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .zannen_contents_slider{
  width: calc((100% - 10px) / 2);
  padding: 20px 0;
}
  }

@media screen and (min-width:768px) and ( max-width:834px) {
.zannen_contents_slider{
  width: 100%;
  padding: 30px 0;
}
}

@media screen and ( max-width:767px) {
.zannen_contents_slider{
  width: 100%;
  padding: 30px 0;
}
  }


/**/
.zan_content_0001{
  margin-top: 20px;
  display:flex;
  justify-content: center;
  align-items: center;
}
.slide_guide_0001{
  width: calc((100% - 10px) / 2);
  padding: 0 2%;
}

.slide_0001{
  width: calc((100% - 10px) / 2);/*width: calc((100% - 100px) / 2);*/
  background-color: #fff;
  margin: 2em 0;
  padding: 2em;
  position: relative;
  /*padding: 30px 0;*/
  border: 25px solid #c69455;
    box-shadow: 2px 2px 10px #79521f, 2px 2px 2px #79521f inset;
}

.slide_guide_0001 h2{
  line-height: 2rem;
  margin: 0 0 20px;
}

.slide_guide_0001 h2 br{
  display: block;
}

/*=== 画像の表示エリア ================================= */
.slide_content_0001 {
  position   : relative;
  overflow   : hidden;
  /* 画像のサイズに合わせて変更ください */
  width      : 380px;
  height     : 380px;
  margin     : auto;
}

 /*=== 画像の設定 ======================================= */
.slide_content_0001 img {
  display    : block;
  position   : absolute;
  /* 画像のサイズを表示エリアに合せる */
  width      : inherit;
  height     : inherit;
  opacity    : 0;
  animation  : slideAnime 15s ease infinite;
}

 /*=== スライドのアニメーションを段差で開始する ========= */
.slide_content_0001 img:nth-of-type(1) { animation-delay: 0s }
.slide_content_0001 img:nth-of-type(2) { animation-delay: 3s }
.slide_content_0001 img:nth-of-type(3) { animation-delay: 6s }
.slide_content_0001 img:nth-of-type(4) { animation-delay: 9s }
.slide_content_0001 img:nth-of-type(5) { animation-delay: 12s }

 /*=== スライドのアニメーション ========================= */
@keyframes slideAnime{
   0% { opacity: 0; transform: rotateY(90deg) }
   1% { opacity: 1; transform: rotateY(0deg)  }
  19% { opacity: 1; transform: rotateY(0deg)  }
  20% { opacity: 0; transform: rotateY(90deg) }
 100% { opacity: 0; transform: rotateY(90deg) }
}

@media screen and (max-width: 768px) {
  .slide_0001{
  width: calc((100% - 10px) / 2);
  padding: 20px 0;
}

.slide_guide_0001 h2 {
  text-align: left;
}
.slide_guide_0001 h2 br{
  display: none;
}
/*=== 画像の表示エリア ================================= */
.slide_content_0001 {
  width      : 350px;
  height     : 350px;
}
  }

@media screen and (min-width:768px) and ( max-width:834px) {
  .zan_content_0001{
  margin-top: 20px;
  display:block;
}
.slide_guide_0001{
  width: 100%;
  padding: 20px 2% 0;
}

.slide_0001{
  width: 100%;
  padding: 30px 0;
}
/*=== 画像の表示エリア ================================= */
.slide_content_0001 {
  width      : 290px;
  height     : 290px;
}
}

@media screen and (min-width:370px) and ( max-width:767px) {
  .zan_content_0001{
  margin-top: 20px;
  display:block;
}

.slide_guide_0001{
  width: 100%;
  padding: 20px 2% 0;
}

.slide_0001{
  width: 100%;
  padding: 30px 0;
}
/*=== 画像の表示エリア ================================= */
.slide_content_0001 {
  width      : 290px;
  height     : 290px;
}
  }

@media screen and (max-width: 369px) {
  .zan_content_0001{
  margin-top: 20px;
  display:block;
}

.slide_guide_0001{
  width: 100%;
  padding: 20px 2% 0;
}

.slide_0001{
  width: 100%;
  padding: 30px 0;
}
/*=== 画像の表示エリア ================================= */
.slide_content_0001 {
  width      : 240px;
  height     : 240px;
}
  }




/* 2021/03/29 */

/* --------------------------------------------------- side menu */
.menu {
  position: fixed;
  display: table;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;/*height: 100%;*/
  background: rgba(0,0,0,.8);
  -webkit-transition: all .5s;
  transition: all .5s;
  visibility: hidden;
  opacity: 0;
  z-index: 100;
}

.side-open .menu {
  cursor: url(../img/cross.svg),auto;
  -webkit-transition: all .5s;
  transition: all .5s;
  visibility: visible;
  opacity: 1;
}

.menu ul {
  display: table-cell;
  vertical-align: middle;
}

.menu li {
  width: 300px;
  margin: 0 auto;
  text-align: center;
  opacity: 0;
  
}
.menu li img{
  margin-right: 5px;
}
.menu li p{
  color: #fff;
  display: inline-block;
  vertical-align: middle;
  
}


.side-open .menu li {
  opacity: 1;
}

.side-open .menu li:nth-child(1) {
  -webkit-transition: opacity 1s ease .5s;
  transition: opacity 1s ease .5s;
}

.side-open .menu li:nth-child(2) {
  -webkit-transition: opacity 1s ease .6s;
  transition: opacity 1s ease .6s;
}

.side-open .menu li:nth-child(3) {
  -webkit-transition: opacity 1s ease .7s;
  transition: opacity 1s ease .7s;
}

.side-open .menu li:nth-child(4) {
  -webkit-transition: opacity 1s ease .8s;
  transition: opacity 1s ease .8s;
}

.side-open .menu li:nth-child(5) {
  -webkit-transition: opacity 1s ease .9s;
  transition: opacity 1s ease .9s;
}

.menu li a {
  display: block;
  height: 80px;
  line-height: 80px;
  font-size: 18px;
  color: #f5f5f5;
  -webkit-transition: all .5s;
  transition: all .5s;
}

.menu li a:hover {
  color: #999;
}

/* --------------------------------------------------- menu-btn */
.menu-btn {
  position: fixed;/*position: absolute;*/
  top: 50%;/*top: 200px;*/
  right: 0px;
  /*width: 100px;*/
  /*height: 50px;*/
  line-height: 50px;
 /* font-size: 12px;*/
  padding: 20px 0;
  text-align: center;
  cursor: pointer;
  z-index: 101;
  background:#fbd31c;
  -webkit-writing-mode: vertical-rl; /* Chrome,Safari対応*/
      -ms-writing-mode: tb-rl; /* IE対応*/
          writing-mode: vertical-rl;
border-radius: 20px 0px 0px 20px;
}

@media screen and (max-width: 480px) {
  .menu-btn {
  position: fixed;
  top: 50%;
  right: 0px;
  line-height: 30px;
}
  }

.menu-btn span {
  color: #222;
  font-weight: bold;
}

.menu-btn span:after {
  content: attr(data-txt-open);
}

.side-open .menu-btn span:after {
  content: attr(data-txt-close);
}

.menu-btn:hover span:nth-child(1):after {
  -webkit-animation: anim .5s ease 0s forwards;
  animation: anim .5s ease 0s forwards;
}

.menu-btn:hover span:nth-child(2):after {
  -webkit-animation: anim .5s ease .1s forwards;
  animation: anim .5s ease .1s forwards;
}

.menu-btn:hover span:nth-child(3):after {
  -webkit-animation: anim .5s ease .2s forwards;
  animation: anim .5s ease .2s forwards;
}

.menu-btn:hover span:nth-child(4):after {
  -webkit-animation: anim .5s ease .3s forwards;
  animation: anim .5s ease .3s forwards;
}

.menu-btn:hover span:nth-child(5):after {
  -webkit-animation: anim .5s ease .4s forwards;
  animation: anim .5s ease .4s forwards;
}

@-webkit-keyframes anim {
  0% {-webkit-transform:translateY(0px);transform:translateY(0px);}
  50% {-webkit-transform:translateY(-5px);transform:translateY(-5px);}
  100% {-webkit-transform:translateY(0px);transform:translateY(0px);}
}

@keyframes anim {
  0% {-webkit-transform:translateY(0px);transform:translateY(0px);}
  50% {-webkit-transform:translateY(-5px);transform:translateY(-5px);}
  100% {-webkit-transform:translateY(0px);transform:translateY(0px);}
}



/* 2022/03/25 ためしよみボタン位置変更 */

/*　新刊本 */
.newbook .btn{
  position: absolute;
  width: 100px;
  bottom: -8%;
  right: -3%;
  z-index: 5;
  padding: 0;
}

.newbook .btn a {
  width: 100px;
  padding: 0;
}

.newbook .btn .active {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  transition: 0.5s;
}
.newbook .btn:hover .active {
  opacity: 1;
}

@media screen and (max-width: 480px) {
  .newbook .btn{
  position: absolute;
  width: 100px;
  bottom: -5%;
  right: -3%;
  z-index: 5;
  padding: 0;
}
  }

/*　本リスト */
.lineup__list--img .btn{
  position: absolute;
  width: 100px;
  bottom: -15%;
  right: -8%;
  z-index: 5;
  padding: 0;
}


.lineup__list--img .btn a {
  width: 100px;
  padding: 0;
}

.lineup__list--img .btn .active {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  transition: 0.5s;
}
.lineup__list--img .btn:hover .active {
  opacity: 1;
}


/*-----------------------------------
zannen_creator
-----------------------------------*/
.zannen_creator{}

.zannen_creator h2{
  font-size:18px;
  font-weight:600;
  color: #231815;
  padding:10px 0;
}

.zannen_creator .zannen_creator_inner{
  display:flex;
}

.zannen_creator .zannen_creator_inner .photo{
  width:30%;
  padding:10px 0;
  text-align:center;
}

.zannen_creator .zannen_creator_inner .about_text{
  width:70%;
  padding:10px;
}

@media screen and (max-width: 540px) {
  .zannen_creator h2{
  text-align:center;
  padding:20px 0 10px;
}

  .zannen_creator .zannen_creator_inner{
  display:block;
}

.zannen_creator .zannen_creator_inner .photo{
  width:70%;
  padding:10px 0;
  text-align:center;
  margin:auto;
}

.zannen_creator .zannen_creator_inner .about_text{
  width:100%;
  padding:10px;
  margin:auto;
}
  }








/**************************\
  Animation Style
\**************************/
@keyframes mmfadeIn {
    from { opacity: 0; }
      to { opacity: 1; }
}

@keyframes mmfadeOut {
    from { opacity: 1; }
      to { opacity: 0; }
}

@keyframes mmslideIn {
  from { transform: translateY(15%); }
    to { transform: translateY(0); }
}

@keyframes mmslideOut {
    from { transform: translateY(0); }
    to { transform: translateY(-10%); }
}

.micromodal-slide {
  display: none;
}

.micromodal-slide.is-open {
  display: block;
}

.micromodal-slide[aria-hidden="false"] .modal__overlay {
  animation: mmfadeIn .3s cubic-bezier(0.0, 0.0, 0.2, 1);
}

.micromodal-slide[aria-hidden="false"] .modal__container {
  animation: mmslideIn .3s cubic-bezier(0, 0, .2, 1);
}

.micromodal-slide[aria-hidden="true"] .modal__overlay {
  animation: mmfadeOut .3s cubic-bezier(0.0, 0.0, 0.2, 1);
}

.micromodal-slide[aria-hidden="true"] .modal__container {
  animation: mmslideOut .3s cubic-bezier(0, 0, .2, 1);
}

.micromodal-slide .modal__container,
.micromodal-slide .modal__overlay {
  will-change: transform;
}


/*カラミーカートに入れる対応*/
.cartjs_box{
  padding: 0 !important;
  position: relative;
}
.cartjs_product_img{
  display: none;
}
.cartjs_cart_in .cartjs_product_name{
  display: none;
}
.cartjs_product_table{
  display: none;
}
.cartjs_sk_link_other{
  display: none;
}

.cartjs_cart_in input {
  display: block;
  background-color: #fff !important;
  border: 2px solid #0033a1 !important;
  color: #0033a1 !important;
  font-weight: bold;
  line-height: 1.2;
  width: 100%!important;
  height: 47px !important;
  position: relative;
  border-radius: 3px !important;
  box-shadow: 0 4px 3px -1px #dddddd;
  padding: 3px 0;
  margin-bottom: 0!important;
  background: url(../img/bg_official.png) center no-repeat;
  text-indent: -9999px;
}



.cartjs_cart_in input value{
  visibility: hidden;
}

.takahashi_official_btn{
  position: relative;
  height: 47px;
}

.takahashi_official_btn .cartjs_box .cartjs_cart_in{
  position: absolute;
  top:0;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}
