@charset "utf-8";
/* ############################################################################################################################
#    2024/11/10　リニューアル
#    v1 articleファイル
############################################################################################################################ */

/* ----------------------------------------------------------------------------------------------------------------------------
.article-head
---------------------------------------------------------------------------------------------------------------------------- */
.article-head {
  margin-inline: 16px;
  padding-block: 40px; 
  border-bottom: 1px solid #e7e7e7;

  &.no-border {
    border: none;
  }
}

.article-head__title {
  margin-block: 24px;
  font-size: 22px;
  font-size: 2.2rem;
  font-weight: 500;
  line-height: 1.6;
}

.article-head .subtitle {
  margin-top: 16px;
  font-size: 13px;
  font-size: 1.3rem;
  font-weight: 600;
  text-align: right;

  a {
    color: #999;
  }

  &.comic {
    width: 32%;
    margin: 20px auto;
  }
}

#temp-23-article-nextissue .article-head h1,#temp-21-article-comic .article-head h1{
  text-align: center;
}

.article-head h1.image {
  width: 89.33%;
}

.article-head h1 p {
  line-height: 26px;
  font-size: 11px;
  font-size: 1.1rem;
  font-weight: normal;
}

.article-head h1 p+p {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
}

.article-head .subtitle+h1 {
  margin-top: 4px;
}

.article-head .context {
  position: relative;
  width: calc(100% - 24px);
  margin: 0 auto;
  font-size: 0;
  display: flex;
  justify-content: space-between;
  color: var(--color-black);
}

#temp-23-article-nextissue .article-head .context {
  display: block;
}

.article-head .context ul {
  display: inline-block;
}

.article-head .context ul li {
  display: inline-block;
  font-size: 12px;
  line-height: 18px;
}

.article-head .context ul li+li:before {
  content: '/';
  padding: 0 0.5em;
}

.article-head .context .date {
  display: inline-block;
  margin-left: 12px;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 18px;
}

.article-head .option {
  font-family: var(--font-hiragino-kaku-gothic);
  margin-top: 24px;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 100% ; 
  text-align: left;
  margin: 0 ;
}

#temp-23-article-nextissue .article-head .context .option {
  text-align: center !important;
}

.article-head .context .option+.option {
  margin-top: 6px;
}

.article-head.promoted .context,
.article-head.member .context {
  padding-bottom: 35px;
}

.article-head.promoted .context:after {
  content: 'Promoted';
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  bottom: 0;
  padding: 0 3px;
  line-height: 12px;
  font-size: 9px;
  font-size: 0.9rem;
  background-color: #ccc;
}

.article-head.member .context:after {
  content: 'MEMBER';
  position: absolute;
  left: 50%;
  -webkit-transform: translateX( -50% );
  transform: translateX( -50% );
  bottom: 0;
  padding: 0 8px;
  line-height: 18px;
  font-size: 13px;
  font-size: 1.3rem;
  font-weight: bold;
  color: #fff;
  background-color: #FF9AA0;
}

.article-head .sns {
  margin: 25px 0;
  font-size: 0;
  text-align: center;
}

.article-head .sns li {
  display: inline-block;
  width: 24px;
}

.article-head .sns li+li {
  margin-left: 12.27% ;
}

/*** author-header ***/
.article-head .author-header{
  margin-block: 16px 24px;
  overflow: hidden;
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.article-head .author-header .author-box{
  /*display: inline-block;*/
  position: relative;
}

.article-head .author-header .author {
  display: flex;
  align-items: center;
  height: 30px;
  padding-left: 35px;
  padding-right: 25px;
  position: relative;
  color: var(--color-black);
  font-family: var(--font-hiragino-kaku-gothic);
  font-size: 13px;
  font-size: 1.3rem;
  font-weight: 600;
  line-height: 150%;
}

.author-header.article-author-profile .author{
  display: block;
}
.article-head .author-header .author:last-child{
    padding-right: 0;
}

.article-head .author-header .author .icon-author {
    display: inline-block;
    width: 30px;
    height: 30px;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 50%;	
}

.article-head .author-header > span.date {
  display: inline-block;
  float: right;
  line-height: 30px;
  color: #757575;
  font-weight: 100;
  font-size: 12px;
  font-size: 1.2rem;
}

.article-head .article-subtitle-series {
  margin: 0 auto 10px;
  width: calc(100% - 24px);
  text-align: left;
  display: block;
  font-size: 14px;
  font-size: 1.4rem;
  color: #666666;
}

.author-header .article-list__icon-list {
  font-size: 12px;
  font-size: 1.2rem;
  width: auto;
  position: static;
  margin: 0;
}

.author-header .article-list__icon-list span.portal47 {
  width: 84px;
  padding: 3px 6px 2px 16px;
}

.author-header .article-list__icon-list span.portal47::before{
  left: 8px;
  top: 3px;
  width: 12px;
  height: 11px;
}

.author-header .article-list__icon-list span.promoted {
  width: 90px;
  padding: 3px 6px 2px 15px;
}

.author-header .article-list__icon-list span.promoted::before{
  left: 6px;
  top: 2.8px;
  width: 12px;
  height: 10px;
}

.article-head .article-list__top {
  margin: 0;
}

.article-head .link-button a {
  width: calc(100% - 24px);
}

.article-head > *:first-child{
  margin-top: 0;
}

.article-head > *:last-child {
  margin-bottom: 0  ;
}

/* .article-head__top */
.article-head__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  font-weight: 500;
}

/* .article-head__labels */
.article-head__labels {
  display: flex;
  flex-direction: column;
  row-gap: 12px;
  margin-top: 24px;
}

/* .article-head__genres, .article-head__keywords */
.article-head__genres,
.article-head__keywords {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;

  > a {
    display: grid;
    place-items: center;
    padding: 3px 12px;
    border: 1px solid #e7e7e7;
    border-radius: 40px;
    color: #212121;
    font-size: 11px;
    font-size: 1.1rem;
    font-weight: 500;
    line-height: 1.6;
  }
}

/* .article-head__author */
.article-head__author {
  display: flex;
  justify-content: space-between;
  margin-top: 12px;

  .author {
    display: flex;
    align-items: center;
    column-gap: 8px;

    .icon-author {
      width: 24px;
      height: 24px;
      background-size: contain;
      border-radius: 50vh;
      overflow: hidden;
    }

    > a {
      color: #212121;
      font-size: 12px;
      font-size: 1.2rem;
      font-weight: 500;
      line-height: 1.6;
    }
  }
}

/* .article-head__related-links */
.article-head__related-links {
  display: flex;
  flex-direction: column;
  row-gap: 4px;

  > a {
    display: inline-flex;
    column-gap: 8px;
    width: fit-content;
    font-size: 14px;
    font-size: 1.4rem;
    color: #1c5dd6;
  }

  > a > span {
    margin-top: 1px;
    color: #212121;
    font-family: var(--font-figtree);
  }
}

/* .article-head__date */
.article-head__date {
  margin-left: auto;
  font-size: 12px;
  font-size: 1.2rem;
  font-family: var(--font-figtree);
}

/* .article-head__casts */
.article-head__casts {
  display: flex;
  flex-wrap: wrap;
  column-gap: 20px;
  margin-top: 32px;
}

.article-head__cast {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 4px;
}

.article-head__cast-image {
  width: 72px;
  height: 72px;
  border-radius: 50vh;
  overflow: hidden;
}

.article-head__cast-text {
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.6;
  font-weight: 400;
}

/* ----------------------------------------------------------------------------------------------------------------------------
.article-keyword
---------------------------------------------------------------------------------------------------------------------------- */

.article-keyword {
  margin: 20px auto 0;
  width: calc(100% - 24px);
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.article-keyword__item {
  display: block;
  padding: 6px 8px;
  font-size: 13px;
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 150%;
  border-radius: 100px;
  border: 1px solid var(--color-black);
  background: var(--color-white);
}

.article-keyword__item:hover {
  color: var(--color-white);
  background: var(--color-black);
  opacity: 1;
}

/* ----------------------------------------------------------------------------------------------------------------------------
.article-series-links
---------------------------------------------------------------------------------------------------------------------------- */
.article-series-links {
  margin-block: 24px 40px;
  background: #f6f6f6;
  font-weight: 500;
  line-height: 1.6;
}

.article-series-links__heading {
  padding: 12px 16px;
  font-size: 12px;
  font-size: 1.2rem;
  position: relative;
  display: flex;
  align-items: center;
  column-gap: 10px;
}

.article-series-links__heading-icon {
  display: grid;
  place-content: center;
  width: 12px;
  height: 12px;

  /* 十字アイコン */
  &::before,
  &::after {
    content: "";
    display: block;
    grid-column: 1 / 1;
    grid-row: 1 / 1;
    margin: auto;
    background: #000;
    transition: rotate .3s ease;
  }

  &::before {
    width: 12px;
    height: 1px;
  }

  &::after {
    width: 1px;
    height: 12px;
  }

  /* 開いているとき */
  [open] &::after {
    rotate: -90deg;
  }
}

.article-series-links__list {
  padding-inline: 16px;

  > li {
    width: 100%;
  }
}

.article-series-links__item {
  display: grid;
  grid-template-areas:
    "image text"
  ;
  grid-template-columns: 21.56% auto;
  grid-template-rows: auto 1fr;
  gap: 4px 16px;
  padding-block: 16px;
  border-top: 1px solid #fff;
}

.article-series-links__image {
  grid-area: image;
  width: 100%;
  height: 100%;

  > img {
    height: 100%;
    object-fit: cover;
  }
}

.article-series-links__text {
  grid-area: text;
  display: flex;
  flex-direction: column;
  justify-content: center;
  row-gap: 4px;
}

.article-series-links__num {
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1;
  font-family: var(--font-figtree);
}

.article-series-links__title {
  --lines: 2;

  min-width: 0;
  min-height: 0;
  overflow: hidden;

  > p {
    line-clamp: var(--lines);
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: var(--lines);
    overflow: hidden;
    font-size: 12px;
    font-size: 1.2rem;
  }
}


/* ----------------------------------------------------------------------------------------------------------------------------
hr
---------------------------------------------------------------------------------------------------------------------------- */
hr {
  clear: both;
  margin-top: 40px;
  border: none;
  border-top: 1px solid #ccc;

  &.hr_black {
    border-top: 1px solid #000;
  }
}

/* ----------------------------------------------------------------------------------------------------------------------------
.link-button
---------------------------------------------------------------------------------------------------------------------------- */
.link-button {
  display: flex;
  justify-content: center;
  margin-block: 40px;
  height: auto;

  &.button01 {
    margin: 40px auto;
    text-align: center;
    width: auto;
    display: flex;
    justify-content: center;
    box-shadow: none;
    max-width: initial;
    height: auto;

    a {
      width: 100%;
      height: 100%;
      padding: 10px 24px;
      border: none;
      border-top: 1px solid var(--color-black);
      border-bottom: 1px solid var(--color-black);
      border-radius: 0;
      text-align: center;
      background: #FFF;
      position: relative;
      display: block;
      box-shadow: none;

      &::before {
        content: none;
      }

      span.fixed-label {
        font-size: 13px;
        font-size: 1.3rem;
        font-weight: 400;
        line-height: normal;
        color: var(--link-active);
        text-decoration: underline;
        margin-right: 15px;
        font-weight: normal;
      }

      span.link-label {
        font-size: 16px;
        font-size: 1.6rem;
        font-weight: 600;
        line-height: 120%;
        text-decoration: underline;
        color: var(--link-active);
        text-align: left;
        flex: 1;
      }
    }
  }

  &.next {
    margin-bottom: 0;

    a {
      border-bottom: none;
    }
  }
}

.link-button a {
  display: grid;
  place-items: center;
  width: fit-content;
  height: auto;
  padding: 10px 40px;
  background: #fff;
  border: 1px solid #212121;
  border-radius: 50px;
  color: #212121 !important;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.6;
  box-shadow: none;

  &:hover {
    background: inherit;
    color: inherit;
    opacity: .5;
  }

  &::before,
  &::after {
    display: none;
  }
}

/* .author */
.link-button.author,
.article-body .link-button.author {
  margin: 40px auto;

  > a {
    display: grid;
    place-items: center;
    height: auto;
    padding: 9px 36px;
    border: 1px solid #212121;
    border-radius: 50px;
    box-shadow: none;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1.6;

    &::before {
      display: none;
    }

    &:hover {
      background: inherit;
      color: inherit;
      opacity: .5;
    }
  }
}

.module-pagination + .link-button.author,
.module-pagination + .article-body .link-button.author {
  margin-top: -24px;
}

/* ----------------------------------------------------------------------------------------------------------------------------
.article-body
---------------------------------------------------------------------------------------------------------------------------- */
/* === メイン === */
.article-body {
  --default-black: #212121;
  --default-gray: #e7e7e7;

  --text-color: var(--default-black);
  --border-color: var(--default-gray);

  position: relative;
  width: calc(100% - 24px);
  margin: 0 auto 50px;
  padding-top: 24px;
  color: var(--text-color);
  font-family: var(--font-hiragino-kaku-gothic);
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 200%;

  &.border_none {
    border: none;
  }

  > *:first-child {
    margin-top: 0;
  }

  img {
    max-width: 100%;
    height: auto;

    &#read-to-end {
      width: 1px !important;
      height: 1px !important;
    }
  }

  .ad-banner {
    width: 100%;
  }
}

/* === 見出し === */
.article-body {
  h2, h3 {
    margin-block: 40px;
    font-weight: 500;
    line-height: 1.6;
  }

  h2 {
    font-size: 22px;
    font-size: 2.2rem;
    font-weight: 500;
    line-height: 1.6;
  }

  h3 {
    font-size: 22px;
    font-size: 2.2rem;
  }

  .moon-type {
    text-align: center;
  }

  #temp-22-article-magazine & h4 {
    margin-block: 32px 24px;
    font-size: 20px;
    font-size: 2.0rem;
  }

  .headline2 {
    margin-block: 40px;
    font-family: var(--font-figtree);
    font-size: 22px;
    font-size: 2.2rem;
    line-height: 1;
    letter-spacing: .04em;
    font-weight: 600;
  }
}

