@charset "utf-8";

/*Original*/
.wrapper {
  --header-height: 120px;
  max-width: 100%;
  min-width: 1280px;
  margin: var(--header-height) auto 0;
  position: relative;
  transition: all 0.6s ease-out;
}
.top .wrapper  {
   --header-height: 156px;
}
.wrapper.active{
  padding: 66px 0 0 0;
}
header {
  width: 100%;
  max-width: 100%;
  min-width: 1280px;
  margin: 0 auto;
  position: fixed;
  top: 0;
  z-index: 8000;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
}

header .header-nav-toggle {
  padding-right: 4px;
}
header .header-nav-toggle a {
    display: block;
    width: 44px;
    position: relative;
    color: #000;
    padding-top: 26px;
    font-size: 11px;
    font-size: 1.1rem;
    transition: opacity .3s;
}
header .header-nav-toggle a::before {
    content: "";
    width: 28px;
    height: 2px;
    display: inline-block;
    position: absolute;
    top: 27%;
    left: calc(50% - 14px);
    bottom: 0;
    background: #000;
}
header .header-nav-toggle a::after{
    content: "";
    width: 28px;
    height: 22px;
    display: inline-block;
    position: absolute;
    top: 0;
    left: calc(50% - 14px);
    bottom: 0;
    border-top: 2px solid #000;
    border-bottom: 2px solid #000;
}

header .header-nav-toggle a:hover {
  opacity: 0.5;
}
header .header-column {
  padding: 5px 25px;
  align-items: center;
  background-color: #fff;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 700;
}
.top header .header-column {
    padding-top: 24px;
    padding-bottom: 24px;
    transition: all 0.3s ease-in-out 0s;
}
.top header.HeightMin .header-column {
  padding-top: 5px;
  padding-bottom: 5px;
}
header .header-logo {
  width: 195px;
  margin: 0 auto;
  position: relative;
  left: 107px;
}
header .header-logo a {
  display: block;
  line-height: 0;
}
.top header .header-logo {
    width: 260px;
    transition: all 0.3s ease-in-out 0s;
}
.top header.HeightMin .header-logo {
  width: 195px;
}
.header-top {
  min-height: 56px;
}
header .header-nav {
  border-top: 1px solid #000;
  padding: 21px 0 23px;
  min-height: 62px;
}
.header-nav {
background: #fff;
}
.header-nav-list {
 display: flex;
 justify-content: center;
}
.header-nav-item--webinar {
position: relative;
margin-left: 24px;
}
.header-nav-item--webinar {
  transition: opacity .3s;
}
.header-nav-item--webinar:hover {
  opacity: 0.3;
}
.header-nav-item--webinar::before {
  position: absolute;
  content:"";
  width: 19px;
  height: 14px;
  background: url(/common/images/bungeishunju/common/webinar.svg) top left no-repeat;
  background-size: 100% auto;
  top: calc(50% - 6px);
  left: -25px;
  z-index: 2;
}
.header-nav-item--webinar.current::before {
  background: url(/common/images/bungeishunju/common/webinar-red.svg) top left no-repeat;
}

header .header-nav-item {
  float: left;
  margin-right: 50px;
  font-weight: bold;
  font-size: 14px;
  font-size: 1.4rem;
}
header .header-nav-item:last-of-type {
  margin-right: 0;
}
header .header-nav-link {
  position: relative;
  display: inline-block;
  color: #000;
  transition: opacity .3s;
}
header .header-nav-link:hover {
  opacity: .5;
}
header .header-nav-link::after {
  content: "";
  width: 100%;
  height: 2px;
  position: absolute;
  bottom: 2px;
  left: 0;
  background: #fff;
  opacity: 0;
  visibility: hidden;
  transition: .3s;
}
header .header-nav-item.current .header-nav-link {
  color: #d21818;
}

