@charset "UTF-8";
/* ---------------------------
 * ALL Width
 * --------------------------- */
@media print {
  .mod-textbox__commenter {
    margin-top: 0px !important; } }

.mod-table.type-block {
  display: block;
  width: auto;
  border-bottom: 1px solid #CBCBCB;
  padding-bottom: 30px;
  margin-bottom: 30px; }
  .mod-table.type-block thead, .mod-table.type-block tbody, .mod-table.type-block tfoot {
    display: block;
    width: auto; }
    .mod-table.type-block thead tr, .mod-table.type-block tbody tr, .mod-table.type-block tfoot tr {
      display: block;
      width: auto; }
      .mod-table.type-block thead tr th, .mod-table.type-block thead tr td, .mod-table.type-block tbody tr th, .mod-table.type-block tbody tr td, .mod-table.type-block tfoot tr th, .mod-table.type-block tfoot tr td {
        display: block;
        width: auto;
        padding: 0;
        border: none; }
      .mod-table.type-block thead tr th, .mod-table.type-block tbody tr th, .mod-table.type-block tfoot tr th {
        margin: 0 0 5px;
        font-size: 16px;
        font-size: 1rem;
        line-height: 2.125;
        text-align: left; }
      .mod-table.type-block thead tr td, .mod-table.type-block tbody tr td, .mod-table.type-block tfoot tr td {
        font-size: 16px;
        font-size: 1rem;
        line-height: 2.125; }
      .mod-table.type-block thead tr + tr th, .mod-table.type-block tbody tr + tr th, .mod-table.type-block tfoot tr + tr th {
        border-top: 1px solid #CBCBCB;
        margin-top: 30px;
        padding-top: 20px; }

.mod-tableB {
  margin: 0 0 20px; }

#b_othercontents .mod-bannerB {
  margin-bottom: 40px; }