/* === テキスト === */
.article-body {
  p {
    margin-bottom: 20px;
    color: var(--color-black);
    font-family: var(--font-hiragino-kaku-gothic);
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 1.9;
    word-break: break-all;
  }

  :is(h2, h3, h4) + p {
    margin-top: 10px;
  }

  strong {
    font-weight: bold;
  }

  small {
    line-height: 18px;
    font-size: 10px;
    font-size: 1.0rem;
  }

  sup {
    vertical-align: super;
    font-size: 9px;
    font-size: 0.9rem;
  }

  sub {
    vertical-align: sub;
    font-size: 9px;
    font-size: 0.9rem;
  }

  em {
    background: var(--color-gray3);
    color: var(--color-text);
    font-family: var(--font-noto-sans);
    font-weight: 500;
    font-size: 18px;
    font-size: 1.8rem;
    line-height: 160%;
    font-style: normal;
    width: 100%;
    display: block;
    padding: 4px 8px;
    margin: 0 0 20px;
  }

  blockquote {
    margin-top: 20px;
    padding: 5px 0 5px 8px;
    border-left: 3px solid #ccc;
  }

  .credit {
    margin-top: 40px;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 150%;
    color: var(--color-black);
  }

  .caption {
    margin-top: 30px;
    line-height: 18px;
    font-size: 12px;
    font-size: 1.2rem;
  }
}

/* === 主題区切り（水平線） === */
.article-body {
  hr {
    clear: both;
    margin-block: 32px;
    border: none;
    border-top: 1px solid #e7e7e7;

    &.hr_black {
      border-top: 1px solid #000;
    }

    &.full-width {
      width: 111.94%;
      margin-left: -5.97%;
    }
  }
}

/* === リンク === */
.article-body {
  > p > a,
  > ul > li > a {
    color: #1c5dd6;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 1.9;
    text-decoration: none;
    font-feature-settings: "palt";
    word-break: break-all;

    &[target="_blank"]::after {
      content: "";
      display: inline-block;
      width: 16px;
      height: 16px;
      margin-inline: 3px;
      background-image: url(/common/crea/images/v1/icon/blank_blue.svg);
      background-position: center;
      background-size: 100%;
      background-repeat: no-repeat;
      translate: 0 2px;
    }
  }

  > ul > li > a {
    width: fit-content;
    line-height: 1.6;
  }

  .link-button {
    display: flex;
    justify-content: center;
    margin-block: 40px;
    height: auto;

    &.download a {
      display: flex;
      align-items: center;
      justify-content: center;

      &::after {
        content: "";
        display: block;
        width: 16px;
        height: 16px;
        background-image: url(/common/crea/images/v1_1/icon/download.svg);
        background-size: contain;
      }
    }

    .link-button.tal {
      justify-content: flex-start;
    }

    &.button01 {
      margin: 40px auto;
      text-align: center;
      width: auto;
      display: flex;
      justify-content: center;
      box-shadow: none;
      max-width: initial;
      height: auto;

      a {
        width: 100%;
        height: 100%;
        padding: 10px 24px;
        border: none;
        border-top: 1px solid var(--color-black);
        border-bottom: 1px solid var(--color-black);
        border-radius: 0;
        text-align: center;
        background: #FFF;
        position: relative;
        display: block;
        box-shadow: none;

        &::before {
          content: none;
        }

        span.fixed-label {
          font-size: 13px;
          font-size: 1.3rem;
          font-weight: 400;
          line-height: normal;
          color: var(--link-active);
          text-decoration: underline;
          margin-right: 15px;
          font-weight: normal;
        }

        span.link-label {
          font-size: 16px;
          font-size: 1.6rem;
          font-weight: 600;
          line-height: 120%;
          text-decoration: underline;
          color: var(--link-active);
          text-align: left;
          flex: 1;
        }
      }
    }

    &.next {
      margin-bottom: 0;

      a {
        border-bottom: none;
      }
    }
  }

  .link-button a {
    display: grid;
    place-items: center;
    width: fit-content;
    height: auto;
    padding: 10px 40px;
    background: #fff;
    border: 1px solid #212121;
    border-radius: 50px;
    color: #212121 !important;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1.6;
    box-shadow: none;

    &:hover {
      background: inherit;
      color: inherit;
      opacity: .5;
    }

    &::before,
    &::after {
      display: none;
    }
  }

  .module-pagination + .link-button.button01 {
    margin-top: -24px;
  }

  .link-basic {
    a {
      font-size: 12px;
      font-size: 1.2rem;
      font-style: normal;
      font-family: 'Noto Sans Japanese', 'Yu Gothic', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, sans-serif;
      text-decoration: none;
    }

    .box-normal & a {
      color: #333;
    }

    a p {
      margin-top: 0;
    }
  }

  .ambassador-link {
    width: auto;
    margin: 20px 0 20px;
    padding: 30px;
    background-color: #EFEFEF;

    h3 {
      margin: 0 0 5px;
    }

    .button {
      margin: 20px 0 0;
    }

    .link-button {
      width: 74.67%;
    }

    .link-button:last-child {
      margin: 20px auto 0;
    }
  }

  .moon-link {
    width: 111.94%;
    margin: 40px 0 30px -5.97%;
    padding: 30px 0;
    background-color: #EFEFEF;

    .link-button:first-child {
      margin-top: 0;
    }

    .link-button:first-child a {
      background-color: #FFCE00;
      border: none;
    }

    .link-button:first-child a:hover {
      background: #FFCE00;
      border: inherit;
      opacity: .5;
    }

    .link-button + .link-button {
      margin-top: 20px;
    }
  }
}

/* === リスト === */
.article-body {
  > ol,
  > ul {
    display: flex;
    flex-direction: column;
    row-gap: 16px;
    margin-block: 40px;

    > li {
      list-style: none;
      color: #212121;
      font-size: 14px;
      font-size: 1.4rem;
      font-weight: 400;
      line-height: 1.6;
    }
  }

  > ol {
    > li {
      counter-increment: number;

      &::before {
        content: counter(number);
        display: block;
        font-size: 14px;
        font-size: 1.4rem;
        font-weight: 500;
        text-align: center;
      }
    }
  }

  > ul {
    > li {
      padding-left: 18px;
      position: relative;

      /* 黒天 */
      &::before {
        content: "";
        display: block;
        flex-shrink: 0;
        width: 4px;
        height: 4px;
        background: #212121;
        border-radius: 50vh;
        position: absolute;
        top: 1em;
        left: 0;
      }
    }

    > li:has(> em) {
      padding-left: 0;

      &::before {
        display: none;
      }
    }
  }
}

/* === テーブル === */
.article-body {
  table {
    width: 100%;
    margin-block: 40px;
    border-collapse: collapse;
    border-bottom: 1px solid #e7e7e7;

    tr {
      display: flex;
      flex-direction: column;
      row-gap: 12px;
      border-top: 1px solid #e7e7e7;
    }

    th, td {
      width: 100% !important;
      line-height: 1.8;
      font-weight: 400;
    }

    th {
      padding-top: 20px;
      font-size: 16px;
      font-size: 1.6rem;
      text-align: left;
    }

    td {
      padding-bottom: 20px;
      font-size: 14px;
      font-size: 1.4rem;
    }


    em {
      margin: 0;
      padding: 0;
      background: transparent;
      color: #e54c78;
      font-size: inherit;
    }

    a {
      color: #1c5dd6;
    }

    &.border {
      th, td {
        padding: 10px;
        border: 1px solid #ccc;
      }
    }
  }
}

/* === メディア === */
.article-body {
  figure, .embed {
    margin-top: 20px;
  }

  figure {
    > a {
      display: inline-block;
    }

    figcaption {
      clear: both;
      padding-top: 8px;
      // line-height: 16px;
      // font-size: 12px;
      // font-size: 1.2rem;
      // color: var(--color-gray7);
      text-align: left;

      color: #6d6d6d;
      font-size: 12px;
      font-size: 1.2rem;
      font-weight: 400;
      line-height: 1.6;
    }
  }

  .image-area {
    margin-bottom: 40px;
  }

  .embed {
    .embed-caption {
      clear: both;
      padding-top: 8px;
      line-height: 16px;
      font-size: 12px;
      font-size: 1.2rem;
      color: var(--color-gray7);
    }

    iframe {
      vertical-align: top;
    }

    &.spotify .embed-obj {
      position: relative;
      width: 90%;
      padding-top: 120%;
      margin: 0 auto;
    }

    &.youtube .embed-obj {
      position: relative;
      width: 100%;
      padding-top: 56.25%;
    }

    &.youtube.vertical .embed-obj {
      width: 90%;
      padding-top: 160%;
      margin: 0 auto;
    }

    &.googlemap .embed-obj {
      position: relative;
      width: 100%;
      padding-top: 100%;
    }

    &.youtube .embed-obj iframe,
    &.googlemap .embed-obj iframe,
    &.spotify .embed-obj iframe {
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
    }

    &.instagram .embed-obj iframe,
    &.twitter .embed-obj twitter-widget {
      width: 100% !important;
      max-width: 100% !important;
      margin: 0 !important;
    }
  }

  .comic-image {
    margin: 100px auto 60px;
  }

  .gallery-icon {
    position: relative;

    &.image-area > a {
      display: block;
      margin-top: 0;
      position: relative;

      &::before {
        content: '';
        position: absolute;
        right: 0;
        top: 0;
        width: 56px;
        height: 56px;
        background: url(/common/crea/images/v1_1/icon/gallery.svg) left top no-repeat;
        background-size: 100%;
      }

      > img {
        display: block;
        width: 100vw;
        max-width: inherit;
        margin-left: -12px;
      }
    }

    *[class^="box-"] & > a > img {
      width: 100%;
      margin-left: 0;
    }
  }

  .gallery-icon__caption {
    width: 100%;
    line-height: 1.6;
  }

  .gallery-icon__link {
    width: fit-content;
    height: fit-content;
    margin-top: 16px;
    margin-left: auto;

    > a {
      display: block;
      padding: 6px 24px;
      border: 1px solid #212121;
      border-radius: 50px;
      color: #212121;
      font-size: 12px;
      font-size: 1.2rem;
      font-weight: 500;
      text-align: center;

      &:hover {
        text-decoration: none;
      }
    }
  }

  .figure-center,
  .figure-left,
  .figure-right {
    margin-top: 20px;
    margin-bottom: 20px;
    margin-left: auto;
    margin-right: auto;
    width: auto !important;
  }

  .figure-center {
    text-align: center;

    figcaption {
      text-align: left;
    }
  }

  .figure-left .text-area,
  .figure-right .text-area {
    margin-top: 20px;
  }

  .figure-left.smartphone-compatible {
    .image-area {
      float: left;
      width: 150px;
      margin-right: 10px;
      margin-bottom: 10px;

      &::before {
        width: 12px;
        height: 12px;
      }
    }

    .text-area {
      margin-top: 0;
    }

    &.no-wraparound .text-area {
      float: right;
      width: calc(100% - 150px - 10px);
    }
  }

  .images-2cols,
  .images-3cols {
    --x-col-margin: 8px;

    display: flex;
    flex-wrap: wrap;
    gap: 8px var(--x-col-margin);
    margin-block: 40px;

    .image-area {
      margin-bottom: 0;
    }

    figcaption {
      width: 100%;
      padding-top: 0;
    }

    &::before,
    &::after {
      display: none;
    }
  }

  .images-2cols  .image-area {
    width: calc((100% / 2) - (var(--x-col-margin) / 2));
  }

  .images-3cols  .image-area {
    width: calc((100% / 3) - (var(--x-col-margin) / 1.5));
  }

  .box-yt {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    margin-top: 20px;

    iframe {
      position: absolute;
      left: 0; top: 0;
      width: 100%; height: 100%;
    }

    span {
      clear: both;
      padding-top: 3px;
      line-height: 16px;
      font-size: 12px;
      font-size: 1.2rem;
      color: #777;
    }
  }
}

/* === ブロック装飾 === */
.article-body {
  .box-normal,
  .box-thick,
  .box-color,
  .box-author {
    margin-top: 20px;
    padding: 14px;
    word-wrap: break-word;
  
    a {
      color: #1c5dd6;
      font-size: inherit;
      text-decoration: none;
      font-feature-settings: "palt";
      word-break: break-all;
  
      &[target="_blank"]::after {
        content: "";
        display: inline-block;
        width: 16px;
        height: 16px;
        margin-inline: 3px;
        background-image: url(/common/crea/images/v1/icon/blank_blue.svg);
        background-position: center;
        background-size: 100%;
        background-repeat: no-repeat;
        translate: 0 2px;
      }
    }

    .link-button a::after {
      display: none;
    }
  }

  :is(h2, h3, h4) + :is(.box-normal, .box-thick, .box-color, .box-author) {
    margin-top: 10px;
  }
}

/* .box-normal */
.article-body :is(.box-normal, .box-color, .box-author) {
  margin-block: 40px;
  padding: 40px 16px;
  border: 1px solid var(--border-color);

  h3 {
    margin-block: 32px;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.6;
  }

  .box-title {
    margin-block: 12px;
    color: var(--text-color);
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.6;
  }

  .image-area {
    margin-top: 20px;

    > figcaption {
      margin-top: 8px;
      padding-top: 0;
      font-size: 12px;
      font-size: 1.2rem;
      font-weight: 400;
      color: var(--color-text-gray1);
    }
  }

  > p:not([class]) {
    margin-block: 12px;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.8;
  }

  > *:first-child {
    margin-top: 0 !important;
  }

  p {
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 160%;
  }

  table,
  ul {
    margin-top: 10px;
  }

  li {
    font-size: 12px;
    font-size: 1.2rem;
  }

  .box-image-center {
    text-align: center;
  }

  .box-image-left {
    width: 100%;
  }

  .box-text-right {
    width: 100%;

    .box-image-left + & {
      margin-top: 24px;
    }

    > *:first-child {
      margin-top: 0 !important;
    }

    > *:last-child {
      margin-bottom: 0 !important;
    }
  }
}