header .header-contents {
  margin-left: 0;
  align-items: center;
  min-width: 265px;
  justify-content: flex-end;
  height: 47px;
}
header .header-contents li a,
header .header-contents li button {
  display: block;
  color: #fff;
  transition: opacity .3s;
}
header .header-contents li a:hover,
header .header-contents li button:hover {
  opacity: 0.5;
}
header .header-contents .header-search,
header .header-contents .header-read-later,
header .header-contents .header-login,
header .header-contents .header-sign-up,
header .header-contents .header-mypage,
header .header-contents .header-logout {
  width: 56px;
  height: 46px;
  margin-right: 10px;
  position: relative;
}
header .header-contents .header-search button.active img {
  visibility: hidden;
}
header .header-contents .header-search button.active::before,
header .header-contents .header-search button.active::after {
  content: "";
  width: 28px;
  display: block;
  position: absolute;
  top: 30%;
  left: 15px;
  border-top: 1px solid #000;
}
header .header-contents .header-search button.active::before {
  transform: rotate(-45deg);
}
header .header-contents .header-search button.active::after {
  transform: rotate(45deg);
}
header .header-contents .header-search button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  appearance: none;
  margin: auto;
}
header .header-contents .header-search button * {
  pointer-events: none;
}
header .header-contents .header-search button,
header .header-contents .header-read-later a,
header .header-contents .header-login a,
header .header-contents .header-sign-up a,
header .header-contents .header-mypage a,
header .header-contents .header-logout a {
  background-size: 21px;
  color: #000;
  font-size: 11px;
  font-size: 1.1rem;
  text-align: center;
  margin-top: 1px;
}
header .header-contents .header-search button img,
header .header-contents .header-read-later a img,
header .header-contents .header-login a img,
header .header-contents .header-sign-up a img,
header .header-contents .header-mypage a img,
header .header-contents .header-logout a img {
  height: 28px;
}
header .header-contents .header-search button p,
header .header-contents .header-read-later a p,
header .header-contents .header-login a p,
header .header-contents .header-sign-up a p,
header .header-contents .header-mypage a p,
header .header-contents .header-logout a p {
  font-size: 11px;
  font-weight: 700;
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
}

header .header-panel {
  position: relative;
}
header .header-panel .search {
  width: 100%;
  position: absolute;
  top: 1px;
  left: 0;
  overflow: hidden;
  background: #fff;
  display: none;
  z-index: 3;
}
header .header-panel .search-form {
  width: 560px;
  margin: 0 auto;
  padding: 10px 0;
  display: block;
}
header .header-panel .search-form .form-inner {
  position: relative;
  border-bottom: 1px solid #000;
}
header .header-panel .search-form input[type='text'] {
  width: 100%;
  height: 40px;
  position: relative;
  padding-right: 40px;
  background: transparent;
  border: none;
  outline: none;
}
header .header-panel .search-form input[type='text']:-webkit-autofill {
  -webkit-box-shadow: 0 0 0px 1000px #fff inset;
  -webkit-text-fill-color: #000 !important;
}
header .header-panel .search-form button[type="submit"] {
  width: 24px;
  height: 27px;
  margin: auto 0;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 8px;
  cursor: pointer;
  background-image: url(/common/images/bungeishunju/common/search.svg);
  background-color: #fff;
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: left top;
  border: none;
  outline: none;
}

.footer {
  margin-top: 50px;
  align-items: center;
  font-size: 12px;
}

.footerbtnWrap{
  display: grid;
  grid-template-columns: 1fr 1fr;
  .footerbtnWrap--col{
    height: 66px;
    display: grid;
    place-content: center;
    font-size: 1.6rem;
    font-weight: bold;
    span{
      display: flex;
      flex-wrap: wrap;
      justfy-content: center;
      align-items: center;
    }
    &.mailmagazine{
      color: #fff;
      background: #000;
      a{
        width: 168px;
        height: 30px;
        margin: 0 0 0 10px;
        font-size: 1.6rem;
        font-weight: bold;
        color: #000;
        border-radius: 100px;
        display: grid;
        place-content: center;
        background: #fff;
        transition: all .3s;
        @media (any-hover: hover) {
            &:hover{
            color: #fff;
            background: #0F92D7;
          }
        }
      }
    }
    &.registrations{
      color: #000;
      background: rgba(184,215,207,0.3);
      a{
        width: 168px;
        height: 30px;
        margin: 0 0 0 10px;
        font-size: 1.6rem;
        font-weight: bold;
        color: #fff;
        border-radius: 100px;
        display: grid;
        place-content: center;
        background: #0F92D7;
        transition: all .3s;
        @media (any-hover: hover) {
            &:hover{
            color: #fff;
            background: #000;
          }
        }
      }
    }
  }
}