.mod-breadcrumb2 {
  margin-bottom: 22px; }
  .l-r-box .mod-breadcrumb2 {
    margin-bottom: 2px; }
  .mod-breadcrumb2__heading {
    margin: -5px 0 5px;
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 2; }
  .mod-breadcrumb2__list {
    margin: 0; }
  .mod-breadcrumb2__listItem {
    padding: 8px 0;
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 1.57143;
    border-top: none; }
    .mod-breadcrumb2__listItem:first-child {
      padding-top: 8px; }
    .mod-breadcrumb2__listItem + .mod-breadcrumb2__listItem {
      border-top: 1px solid #CBCBCB; }
    .l-r-box .mod-breadcrumb2__listItem {
      border-top-color: #EAEAEA; }

.mod-form .mod-table {
  margin-top: 0; }

.mod-form html, .mod-form body {
  background: none !important; }

.mod-form iframe {
  width: 100% !important;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

.mod-r-detail .mod-iconlist__item {
  margin-right: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start; }
  .mod-r-detail .mod-iconlist__item .icon {
    margin-right: 10px;
    white-space: nowrap; }
  .mod-r-detail .mod-iconlist__item .title {
    -webkit-box-flex: 1;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    padding: 2px 0 0; }

.mod-keyword:after {
  content: ".";
  display: block;
  clear: both;
  height: 0px;
  visibility: hidden; }

.l-row .mod-keyword {
  margin-bottom: 0; }

.l-r-box {
  padding: 25px 30px;
  background-color: #FAFAFA; }
  .l-r-box__heading {
    margin: 0 0 10px;
    font-weight: bold;
    font-size: 16px;
    font-size: 1rem;
    line-height: 2; }
  .l-r-box__separate {
    display: block;
    margin: 30px 0;
    width: 100%;
    height: 1px;
    background-color: #9B9B9B; }

.l-r-toggle {
  margin-bottom: 30px;
  border: 1px solid #CBCBCB; }
  .l-r-toggle__head {
    position: relative;
    padding: 14px 20px 13px;
    font-size: 16px;
    font-size: 1rem;
    line-height: 2;
    text-align: center;
    cursor: pointer;
    background: none; }
    .l-r-toggle__head:hover {
      background-color: #fff; }
    .l-r-toggle.is-open .l-r-toggle__head {
      background-color: #fff; }
  .l-r-toggle__icon {
    position: absolute;
    top: 50%;
    right: 20px;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%); }
    .l-r-toggle__icon:before, .l-r-toggle__icon:after {
      position: absolute;
      top: 50%;
      left: 50%;
      display: block;
      content: '';
      background: #000;
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%); }
    .l-r-toggle__icon:before {
      width: 11px;
      height: 1px; }
    .l-r-toggle__icon:after {
      width: 1px;
      height: 11px; }
    .l-r-toggle.is-open .l-r-toggle__icon:after {
      display: none; }
  .l-r-toggle__body {
    display: none;
    border-top: 1px solid #CBCBCB;
    background-color: #fff; }
    .l-r-toggle.is-open .l-r-toggle__body {
      display: block; }
    .l-r-toggle__body .mod-form {
      margin-bottom: 0; }
    .l-r-toggle__body > *:first-child {
      margin-top: 0 !important; }
    .l-r-toggle__body > *:last-child {
      margin-bottom: 0 !important; }

.mod-r-buttonA {
  display: block;
  padding: 15px 10px 14px;
  border: 2px solid #000;
  background-color: #FDEC54;
  color: #000;
  font-weight: bold;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.6875;
  text-align: center;
  text-decoration: none; }
  .mod-r-buttonA:link, .mod-r-buttonA:visited {
    color: #000; }
  .mod-r-buttonA.type-cart:before {
    position: relative;
    top: 5px;
    display: inline-block;
    content: '';
    width: 24px;
    height: 24px;
    background: url("../img/icon-cart-black.svg") no-repeat 0 0;
    background-size: 24px auto;
    margin-right: 5px;
    margin-top: -24px; }
  .mod-r-buttonA.type-book:before {
    position: relative;
    top: 6px;
    display: inline-block;
    content: '';
    width: 24px;
    height: 24px;
    background: url("../img/icon-book.svg") no-repeat 0 0;
    background-size: 24px auto;
    margin-right: 5px;
    margin-top: -24px; }

.mod-r-buttonB {
  display: block;
  padding: 15px 10px 14px;
  border: 2px solid #000;
  background-color: #FFF;
  color: #000;
  font-weight: bold;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.6875;
  text-align: center; }
  .mod-r-buttonB:link, .mod-r-buttonB:visited {
    color: #000; }
  .mod-r-buttonB.type-specialpage:before {
    position: relative;
    top: 5px;
    display: inline-block;
    content: '';
    width: 24px;
    height: 24px;
    background: url("../img/icon-specialpage.svg") no-repeat 0 0;
    background-size: 24px auto;
    margin-right: 5px;
    margin-top: -24px; }

.mod-r-buttonC {
  -webkit-transition: all .1s linear;
  -o-transition: all .1s linear;
  transition: all .1s linear;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: inline-block;
  min-width: 100px;
  padding: 3px 5px;
  background: #fff;
  border: 1px solid #000;
  color: #000;
  font-size: 10px;
  font-size: .625rem;
  line-height: 1.4;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  outline: none;
  cursor: pointer; }
  .mod-r-buttonC:link, .mod-r-buttonC:visited {
    color: #000; }

.mod-r-book {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center; }
  .mod-r-book__image {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-right: 25px; }
    .mod-r-book__image img {
      max-width: 100%;
      max-height: 100%; }
  .mod-r-book__title {
    position: relative;
    margin: 0 0 0 -15px;
    padding-left: 15px;
    font-weight: normal; }
    .mod-r-book__title:before {
      position: absolute;
      left: 0;
      display: inline-block;
      content: '\e649';
      font-family: 'themify';
      speak: none;
      font-style: normal;
      font-weight: normal;
      font-variant: normal;
      text-transform: none;
      font-size: 11px;
      font-size: 0.6875rem;
      line-height: 1;
      vertical-align: middle; }
    .mod-r-book__title a {
      color: inherit; }
  .mod-r-book__author {
    margin: 5px 0 0; }
  .mod-r-book__text {
    margin-top: 10px;
    font-size: 12px;
    font-size: .75rem;
    line-height: 1.5; }

.mod-r-browsing__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }

.mod-r-browsing__navItem {
  position: relative;
  width: 50%;
  padding: 0 10px 10px;
  font-weight: bold;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.5;
  text-align: center;
  z-index: 5; }
  .mod-r-browsing__navItem:link, .mod-r-browsing__navItem:visited {
    color: #000; }
  .mod-r-browsing__navItem:hover {
    opacity: 1 !important;
    color: #4d4d4d;
    text-decoration: none; }
  .mod-r-browsing__navItem.is-current:before {
    position: absolute;
    left: 0;
    bottom: -2px;
    display: block;
    content: '';
    width: 100%;
    height: 2px;
    background-color: #FFEF00; }

.mod-r-browsing__frame {
  position: relative;
  padding-top: 40px; }
  .mod-r-browsing__frame:before {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    content: '';
    width: 100%;
    height: 2px;
    background-color: #666666; }

.mod-r-browsing__textcontents > *:first-child {
  margin-top: 0 !important; }

.mod-r-browsing__textcontents p {
  margin: 30px 0; }

.mod-r-browsing__textcontents h3 {
  margin: 60px 0 30px; }

.mod-r-browsing__textcontents h4 {
  margin: 30px 0; }

.mod-r-browsing__main > *:first-child {
  margin-top: 0 !important; }

.mod-r-browsing__photo {
  margin: 0 0 80px;
  text-align: center; }

.mod-r-browsing__share {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  line-height: 1; }
  .mod-r-browsing__share .sns {
    margin: 0 5px; }

.mod-r-browsing__subSection:not(#b_section01) {
  display: none; }

.mod-r-banner__heading {
  margin: 0 0 30px;
  padding: 0 0 10px;
  border-bottom: 1px solid #000;
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.55556; }

.mod-r-banner__list {
  list-style: none;
  margin: -12px -6px 0;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }

.mod-r-banner__listItem {
  margin: 12px 6px 0; }
  .mod-r-banner__listItem a {
    display: block; }
    .mod-r-banner__listItem a img {
      width: 100%;
      height: auto;
      border: 1px solid #979797; }

.mod-r-banner__button {
  margin: 40px 0 0; }

.mod-r-profile__head {
  margin-bottom: 32px; }

.mod-r-profile__photo {
  position: relative;
  margin: 0 0 20px;
  z-index: 3; }

.mod-r-profile__name {
  margin: 0 0 10px; }

.mod-r-profile__ruby {
  font-size: 12px;
  font-size: 0.75rem;
  line-height: 1.25; }

.mod-r-profile__body > *:last-child {
  margin-bottom: 0 !important; }

.mod-r-buttonGroupB__heading {
  margin: -5px 0 15px;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.75; }

.mod-r-buttonGroupB__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin: 10px 0 0; }

.mod-r-buttonGroupB__title {
  margin: 0 20px 0 0;
  font-size: 16px;
  font-size: 1rem;
  line-height: 2; }

.mod-r-buttonGroupB__button {
  width: 80px;
  min-width: 80px; }
  .mod-r-buttonGroupB__button a, .mod-r-buttonGroupB__button button {
    padding: 4px 5px 3px;
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 2.28571; }

.mod-r-item a {
  display: block;
  text-decoration: none; }

.mod-r-item__image {
  width: 158px;
  margin: 0 0 10px; }

.mod-r-item__title {
  position: relative;
  margin: 0;
  font-weight: normal;
  color: #000;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.625; }
  .mod-r-item__title:before {
    content: '\e649';
    font-family: 'themify';
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    font-size: 11px;
    margin-right: 5px; }

.mod-r-detail {
  position: relative; }
  .mod-r-detail__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 160px;
    background: no-repeat 50% 0;
    background-size: 100% auto; }
  .mod-r-detail__frame {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    background-color: #fff; }
  .mod-r-detail__catchcopy {
    position: relative;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin: 0;
    font-weight: normal;
    font-family: 'TP Mincho StdN High B', '游明朝', YuMincho, 'Hiragino Mincho ProN', Meiryo, serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale; }
  .mod-r-detail__title {
    margin: 0;
    font-weight: bold; }
  .mod-r-detail__author {
    margin-top: 0;
    font-size: 18px;
    font-size: 1.125rem;
    line-height: 1.55556; }
  .mod-r-detail__price {
    margin: 0;
    font-weight: bold;
    font-size: 18px;
    font-size: 1.125rem;
    line-height: 1.55556; }
    .mod-r-detail__price .tax {
      font-size: 12px;
      font-size: 0.75rem;
      line-height: 1.5; }
  .mod-r-detail__specs {
    position: relative;
    margin: 0 0 20px; }
  .mod-r-detail__date {
    margin: 0;
    color: #9B9B9B;
    font-size: 12px;
    font-size: 0.75rem;
    line-height: 1.5; }
  .mod-r-detail__spec {
    position: absolute;
    right: 0;
    bottom: 3px;
    margin: 0;
    font-size: 12px;
    font-size: 0.75rem;
    line-height: 1.5; }
    .mod-r-detail__spec a {
      display: inline-block;
      padding: 5px 8px;
      color: #000;
      border: 1px solid #cbcbcb;
      text-decoration: none; }
      .mod-r-detail__spec a:before {
        display: inline-block;
        content: '\e6c2';
        font-family: 'themify';
        speak: none;
        font-style: normal;
        font-weight: normal;
        font-variant: normal;
        text-transform: none;
        line-height: 1;
        margin-right: 5px;
        vertical-align: -1px; }
      .mod-r-detail__spec a:hover {
        opacity: 0.7; }
      .mod-r-detail__spec a.is-active {
        color: #000;
        background-color: #efefef;
        opacity: 1; }
  .mod-r-detail__buttons {
    list-style: none;
    margin: -10px 0 0;
    padding: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap; }
  .mod-r-detail__buttonsItem {
    margin-top: 10px;
    margin-left: 10px;
    width: calc((99.999% - 10px)/2); }
    .mod-r-detail__buttonsItem a, .mod-r-detail__buttonsItem button {
      width: 100%;
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      max-width: none; }
    .mod-r-detail__buttonsItem.type-wide {
      margin-left: 0;
      width: 100%; }
    .mod-r-detail__buttonsItem:nth-child(2n+1) {
      margin-left: 0; }
  .mod-r-detail__share {
    margin: 30px 0 40px;
    line-height: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end; }
    .mod-r-detail__share .sns {
      display: block;
      margin-right: 10px;
      margin-top: 10px; }
  .mod-r-detail__shareCol {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
  .mod-r-detail__specContents.js-toggle__body {
    display: none; }

.mod-r-gallery__mainPhoto {
  position: relative;
  padding: 10px;
  margin: 0 -10px 10px; }

.mod-r-gallery__mainImage {
  position: relative;
  display: table;
  width: 100%;
  table-layout: fixed;
  border: 1px solid #cbcbcb;
  background-color: #fff;
  text-align: center;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  z-index: 19;
  overflow: hidden; }
  .mod-r-gallery__mainImage a {
    position: relative;
    display: table-cell;
    width: 100%;
    height: 518px;
    text-align: center;
    vertical-align: middle;
    z-index: 20; }
    .mod-r-gallery__mainImage a:hover {
      opacity: 1; }
      .mod-r-gallery__mainImage a:hover .mod-r-gallery__mainThumbnail {
        opacity: .6; }
  .mod-r-gallery__mainImage:before {
    position: absolute;
    right: 10px;
    bottom: 10px;
    font-family: 'themify';
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    content: '\e611';
    width: 25px;
    height: 25px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    font-size: 25px;
    font-size: 1.5625rem;
    line-height: 1;
    display: block;
    z-index: 10;
    cursor: pointer; }

.mod-r-gallery__mainThumbnail {
  position: relative;
  display: inline-block; }
  .mod-r-gallery__mainThumbnail:after {
    position: absolute;
    left: 2%;
    bottom: -5px;
    display: block;
    content: '';
    width: 96%;
    height: 3px;
    border-radius: 100%;
    background: rgba(0, 0, 0, 0.16);
    -webkit-box-shadow: 0 0 8px 2px rgba(0, 0, 0, 0.23);
    box-shadow: 0 0 8px 2px rgba(0, 0, 0, 0.23);
    opacity: .6;
    z-index: 2; }
  .mod-r-gallery__mainThumbnail:before {
    position: absolute;
    left: 0;
    bottom: -6px;
    display: block;
    content: '';
    width: 100%;
    height: 2px;
    border-radius: 100%;
    background: rgba(0, 0, 0, 0.12);
    -webkit-box-shadow: 0 0 30px 14px rgba(0, 0, 0, 0.13);
    box-shadow: 0 0 30px 14px rgba(0, 0, 0, 0.13);
    opacity: .9;
    z-index: 1; }
  .mod-r-gallery__mainThumbnail img {
    position: relative;
    z-index: 10;
    vertical-align: bottom; }

.mod-r-gallery__thumbnails {
  margin: 0 0 0 -10px;
  overflow: hidden; }

.mod-r-gallery__thumbnail {
  float: left;
  margin-left: 10px; }
  .mod-r-gallery__thumbnail a {
    position: relative;
    display: block;
    width: 43px;
    height: 43px;
    border: 1px solid #9b9b9b;
    text-align: center;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background-color: #fff; }
    .mod-r-gallery__thumbnail a:hover {
      opacity: 1;
      border: 1px solid #000; }
      .mod-r-gallery__thumbnail a:hover:after {
        position: absolute;
        top: 0;
        left: 0;
        display: block;
        content: '';
        width: 100%;
        height: 100%;
        background: rgba(255, 237, 27, 0.55);
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        z-index: 10; }

.mod-r-gallery__thumbnail.is-active a {
  position: relative; }

.mod-r-gallery__thumbnail.is-active a:before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  content: '';
  width: 100%;
  height: 100%;
  border: 3px solid #ffed1b;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  z-index: 10; }

.mod-r-gallery__label {
  position: absolute;
  top: 0;
  left: -10px;
  width: 120px; }

.mod-r-gallery__label .label-new__inner {
  width: 140px;
  padding: 10px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 14px;
  line-height: 1;
  z-index: 30; }

.mod-r-gallery__label .label-new:before {
  top: 55px; }

.mod-r-gallery__label .label-new:after {
  left: 65px; }

.mod-r-gallery__label .label-soon__inner, .mod-r-gallery__label .label-outofstock__inner {
  position: absolute;
  top: 17px;
  left: -28px;
  width: 140px;
  padding: 10px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 12px;
  line-height: 1; }

.mod-r-gallery__label .label-soon:before, .mod-r-gallery__label .label-outofstock:before {
  top: 52px; }

.mod-r-gallery__label .label-soon:after, .mod-r-gallery__label .label-outofstock:after {
  left: 61px; }

.mod-r-gallery__thumbnail_inner {
  display: table;
  text-align: center;
  width: 41px;
  height: 41px; }

.mod-r-gallery__thumbnail div.mod-r-gallery__thumbnail_img {
  display: table-cell;
  vertical-align: middle;
  line-height: 0; }

.mod-r-gallery__mainThumbnail img {
  width: 100%; }

.mod-r-gallery__thumbnail .mod-r-gallery__thumbnail_inner .mod-r-gallery__thumbnail_img img {
  max-width: 41px;
  max-height: 41px; }

.mod-r-gallery__thumbnails {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0 -5px; }

.mod-r-gallery__thumbnail {
  float: none;
  margin: 0 5px; }

.mod-r-preview {
  list-style: none;
  margin: 0;
  padding: 0; }
  .mod-r-preview__item {
    text-align: center; }
    .mod-r-preview__item + .mod-r-preview__item {
      margin-top: 10px; }
    .mod-r-preview__item a {
      position: relative;
      display: inline-block; }
      .mod-r-preview__item a:before {
        position: absolute;
        top: 5px;
        right: 5px;
        display: block;
        content: '';
        width: 15px;
        height: 15px;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        z-index: 10;
        background: url("../img/icon-zoom.svg") no-repeat 0 0;
        background-size: 15px auto;
        cursor: pointer;
        overflow: hidden; }
    .mod-r-preview__item img {
      max-height: calc(100vh - 60px); }

.mod-r-more__link {
  display: inline-block;
  min-width: 110px;
  padding: 2px 10px;
  border: 1px solid #CBCBCB;
  color: #9b9b9b !important;
  font-weight: bold;
  font-size: 12px;
  font-size: 0.75rem;
  line-height: 2;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }
  .mod-r-more__link:after {
    display: inline-block;
    content: '\e657';
    font-family: 'themify';
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    color: #9b9b9b;
    font-size: 12px;
    font-size: .75rem;
    line-height: 1; }
  .mod-r-more__link:hover {
    text-decoration: none; }

.mod-r-floatingNavi {
  display: none;
  position: fixed;
  right: 20px;
  bottom: 40px;
  list-style: none;
  margin: 0;
  padding: 0;
  z-index: 210; }
  .mod-r-floatingNavi__item + .mod-r-floatingNavi__item {
    margin-top: 10px; }
  .mod-r-floatingNavi__item a {
    position: relative;
    display: block;
    width: 56px;
    height: 56px;
    border-radius: 100%;
    background-color: #FDEC54;
    -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.15); }
    .mod-r-floatingNavi__item a:hover {
      background-color: #000;
      color: #FFF;
      text-decoration: none;
      opacity: 1; }
    .mod-r-floatingNavi__item a.type-cart:before {
      position: absolute;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      display: inline-block;
      content: '';
      width: 24px;
      height: 24px;
      background: url("../img/icon-cart-black.svg") no-repeat 0 0;
      background-size: 24px auto; }
    .mod-r-floatingNavi__item a.type-book:before {
      position: absolute;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      display: inline-block;
      content: '';
      width: 24px;
      height: 24px;
      background: url("../img/icon-book.svg") no-repeat 0 0;
      background-size: 24px auto; }

@media print, screen and (min-width: 1367px) {
  .mod-r-floatingNavi {
    right: 40px; } }

.mod-r-pagetop {
  position: fixed;
  top: 0;
  right: 20px;
  opacity: 0;
  z-index: 170;
  -webkit-transition: opacity .5s;
  -o-transition: opacity .5s;
  transition: opacity .5s; }
  .mod-r-pagetop a {
    display: none;
    background-color: #fff;
    color: inherit;
    text-align: center;
    -webkit-box-sizing: border-box;
    box-sizing: border-box; }
    .mod-r-pagetop a:hover {
      text-decoration: none; }
  .mod-r-pagetop.is-show {
    opacity: .9; }
  .mod-r-pagetop.is-show a {
    display: block; }
  .mod-r-pagetop.is-stop {
    position: absolute !important;
    top: -90px;
    right: 50px; }

.mod-r-pager {
  margin: 40px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center; }
  .mod-r-pager__item {
    border-right: 1px solid #EFEFEF; }
    .mod-r-pager__item:first-child {
      border-left: 1px solid #EFEFEF; }
    .mod-r-pager__item a, .mod-r-pager__item span {
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      display: block;
      width: 50px;
      height: 50px;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center;
      border: 3px solid transparent;
      color: #000000;
      font-size: 14px;
      font-size: 0.875rem;
      line-height: 1.42857; }
    .mod-r-pager__item:hover a, .mod-r-pager__item:hover span, .mod-r-pager__item.is-current a, .mod-r-pager__item.is-current span {
      border-color: #FFED1B;
      text-decoration: none; }

@media print, screen and (min-width: 720px) {
  /* ---------------------------
 * PC
 * --------------------------- */
  .l-section#b_othercontents {
    margin-bottom: 110px; }
  .mod-textbox__head {
    margin-bottom: 40px; }
    .mod-textbox__head .mod-textbox__title {
      margin-bottom: 10px; }
    .mod-textbox__head .mod-textbox__commenter {
      line-height: 1.5; }
  .mod-breadcrumb__inner {
    max-width: 1060px;
    width: auto; }
  .mod-breadcrumb2 {
    margin: 0;
    padding-left: 0; }
  .mod-itemA.type-rwd {
    width: 100%; }
    .mod-itemA.type-rwd .mod-itemA__date {
      margin: 0;
      color: #9B9B9B;
      font-size: 14px;
      font-size: 0.875rem;
      line-height: 1.42857; }
    .mod-itemA.type-rwd .mod-itemA__name {
      font-size: 14px;
      font-size: 0.875rem;
      line-height: 1.42857; }
    .mod-itemA.type-rwd .mod-itemA__price {
      font-size: 14px;
      font-size: 0.875rem;
      line-height: 1.42857; }
  .mod-r-detail .mod-iconlist {
    margin-top: 40px;
    margin-bottom: 40px; }
  .mod-r-detail .mod-iconlist__item + .mod-iconlist__item {
    margin-top: 10px; }
  .mod-keyword {
    margin-top: -20px;
    margin-left: -10px; }
  .l-r-box {
    margin-bottom: 110px; }
    .l-r-box .l-section {
      margin-bottom: 40px; }
  .l-r-toggle__body {
    padding: 25px 20px; }
  .mod-r-buttonA:hover {
    background-color: #000;
    color: #FFF;
    text-decoration: none;
    opacity: 1; }
  .mod-r-buttonA.type-cart:hover:before {
    background-image: url("../img/icon-cart-white.svg"); }
  .mod-r-buttonA.type-book:hover:before {
    background-image: url("../img/icon-book-white.svg"); }
  .mod-r-buttonB {
    max-width: 350px;
    margin-left: auto;
    margin-right: auto; }
    .mod-r-buttonB:hover {
      background-color: #000;
      color: #FFF;
      text-decoration: none !important;
      opacity: 1; }
    .mod-r-buttonB.type-specialpage:hover:before {
      background-image: url("../img/icon-specialpage-white.svg"); }
  .mod-r-buttonC:hover {
    background-color: #000;
    color: #FFF;
    text-decoration: none; }
  .mod-r-buttonC.disabled, .mod-r-buttonC[disabled] {
    cursor: default;
    background: #fff;
    border-color: #cbcbcb;
    color: #cbcbcb; }
  .mod-r-book {
    margin-bottom: 24px; }
    .mod-r-book__image {
      min-width: 100px;
      width: 100px;
      height: 87px; }
    .mod-r-book__title {
      font-size: 26px;
      font-size: 1.625rem;
      line-height: 1.23077; }
      .mod-r-book__title:before {
        top: 11px; }
    .mod-r-book__author {
      font-size: 18px;
      font-size: 1.125rem;
      line-height: 1.66667; }
  .mod-r-browsing__head {
    max-width: 700px;
    margin: 0 auto;
    padding: 0 10px; }
  .mod-r-browsing__body {
    max-width: 1060px;
    margin: 0 auto;
    padding: 0 10px; }
  .mod-r-browsing__textcontents {
    max-width: 700px;
    margin: 0 auto; }
  .mod-r-browsing__frame {
    padding-top: 40px; }
  .mod-r-browsing__main {
    margin-bottom: 80px;
    font-size: 18px;
    font-size: 1.125rem;
    line-height: 2; }
    .mod-r-browsing__main > h2 {
      margin: 80px 0;
      font-size: 24px;
      font-size: 1.5rem;
      line-height: 1.5; }
  .mod-r-browsing__share {
    margin: 40px 0; }
  .mod-r-browsing__buttons {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 80px -5px; }
  .mod-r-browsing__button {
    margin: 0 5px;
    width: calc((100% - 20px)/2);
    max-width: 334px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box; }
    .mod-r-browsing__button:first-child {
      max-width: 345px; }
  .mod-r-banner {
    margin: 60px 0 110px; }
    .mod-r-banner__seciton {
      margin: 0 0 110px; }
    .mod-r-banner__listItem {
      width: calc((100% - 48px)/4); }
  .mod-r-profile {
    margin: 0 0 70px; }
    .mod-r-profile__name {
      font-size: 24px;
      font-size: 1.5rem;
      line-height: 1.25; }
  .mod-r-buttonGroupB {
    margin-bottom: 30px; }
    .mod-r-buttonGroupB__items {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      margin-top: -10px;
      margin-left: -40px; }
    .mod-r-buttonGroupB__item {
      margin-left: 40px; }
  .mod-r-item a:hover .mod-r-item__title .text {
    text-decoration: underline; }
  .mod-r-detail {
    position: relative;
    padding-top: 160px; }
    .mod-r-detail:before {
      position: absolute;
      top: 100px;
      right: 50%;
      display: block;
      content: '';
      width: 50%;
      height: calc(100% - 100px);
      background: #FFF;
      z-index: 1; }
    .mod-r-detail__frame {
      position: relative;
      min-height: 745px;
      max-width: 1060px;
      margin: 0 auto;
      padding: 0 20px;
      z-index: 2; }
    .mod-r-detail__thumbnail {
      position: absolute;
      top: -86px;
      right: 10px; }
      .mod-r-detail__thumbnail img {
        -webkit-box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.15);
        box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.15);
        max-width: 100px;
        max-height: 145px; }
    .mod-r-detail__catch {
      -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
      order: 1; }
    .mod-r-detail__gallery {
      -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
      order: 2; }
    .mod-r-detail__head {
      -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
      order: 3; }
    .mod-r-detail__contents {
      -webkit-box-ordinal-group: 5;
      -ms-flex-order: 4;
      order: 4; }
    .mod-r-detail__outline {
      -webkit-box-ordinal-group: 6;
      -ms-flex-order: 5;
      order: 5; }
    .mod-r-detail__catch {
      position: relative;
      z-index: 3;
      background-color: #fff;
      margin-top: -60px;
      margin-bottom: 60px;
      min-height: 120px;
      padding: 25px 50px 0 0;
      width: 79.62264%;
      -webkit-box-sizing: border-box;
      box-sizing: border-box; }
    .mod-r-detail__gallery {
      width: 49.0566%;
      height: 585px;
      margin-bottom: -585px; }
    .mod-r-detail__head {
      width: 47.16981%;
      margin-left: auto; }
    .mod-r-detail__contents {
      width: 47.16981%;
      margin-left: auto; }
    .mod-r-detail__outline {
      width: 47.16981%;
      margin-left: auto; }
    .mod-r-detail__catchcopy {
      font-size: 32px;
      font-size: 2rem;
      line-height: 1.5; }
    .mod-r-detail__title {
      font-size: 26px;
      font-size: 1.625rem;
      line-height: 1.23077; }
    .mod-r-detail__author {
      margin-top: 5px; }
    .mod-r-detail__buttons {
      margin-bottom: 40px; }
  .mod-r-gallery {
    margin: -10px -10px 20px;
    padding: 0 10px;
    overflow: hidden; }
    .mod-r-gallery__mainImage a {
      width: 100%; }
  .mod-r-floatingNavi a.type-cart:hover:before {
    background-image: url("../img/icon-cart-white.svg"); }
  .mod-r-floatingNavi a.type-book:hover:before {
    background-image: url("../img/icon-book-white.svg"); }
  .mod-r-pagetop {
    position: fixed;
    top: 0;
    width: 80px; }
    .mod-r-pagetop a {
      padding-top: 15px;
      width: 80px;
      height: 80px; }
      .mod-r-pagetop a i {
        font-size: 50px; } }

@media print, screen and (min-width: 720px) and (min-width: 1367px) {
  .mod-r-pagetop {
    right: 40px; } }

@media print, screen and (min-width: 720px) {
  .mod-r-pagetopB {
    display: none; } }

@media screen and (max-width: 719px) {
  /* ---------------------------
 * SmartPhone
 * --------------------------- */
  .l-section {
    margin-bottom: 90px; }
  .label-new__inner {
    font-size: 10px;
    line-height: 18px;
    letter-spacing: 1.58px;
    display: inline-block;
    position: absolute;
    top: 10px;
    left: -25px;
    width: 100px;
    padding: 6px 10px;
    z-index: 100; }
  .mod-textbox__figure {
    margin: 0 0 25px; }
    .mod-textbox__figure img {
      width: 100%;
      height: auto; }
  .mod-textbox .l-row [class^='l-col-'],
  .mod-textbox .l-row [class*=' l-col-'] {
    float: none !important;
    width: auto !important;
    margin: 0 !important; }
  .mod-tableB table {
    width: 100%;
    background-color: #fffffa;
    border-top: 1px solid #9b9b9b; }
    .mod-tableB table th, .mod-tableB table td {
      padding-top: 5px;
      padding-bottom: 5px;
      font-size: 12px;
      font-size: 0.75rem;
      line-height: 1.5;
      border-bottom: 1px solid #9b9b9b;
      text-align: left; }
    .mod-tableB table th {
      font-weight: bold;
      white-space: nowrap;
      padding-right: 40px; }
    .mod-tableB table td {
      width: 100%; }
      .mod-tableB table td a {
        font-weight: bold; }
  .mod-headingB {
    border: solid #000;
    border-width: 1px 0;
    padding: 16px 20px 14px; }
    .mod-headingB.type-sp-nomargin {
      margin-bottom: 0;
      position: relative;
      z-index: 10; }
  .mod-tsunagu > *:last-child {
    margin-bottom: 0 !important; }
  .mod-tsunagu:after {
    display: none; }
  .mod-tsunagu__main {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 40px 0 0; }
    .mod-tsunagu__main:before {
      top: 93px; }
    .mod-tsunagu__main:after {
      top: 93px; }
  .mod-tsunagu__colL, .mod-tsunagu__colR {
    position: relative;
    z-index: 5;
    border: 1px solid #707070;
    background-color: #fff;
    padding: 10px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 34.13333%; }
  .mod-tsunagu__colL {
    float: none;
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    margin-right: auto; }
  .mod-tsunagu__colR {
    float: none;
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2; }
  .mod-tsunagu__words {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
    width: 100%;
    margin: 20px 0 0; }
  .mod-tsunagu__image {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 100%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box; }
  .mod-tsunagu__number {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%; }
  .mod-tsunagu__word {
    margin-bottom: 0; }
  .mod-tsunagu__title {
    margin-top: 20px; }
  .mod-tsunagu.type-border + .mod-tsunagu.type-border {
    padding-top: 30px;
    border-top: 1px solid #efefef; }
  .mod-itemA.type-rwd {
    position: relative;
    margin: -1px -20px 0;
    padding: 15px 15px 15px 0;
    border: solid #CBCBCB;
    border-width: 1px 0;
    overflow: hidden; }
    .mod-itemA.type-rwd a {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex; }
    .mod-itemA.type-rwd .mod-itemA__head {
      position: static;
      width: 107px;
      min-width: 107px;
      padding: 0;
      margin: 0 10px 0 0;
      text-align: center;
      -webkit-box-shadow: none;
      box-shadow: none; }
    .mod-itemA.type-rwd .mod-itemA__figure {
      display: inline-block; }
    .mod-itemA.type-rwd .mod-itemA__image {
      position: relative;
      border: none;
      display: block;
      width: auto;
      height: auto;
      padding: 0 0 5px; }
    .mod-itemA.type-rwd .mod-itemA__thumbnail {
      position: relative; }
      .mod-itemA.type-rwd .mod-itemA__thumbnail:before {
        display: none; }
    .mod-itemA.type-rwd .mod-itemA__label .label-new__inner {
      padding: 2px 6px 1px 0; }
    .mod-itemA.type-rwd .mod-itemA__main {
      -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
      flex: 1 1 auto; }
    .mod-itemA.type-rwd .mod-itemA__title {
      font-weight: bold; }
    .mod-itemA.type-rwd .mod-itemA__date,
    .mod-itemA.type-rwd .mod-itemA__name,
    .mod-itemA.type-rwd .mod-itemA__price {
      font-size: 12px;
      font-size: 0.75rem;
      line-height: 1.5;
      text-align: left; }
  .mod-keyword {
    margin-top: -15px;
    margin-left: -10px; }
  .l-r-box {
    margin: 0 -20px 90px;
    padding: 20px; }
  .l-r-toggle__body {
    padding: 25px 20px; }
  .mod-r-buttonC.disabled, .mod-r-buttonC[disabled] {
    cursor: default;
    background: #e6e6e6;
    border-color: #e6e6e6;
    color: #FFF; }
  .mod-r-book {
    margin-bottom: 10px; }
    .mod-r-book__image {
      min-width: 80px;
      width: 80px;
      height: 73px; }
    .mod-r-book__title {
      font-size: 16px;
      font-size: 1rem;
      line-height: 1.375; }
      .mod-r-book__title:before {
        top: 6px; }
    .mod-r-book__author {
      font-size: 13px;
      font-size: 0.8125rem;
      line-height: 1.53846; }
  .mod-r-browsing {
    margin: 0 0 90px;
    overflow: hidden; }
    .mod-r-browsing__frame {
      padding-left: 20px;
      padding-right: 20px; }
    .mod-r-browsing__main {
      margin-bottom: 40px;
      font-size: 13px;
      font-size: 0.8125rem;
      line-height: 1.92308; }
      .mod-r-browsing__main > h2 {
        margin: 40px 0;
        font-size: 17px;
        font-size: 1.0625rem;
        line-height: 1.58824; }
    .mod-r-browsing__buttons {
      margin: 40px 0 0; }
    .mod-r-browsing__button {
      display: block; }
      .mod-r-browsing__button + .mod-r-browsing__button {
        margin-top: 10px; }
  .mod-r-banner {
    margin-top: 30px;
    margin-bottom: 90px; }
    .mod-r-banner__seciton {
      margin: 0 0 90px; }
    .mod-r-banner__heading {
      margin-left: -20px;
      margin-right: -20px;
      padding: 15px 20px;
      border: solid #000;
      border-width: 1px 0; }
    .mod-r-banner__listItem {
      width: calc((100% - 24px)/2); }
  .mod-r-profile {
    margin-bottom: 90px; }
    .mod-r-profile + .mod-r-profile {
      border-top: 1px solid #CBCBCB;
      margin-top: -50px;
      padding-top: 40px; }
    .mod-r-profile__name {
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1.5; }
  .mod-r-buttonGroupB {
    margin-bottom: 30px; }
    .mod-r-buttonGroupB__heading {
      margin-bottom: 6px; }
    .mod-r-buttonGroupB__item {
      margin: 0;
      padding: 12px 0;
      -webkit-box-pack: justify;
      -ms-flex-pack: justify;
      justify-content: space-between;
      border-top: none; }
      .l-r-box .mod-r-buttonGroupB__item {
        border-top-color: #EAEAEA !important; }
      .mod-r-buttonGroupB__item:last-child {
        padding-bottom: 0; }
      .mod-r-buttonGroupB__item + .mod-r-buttonGroupB__item {
        border-top: 1px solid #CBCBCB; }
  .mod-r-item {
    margin: 0 0 20px; }
  .mod-r-detail {
    padding: 30px 20px 0; }
    .mod-r-detail__bg {
      width: 100%;
      height: 30px; }
    .mod-r-detail__thumbnail {
      display: none; }
    .mod-r-detail__author {
      margin-top: 5px;
      margin-bottom: 5px; }
    .mod-r-detail__catchcopy {
      margin: 50px -20px 20px;
      padding: 10px 20px;
      border: solid #000;
      border-width: 1px 0;
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1.6; }
    .mod-r-detail__head {
      padding: 15px 0 0; }
    .mod-r-detail__title {
      font-size: 24px;
      font-size: 1.5rem;
      line-height: 1.33333; }
    .mod-r-detail__share {
      display: block; }
    .mod-r-detail__shareCol {
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center; }
  .mod-r-gallery {
    margin-bottom: 50px; }
    .mod-r-gallery__mainPhoto {
      padding: 0;
      margin-top: 10px;
      margin-left: 0;
      margin-right: 0;
      overflow: hidden; }
    .mod-r-gallery__mainImage a {
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      padding: 15px;
      height: 280px; }
  .mod-r-preview {
    margin-bottom: 40px; }
  .mod-r-floatingNavi__item a {
    width: 48px;
    height: 48px; }
  .mod-r-floatingNavi a.type-cart:hover:before {
    background-image: url("../img/icon-cart-white.svg"); }
  .mod-r-floatingNavi a.type-book:hover:before {
    background-image: url("../img/icon-book-white.svg"); }
  .mod-r-pagetop {
    width: 50px; }
    .mod-r-pagetop a {
      padding-top: 10px;
      width: 50px;
      height: 50px; }
      .mod-r-pagetop a i {
        font-size: 30px; }
    .mod-r-pagetop.is-show {
      opacity: .9; }
    .mod-r-pagetop.is-show a {
      display: block; }
    .mod-r-pagetop.is-stop {
      display: none !important; }
  .mod-r-pagetopB {
    background-color: #efefef;
    border-bottom: 1px solid #000;
    color: #000;
    text-align: center;
    font-size: 12px;
    font-weight: bold;
    line-height: 40px; }
    .mod-r-pagetopB i {
      font-weight: normal;
      margin-left: 10px; }
    .mod-r-pagetopB a {
      display: block; }
      .mod-r-pagetopB a:link, .mod-r-pagetopB a:visited {
        color: #000; } }

@media screen and (max-width: 374px) {
  /* ---------------------------
 * SmartPhone 374px 以下
 * --------------------------- */ }