/* .box-thick */
.article-body .box-thick {
  position: relative;
  padding: 20px;
  border: 1px solid #212121;

  .box-title {
    margin-block: 12px;
    color: var(--text-color);
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.6;
  }

  h4 {
    color: var(--color-black);
    font-family: var(--font-josefin-sans);
    font-size: 24px;
    font-size: 2.4rem;
    font-weight: 600;
    line-height: 100%;
    margin-bottom: 20px;

    small {
      display: block;
      margin-bottom: 10px;
      font-size: 14px;
      font-size: 1.4rem;
      font-weight: 400;
      line-height: 100%;
    }
  }

  p {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 150%;

    small {
      font-size: 14px;
      font-size: 1.4rem;
      font-weight: 400;
      line-height: 100%;
    }
  }

  .box-image-center {
    text-align: center;
  }

  .box-image-left {
    width: 100%;
  }

  .box-text-right {
    width: 100%;
  }

  > *:first-child {
    margin-top: 0;
  }
}

/* .box-color */
.article-body .box-color {
  border: none;
  background-color: #f6f6f6;

  p {
    margin-top: 20px;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 160%;
  }

  table,
  ul {
    margin-top: 10px;
  }

  li {
    font-size: 12px;
    font-size: 1.2rem;
  }

  .box-title {
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 160%;
  }

  .box-image-center {
    text-align: center;
  }

  &.moon {
    background-color: #FFCE00;

    p {
      font-size: 20px;
      font-size: 2.0rem;
      line-height: 1.7em;
    }
  }

  &.member {
    background-color: #f6f6f6;
  }
}

/* .box-author */
.article-body .box-author {
  background-color: #f6f6f6;
  border: none;

  &.no-color {
    background-color: #fff;
    border: 1px solid #ccc;
  }

  .box-title {
    margin-block: 32px;
    font-size: 20px;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.6;
  }

  p {
    margin-top: 16px;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.8;
  }

  .box-image-center {
    text-align: center;
  }

  .box-image-left {
    float: left;
    width: 80px;
    height: 80px;
    border-radius: 50vh;
    overflow: hidden;
  
    img {
      width: 100%;
      object-fit: cover;
    }
  }

  .box-text-right {
    float: right;
    width: calc(100% - 80px - 20px);
    margin-bottom: 20px;

    .box-title {
      margin-block: 16px;
      font-size: 16px;
      font-size: 1.6rem;
    }
  }

  .box-bottom {
    clear: both;
    padding-top: 13px;
  }
}

/* .column-box */
.article-body .column-box {
  display: flex;
  flex-direction: column;
  row-gap: 24px;
  margin-block: 40px;
  padding: 40px 16px;
  border: 1px solid #212121;

  &.cf::before,
  &.cf::after {
    display: none;
  }

  .image {
    padding-top: 66%;
    background: top center no-repeat;
    background-size: contain;
  }

  .text-box {
    width: 70%;
    padding-left: 14px;
  }

  .text {
    display: flex;
    flex-direction: column;
    row-gap: 12px;

    .genre {
      margin-bottom: -.5em;
      font-size: 12px;
      font-size: 1.2rem;
      font-weight: 500;
      line-height: 1;
    }

    .title {
      margin: 0;
      font-size: 16px;
      font-size: 1.6rem;
      line-height: 1.6;
      font-weight: 500;
    }
  }

  .detail {
    > p {
      font-size: 14px;
      font-size: 1.4rem;
      line-height: 1.8;
      font-weight: 400;
    }
  }
}

/* .box-magazine */
.article-body .box-magazine {
  img {
    width: 200px;
    height: 256px;
  }

  .image-left {
    margin: 0;
  }

  .image-area {
    margin: 0;
  }

  .blank-caption {
    width: 0;
    height: 0;
    margin: 0;
    padding: 0;
    visibility: hidden;
  }

  .box-normal {
    margin: 24px 0 0;
  }
}

/* === feature === */
.article-body .feature {
  margin: 40px auto 0;

  h5 {
    font-size: 16px;
    font-size: 1.6rem;
    margin-bottom: 18px;
  }

  .item {
    padding-bottom: 0;

    & + .item {
      border-top: none;
    }

    a {
      color: #333;

      .image {
        width: 17.91%;
        padding-top: 17.91%;
      }

      .text {
        width: calc(100% - 17.91% - 10px);
        padding-top: 0;

        p {
          margin-top: 0;
          padding-bottom: 6px;
        }

        li {
          margin-top: 0;
        }

        .title {
          font-size: 13px;
          font-weight: normal;
        }
      }
    }
  }
}

/* === ページネーション === */
.article-body {
  .module-pagination {
    ul li { line-height: 40px; }

    ul li a { text-decoration: none; }
  }

  .module-next-button {
    a { text-decoration: none; }
  }
}

/* === 購入する === */
.article-body {
  .magazine-buy {
    margin: 50px auto;

    h4 {
      position: relative;
      color: var(--color-black);
      font-family: var(--font-josefin-sans);
      font-size: 20px;
      font-size: 2.0rem;
      font-weight: 600;
      line-height: 100%;
      margin: 30px 0 18px;
    }

    .pr {
      position: relative;

      &::after {
        content: '【PR】';
        display: inline-block;
      }
    }

    ul {
      margin-top: 0;
      font-size: 0;
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
      margin-bottom: 30px;

      li {
        display: inline-block;
        width: 166px;
        margin: 0;
      }
    }
  }

  .purchase {
    margin-top: 20px;

    ul {
      font-size: 0;
      margin: 0 0 0 -1.1%;

      li {
        display: inline-block;
        width: 32.21%;
        margin: 5px 0 0 1.1%;
        border: 1px solid #e6e6e6;

        img { width: 100%; }
      }

      &.digital li { width: 23.9%; }
    }
  }
}

/* === psychology === */
.article-body {
  .psychology-answer {
    font-size: 20px;
    font-size: 2.0rem;
    font-weight: bold;
    text-align: center;

    + p {
      margin-top: 10px;
      text-align: center;
    }
  }

  .psychology-result {
    padding: 25px 20px;
    font-size: 20px;
    font-size: 2.0rem;
    font-weight: bold;
    text-align: center;
    background-color: #D8F2DF;
  }

  .psychology-share {
    margin-top: 20px;
    font-size: 13px;
    font-size: 1.3rem;
    text-align: center;

    .inner {
      width: 166px;
      padding: 20px;
      margin: 5px auto 0;
      background-color: #EFEFEF;
      border-radius: 10px;

      a + a { margin-left: 30px; }

      .facebook img { width: 34px !important; }
      .twitter  img { width: 40px !important; }
      .x_psychology img { width: 30px !important; }
    }
  }
}

/* === books === */
.article-body.books {
  th, td {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.4;
    border: solid 1px #dcdcdc;
    padding: 2%;
  }

  th {
    background-color: #e9f5fd;
    width: 20%;
    max-width: 120px;
    font-weight: bold;
  }

  th, td {
    display: block;
    width: 100%;
    max-width: 100%;
    border-bottom: 0;
    padding: 2% 4% 3%;
  }

  td {
    padding: 2% 4% 4%;
  }

  td:last-child {
    border-bottom: solid 1px #dcdcdc;
  }

  figure {
    text-align: center;
    margin-bottom: 20px;

    figcaption { text-align: left; }
  }
}

/* === .module-sanmeigaku === */
.article-body .module-sanmeigaku {
  width: 100%;
  margin: 30px auto;

  .col .item {
    margin: 0;
  }
}

/* ----------------------------------------------------------------------------------------------------------------------------
#temp-static-about_ad, #temp-static-comic-essay_contribution
---------------------------------------------------------------------------------------------------------------------------- */
:is(#temp-static-about_ad, #temp-static-comic-essay_contribution) .article-body {
  .link-button {
    margin-block: 40px;
  }

  .link-button > a {
    padding: 10px 28px;
    border: 1px solid #212121;
    border-radius: 50px;
    box-shadow: none;
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.6;
    font-weight: 500;

    &:hover {
      background: inherit;
      color: inherit;
      opacity: .5;
    }

    &::before {
      display: none;
    }
  }
}

/* ----------------------------------------------------------------------------------------------------------------------------
.article-magazine-next
---------------------------------------------------------------------------------------------------------------------------- */
.article-body {
  .article-magazine-next {
    display: flex;
    flex-direction: column;
    row-gap: 16px;
    padding: 40px 16px;
    background: #f6f6f6;
    color: #212121;
  }

  .article-magazine-next__heading {
    display: flex;
    flex-direction: column;
    row-gap: 9px;
    margin: 0 !important;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1.6;

    > span {
      font-size: 12px;
      font-size: 1.2rem;
    }
  }


  .article-magazine-next__summary {
    margin: 0 !important;
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.6;
    font-weight: 400;
  }

  .article-magazine-next__note {
    display: flex;
    align-items: center;
    gap: 1em;
    color: #6d6d6d;
    font-size: 12px;
    font-size: 1.2rem;
  }

  .article-magazine-next__links {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;

    a {
      display: grid;
      place-items: center;
      height: auto;
      padding: 6px 24px;
      background: transparent;
      box-shadow: none;
      border: 1px solid #212121;
      border-radius: 50px;
      color: #212121;
      font-size: 12px;
      font-size: 1.2rem;
      line-height: 1.6;
      font-weight: 500;
    }
  }
}

/* ----------------------------------------------------------------------------------------------------------------------------
.article-image
---------------------------------------------------------------------------------------------------------------------------- */

.article-image {
  width: 89.33%;
  margin: 0 auto;
}

.article-image h1 {
  position: relative;
  padding: 15px 0 15px 20px;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
}

.article-image h1:before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(180deg);
  transform: translateY(-50%) rotate(180deg);
  width: 12px;
  height: 12px;
  background: url(/common/crea/images/v1/icon/arrow_black.png) left top no-repeat;
  background-size: 100%;
}

.article-image article {
  width: 111.94%;
  margin: 0 0 30px -5.97%;
  border-bottom: 1px solid #707070;
}

.article-image article .main-image {
  position: relative;
  margin-bottom: 40px;
}

.article-image article .main-image .image {
  position: relative;
  margin: 0 auto 10px;
  width: auto;
}

.article-image article .main-image .caption {
  margin: 10px auto 0;
  padding: 0 20px;
  line-height: 16px;
  font-size: 12px;
  font-size: 1.2rem;
  color: #999;
}

.article-image article .main-image .prev {
  position: absolute;
  left: -6.4%;
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(180deg);
  transform: translateY(-50%) rotate(180deg);
  width: 20px;
  height: 20px;
  /*
  background: url(/common/crea/images/v1/icon/arrow_white.png) left top no-repeat;
  background-size: 100%;
  */
}

.article-image article .main-image .next {
  position: absolute;
  right: -6.4%;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  /*
  background: url(/common/crea/images/v1/icon/arrow_white.png) left top no-repeat;
  background-size: 100%;
  */
}

.article-image article ul {
  width:auto;
  padding: 0 20px;
  margin: 0 auto 40px;
  font-size: 0;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 14px;
}

.article-image article ul li {
  display: inline-block;
  /*
  width: 36px;
  height:36px;
  */
  width: auto;
  height: auto;
  border: 1px solid #707070;
}

.article-image article ul li.active {
  border: 1px solid #E54C78;
}

.article-image article ul li a {
  display: block;
  width: 100%;
  padding-top: 100%;
  background: center center no-repeat;
  background-size: cover;
}
.article-image article ul li span {
  display: block;
  width: 100%;
  padding-top: 100%;
  background: center center no-repeat;
  background-size: cover;
}
.gallery-button-prev,
.gallery-button-next {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23ffffff'%2F%3E%3C%2Fsvg%3E");
  background-size: 19px 19px;
  height: 44px;
  margin-top: -24px;
  top: 50%;
  width: 44px;
  border-radius: 50%;
}
.gallery-button-prev{left:-2%;}
.gallery-button-next {
  transform: rotate(180deg);
  right:-2% ;
}
.gallery-thumbList__item.is-current{
  border: 1px solid #E2CBBD;
}
.gallery-thumbList__item:not(.is-current) img {
  opacity: .5;
}
.gallery-slide__inner {
  width: 100% ;
}
.gallery-slide__img > img {
  height: auto;
  max-width: 100% ;
}
.gallery-thumbList__item {
  height: 65px;
  position: relative;
  width: 100% ;
}
.gallery-thumbList__item > img {
  left: 50% ;
  max-height: 100% ;
  max-width: 100% ;
  position: absolute;
  top: 50% ;
  -webkit-transform: translate( -50% , -50% );
  transform: translate( -50% , -50% );
  width: auto;
}

/* ----------------------------------------------------------------------------------------------------------------------------
.list-normal
---------------------------------------------------------------------------------------------------------------------------- */

.list-normal {
  width: auto;
  margin: 30px auto;
}
.list-normal.--type-w{
  width: 100%;
}

.headline+.list-normal {
  margin-top: 0;
}

.list-normal+.list-normal {
  /* display: none; */
  margin-top: 0;
  padding-top: 30px;
  border-top: 1px solid #ccc;
}

.list-normal .item {
  position: relative;
  padding-bottom: 27px;
}

.list-normal .item+.item{
  padding-top: 15px;
  border-top: 1px solid #ccc;
}

.list-normal.fortune .pickup{
 border-bottom: 1px solid #ccc;
 border-top:none;
 margin-bottom:15px;
}

.list-normal.--type-w .item{
  padding-bottom:10px;
}
.list-normal.--type-w .item+.item{
 padding-top:10px;
}

.list-normal .item:last-child {
  padding-bottom: 0;
}

.list-normal .item a {
  display: flex;
  gap: 15px;
}

.list-normal .item .image {
  position: relative;
  float: left;
  width: 25.37%;
  padding-top: 25.37%;
  background: center center no-repeat;
  background-size: cover;
}
.list-normal.--type-w .item .image{
 margin-left:1px;
 width:85px;
 padding-top:85px;
}

.list-normal .item.new .image:before {
  content: 'NEW';
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  top: -9.5px;
  width: 46px;
  line-height: 19px;
  font-size: 12px;
  font-size: 1.2rem;
  font-weight: bold;
  text-align: center;
  background-color: #FFED12;
}

.list-normal .item.new.pickup .image:before {
  top: 0;
  left: auto;
}

.list-normal .item .text {
  float: right;
  width: calc(100% - 25.37% - 15px);
}
.list-normal.--type-w .item .text{
 margin-left:10px;
}

.list-normal .item .text .title {
  padding-bottom: 22px;
  line-height: 22px;
  font-size: 13px;
  font-size: 1.3rem;
}
.list-normal.fortune .item .text .title{
  font-size:15px;
  font-size: 1.5rem;
  font-weight:bold;
}