.footerWrap{
  border-top: 1px solid #000;
  padding: 50px 46px;
  display: grid;
  grid-template-columns: 350px 1fr;
  gap: 70px;
  box-sizing: border-box;
  .footerWrap__cont--logo{
    width: 100%;
    height: auto;
    margin: 0 0 24px;
    display: block;
  }
  .footerWrap__cont--nav{
    margin: 0;
    padding: 0;
    list-style-type: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }
  .footerWrap__cont--navli{
    width: 16%;
    margin: 0 1.5%;
    transition: opacity .3s;
    &:hover{
      opacity: 0.5;
    }
  }
  .footerWrap__cont--navli{
    border: 1px solid #000;
    border-radius: 100%;
    box-sizing: border-box;
    a{
      width: 100%;
      padding: 100% 0 0 0;
      display: block;
      border-radius: 100%;
      box-sizing: border-box;
      &.footerWrap__cont--navli--facebook{
        background: url(/common/images/bungeishunju/common/ico_facebook.svg) 50% 50% no-repeat;
        background-size: 26px;
      }
      &.footerWrap__cont--navli--x{
        background: url(/common/images/bungeishunju/common/ico_x.svg) 50% 50% no-repeat;
        background-size: 26px;
      }
      &.footerWrap__cont--navli--instagram{
        background: url(/common/images/bungeishunju/common/ico_instagram.svg) 50% 50% no-repeat;
        background-size: 26px;
      }
      &.footerWrap__cont--navli--youtube{
        background: url(/common/images/bungeishunju/common/ico_youtube.svg) 50% 50% no-repeat;
        background-size: 26px;
      }
      &.footerWrap__cont--navli--applemusic{
        background: url(/common/images/bungeishunju/common/ico_applemusic.svg) 50% 50% no-repeat;
        background-size: 24px;
      }
      &.footerWrap__cont--navli--spotify{
        background: url(/common/images/bungeishunju/common/ico_spotify.svg) 50% 50% no-repeat;
        background-size: 26px;
      }
    }
  }
  .footerWrap__nav{
    max-width: 840px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4%;
    .footerWrap__nav__col__index{
      margin: 0 0 26px;
      padding: 0 0 6px;
      font-size: 1.4rem;
      font-weight: 700;
      border-bottom: 2px solid #000;
      display: inline-block;
    }
    .footerWrap__nav__col__list{
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 20px;
    }
    .footerWrap__nav__col__list--ul{
      margin: 0;
      padding: 0;
      display: block;
    }
    .footerWrap__nav__col__list--li{
      margin: 0 0 16px;
      padding: 0;
      font-size: 1.8rem;
      font-weight: 700;
      display: block;
    }
    .footerWrap__nav__col__list--li a{
      width: 100%;
      color: #000;
      transition: all .3s;
      display: block;
      @media (any-hover: hover) {
          &:hover{
            opacity: 0.5;
        }
      }
    }
  }
}

.footer__bottom{
  padding: 0 7px;
  font-size: 1.2rem;
  line-height: 100%;
  display: flex;
  background-color: #f2f2f2;
}
.footer .footer-logo {
  width: 90px;
  display: block;
  margin-right: 24px;
}
.footer .footer-contents {
  display: flex;
  flex: 1;
}
.footer .footer-item a {
  padding: 20px 14px;
  font-size: 1.2rem;
  color: #000;
  display: grid;
  place-content: center;
  transition: all .3s;
}
.footer .footer-item a:hover {
  font-weight: 700;
}
.footer .footer-copyright {
  padding: 20px 14px;
  font-size: 1.2rem;
  color: #000;
  display: grid;
  place-content: center;
}

main{
  overflow: hidden;
}

.column-outer {
  margin: 70px auto 0;
  position: relative;
  background-color: #fff;
  padding-bottom: 15px;
}

.content-wrapper {
  margin: 0 auto;
  position: relative;
}

.breadcrumbs-list {
  margin: 20px 0 40px;
  list-style: none;
}
.breadcrumbs-list li {
  max-width: 300px;
  margin-right: 8px;
  padding-bottom: 1px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-size: 1.2rem;
}
.breadcrumbs-list li a {
  color: #2379CA;
}
.breadcrumbs-list li::before {
  content: "/";
  padding-right: 5px;
}
.breadcrumbs-list li:first-of-type::before {
  display: none;
}