.list-normal .item .text .bottom {
  position: relative;
  padding-right: 60px;
  line-height: 14px;
  font-size: 11px;
  font-size: 1.1rem;
}

.list-normal .item .text .bottom li {
  display: inline-block;
}

.list-normal .item .text .bottom li+li:before {
  content: '/';
  padding: 0 0.5em;
}

.list-normal .item .text .bottom li.blank {
  padding-right: 20px;
  background: url(/common/crea/images/v1/icon/link_blank.png) 100% center no-repeat;
  background-size: 13px;
}

.list-normal .item .text .bottom .date {
  position: absolute;
  right: 0;
  bottom: -5px;
  font-size: 10px;
  font-size: 1.0rem;
  color: #707070;
}

@media print,
screen and (max-width: 374px) {
  .list-normal .item .text {
    /*.title {
          padding-bottom: 18px;
          line-height: 18px;
          font-size: 10px;
          font-size: 1.0rem;
          }
          .bottom,
          .date {
          font-size: 9px;
          font-size: 0.9rem;
          }*/
  }
}

.list-normal .item.promoted .title:after {
  content: 'Promoted';
  position: relative;
  top: -2px;
  margin-left: 6px;
  padding: 0 3px;
  line-height: 12px;
  font-size: 9px;
  font-size: 0.9rem;
  background-color: #ccc;
}

.list-normal .item.member .title:after {
  content: 'MEMBER';
  position: relative;
  top: -2px;
  margin-left: 6px;
  padding: 0 3px;
  line-height: 12px;
  font-size: 9px;
  font-size: 0.9rem;
  color: #fff;
  background-color: #F597AD;
}

.list-normal .item.traveller .title:after {
  content: 'CREA Traveller';
  position: relative;
  top: -2px;
  margin-left: 6px;
  padding: 0 3px;
  line-height: 12px;
  font-size: 9px;
  font-size: 0.9rem;
  color: #fff;
  background-color: var(--traveller-key-color, #bfa366);
  display: inline-block;
}

.list-normal .item .period {
  clear: both;
  padding-top: 12px;
  font-size: 10px;
  font-size: 1.0rem;
}

.list-normal .item.pickup .image {
  float: none;
  width: 100%;
  height: 0;
  padding-top: 100%;
  margin-bottom: 20px;
}

.list-normal .item.pickup.promoted .image:before {
  content: 'Promoted';
  position: absolute;
  right: 0;
  top: 0;
  padding: 0 3px;
  line-height: 12px;
  font-size: 9px;
  font-size: 0.9rem;
  background-color: rgba(255, 255, 255, 0.3);
}

.list-normal .item.pickup .text {
  width: 100%;
  float: none;
  text-align: center;
}

.list-normal .item.pickup .text .title {
  padding-bottom: 5.5px;
  line-height: 26px;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: bold;
}

.list-normal .item.pickup .text .bottom {
  padding: 0;
}

.list-normal .item.pickup .text .bottom ul {
  display: inline-block;
  font-size: 12px;
  font-size: 1.2rem;
}

.list-normal .item.pickup .text .bottom .date {
  position: static;
  display: inline-block;
  margin-left: 12px;
  font-size: 10px;
  font-size: 1.0rem;
}

.list-normal .item.pickup.promoted .title:after {
  content: none;
}

.list-normal .item.crea30 .title .crea30-badge {
  position: relative;
  top: -2px;
  margin-left: 6px;
  padding: 0 6px;
  line-height: 12px;
  font-size: 9px;
  font-size: 0.9rem;
  background-color: #e61b10;
  color: #fff;
}

/* ----------------------------------------------------------------------------------------------------------------------------
.list-vertical-03
---------------------------------------------------------------------------------------------------------------------------- */

.list-vertical-03 {
  margin: 50px auto;
}

.list-vertical-03 .item {
  position: relative;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.list-vertical-03 .item+.item {
  margin-top: 20px;
}

.list-vertical-03 .item a {
  display: flex;
  gap: 16px;
  padding-bottom:16px;
  border-bottom:solid 1px var(--color-gray5);
}

.list-vertical-03 .item .image {
  position: relative;
  width: 88px;
  height: 88px;
  background: center center no-repeat;
  background-size: cover;
  border: 1px solid #EFEFEF;
}

.list-vertical-03 .item.member .image:before {
  content: 'MEMBER';
  position: absolute;
  right: 0;
  top: 0;
  padding: 0 7px;
  line-height: 19px;
  font-size: 12px;
  font-size: 1.2rem;
  font-weight: bold;
  text-align: center;
  color: #fff;
  background-color: #F597AD;
}

.list-vertical-03 .item.traveller .image:before {
  content: 'CREA Traveller';
  position: absolute;
  right: 0;
  top: 0;
  padding: 0 7px;
  line-height: 19px;
  font-size: 12px;
  font-size: 1.2rem;
  font-weight: bold;
  text-align: center;
  color: #fff;
  background-color: var(--traveller-key-color, #bfa366);
}

.list-vertical-03 .item.new .image:before {
  content: 'NEW';
  position: absolute;
  right: 0;
  top: 0;
  width: 45px;
  line-height: 19px;
  font-size: 12px;
  font-weight: bold;
  text-align: center;
  background-color: #FFED12;
}

.list-vertical-03 .item.promoted .image:after {
  content: 'Promoted';
  position: absolute;
  right: 0;
  top: 0;
  padding: 0 5px;
  line-height: 12px;
  font-size: 8px;
  font-size: 0.8rem;
  background-color: rgba(255, 255, 255, 0.8);
}

.list-vertical-03 .item.new.promoted .image:after {
  top: 18px;
}

.list-vertical-03 .item .text {
  position: relative;
  width: auto;
  flex: 1;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: normal;
}

.list-vertical-03 .item.member-present .text {
  height: auto;
  min-height: 187px;
  color: var(--color-black);
  font-family: var(--font-hiragino-kaku-gothic);
}

.list-vertical-03 .item .text .title {
  margin-bottom: 12px;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: normal;
}

.list-vertical-03 .item .text .about {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: normal;
  margin: 0 auto 10px;
}

.list-vertical-03 .item .text .about p+p {
  margin-top: 4px;
}

.list-vertical-03 .item .text .bottom {
  font-size: 13px;
  font-size: 1.3rem;
  font-weight: 400;
  line-height: normal;
}

.list-vertical-03 .item.member-present .text .bottom {
  position: static;
}

.list-vertical-03 .item .text .bottom ul {
  display: block;
  margin-top: 10px;
}

.list-vertical-03 .item .text .bottom ul li {
  display: inline-block;
}

.list-vertical-03 .item .text .bottom ul li+li {
  padding: 0 0.5em;
}

.list-vertical-03 .item .text .bottom ul li span {
  display: block;
  position: relative;
  z-index: 1;
}

.list-vertical-03 .item .text .bottom ul li span:before {
  content: "";
  width: 100%;
  height: 4px;
  background: var(--color-secondary);
  position: absolute;
  left: 0;
  bottom: 1px;
  right: 0;
  z-index: -1;
}

.list-vertical-03 .item .text .bottom .date {
  margin-top: 7px;
}

.list-vertical-03 .item.crea30 .crea30-badge {
  position: absolute;
  top: 1px;
  right: 1px;
  width: 40px;
  height: 40px;
  line-height: 40px;
  border-radius: 40px;
  background-color: #e61b10;
  color: #fff;
  font-size: 9px;
  font-size: 0.9rem;
  text-align: center;
}

.list-vertical-03 .item.crea30.new .crea30-badge {
  top: 22px;
}

.list-vertical-03 .item.crea30.promoted .crea30-badge {
  top: 32px;
}

/* ----------------------------------------------------------------------------------------------------------------------------
.list-text
---------------------------------------------------------------------------------------------------------------------------- */

.list-text {
  width: 89.33%;
  margin: 30px auto;
}

.headline+.list-text {
  margin-top: 0;
}

.list-text .item {
  position: relative;
  padding-bottom: 10px;
}

.list-text .item+.item {
  padding-top: 20px;
  border-top: 1px solid #ccc;
}

.list-text .item:last-child {
  padding-bottom: 0;
}

.list-text .item a {
  display: block;
}

.list-text .item .text .title {
  line-height: 22px;
  font-size: 13px;
}

.list-text .item .text .bottom .date {
  font-size: 10px;
  font-size: 1.0rem;
  text-align: right;
  color: #707070;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.list-member
---------------------------------------------------------------------------------------------------------------------------- */
.list-member {
  width: 89.33%;
  margin: 30px auto;
}

.list-member .item+.item {
  margin-top: 30px;
  padding-top: 30px;
  border-top: 1px solid #ccc;
}

.list-member .item .image {
  width: 44.78%;
  margin: 0 auto 30px;
}

.list-member .item .image.bg {
  width: 150px;
  height:200px;
  margin: 0 auto 30px;
  position: relative;
  background: center center no-repeat;
  background-size: cover;
  border: 1px solid #EFEFEF;
}

.list-member .item .name,
.list-member .item .title {
  margin-bottom: 20px;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: bold;
  text-align: center;
}

.list-member .item .about a {
  text-decoration: underline;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.list-magazine
---------------------------------------------------------------------------------------------------------------------------- */

.list-magazine {
  width: 89.33%;
  margin: 30px auto;
}

.headline+.list-magazine {
  margin-top: 0;
}

.list-magazine .item {
  padding-bottom: 30px;
  border-bottom: 1px solid #ccc;
}

.list-magazine .item+.item {
  margin-top: 30px;
}

.list-magazine .item .title {
  margin-bottom: 10px;
  font-size: 22px;
  font-size: 2.2rem;
  font-weight: bold;
  text-align: center;
}

.list-magazine .item .image {
  width: 69.85%;
  margin: 0 auto 10px;
  margin: 0 auto;
}

.list-magazine .item .number {
  margin-bottom: 10px;
  font-weight: bold;
  text-align: center;
}

.list-magazine .item .copy {
  margin-bottom: 10px;
  line-height: 26px;
  text-align: center;
}

.list-magazine .item .copy strong {
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: bold;
}

.list-magazine .item .button {
  margin-bottom: 10px;
  text-align: center;
}

.list-magazine .item .button .link-button {
  display: inline-block;
  width: 134px;
  margin: 0;
}

.list-magazine .item .button .link-button+.link-button {
  margin-left: 10px;
}

.list-magazine .item .button .link-button a {
  padding: 6px 30px 6px 12px;
  text-align: left;
}

.list-magazine .item .keyword {
  margin: 20px auto 0;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.list-book
---------------------------------------------------------------------------------------------------------------------------- */

.list-book {
  width: 89.33%;
  margin: 30px auto;
}

.headline+.list-book {
  margin-top: 0;
}

.list-book .item {
  padding-bottom: 20px;
  border-bottom: 1px solid #ccc;
}

.list-book .item+.item {
  margin-top: 20px;
}

.list-book .item .image-left {
  float: left;
  width: 25.37%;
}

.list-book .item .text-right {
  float: right;
  width: 70.15%;
  margin-bottom: 20px;
}

.list-book .item .text-right .title {
  font-weight: bold;
}

.list-book .item .text-right .author {
  margin-bottom: 10px;
  font-weight: bold;
}

.list-book .item .text-right .date {
  margin-bottom: 10px;
}

.list-book .item .link-button {
  clear: both;
  margin: 20px auto;
}

.list-book .item .link p {
  font-size: 12px;
  font-size: 1.2rem;
}

.list-book .item .link ul {
  font-size: 0;
}

.list-book .item .link ul li {
  display: inline-block;
  width: 23.58%;
}

.list-book .item .link ul li+li {
  margin-left: 1.79%;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.list-back-number
---------------------------------------------------------------------------------------------------------------------------- */

.list-back-number {
  width: 89.33%;
  margin: 30px auto;
}

.list-back-number .item {
  position: relative;
}

.list-back-number .item+.item {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid #ccc;
}

.list-back-number .item a {
  display: block;
}

.list-back-number .item .image {
  float: left;
  width: 25.37%;
  border: 1px solid #E1E1E1;
}

.list-back-number .item .text {
  position: relative;
  float: right;
  width: calc(100% - 25.37% - 20px);
}

.list-back-number .item .text .title {
  margin-bottom: 15px;
  line-height: 26px;
  font-size: 13px;
  font-size: 1.2rem;
}

.list-back-number .item .text .title strong {
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: bold;
}

.list-back-number .item .text .media {
  font-size: 13px;
  font-size: 1.3rem;
  margin-bottom: 5px;
}

.list-back-number .item .text .number {
  font-size: 13px;
  font-size: 1.3rem;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.list-col2
---------------------------------------------------------------------------------------------------------------------------- */

.list-col2 {
  width: 89.33%;
  margin: 30px auto 10px;
}

.headline+.list-col2 {
  margin-top: 0;
}

.list-col2 .item {
  position: relative;
  float: left;
  width: 48.36%;
  margin-bottom: 20px;
}

.list-col2 .item:nth-child(odd) {
  clear: both;
}

.list-col2 .item:nth-child(even) {
  margin-left: 2.99%;
}

.list-col2 .item a {
  display: block;
}

.list-col2 .item .image {
  position: relative;
  width: 100%;
  /*padding-top: 71.6%;*/
  padding-top: 75.16%;
  margin-bottom: 10px;
  background: center center no-repeat;
  background-size: cover;
}

.list-col2 .item.promoted .image:before {
  content: 'Promoted';
  position: absolute;
  right: 0;
  top: 0;
  padding: 0 3px;
  line-height: 12px;
  font-size: 9px;
  background-color: rgba(255, 255, 255, 0.3);
}

.list-col2 .item .text .title {
  padding-bottom: 10px;
  line-height: 22px;
  font-size: 13px;
  font-size: 1.3rem;
}

.list-col2 .item .text .bottom {
  line-height: 14px;
  font-size: 10px;
  font-size: 1.0rem;
}

.list-col2 .item .text .bottom li {
  display: inline-block;
  margin-bottom: 5px;
}

.list-col2 .item .text .bottom li+li:before {
  content: '/';
  padding: 0 0.5em;
}

.list-col2 .item .text .bottom li.blank {
  padding-right: 20px;
  background: url(/common/crea/images/v1/icon/link_blank.png) 100% center no-repeat;
  background-size: 13px;
}

.list-col2 .item .text .bottom .date {
  color: #707070;
}

@media print,
screen and (max-width: 374px) {
  .list-col2 .item .text .title {
    padding-bottom: 7px;
    line-height: 18px;
    font-size: 10px;
    font-size: 1.0rem;
  }
  .list-col2 .item .text .bottom,
  .list-col2 .item .text .date {
    font-size: 8px;
    font-size: 0.8rem;
  }
  .list-col2 .item .text .bottom li {
    margin-bottom: 2px;
  }
}

.list-col2 .item .subtitle {
  padding-bottom: 6px;
  font-size: 10px;
  font-size: 1.0rem;
  font-weight: bold;
}

.list-col2 .item.pickup {
  float: none;
  width: 100%;
  margin: 0 0 20px;
}

.list-col2 .item.pickup .image {
  /* padding-top: 100%; */
  margin-bottom: 20px;
}

.list-col2 .item.pickup.promoted .image:before {
  content: 'Promoted';
  position: absolute;
  right: 0;
  top: 0;
  padding: 0 3px;
  line-height: 12px;
  font-size: 9px;
  font-size: 0.9rem;
  background-color: rgba(255, 255, 255, 0.3);
}

.list-col2 .item.pickup .text {
  width: 100%;
  text-align: center;
}

.list-col2 .item.pickup .text .title {
  padding-bottom: 5.5px;
  line-height: 26px;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
}

.list-col2 .item.pickup .text .bottom {
  padding: 0;
}

.list-col2 .item.pickup .text .bottom ul {
  display: inline-block;
  font-size: 12px;
  font-size: 1.2rem;
}

.list-col2 .item.pickup .text .bottom .date {
  position: static;
  display: inline-block;
  margin-left: 12px;
  font-size: 10px;
  font-size: 1.0rem;
}

.list-col2 .item.pickup.promoted .title:after {
  content: none;
}

/* ----------------------------------------------------------------------------------------------------------------------------
.list-col3
---------------------------------------------------------------------------------------------------------------------------- */

.list-col3 {
  width: 89.33%;
  margin: 30px auto 10px;
}

.headline+.list-col3 {
  margin-top: 0;
}

.list-col3 .item {
  position: relative;
  float: left;
  width: 48.36%;
  margin-bottom: 20px;
}

.list-col3 .item:nth-child(odd) {
  clear: both;
}

.list-col3 .item:nth-child(even) {
  margin-left: 2.99%;
}

.list-col3 .item a {
  display: block;
}

.list-col3 .item .image {
  position: relative;
  width: 100%;
  /*padding-top: 71.6%;*/
  padding-top: 75.16%;
  margin-bottom: 10px;
  background: center center no-repeat;
  background-size: cover;
}

.list-col3 .item.promoted .image:before {
  content: 'Promoted';
  position: absolute;
  right: 0;
  top: 0;
  padding: 0 3px;
  line-height: 12px;
  font-size: 9px;
  font-size: 0.9rem;
  background-color: rgba(255, 255, 255, 0.3);
}

.list-col3 .item .text .title {
  padding-bottom: 5px;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 21px;
}

.list-col3 .item .text .bottom {
  color: #222;
  font-size: 12px;
  font-size: 1.2rem;
  font-weight: 400;
  display: grid;
  grid-template-columns: 64% 1fr;
  gap: 4px;
  line-height: 100%;
}

.list-col3 .item .text .bottom li {
  display: inline-block;
  margin-bottom: 5px;
}

.list-col3 .item .text .bottom li+li:before {
  content: '/';
  padding: 0 0.5em;
}

.list-col3 .item .text .bottom li.blank {
  padding-right: 20px;
  background: url(/common/crea/images/v1/icon/link_blank.png) 100% center no-repeat;
  background-size: 13px;
}

.list-col3 .item .text .bottom .date {
  color: #666;
}

.list-col3 .item .text .bottom .date.right {
  text-align: right;
}

@media print,
screen and (max-width: 374px) {
  .list-col3 .item .text .title {
    padding-bottom: 5px;
    line-height: 18px;
    font-size: 12px;
    font-size: 1.2rem;
  }
  .list-col3 .item .text .bottom,
  .list-col3 .item .text .date {
    font-size: 12px;
    font-size: 1.2rem;
  }
  .list-col3 .item .text .bottom li {
    margin-bottom: 2px;
  }
}

.list-col3 .item .subtitle {
  padding-bottom: 6px;
  font-size: 10px;
  font-size: 1.0rem;
  font-weight: bold;
}

.list-col3 .item.pickup {
  float: none;
  width: 100%;
  margin: 0 0 18px;
  border-bottom: 1px solid #CCC;
  padding-bottom: 18px;
}

.list-col3 .item.pickup a {
  display: grid;
  gap: 14px;
  grid-template-columns: 148px 1fr;
}

.list-col3 .item.pickup .image {
  margin-bottom: 0;
  padding-top: 0;
  height: 148px;
}

.list-col3 .item.pickup.promoted .image:before {
  content: 'Promoted';
  position: absolute;
  right: 0;
  top: 0;
  padding: 0 3px;
  line-height: 12px;
  font-size: 9px;
  font-size: 0.9rem;
  background-color: rgba(255, 255, 255, 0.3);
}

.list-col3 .item.pickup .text {
  width: 100%;
  padding-bottom: 5.5px;
  line-height: 25px;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: left;
}

.list-col3 .item.pickup .text .title {
  padding-bottom: 10px;
  line-height: 25px;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: bold;
}

.list-col3 .item.pickup .text .bottom {
  padding: 0;
  display: block;
}

.list-col3 .item.pickup .text .bottom ul {
  display: block;
  font-size: 13px;
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 19.5px;
}

.list-col3 .item.pickup .text .bottom .date {
  position: static;
  display: block;
  margin-left: 0;
  font-size: 13px;
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 19.5px;
}

.list-col3 .item.pickup.promoted .title:after {
  content: none;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.list-head
---------------------------------------------------------------------------------------------------------------------------- */

.list-head {
  width: 89.33%;
  margin: 20px auto;
  font-weight: bold;
  text-align: center;
}

.list-head .inner {
  position: relative;
  padding: 5px 0;
}

.list-head .inner .genre {
  font-size: 10px;
  font-size: 1.0rem;
  margin-bottom: 15px;
}

.list-head .inner h1 {
  font-size: 16px;
  font-size: 1.6rem;
}

.list-head .inner h1.ambassador img {
  width: 56.12% ;
}

.list-head .inner.strong :is(h1, h2) {
  font-size: 26px;
  font-size: 2.6rem;
}

.list-head .inner.keyword h1 {
  line-height: 30px;
  font-size: 20px;
  font-size: 2.0rem;
}

.list-head .inner.border {
  padding: 36px 12px;
  border: 1px solid #707070;
}

.list-head .inner.border h1 {
  font-size: 26px;
  font-size: 2.6rem;
}

.list-head .inner.border .genre {
  position: absolute;
  left: 0;
  top: 5px;
  width: 100% ;
}

.list-head .inner.color {
  padding: 36px 12px;
  background-color: #EFEFEF;
}

.list-head .inner.color h1 {
  font-size: 26px;
  font-size: 2.6rem;
}

.list-head .inner.color .genre {
  position: absolute;
  left: 0;
  top: 5px;
  width: 100%;
}

.list-head .paging {
  margin-top: 5px;
  font-size: 10px;
  font-size: 1.0rem;
}

.list-head .banner {
  margin: 20px auto;
}

.list-head .banner img {
  border: 1px solid #EFEFEF;
}

.list-head .about {
  margin-bottom: 10px;
  padding:0 10px;
  font-weight: normal;
  text-align: left;
}

.list-head .author {
  margin-bottom: 20px;
  padding:0 10px;
  font-weight: normal;
  font-size: 12px;
  font-size: 1.2rem;
}

.list-head .sns {
  width: 111.94%;
  margin: 20px 0 20px -5.97%;
  padding-bottom: 25px;
  font-size: 0;
  text-align: center;
  border-bottom: 1px solid #707070;
}

.list-head .sns li {
  display: inline-block;
  width: 18px;
}

.list-head .sns li+li {
  margin-left: 12.27%;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.list-writer
---------------------------------------------------------------------------------------------------------------------------- */

.list-writer {
  width: 100%;
  margin: 30px auto;
  font-size: 0;
  display: flex;
  flex-wrap: wrap;
  gap:20px 10px;
}

.headline+.list-writer {
  margin-top: 0;
}

.list-writer .item {
  display: inline-block;
  width: 22.69%;
}

.list-writer .item a {
  display: block;
}

.list-writer .item a .image {
  width: 100%;
  padding-top: 100%;
  border: 1px solid #707070;
  background: center center no-repeat;
  background-size: cover;
}

.list-writer .item a .name {
  font-size: 13px;
  font-size: 1.3rem;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.list-serial
---------------------------------------------------------------------------------------------------------------------------- */

.list-serial {
  width: 89.33%;
  margin: 30px auto;
}

.headline+.list-serial {
  margin-top: 0;
}

.list-serial .item {
  margin-bottom: 30px;
  padding: 20px;
  line-height: 22px;
  font-size: 12px;
  font-size: 1.2rem;
  border: 1px solid #707070;
}

.list-serial .item .thumb {
  width: calc(100% + 40px);
  margin: -20px 0 0 -20px;
}

.list-serial .item .box-image-left {
  float: left;
  width: 50px;
  margin-top: 20px;
}

.list-serial .item .box-text-right {
  float: right;
  width: calc(100% - 50px - 20px);
  font-weight: bold;
  margin-top: 20px;
}

.list-serial .item .box-bottom {
  clear: both;
  padding-top: 20px;
}

.list-serial .item .box-bottom ul {
  margin: 20px 0;
}

.list-serial .item .box-bottom ul li {
  padding: 15px 0;
  font-size: 13px;
  font-size: 1.3rem;
  border-bottom: 1px solid #ccc;
}

.list-serial .item .box-bottom ul li a {
  color: #333;
}

.list-serial .item .box-bottom .title {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
}

.list-serial .item .box-bottom .caption {
  text-align: center;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.box-previously
---------------------------------------------------------------------------------------------------------------------------- */

.box-previously {
  width: 89.33%;
  margin: 30px auto;
  font-size: 0;
}

.headline+.box-previously {
  margin-top: 0;
}

.box-previously li {
  display: inline-block;
  vertical-align: top;
  width: 22.69%;
}

.box-previously li+li {
  margin-left: 2.99%;
}

.box-previously li:nth-child(4n + 1) {
  margin-left: 0;
}

.box-previously li a {
  display: block;
  color: #333;
}

.box-previously li a p {
  line-height: 15px;
  font-size: 11px;
  font-size: 1.1rem;
}

.box-previously li a p+p {
  margin-top: 5px;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.button-box
---------------------------------------------------------------------------------------------------------------------------- */

.button-box {
  margin: 30px auto;
  padding: 30px 0;
  background-color: #EFEFEF;
}

.button-box .link-button {
  margin: 0 auto;
}

.button-box .link-button+.link-button {
  margin-top: 10px;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.comic-essay-bottom
---------------------------------------------------------------------------------------------------------------------------- */

.comic-essay-bottom {
  margin: 30px auto;
  padding: 30px 5.33%;
  border-top: 1px solid #707070;
  border-bottom: 1px solid #707070;
}

.comic-essay-bottom a {
  color: #E54C78;
  font-weight: bold;
}

.comic-essay-bottom .box {
  margin-bottom: 30px;
  padding: 20px;
  line-height: 22px;
  font-size: 12px;
  font-size: 1.2rem;
  border: 1px solid #707070;
  gap: 20px;

  display: grid;
  grid-template-areas:
    "image title"
    "text text"
  ;
  grid-template-columns: 50px 1fr;
}

.comic-essay-bottom .box .box-image-left {
  grid-area: image;
  width: 50px;
}

.comic-essay-bottom .box .box-text-right {
  grid-area: title;
  width: calc(100% - 50px - 20px);
  font-weight: bold;
}

.comic-essay-bottom .box .box-bottom {
  grid-area: text;
  clear: both;
}

.comic-essay-bottom .box .box-bottom ul {
  margin: 20px 0;
}

.comic-essay-bottom .box .box-bottom ul li {
  padding: 15px 0;
  font-size: 13px;
  font-size: 1.3rem;
  border-bottom: 1px solid #ccc;
}

.comic-essay-bottom .box .box-bottom ul li a {
  color: #333;
}

.comic-essay-bottom .box .box-bottom .caption {
  text-align: center;
}

.comic-essay-bottom h5 {
  margin-top: 20px;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: bold;
}

.comic-essay-bottom p {
  margin-top: 10px;
  font-size: 13px;
  font-size: 1.3rem;
}

.comic-essay-bottom .link-button a {
  color: #333;
}

.comic-essay-bottom .previously {
  font-size: 0;
}

.comic-essay-bottom .previously li {
  display: inline-block;
  width: 22.69%;
}

.comic-essay-bottom .previously li+li {
  margin-left: 2.99%;
}

.comic-essay-bottom .previously li:nth-child(4n + 1) {
  margin-left: 0;
}

.comic-essay-bottom .previously li a {
  display: block;
  color: #333;
}

.comic-essay-bottom .previously li a p {
  line-height: 15px;
  font-size: 11px;
  font-size: 1.1rem;
}

.comic-essay-bottom .previously li a p+p {
  margin-top: 5px;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.keyword
---------------------------------------------------------------------------------------------------------------------------- */

.keyword {
  margin-top: 30px;
  text-align: right;
  font-size: 0;
}

.keyword p {
  display: inline-block;
  margin: 5px;
}

.article-body .keyword p,
.article-body .keyword a {
  text-align: center;
  font-family: var(--font-hiragino-kaku-gothic);
  font-weight: 600;
  line-height: 100%;
  text-align: left;
}

.article-body .keyword a:before {
  content: "\00BB";
  font-size: 18px;
  font-size: 1.8rem;
  color:var(--link-color);
  padding-right: 5px;
}

.article-body .keyword a {
  text-decoration: none;
  color:var(--link-active);
  font-size: 18px;
  font-size: 1.8rem;
}

.keyword p a.blank {
  position: relative;
  padding-right: 30px;
}

.keyword p a.blank:before {
  content: '';
  position: absolute;
  right: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 13px;
  height: 12px;
  background: url(/common/crea/images/v1/icon/link_blank.png) left top no-repeat;
  background-size: 100%;
}

.keyword.back-number {
  width: 89.33%;
  margin: 30px auto 0;
  text-align: left;
}

.keyword.back-number p {
  width: 18.81%;
  margin: 0 0 5px;
  padding: 4px 0;
  text-align: center;
}

.keyword.back-number p+p {
  margin-left: 1.49%;
}

.keyword.back-number p:nth-child(5n + 1) {
  margin-left: 0;
}

.keyword.back-number p a {
  font-size: 12px;
  font-size: 1.2rem;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.profile-box
---------------------------------------------------------------------------------------------------------------------------- */

.profile-box {
  width: 89.33%;
  margin: 30px auto 20px;
  padding: 20px;
  border: 1px solid #ccc;
}

.profile-box .image-left {
  float: left;
  width: 50px;
}

.profile-box .text-right {
  float: right;
  width: calc(100% - 50px - 20px);
  line-height: 22px;
  font-size: 12px;
  font-size: 1.2rem;
  font-weight: bold;
}

.profile-box .about {
  margin-top: 15px;
  line-height: 22px;
  font-size: 12px;
  font-size: 1.2rem;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.ranking-box
---------------------------------------------------------------------------------------------------------------------------- */

.ranking-box .tabs {
  position: relative;
  width: 89.33%;
  margin: 0 auto;
  font-size: 0;
  display:flex;
}

.ranking-box .tabs:before {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  border-bottom: 1px solid #707070;
}

.ranking-box .tabs li {
  position: relative;
  width: calc(100% / 3 - 2px);
  line-height: 28px;
  font-size: 13px;
  font-size: 1.3rem;
  color: #999;
  text-align: center;
  background-color: #EFEFEF;
  border-top: 1px solid #EFEFEF;
  border-bottom: 1px solid #707070;
}

.ranking-box .tabs li+li {
  margin-left: 3px;
}

.ranking-box .tabs li:nth-child(3) {
  float: right;
}

.ranking-box .tabs li.active {
  color: #222;
  background-color: #fff;
  border: 1px solid #707070;
  border-bottom: 1px solid #fff;
}

.ranking-box .pattern+.pattern {
  display: none;
}

.ranking-box .pattern .item {
  counter-increment: count-number;
}

.ranking-box .pattern .item .image:before {
  content: counters(count-number, "");
  position: absolute;
  left: 50%;
  top: 0;
  -webkit-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  width: 24px;
  line-height: 24px;
  font-size: 12px;
  font-size: 1.2rem;
  text-align: center;
  background-color: #FFED12;
  border-radius: 24px;
}

.ranking-box .link-button {
  display: none;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.author-introduction
---------------------------------------------------------------------------------------------------------------------------- */

.author-introduction {
  width: 89.33%;
  margin: 0 auto 30px;
}

.author-introduction .box {
  margin-top: 30px;
}

.author-introduction .box .image-left {
  float: left;
  width: 80px;
}

.author-introduction .box .text-right {
  position: relative;
  float: right;
  width: calc(100% - 80px - 20px);
  padding: 20px;
  background-color: #fff;
  border: 1px solid #707070;
  border-radius: 5px;
}

.author-introduction .box .text-right:before {
  content: '';
  position: absolute;
  left: -13px;
  top: 12px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 11px 13px 11px 0;
  border-color: transparent #707070 transparent transparent;
}

.author-introduction .box .text-right:after {
  content: '';
  position: absolute;
  left: -11px;
  top: 12px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 11px 13px 11px 0;
  border-color: transparent #fff transparent transparent;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.comic-introduction
---------------------------------------------------------------------------------------------------------------------------- */

.comic-introduction {
  width: 89.33%;
  margin: 30px auto 40px;
}

.comic-introduction .item {
  padding: 15px 0;
  border-bottom: 1px solid #ccc;
}

.comic-introduction .item:first-child {
  padding-top: 0;
}

.comic-introduction .item a {
  display: block;
}

.comic-introduction .item.pickup {
  border-bottom: none;
}

.comic-introduction .item.pickup .image {
  margin-bottom: 15px;
  border: 1px solid #E1E1E1;
}

.comic-introduction .item.pickup .title {
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: bold;
  text-align: center;
}

.comic-introduction .item.pickup .author {
  margin-bottom: 15px;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: bold;
  text-align: center;
}

.comic-introduction .item.pickup .about {
  margin-bottom: 20px;
  line-height: 17px;
  font-size: 10px;
  font-size: 1.0rem;
}

.comic-introduction .item.pickup .bottom {
  position: relative;
  margin-top: 15px;
  line-height: 14px;
  text-align: center;
}

.comic-introduction .item.pickup .bottom ul {
  display: inline-block;
  margin-right: 20px;
}

.comic-introduction .item.pickup .bottom ul li {
  display: inline-block;
  font-size: 10px;
  font-size: 1.0rem;
}

.comic-introduction .item.pickup .bottom ul li+li:before {
  content: '/';
  padding: 0 0.5em;
}

.comic-introduction .item.pickup .bottom .date {
  display: inline-block;
  font-size: 10px;
  font-size: 1.0rem;
}

/* ============================================================================================================================
.box-mail-magazine
============================================================================================================================ */
.box-mail-magazine {
  margin: 50px auto;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 150%;
}

.box-mail-magazine .notes {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 150%;
  margin-bottom:30px;
}

.box-mail-magazine .link-button {
  margin: 0 auto 50px;
}

.box-mail-magazine .caption {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 150%;
  text-align: right;
}

.box-mail-magazine .caption a {
  color: var(--link-active);
  text-decoration: underline;
}

/* ============================================================================================================================
.box-notes
============================================================================================================================ */

.box-notes {
  padding: 20px 30px;
  line-height: 19px;
  font-size: 12px;
  color: #707070;
  border: 1px solid #ccc;
}

.box-notes .text {
  display: flex;
  justify-content: center;
  align-items: center;
  gap:10px;
}

.box-notes p:not(:last-child) {
    margin-bottom: 10px;
}

.box-notes span {
  padding: 0 7px;
  color: #fff;
  font-weight: bold;
  background-color: #FF9AA0;
  display: block;
  text-align: center;
  min-height: 35px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.box-notes a {
  color: #E54C78;
}

.box-notes p.travller span {
  background-color: var(--traveller-key-color, #bfa366);
}

.box-notes p.travller a {
  color: var(--traveller-key-color, #bfa366);
}

/* ============================================================================================================================
#temp-03-list-b
============================================================================================================================*/
#temp-03-list-b {
  .list-normal .item a {
    align-items: flex-start;
  }
}

/* ============================================================================================================================
#temp-14-list-m
============================================================================================================================*/
#temp-14-list-m {
  h3 {
    margin-bottom: 10px;
    font-size: 15px;
    font-size: 1.5rem;
  }

  .list-vertical-03 {
    .item {
      > a {
        padding-bottom: 0;
        border: none;
      }

      & +.item {
        padding-top: 15px;
        border-top: 1px solid #ccc;
      }
    }

    .title {
      margin-bottom: 22px;
      font-size: 13px;
      font-size: 1.3rem;
      font-weight: 400;
    }

    .text {
      min-height: inherit;
    }

    .bottom {
      display: flex;
      justify-content: flex-end;
      font-size: 10px;
      font-size: 1rem;

      .date {
        margin-top: 0;
        display: inline-block;
      }
    }
  }

  .box-border-pink {
    margin-top: 40px;
  }
}

/* ============================================================================================================================
#temp-21-article-comic
============================================================================================================================*/
#temp-21-article-comic {
  .link-button > a {
    width: auto;
    padding-inline: 20px;
  }
}

/* ============================================================================================================================
#temp-crea-ambassador
============================================================================================================================*/
#temp-crea-ambassador {
  .member-text {
    width: 89.33%;
    margin-left: auto;
    margin-right: auto;
    font-size: 13px;
    font-size: 1.3rem;
  }

  .member-text .title.pc {
    display: none;
  }

  .list-member .item .about {
    font-size: 13px;
    font-size: 1.3rem;
  }
}


/* ============================================================================================================================
.box-member
============================================================================================================================ */

.box-member {
  border: 1px solid var(--color-black);
  display: flex;
  flex-direction: column;
  margin-bottom:40px;
}

.box-member:before {
  content:none;
}

.box-member .member-left {
  padding: 24px;
}

.box-member .member-left .inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.box-member .member-left .inner .link-button {
  margin: 0 0 20px;
  width: 100% ;
}

.box-member .member-left .inner .link-button a {
  width: 100% ;
}

.box-member .member-left .inner p {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 150%;
}

.box-member .link-right {
  padding: 22px 20px;
  border-top: 1px solid var(--color-black);
}

.box-member .link-right p {
  margin-bottom: 10px;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 150%;
}

.box-member .link-right li {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 150%;
}

.box-member .link-right li a {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 150%;
  color: var(--link-active);
  background: none;
}

.box-member .link-right li+li {
  margin-top: 10px;
}

/* ============================================================================================================================
box-border
============================================================================================================================ */
.box-border,
.box-border-pink {
  width: 89.33%;
  margin: 0 auto 10px;
  padding: 20px;
  font-size: 10px;
  border: 1px solid #ccc;
}

.box-border-pink {
  width: 95%;
}

.box-border .headline,
.box-border-pink .headline {
  font-size: 15px;
}

.box-border p,
.box-border-pink p {
  margin-bottom: 20px;
}

.box-border a,
.box-border-pink a {
  color: #F597AD;
}

.box-border .link-button,
.box-border-pink .link-button {
  margin: 20px auto;
}

.box-border .link-button a,
.box-border-pink .link-button a {
  color: #222;
}

.box-border .caption,
.box-border-pink .caption {
  margin: 0;
  font-size: 11px;
  text-align: center;
}

.box-border.member > div:not(:last-child) {
    margin-bottom: 15px;
}

.box-border.member .col,
.member.box-border-pink .col {
  width: 230px;
  margin: 0 auto 10px;
}

.box-border.member .col .label,
.member.box-border-pink .col .label {
  float: left;
  width: 70px;
  margin: 0;
  padding: 2px 7px;
  line-height: 19px;
  font-size: 12px;
  font-weight: bold;
  text-align: center;
  color: #fff;
  background-color: #FF9AA0;
}

.box-border.member .col .text,
.member.box-border-pink .col .text {
  float: right;
  margin: 0;
  line-height: 13px;
  font-size: 10px;
  color: #707070;
}

.box-border .headline2 {
  text-align: center;
}

.box-border a {
  color: #1c5dd6;
  text-decoration: none;
}

.lists-default + .box-border {
  margin-top: 40px;
}

/***/
.box-border.member .traveler-info .col .label {
  background-color: var(--traveller-key-color, #bfa366);
  line-height: 12px;
}

.box-border.member .traveler-info a {
  color: var(--traveller-key-color, #bfa366);
}

.box-border-pink {
  padding: 30px;
  border: 1px solid #F597AD;
}

.box-border-pink .link-button {
  width: 100%;
  margin: 0 0 30px;
}

.box-border-pink p {
  margin: 0;
  color: #707070;
}

.box-gray {
  width: 95%;
  margin: 0 auto 40px;
  padding: 30px;
  background-color: #EFEFEF;

  ul > li > a {
    font-size: 13px;
    font-size: 1.3rem;
  }
}

.box-gray li+li {
  margin-top: 10px;
}

/* ============================================================================================================================
#temp-static-monthly
============================================================================================================================ */

#temp-static-monthly .content .box {
  width: 89.33%;
  margin: 30px auto;
}

#temp-static-monthly .content .box p {
  font-size: 15px;
  font-weight: bold;
}

#temp-static-monthly .content .box ul {
  font-size: 0;
}

#temp-static-monthly .content .box ul li {
  display: inline-block;
  width: calc(33.33% - 2px);
  margin-top: 10px;
  padding: 2px;
  font-size: 13px;
  text-align: center;
  background-color: #EFEFEF;
  border-radius: 5px;
}

#temp-static-monthly .content .box ul li+li {
  margin-left: 3px;
}

#temp-static-monthly .content .box ul li:nth-child(3n + 1) {
  margin-left: 0;
}

/* ============================================================================================================================
#temp-static-sitemap
============================================================================================================================ */

#temp-static-sitemap .article-body {
  font-size: 13px;
  font-size: 1.3rem;
  border:none;
}

#temp-static-sitemap .article-body a {
  color: #222;
  text-decoration: none;
  font-size: 14px;
  font-size: 1.4rem;
}

#temp-static-sitemap .article-body hr {
  margin: 40px auto;
}

#temp-static-sitemap .article-body .box {
  float: left;
  width: 50%;
  padding-right: 20px;
}

#temp-static-sitemap .article-body .box:nth-child(odd) {
  clear: both;
}

#temp-static-sitemap .article-body .box:nth-child(n + 3) {
  margin-top: 20px;
}

#temp-static-sitemap .article-body .box a {
  font-weight: normal;
}

#temp-static-sitemap .article-body .box p {
  padding-bottom: 5px;
  font-size: 14px;
  font-weight: bold;
  border-bottom: 1px solid #ccc;
}

#temp-static-sitemap .article-body .box p a {
  font-weight: bold;
}

#temp-static-sitemap .article-body .other a {
  font-weight: normal;
}

/* ============================================================================================================================
#temp-static-tarot
============================================================================================================================ */

#temp-static-tarot #scene_3 .txt .title{
  line-height: 1;
}

/* ============================================================================================================================
#temp-static-contact
============================================================================================================================ */

#temp-static-contact .article-body .box-color a {
  color: #666;
}

/* ============================================================================================================================
#temp-static-moon
============================================================================================================================ */

#temp-static-moon .box-normal {
  margin-top: 30px;
  padding-top: 0;
}

#temp-static-moon .box-normal .box-title {
  padding: 5px;
  background-color: #fff;
  text-align: center;
}