.icon-label.new {
  border-top: 1px solid #d21818;
  border-bottom: 1px solid #d21818;
  color:#d21818;
  font-size: 13px;
  font-size: 1.3rem;
  font-family: futura-pt, Futura, sans-serif;
  line-height: 1.9em;
  letter-spacing: 0.05em;
}

.icon-label.pickup {
  border-top: 1px solid #d21818;
  border-bottom: 1px solid #d21818;
  color:#d21818;
  font-size: 13px;
  font-size: 1.3rem;
  font-family: futura-pt, Futura, sans-serif;
  line-height: 1.9em;
  letter-spacing: 0.05em;
}

.icon-label.scoop {
  padding: 0 2px;
  background: #ffea00;
  color:#000;
  font-size: 13px;
  font-size: 1.3rem;
  font-family: futura-pt, Futura, sans-serif;
  line-height: 1.9em;
  letter-spacing: 0.05em;
}

.icon-label.original {
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
  color:#000;
  font-size: 13px;
  font-size: 1.3rem;
  font-family: futura-pt, Futura, sans-serif;
  line-height: 1.9em;
  letter-spacing: 0.05em;
}

.icon-label.pr {
  border-style: solid;
  border-width: 1px 0;
  color: #7e7d7d;
  font-size: 13px;
  font-size: 1.3rem;
  font-family: futura-pt, Futura, sans-serif;
  line-height: 1.9em;
  letter-spacing: 0.05em;
}
.icon-label.upper-left-pr {
  position: absolute;
  top: 4px;
  left: 4px;
  display: inline-block;
  background: #2379CA;
  color: #fff;
  font-weight: 700;
  z-index: 2;
  font-size: 1.4rem;
  font-family: Yu Gothic Pr6N;
  padding: 4px 10px 4px 22px;
  border-radius: 100px;
}

.icon-label.upper-left-pr:before{
  content:'';
  position: absolute;
  top: 5px;
  left: 6px;
  width: 14px;
  height: 14px;
  background: url(/common/images/bungeishunju/common/ico_pr.svg);
  background-size: cover;
}

.icon-label.pr.left10 {
  left: 14px;
}

.icon-label.upper-left-pr.left10 {
  left: 14px;
}

.icon-webinar {
  position: relative;
  padding-left: 29px;
  display: inline-block;
}
.icon-webinar::before {
  position: absolute;
  content: "";
  width: 19px;
  height: 14px;
  background: url(/common/images/bungeishunju/common/webinar.svg) top left no-repeat;
  background-size: 100% auto;
  top: calc(50% - 7px);
  left: 0;
  z-index: 2;
}

.hover-fade {
  transition: opacity .3s;
}
.hover-fade:hover {
  opacity: .5;
}

/*Webフォント*/
.futura {
font-family: futura-pt, sans-serif;
font-weight: 500;
font-style: normal;
}
.futura-bold {
font-family: futura-pt-bold, sans-serif;
font-weight: 700;
font-style: normal;
}
.futura-cond {
font-family: futura-pt-condensed, sans-serif;
font-weight: 500;
font-style: normal;
}
.futura-cond-bold{
font-family: futura-pt-condensed, sans-serif;
font-weight: 700;
font-style: normal;
}

/* コンテンツ共通タイトル */
.content-title {
  text-align: center;
}
/*.content-title:after {
  content: "";
  display: block;
  width: 60px;
  height: 0.5px;
  background: #000;
  margin: 0 auto;
}*/
.content-title .e {
  font-size: 36px;
  font-size: 3.6rem;
  margin-bottom: 10px;
  display: block;
   letter-spacing: 0.06em;
   font-family: 'futura-pt', sans-serif;
}
.content-title .e--only {
  margin-bottom: 20px;
}
.content-title .j {
  font-size: 3.4rem;
  display: inline-block;
}
.content-title .icon-webinar::before {
    width: 23px;
    height: 18px;
    top: calc(50% - 9px);
    left: 4px;
}

/* コンテンツ共通ボタン */
.content-btn {
  max-width: 560px;
  width: 100%;
  margin: 0 auto;
  padding-bottom: 20px;
  text-align: center;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
  position: relative;
  transition: all .3s;
}

.category-pagination + .content-btn,
.thumb-column-wrap + .content-btn{
  margin-top: 40px;
}

.content-btn-link {
  display: block;
  width: 100%;
  border: 1px #000 solid ;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
  padding: 30px 0;
  position: relative;
  z-index: 2;
}