#temp-static-moon .box-normal h4+p {
  margin-top: 5px;
}

#temp-static-moon .box-normal.flame {
  border-color: #ED705A;
  display: block;
}

#temp-static-moon .box-normal.flame hr {
  border-color: #ED705A;
}

#temp-static-moon .box-normal.flame .box-title {
  background-color: #ED705A;
}

#temp-static-moon .box-normal.earth {
  border-color: #9F956D;
  display: block;
}

#temp-static-moon .box-normal.earth hr {
  border-color: #9F956D;
}

#temp-static-moon .box-normal.earth .box-title {
  background-color: #9F956D;
}

#temp-static-moon .box-normal.wind {
  border-color: #A0C7B5;
  display: block;
}

#temp-static-moon .box-normal.wind hr {
  border-color: #A0C7B5;
}

#temp-static-moon .box-normal.wind .box-title {
  background-color: #A0C7B5;
}

#temp-static-moon .box-normal.water {
  border-color: #93C7D6;
  display: block;
}

#temp-static-moon .box-normal.water hr {
  border-color: #93C7D6;
}

#temp-static-moon .box-normal.water .box-title {
  background-color: #93C7D6;
}

#temp-static-moon .moon-calendar-table {
  border-collapse: collapse;
}

#temp-static-moon .moon-calendar-table td,
#temp-static-moon .moon-calendar-table th {
  border: 1px solid #FFCE00;
}

#temp-static-moon .moon-calendar-table th {
  text-align: center;
  background-color: #FFCE00;
}

#temp-static-moon .moon-calendar-table th+th {
  border-left: 1.5px solid #fff;
}

#temp-static-moon .moon-calendar-table td {
  padding: 20px;
}

#temp-static-moon .box-author .box-image-left {
  width: 50px;
}

#temp-static-moon .box-author .box-text-right {
    width: calc(100% - 50px - 20px);
    margin-bottom: 20px;
}

#temp-static-moon .box-author p {
  margin-top: 0;
}

#temp-static-moon {
  .moon-calendar-table {
    th {
      font-size: 16px;
      font-size: 1.6rem;
    }
  }

  .box-normal {
    .box-title {
      width: calc(100% + 32px);
      margin-left: -16px;
      font-size: 15px;
      font-size: 1.5rem;
      font-weight: 600;
    }

    p {
      font-size: 12px;
      font-size: 1.2rem;
    }

    h4 {
      font-size: 15px;
      font-size: 1.5rem;
    }
  }
}

/* ============================================================================================================================
#temp-33-interview-list
============================================================================================================================ */
#temp-33-interview-list #interview-keyvisual {
  position: relative;
  height: 538px;
  overflow: hidden;
}

#temp-33-interview-list #interview-keyvisual #keyvisual-swiper {
  height: 100%;
}

#temp-33-interview-list #interview-keyvisual #keyvisual-swiper:before {
  content: '';
  position: absolute;
  z-index: 2;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.2);
}

#temp-33-interview-list #interview-keyvisual #keyvisual-swiper .swiper-slide {
  background: 50% 50% no-repeat;
  background-size: cover;
}

#temp-33-interview-list #interview-keyvisual #keyvisual-swiper .swiper-pagination {
  bottom: 30px;
}

#temp-33-interview-list #interview-keyvisual #keyvisual-swiper .swiper-pagination-bullet {
  top: 0;
  width: 15px;
  height: 15px;
  margin: 0 15px;
  background-color: #fff;
  opacity: 1;
  transition: all 0.4s ease;
}

#temp-33-interview-list #interview-keyvisual #keyvisual-swiper .swiper-pagination-bullet-active {
  background-color: #AEAEAE;
}

#temp-33-interview-list #interview-keyvisual .video-wrapper {
  position: relative;
  z-index: 0;
  height: 100%;
}

#temp-33-interview-list #interview-keyvisual .video-wrapper video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#temp-33-interview-list #interview-keyvisual .video-wrapper:before {
    content: '';
    position: absolute;
    z-index: 2;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.2);
}

#temp-33-interview-list #interview-keyvisual .text {
  position: absolute;
  bottom: 100px;
  z-index: 1;
  width: 100%;
  color: #fff;
  font-weight: normal;
}

#temp-33-interview-list #interview-keyvisual .video-wrapper + .text {
  bottom: 50px
}

#temp-33-interview-list #interview-keyvisual .text .title {
  width: 85.3333333%;
  margin: 0 auto 26px;
  font-size: 22px;
  font-weight: bold;
  line-height: 26px;
}

#temp-33-interview-list #interview-keyvisual .text .summary {
  width: 85.3333333%;
  margin: 0 auto;
  font-size: 14px;
  line-height: 17px;
}

#temp-33-interview-list #interview-keyvisual .traveler {
  font-family: 'Noto Serif', serif;
}

#temp-33-interview-list #interview-keyvisual .traveler .summary,
#temp-33-interview-list #interview-keyvisual .traveler .title {
  text-align: center;
}

/* ============================================================================================================================
ad-overlay
============================================================================================================================ */
.ad-overlay {
  text-align: center;
  width: 100%;
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 2147483646;
}

/*
連載記事関連
============================ */
/* 連載記事内のタイトル  */
.article-head .article-subtitle-series {
  width: 90%;
  text-align: left;
  display: block;
  margin: 5px 25px 10px;
  font-size: 14px;
  color: #666666;
}

/* 連載記事内のスライダー  */
.article-series-section {
  margin-bottom: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid #707070;
}
.article-series-section p:first-child {
  color: #333333;
  text-align: center;
  font-weight: bold;
  font-size: 14px;
  line-height: 19.6px;
}

.article-series-section .first-link {
  margin: 20px auto 0;
  text-align: center;
}

.article-series-section .first-link a{
  display: inline-block;
  text-decoration: none;
  font-size: 14px;
  font-weight: bold;
  border: solid 1px #CCCCCC;
  padding: 8px 10px;
}

.article-series-section .first-link a span{
  color: #222222;
  font-size: 14px;
  font-weight: 400;
}

#article-series-header-column {
  width: 90%;
  margin: 0 auto;
  background:#fff url(/common/crea/images/crea30-tokyo/sp/loading.gif) no-repeat center center;
}

#article-series-header-column li {
  visibility: hidden;
}

#article-series-header-column.slick-initialized {
  display: block;
  background: none;
}

#article-series-header-column.slick-initialized li {
  visibility: visible;
}

#article-series-header-column li {
    width: 96px;
    height: 73px;
    position: relative;
    margin: 0 14px 0 0;
}

#article-series-header-column li .title {
  width: 96px;
  max-height: 40px;
  position: absolute;
  background: #00000080;
  color: #ffffff;
  font-size: 9px;
  bottom: 0;
  padding: 3px;
  line-height: 1.2;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  min-height: 30px;
}

#article-series-header-column li .subtitle {
  width: 96px;
  max-height: 40px;
  position: absolute;
  background: #00000080;
  color: #ffffff;
  font-size: 11px;
  bottom: 0;
  padding: 3px;
  line-height: 1.2;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  min-height: 30px;
}

#article-series-header-column .image img {
    width: 96px;
    height: 73px;
    text-align: center;
    margin: 0 auto;
    display: block;
    object-fit: cover;
}

#article-series-header-column .slide-arrow {
  width: 9px;
  position: absolute;
  top: 50%;
  margin-top: -9px;
  cursor: pointer;
}
#article-series-header-column .prev-arrow {
  left: -17px;
}
#article-series-header-column .next-arrow {
  right: -17px;
}

/* ----------------------------------------------------------------------------------------------------------------------------
.comic-label/essay-label
---------------------------------------------------------------------------------------------------------------------------- */
.label-comic, .label-essay  {
  position: relative;
}
.label-comic:after {
  content: 'COMIC';
  position: absolute;
  right: 0;
  top: 0;
  padding: 2px 13px;
  line-height: 12px;
  font-size: 8px;
  color: #fff;
  background-color: rgba(255, 162, 0, 0.50);
  font-weight: bold;
}
.label-essay:after {
  content: 'ESSAY';
  position: absolute;
  right: 0;
  top: 0;
  padding: 2px 13px;
  line-height: 12px;
  font-size: 8px;
  color: #fff;
  background-color: rgba(20, 204, 250, 0.55);
  font-weight: bold;
}

#article-series-header-column li.current-page {
  opacity: 0.5;
}

/* 連載記事内の次の記事へのリンク  */
.article-series-next-link {
  border: 2px solid #CCCCCC;
  padding: 20px;
  margin: 30px 0 16px;
}
.article-series-next-link .next-link-label {
  background: #666666;
  color: #ffffff;
  border-radius: 14px;
  display: inline-block;
  margin: 0 auto;
  width: 150px;
  height: 24px;
  display: block;
  text-align: center;
  padding: 2px 20px;
  margin-bottom: 10px;
  font-size: 12px;
}
.article-series-next-link a {
  text-decoration: none;
}
.article-series-next-link .next-link-title {
  display: block;
  font-size: 12px;
}

/* はじめから読むのリンク  */
.article-series-first-link {
  margin: 40px auto;
  padding: 0;
  text-align: right;
}
.article-series-first-link a{
  display: inline-block;
  text-decoration: none;
  font-size: 14px;
  font-weight: bold;
  border: solid 1px #CCCCCC;
  padding: 8px 10px;
}
.article-series-first-link a span{
  color: #222222;
  font-size: 14px;
  font-weight: 400;
}

#interview-keyvisual .main-visual {
    width: 46%;
    position: absolute;
    z-index: 9999;
    top: 100px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
}
#section .sns-traveller {
    width: 90%;
    margin: 0 auto 40px;
    padding: 10px;
    text-align: center;
    line-height: 30px;
    font-size: 16px;
    color: #fff;
    background-color: var(--key-color, #bfa366);
}
#section .sns-traveller p,
#section .sns-traveller ul,
#section .sns-traveller li {
    display: inline-block;
    vertical-align: middle;
}
#section .sns-traveller img,
#section .sns-traveller svg {
    vertical-align: middle;
}
#section .sns-traveller a {
    display: block;
    width: 40px;
    height: 40px;
    line-height: 40px;
    text-align: center;
    background-color: #fff;
    border-radius: 100%;
}
#section .sns-traveller li {
    margin-left: 36px;
}
#section .sns-traveller li+li {
    margin-left: 9px;
}
#section .sns-traveller li:nth-child(1) svg {
    width: 10px;
}
#section .sns-traveller li:nth-child(2) svg {
    width: 22px;
}
#section .sns-traveller li:nth-child(3) svg {
    width: 20px;
}
#section .magazine-info {
    width: 90%;
    margin: 40px auto;
    padding: 10px 15px;
    color: #333;
    border: 1px solid var(--key-color, #bfa366);
}
#section .magazine-info .col .image {
    float: left;
    width: 31.65%;
}
#section .magazine-info p {
    margin-top: 0;
    margin-bottom: 20px;
}
#section .magazine-info .col .text {
    float: right;
    width: 62.97%;
    line-height: 17px;
    font-size: 10px;
}
#section .magazine-info .col .text .copy {
    padding: 17px 0;
    font-weight: 200;
}
#section .magazine-info .col .text .copy strong {
    font-size: 17px;
    font-weight: bold;
}
#section .magazine-info .col .text .button {
    position: relative;
    display: block;
    margin-top: 14px;
    line-height: 34px;
    font-size: 12px;
    color: var(--key-color, #bfa366);
    text-align: center;
    text-decoration: none;
    background-color: #fff;
    border: 1.5px solid var(--key-color, #bfa366);
    border-radius: 34px;
}
#section .magazine-info .col .text .button:before {
    content: '';
    position: absolute;
    right: 10px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 6px 5.5px 0 5.5px;
    border-color: var(--key-color, #bfa366) transparent transparent transparent;
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
}
#section .magazine-info .col .text .button:after {
    content: '';
    position: absolute;
    right: 10px;
    top: 50% ;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    margin-top: -1px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 6px 5.5px 0 5.5px;
    border-color: #fff transparent transparent transparent;
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
}
/* box */
.box-style1 {
  border: 1px solid #000;
  padding: 20px;
}
.box-style1 p,
.article-body .box-style1 p{
  padding: 0;
  margin: 0;
}
.box-style1 table,
.article-body .box-style1 table{
  padding: 0;
  margin: 0;
}
.box-style1 {
  border: 1px solid #000;
  padding: 20px;
}
/*----アイコン address----*/
.box-style1 .icon-address:before {
  content: '\3012';
  line-height: 1.3;
  padding-left: 20px;
}
.box-style1 .icon-mail {
  color: var(--link-active);
  font-weight: 700;
}

/* ============================================================================================================================
etc
============================================================================================================================ */

.hidden {
  display: none;
}

.billboard-banner {
  text-align: center;
}

.ad-banner-list {
  margin: 40px 0;
}

.ad-banner {
  width: 89.33%;
  margin: 20px auto;
  text-align: center;
}

#sub-bnr-one-swiper .ad-banner{
  width: 100%;
  margin: 0px auto;
}

.ad-banner.full-width {
  width: 100%;
}

.ad-banner-block {
  width: 89.33%;
  margin: 10px auto;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
}

.not-margin {
  margin: 0 auto !important;
}

.small-margin {
  margin-top: 20px !important;
}

.medium-margin {
  margin-top: 40px !important;
}

.large-margin {
  margin-top: 60px !important;
}

.align-center {
  text-align: center !important;
}

.align-left {
  text-align: left !important;
}

.align-right {
  text-align: right !important;
}


.photo-link-button {
  width: calc(100% - 24px);
  margin: 40px auto 0;
}

.photo-link-button a {
  width: 100%;
  height: 100%;
  padding: 10px 24px;
  border: none;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  border-radius: 0;
  text-align: center;
  background: #FFF;
  position: relative;
  display: block;
  box-shadow: none;
}

.link-button.back a:before {
  left: 14px;
  right: auto;
  -webkit-transform: translateY(-50%) rotate(-45deg);
  transform: translateY(-50%) rotate(-45deg);
}

.link-button.black a {
  color: #fff;
  background-color: #707070;
  border: none;
}

.link-button.black a:before {
  background-image: url(/common/crea/images/v1/icon/arrow_white.png);
}

.link-button.pink {
  border-color: #F597AD;
}

.link-button.pink a {
  background-color: #F597AD;
  border: none;
}

.link-button.green {
  border-color: #8FC31F;
}