.content-btn:hover::after {
  right: -15px;
  bottom: 5px;
}

.content-btn::after {
  position: absolute;
  content: "";
  right: -10px;
  bottom: 10px;
  height: 77%;
  width: 99%;
  background: none;
  border-right: 1px solid #000;
  border-bottom: 1px solid #000;
  transition: all .3s;
}

.link-arrow {
  position:relative;
  padding-right: 16px;
}

.link-arrow:after {
    content: "";
    width: 10px;
    height: 10px;
    position: absolute;
    top: calc(50% - 5px);
    right: 0;
    border-bottom: solid 1px #000;
    border-right: solid 1px #000;
    transform: rotate(-45deg);
}

/*配信header*/
.movienotice{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 66px;
  padding: 12px 4%;
  background: #000;
  display: none;
  justify-content: center;
  align-items: center;
  transition: all 0.6s ease-out;
}
.movienotice.active{
  display: flex;
}
.movienotice:hover{
  background: #777;
}
.movienotice:hover .movienotice__title{
  text-decoration: underline;
}
.movienotice__link{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 150;
  cursor: pointer;
  display: block;
}

.movienotice__inner{
  position: relative;
  width: 1058px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

.movienotice__icon{
  position: relative;
  width: 62px;
  height: 32px;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
  border-radius: 6px;
  background: #EB0400;
  display: flex;
  justify-content: center;
  align-items: center;
}
.movienotice__title{
  position: relative;
  margin: 0 auto;
  width: calc(100% - 62px - 148px - 4%);
  font-size: 1.6rem;
  color: #fff;
  font-weight: 700;
  display: flex;
  white-space: nowrap;
  overflow: hidden;
  gap: 1rem;
  z-index: 151;
  cursor: pointer;
}
.movienotice__title__inner{
  animation: marquee 20s linear infinite;
}
@keyframes marquee {
  0%   { translate: 0; }
  100% { translate: calc(-100% - 1rem); }
}
.movienotice__button{
  position: relative;
  margin: 0;
  padding: 0;
  width: 148px;
  height: 32px;
  color: #000;
  font-size: 1.6rem;
  font-weight: bold;
  background: #fff;
  text-align: center;
  transition: opacity .3s;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 151;
  cursor: pointer;
}

/*配信エリア*/
.liveWrap{
  position: fixed;
  right: 14px;
  bottom: 14px;
  width: 407px;
  height: 272px;
  background: #000;
  z-index: 300;
  display: none;
}

.liveWrap__header{
  position: relative;
  width: 100%;
  height: 46px;
  margin: 0 auto;
  padding: 0 0 0 12px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
}

.liveWrap__header__icon{
  position: relative;
  width: 62px;
  height: 30px;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
  border-radius: 6px;
  background: #EB0400;
  display: flex;
  justify-content: center;
  align-items: center;
}
.liveWrap__header__title{
  position: relative;
  margin: 0 auto;
  width: calc(100% - 62px - 46px - 4%);
  font-size: 1.6rem;
  color: #fff;
  font-weight: 700;
  display: flex;
  white-space: nowrap;
  overflow: hidden;
  gap: 1rem;
  cursor: pointer;
}
.liveWrap__header__title__inner{
  animation: marquee 30s linear infinite;
}
.liveWrap__header__close{
  position: relative;
  margin: 0;
  padding: 0;
  width: 46px;
  height: 46px;
  background: rgba(255,255,255,0.34);
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: all .4s;
  cursor: pointer;
}
@media (any-hover: hover) {
  .liveWrap__header__close:hover{
    background: rgba(255,255,255,0.6);
  }
}
.liveWrap__header__close span{
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 28px;
    height: 2px;
    background: var(--secondary-text);
    border-radius: 4px;
    display: inline-block;
    box-sizing: border-box;
    background: #fff;
}
.liveWrap__header__close span:nth-of-type(1) {
  top: 9px;
  transform: translateY(14px) rotate(-315deg);
}
.liveWrap__header__close span:nth-of-type(2) {
  bottom: 1px;
  transform: translateY(-20px) rotate(315deg);
}
.liveWrap__col{
  position: relative;
  padding: 0 12px 12px;
}
.liveWrap__col__movie{
  position: relative;
  width: 100%;
  padding: 55.87% 0 0 0;
}
.liveWrap__col__movie iframe{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}