.link-button.green a {
  color: #fff;
  background-color: #8FC31F;
  border: none;
}

.link-button.green a:before {
  border-top: 2px solid var(--color-white);
  border-left: 2px solid var(--color-white);
}

.link-button.brown a {
  color: #fff;
  background-color: #A9966E;
  border: none;
}

.link-button.brown a:before {
  background-image: url(/common/crea/images/v1/icon/arrow_white.png);
}

.link-banner {
  width: 89.33%;
  margin: 30px auto;
}

.link-banner a {
  display: block;
  line-height: 16px;
  font-size: 11px;
  font-size: 1.1rem;
  color: #333;
  background: url(/common/crea/images/v1/icon/arrow_black.png) calc(100% - 14px) center no-repeat;
  background-size: 12px;
  border: 1px solid #ccc;
}

@media print,
screen and (max-width: 374px) {
  .link-banner a {
    font-size: 9px;
    font-size: 0.9rem;
  }
}

.link-banner a p {
  float: left;
  width: 50%;
  margin: 0;
}

.link-banner a p img {
  vertical-align: bottom;
}

.link-banner a p.image {
  width: 150px;
  padding: 10px 0;
}

.link-banner a p.text {
  width: calc(100% - 150px);
  padding: 20px 0;
}

@media print,
screen and (max-width: 374px) {
  .link-banner a p.image {
    width: 120px;
  }
  .link-banner a p.text {
    width: calc(100% - 120px);
    padding: 16px 0;
  }
}

.headline.pr {
  position: relative;
}

.headline.pr:after {
    content: '【PR】';
    display: inline-block;
}

.headline.small {
  width: 89.33%;
  margin: 0 auto 10px;
  font-size: 15px;
  font-size: 1.5rem;
  text-align: left;
}

.headline.medium {
  width: 89.33%;
  margin: 0 auto 10px;
  font-size: 18px;
  font-size: 1.8rem;
}

.headline-ribbon-wrap {
  text-align: center;
}

.headline-ribbon {
  display: inline-block;
  position: relative;
  text-align: center;
  box-sizing: border-box;
  z-index: 1;
}

.headline-ribbon:before,
.headline-ribbon:after {
  content: '';
  position: absolute;
  bottom: -13px;
  z-index: 0;
  border: 21px solid #E2CBBD;
  width: 60px;
  box-sizing: border-box;
}

.headline-ribbon:before {
  left: -21px;
  border-left-color: transparent;
  border-left-width: 14px;
}

.headline-ribbon:after {
  right: -21px;
  border-right-color: transparent;
  border-right-width: 14px;
  z-index: -1;
}

.article-body .headline-ribbon h3,
.headline-ribbon h3 {
  width: 280px;
  display: inline-block;
  position: relative;
  margin: 0;
  padding: 7px 10px;
  font-size: 17px;
  font-size: 1.7rem;
  font-weight: 600;
  line-height: 25.5px;
  color: #222;
  background: #FFF;
  border-top:solid 1px #707070;
  border-bottom:solid 1px #707070;
}

.headline-ribbon h3:before {
  position: absolute;
  content: '';
  top: 100%;
  left: 0;
  border: none;
  border-bottom: solid 14px transparent;
  border-right: solid 38px #707070;
}

.headline-ribbon h3:after {
  position: absolute;
  content: '';
  top: 100%;
  right: 0;
  border: none;
  border-bottom: solid 14px transparent;
  border-left: solid 38px #707070;
}

.headline-ribbon-icon {
  position: absolute;
  margin: 0 auto;
  top: -32px;
  left: 0;
  right: 0;
  width: 62px;
  height: 62px;
  border: solid 1px #707070;
  border-radius: 50%;
  background: #FFF;
}

.headline-ribbon-icon img {
  width: 18px;
  height: 18px;
  position: relative;
  top: 9px;
}

.comic-title {
  width: 50.15%;
  margin: 0 auto 10px;
}

.basic-width {
  width: 89.33%;
  margin-left: auto;
  margin-right: auto;
}

a.blank {
  text-decoration: underline;
  padding-right: 20px;
  background: url(/common/crea/images/v1/icon/link_blank.png) calc(100% - 5px) center no-repeat;
  background-size: 10px;
}

a.arrow:after {
  content: '＞';
  padding-left: 0.5em;
}

.gray {
  color: #aaa;
}

@media print,
screen and (max-width: 374px) {
  .article-body .headline-ribbon h3,
  .headline-ribbon h3 {
    width: 250px;
    font-size: 15px;
    font-size: 1.5rem;
  }
}


/* =========================================
 広告制御
========================================= */
.ad-banner-space{/*max-width:320px;min-width:300px;*/margin:20px auto;text-align:center;display:block !important;}
.ad-banner-space.-sp_underarticle{
  min-height: 250px;
}
.ad-banner-space.-sp_photo_1st{
  min-height: 250px;
}
.ad-banner-space.-sp_footer_1st{
  /*min-height: 250px;*/
}
.ad-banner-space.-sp_photo_footer_1st{
  /*min-height: 250px;*/
}
.ad-banner-space.-sp_photo_footer_2nd{
  /*min-height: 250px;*/
}
.ad-banner-space.-sp_footer_2nd{
  /*min-height: 250px;*/
}
 .sp_article_inarticle{
  min-height: calc(250px + 53px);
}
.ad-banner-space div{margin:auto;}

/* --------------------
提携メディア用
----------------------- */
.associated-image{width:120px;}
.associated-image img{max-width:100%;width:auto;vertical-align:bottom;margin:20px 0;}
.associated-related{margin-bottom:40px;}
.associated-related ul li{font-size:14px;font-size:1.4rem;margin-bottom:12px;}
.associated-related ul li:last-child{margin-bottom:0;}
.associated-related ul li a{color:#666;font-weight:normal;text-decoration:none;}

/* =========================================
 連携記事へのページ上部リンク
========================================= */
#series-column{
  display: flex;
  justify-content:space-between;
  margin: 0 auto;
  width: calc(100% - 24px);
}

#series-column.space{
  padding:0 0 20px;
}

#series-column li{
  font-family: var(--font-hiragino-kaku-gothic);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  text-align:center;
  flex-grow: 1;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight:600;
  margin:0 3px;
  padding:0;
  line-height:100%;
}

#series-column li:before{
   display:none;
}

#series-column li:after{
   background-color: var(--color-gray6);
   border-radius: 2px;
   content: "";
   display: block;
   height: 3px;
}

#series-column li a{
  padding-bottom: 6px;
  color:var(--color-gray6);
}

#series-column li.current{
  flex-grow: 2;
  color:var(--link-active);
}

#series-column li.current:after{
  background-color: var(--link-active);
}

/* =========================================
 連携記事の次ページ下部リンク
========================================= */
.article-series-next-link {
/*
  background: var(--color-gray2);
*/
  padding:15px 14px;
}

.article-series-next-link__inner {
  margin: 0 auto;
}
.article-body a.article-series-next-link__link,
.article-series-next-link__link {
  text-decoration: none;
  display: flex;
  gap:20px;
}

.article-series-next-link__imgwrap {
  width: 78px;
  height: 78px;
  overflow: hidden;
}

.article-series-next-link__img {
  height: 0;
  padding-top: 100%;
  background-size: cover;
  background-position: center;
}

.article-series-next-link__content {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
}

.article-series-next-link__label {
  color: var(--color-black);
  font-family: var(--font-hiragino-kaku-gothic);
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: normal;
  text-decoration: none;
}

.article-series-next-link__title {
  color: var(--link-active);
  font-family: var(--font-hiragino-kaku-gothic);
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 150% ;
  text-decoration: underline;
}

/* はじめから読むのリンク  */
.article-series-first-link {
  margin: 0;
  padding: 0;
  text-align: right;
}

.photo-link-button + .article-series-first-link{
  margin: 0 24px 40px;
}

.article-series-first-link a{
  display: block;
  padding: 16px 24px;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black); 
  text-align: center;
  background: #FFF;
  position: relative;
  color: var(--link-active);
}

/* =========================================
 目次
========================================= */
.toc {
  margin-block: 40px;
  padding: 40px 32px;
  border: 1px solid #212121;
  position: relative;

  &::before,
  &::after {
    content: "";
    display: block;
    width: calc(100% - 40px);
    height: 3px;
    background: #fff;
    position: absolute;
    left: 20px;
  }

  &::before {
    top: -2px;
  }


  &::after {
    bottom: -2px;
  }
}

.toc__title {
  font-family: var(--font-figtree);
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1;
  font-weight: 500;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.toc__list {
  display: flex;
  flex-direction: column;
  row-gap: 16px;
  margin-top: 32px;
}

.toc__item {
  display: flex;
  column-gap: 8px;

  &::before {
    content: "";
    display: block;
    flex-shrink: 0;
    width: 7px;
    height: 7px;
    border-right: 1.5px solid #212121;
    border-bottom: 1.5px solid #212121;
    rotate: 45deg;
    translate: 0 .4em;
  }
}

.toc__link {
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.6;
}

/* ----------------------------------------------------------------------------------------------------------------------------
.article-nextprev
---------------------------------------------------------------------------------------------------------------------------- */
.article-nextprev {
  margin-block: 40px;
}

.article-nextprev__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 20px;
  padding: 32px;
  background: #e9f7f0;
  font-weight: 500;
  line-height: 1.6;
  text-align: center;

  &:hover {
    text-decoration: none;
  }
}

.article-nextprev__label {
  color: #888;
  font-size: 14px;
  font-size: 1.4rem;
}

.article-nextprev__heading {
  display: inline-flex;
  align-items: center;
  column-gap: 8px;
  color: #212121;
  font-size: 16px;
  font-size: 1.6rem;

  /* アイコン */
  &::after {
    content: "";
    display: block;
    flex-shrink: 0;
    width: 7px;
    height: 7px;
    border-top: 1px solid #212121;
    border-right: 1px solid #212121;
    rotate: 45deg;
  }

  > span {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
  }
}

/* ----------------------------------------------------------------------------------------------------------------------------
.article-info
---------------------------------------------------------------------------------------------------------------------------- */
.article-info {
  margin-block: 80px 40px;
}

.article-info__list {
  display: flex;
  flex-direction: column;
  row-gap: 16px;
}

.article-info__list > div {
  display: flex;
  column-gap: 16px;

  > dt {
    flex-shrink: 0;
    width: 82px;
    padding-top: .4em;
    color: #888;
    font-family: var(--font-figtree);
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 1;
    text-transform: uppercase;
  }

  > dd {
    color: #212121;
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 1.8;
  }

  time {
    font-family: var(--font-figtree);
    font-size: 13px;
    font-size: 1.3rem;
  }

  .author {
    display: flex;
    align-items: center;
    column-gap: 8px;

    .icon-author {
      width: 24px;
      height: 24px;
      background-size: contain;
      border-radius: 50vh;
      overflow: hidden;
    }

    > a {
      color: #212121;
      font-size: 12px;
      font-size: 1.2rem;
      font-weight: 500;
      line-height: 1.6;
    }

    & + .author {
      margin-top: 10px;
    }
  }
}

.article-info__category,
.article-info__keywords {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;

  > li > a {
    padding: 3px 12px;
    border: 1px solid #e7e7e7;
    border-radius: 40px;
    color: #212121;
    font-size: 11px;
    font-size: 1.1rem;
    font-weight: 500;
    line-height: 1.6;
  }
}

.article-info__casts {
  align-items: center;

  > dt {
    display: flex;
    flex-wrap: wrap;
    column-gap: 14px;
    padding-top: 0;
  }
}

.article-info__cast {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 4px;
}

.article-info__cast-image {
  width: 64px;
  height: 64px;
  border-radius: 50vh;
  overflow: hidden;
}

.article-info__cast-text {
  font-size: 11px;
  font-size: 1.1rem;
  line-height: 1.6;
  font-weight: 400;
}

/* ----------------------------------------------------------------------------------------------------------------------------
.article-carousel
---------------------------------------------------------------------------------------------------------------------------- */
.article-carousel {
  margin-left: calc(50% - 50vw);
  margin-bottom: 40px;
  width: 100vw;
}
.article-carousel__column--main {
  margin-bottom: 16px;
}
.article-carousel__column--sub {
  padding: 0 16px;
}
.article-carousel__caption {
  color: #6d6d6d;
  font-size: 12px;
  line-height: 1.6;
  padding: 0 16px;
}
.article-carousel__title {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.6;
  margin-bottom: 16px;
}
.article-carousel__detail {
  font-size: 14px;
  line-height: 1.8;
  margin-bottom: 24px;
}
.article-carousel__btn-wrap {
  text-align: right;
}
.article-carousel__btn {
  display: inline-flex;
  gap: 4px;
  align-items: center;
  border-radius: 9999px;
  border: solid 1px #212121;
  color: #212121 !important;
  font-size: 12px;
  font-weight: bold !important;
  text-decoration: none !important;
  line-height: 1;
  padding: 6.5px 24px;
}
.article-carousel__icon {
  width: auto !important;
  height: auto !important;
}
.article-carousel-main,
.article-carousel-main__item,
.article-carousel-sub,
.article-carousel-sub__item,
.article-carousel-thumbnail,
.article-carousel-thumbnail__item {
  margin: 0 !important;
}
.article-carousel-main__item {
  height: 0;
  overflow: hidden;
}
.article-carousel-main__item.swiper-slide-active {
  height: auto;
}
.article-carousel-main__img-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 8px;
  width: 100%;
  min-height: 250px;
}
.article-carousel-main__img {
  object-fit: contain;
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
}
.article-carousel-sub__item {
  height: 0;
  overflow: hidden;
}
.article-carousel-sub__item.swiper-slide-active {
  height: auto;
}
.article-carousel-sub__content {
  padding-top: 24px;
}
.article-carousel-thumbnail {
  display: flex;
  gap: 4px;
  padding: 0 16px;
  overflow-x: scroll;
  scrollbar-width: none;
}
.article-carousel-thumbnail::-webkit-scrollbar {
  display: none;
}
.article-carousel-thumbnail__item {
  flex-shrink: 0;
}
.article-carousel-thumbnail__item.is-active {
  opacity: .2;
}
.article-carousel-thumbnail__img-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 48px;
}
.article-carousel-thumbnail__img {
  object-fit: contain;
  height: 100% !important;
}
