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

/* ----------------------------------------------------------------------------------------------------------------------------
.article-head
---------------------------------------------------------------------------------------------------------------------------- */

.article-head {
  position: relative;
  padding-bottom:25px;
}

.article-head .subtitle {
  margin: 20px auto 0;
  width: calc(100% - 24px);
  font-size: 13px;
  font-size: 1.3rem;
  font-weight: bold;
  text-align: right;
}

.article-head .subtitle a{
  color: #999;
}

.article-head .subtitle.comic {
  width: 32%;
  margin: 20px auto;
}

.article-head .subtitle.comic-02 {
  width: 44.8%;
  margin: 20px auto;
}

.article-head .box {
  margin: 0 auto 10px;
  width: calc(100% - 24px);
  color: var(--color-quaternary);
  text-align: left;
  color: var(--color-black);
  font-family: var(--font-hiragino-kaku-gothic);
}

.article-head .box .genre {
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 130%
}

.article-head .box .subtitle {
  margin: 0;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 100% ;
  text-align: left;
}

.article-head .box a {
  display: block;
  color: var(--color-quaternary);
}

.article-head .magazine-title {
  margin-top: 20px;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: bold;
  text-align: center;
}

.article-head .magazine-title strong {
  font-size: 26px;
  font-size: 2.6rem;
}

.article-head h1 {
  margin: 10px auto;
  width: calc(100% - 24px);
  text-align: left;
  color: var(--color-black);
  font-family: var(--font-hiragino-kaku-gothic);
  font-size: 24px;
  font-size: 2.4rem;
  font-weight: 600;
  line-height: 140%;
}

#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: 10px;
}

.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: 10px auto 15px;
  width: calc(100% - 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 {
  width: calc(100% - 24px);
}

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

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

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

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

.article-keyword {
  position: relative;
  margin: 5px auto 8px;
  padding-left: 44px;
  width: 89.33%;
}

.article-keyword::before {
  position: absolute;
  top: 0;
  left: 0;
  background: url(/common/crea/images/v1/icon/tag.png) no-repeat;
  background-size: contain;
  content: '';
  display: block;
  margin: 5px 10px 5px 5px;
  width: 24px;
  height: 24px;
}

.article-keyword .item {
  display: inline-block;
  background-color: #efefef;
  border-radius: 5px;
  font-size: 15px;
  margin: 0 5px 10px 0;
  padding: 5px;
}

/* ----------------------------------------------------------------------------------------------------------------------------
.article-series-links
---------------------------------------------------------------------------------------------------------------------------- */
.article-series-links {
  margin: 0 12px 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;
  }
}

/* ----------------------------------------------------------------------------------------------------------------------------
.article-body
---------------------------------------------------------------------------------------------------------------------------- */

.article-body {
  position: relative;
  margin: 0px auto 120px;
  width: calc(100% - 24px);
  padding-top: 24px;
  color: var(--color-black);
  font-family: var(--font-hiragino-kaku-gothic);
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 200% ; 
  border-top: 1px solid #707070;
}

.article-body.border_none {
  border:none;
}

.article-body h2 {
  position: relative;
  margin-top: 50px;
  font-weight: 500;
  font-size: 20px;
  font-size: 2.0rem;
  line-height: 160%;
  text-align: center;
}

.article-body h2.moon-type {
  line-height: 26px;
  font-size: 18px;
  font-size: 1.8rem;
  text-align: center;
}

.article-body h3 {
  background: var(--color-primary);
  position: relative;
  margin-top: 20px;
  color: var(--color-black);
  font-family: var(--font-hiragino-kaku-gothic);
  font-size: 20px;
  font-size: 2.0rem;
  font-weight: 600;
  line-height: 140%; 
  padding: 6px 10px;
}

.article-body h4 {
  position: relative;
  margin-top: 20px;
  font-size: 15px;
  font-size: 1.5rem;
}

.article-body .magazine_title_contents {
  font-size: 22px;
  font-size: 2.2rem;
  font-weight: bold;
}

.article-body p {
  margin-top: 20px;
  font-size:16px;
  font-size: 1.6rem;
  line-height: 180% ;
  font-weight: 400;
  word-break: break-all;
}

.article-body h2+p,
.article-body h3+p,
.article-body h4+p {
  margin-top: 10px;
}

hr,
.article-body hr {
  clear: both;
  margin-top: 40px;
  border: none;
  border-top: 1px solid #ccc;
}

hr.hr_black,
.article-body hr.hr_black {
  border-top: 1px solid #000;
}


.article-body hr.full-width {
  width: 111.94%;
  margin-left: -5.97%;
}

.article-body strong {
  font-weight: bold;
}

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

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

.article-body em {
  background: var(--color-primary);
  color: var(--link-color);
  font-family: var(--font-hiragino-kaku-gothic);
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 140% ;
  font-style: normal;
  width: 100% ;
  display: block;
  padding:6px 10px;
  margin:0 0 20px;
}

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

.article-body a {
  color: var(--link-active);
  font-family: var(--font-hiragino-kaku-gothic);
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 180%;
  text-decoration: none;
}

.article-body img {
  max-width: 100%;
  height: auto;
}

.article-body img#read-to-end {
  width: 1px !important;
  height: 1px !important;
}

.link-button,
.article-body .link-button {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0;
  transition: all 0.25s ease;
  margin: 30px auto;
  box-shadow:none;
}

.link-button.space_b,
.article-body .link-button.space_b {
  margin-bottom: 50px ;
}

.link-button a,
.article-body .link-button a {
  min-width: 228px;
  height: 42px;
  padding:10px 16px;
  border: 1px solid var(--color-text);
  border-radius: 50px;
  font-family: var(--font-noto-sans);
  font-weight: 500;
  font-size: 14px;
  font-size: 1.4rem;
  padding-top: 8px;
  line-height: 160%;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #fff;
}

.article-body .link-button+.link-button{
  margin-bottom: 0;
}

/*button01*/
.article-body .link-button.button01 {
  margin:50px auto 0;
  text-align: center;
  width: auto;
  display: flex;
  justify-content: center;
  box-shadow: none;
  max-width: initial;
  height: auto;
}

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

.article-body .link-button.button01 a:before {
  content: none;
}

.article-body .link-button.button01 a 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;
}

.article-body .link-button.button01 a 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;
}

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

.article-body ol,
.article-body ul {
  margin-top: 20px;
}

.article-body ol li,
.article-body ul li {
  list-style: none;
}

.article-body ol li {
  text-indent: -1.2em;
  margin-left: 1.2em;
  counter-increment: number;
}

.article-body ol li:before {
  content: counter(number) ".";
  margin-right: 5px;
  font-weight: bold;
}

.article-body ol li+li,
.article-body ul li+li {
  margin-top: 10px;
}

.article-body table {
  width: 100%;
  margin-top: 20px;
  font-size: 13px;
  font-size: 1.3rem;
  border-collapse: collapse;
}

.article-body table th {
  font-weight: bold;
  text-align: left;
}

.article-body table th,
.article-body table td {
  padding: 5px 5px 5px 0;
}

.article-body table.border th,
.article-body table.border td {
  padding: 10px;
  border: 1px solid #ccc;
}

.article-body table.border-bottom th,
.article-body table.border-bottom td {
  padding: 10px 0;
  border-bottom: 1px solid #ccc;
}

/* 本の話記事交換テーブル対応 BUNSHUN_DEVELOPER-395 20221021 */
.article-body.books th, .article-body.books td {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.4;
  border: solid 1px #dcdcdc;
  padding: 2%;
}
.article-body.books th {
  background-color: #e9f5fd;
  width: 20%;
  max-width: 120px;
  font-weight: bold;
}
.article-body.books th,.article-body.books td {
  display: block;
  width: 100%;
  max-width: 100%;
  border-bottom: 0;
  padding: 2% 4% 3%;
}
.article-body.books td {
  padding: 2% 4% 4%;
}
.article-body.books td:last-child {
  border-bottom: solid 1px #dcdcdc;
}

.article-body.books figure{
  text-align: center;
  margin-bottom: 20px;
}

.article-body.books figure figcaption{
  text-align: left; 
}

.article-body figure,
.article-body .embed {
  margin-top: 20px;
}

.article-body figure > a {
  display: inline-block;
}

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

.article-body .embed iframe {
  vertical-align: top;
}

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

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

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

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

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

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

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

.article-body .gallery-icon {
  position: relative;
}

.article-body .gallery-icon > a {
  position: relative;
}
.article-body .gallery-icon > a:before {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  width: 19px;
  height: 19px;
  background: url(/common/crea/images/v1/icon/gallery.png) left top no-repeat;
  background-size: 100%;
}

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

.article-body .figure-center {
  text-align: center;
}

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

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

.article-body .figure-left.smartphone-compatible .image-area:before {
  width: 12px;
  height: 12px;
}

.article-body .figure-left.smartphone-compatible .text-area {
  margin-top: 0;
}

.article-body .figure-left.smartphone-compatible.no-wraparound .text-area {
  float: right;
  width: calc(100% - 150px - 10px);
}

.article-body .images-2cols {
  margin-top: 20px;
  position:relative;
}

.article-body .images-2cols .image-area {
  float: left;
  width: calc(50% - 1px);
}

.article-body .images-2cols .image-area img {
  width: 100%;
}

.article-body .images-2cols .image-area:before {
  width: 12px;
  height: 12px;
}

.article-body .images-2cols .image-area+.image-area {
  margin-left: 2px;
}

.article-body .images-3cols {
  margin-top: 20px;
  position:relative;
}

.article-body .images-3cols .image-area {
  float: left;
  width: calc(33.3333% - 2px);
}

.article-body .images-3cols .image-area img {
  width: 100%;
}

.article-body .images-3cols .image-area:before {
  width: 9px;
  height: 9px;
}

.article-body .images-3cols .image-area+.image-area {
  margin-left: 2.5px;
}

.article-body .figure-center figcaption {
  text-align: left;
}

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

.article-body .box-normal,
.article-body .box-thick,
.article-body .box-color,
.article-body .box-author {
  margin-top: 20px;
  padding: 14px;
  word-wrap: break-word;
}

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

.article-body .box-color .link-button > span {
  width: 100%;
}

.article-body .box-normal {
  background: var(--color-white);
  border: 1px solid var(--color-gray5);
}

.article-body .box-normal *:first-child {
  margin-top: 0 ;
}

.article-body  .box-magazine .box-normal {
  background: var(--color-primary);
  border: none;
}

.article-body  .box-magazine .box-normal .box-title {
  color: var(--color-black);
  font-family: var(--font-hiragino-kaku-gothic);
  font-size: 20px;
  font-size: 2.0rem;
  font-weight: 600;
  line-height: 150% ;
}

.article-body  .box-magazine .box-normal p {
  color: var(--color-black);
  font-family: var(--font-hiragino-kaku-gothic);
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 150% ;
}

.article-body .box-thick {
  position:relative;
  padding: 20px;
  border: 3px solid #ccc;
}

.article-body .box-thick 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;
}

.article-body .box-thick h4 small{
  display: block;
  margin-bottom:10px;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 100%;
}

.article-body .box-thick p{
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 150%;
}

.article-body .box-thick p small{
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 100%;
}

.article-body .box-color .link-button a,
.article-body .box-thick .link-button a {
  margin-top: 0;
  color:var(--color-black);
  font-family: var(--font-josefin-sans);
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 150%;
}

.article-body .box-author {
  padding: 20px;
  border: 1px solid #ccc;
  background: var(--color-white);
  margin: 30px 0 ;
}

.article-body .box-color {
  border: 1px solid var(--color-black);
  background: var(--color-white);
}

.article-body .box-color .link-button,
.article-body .box-author .link-button {
  max-width: 300px;
}

.article-body .box-color .link-button a,
.article-body .box-author .link-button a {
  font-size: 13px;
  font-size: 1.3rem;
}

.article-body .box-color.moon {
  background-color: #FFCE00;
}

.article-body .box-color.moon p {
  font-size:20px;
  font-size: 2.0rem;
  line-height:1.7em;
}

.article-body .box-color.member {
  background-color: #F597AD;
}

.article-body .box-author.no-color {
  background-color: #fff;
  border: 1px solid #ccc;
}

.article-body .box-normal p,
.article-body .box-color p,
.article-body .box-author p {
  margin-top: 20px;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 160% ;
}

.article-body .box-normal a,
.article-body .box-thick a,
.article-body .box-color a,
.article-body .box-author a {
  margin-top:12px;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 160% ;
}

.article-body .box-normal table,
.article-body .box-thick table,
.article-body .box-color table,
.article-body .box-author table,
.article-body .box-normal ul,
.article-body .box-thick ul,
.article-body .box-color ul,
.article-body .box-author ul {
  margin-top: 10px;
}

.article-body .box-normal li,
.article-body .box-thick li,
.article-body .box-color li,
.article-body .box-author li {
  font-size: 12px;
  font-size: 1.2rem;
}

.article-body .box-normal .box-title,
.article-body .box-thick .box-title,
.article-body .box-color .box-title {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 160% ;
}

.article-body .box-author .box-title {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 100% ;
  margin: 0 0 20px;
  padding: 0;
}

.article-body .box-normal .box-title+p,
.article-body .box-thick .box-title+p,
.article-body .box-color .box-title+p,
.article-body .box-author .box-title+p {
  margin-top: 10px;
}

.article-body .box-normal .box-image-center,
.article-body .box-thick .box-image-center,
.article-body .box-color .box-image-center {
  text-align: center;
}

.article-body .box-normal .box-image-left,
.article-body .box-thick .box-image-left,
.article-body .box-color .box-image-left,
.article-body .box-author .box-image-left {
  float: left;
  width: 100px;
}

.article-body .box-normal .box-image-left:before,
.article-body .box-thick .box-image-left:before,
.article-body .box-color .box-image-left:before,
.article-body .box-author .box-image-left:before {
  width: 13px;
  height: 13px;
}

.article-body .box-normal .box-image-left img,
.article-body .box-thick .box-image-left img,
.article-body .box-color .box-image-left img,
.article-body .box-author .box-image-left img {
  padding-top: 3px;
}

.article-body .box-normal .box-text-right,
.article-body .box-thick .box-text-right,
.article-body .box-color .box-text-right,
.article-body .box-author .box-text-right {
  float: right;
  width: calc(100% - 100px - 20px);
}

.article-body .box-color .box-image-left {
  margin-left: -10px;
}

.article-body .box-color .box-text-right {
  width: calc(100% - 100px);
}

.article-body .box-color *:first-child {
  margin-top: 0 ;
}

.article-body .box-author .box-image-left {
  width: 100px;
}

.article-body .box-author .box-image-left:before {
  content: none;
}

.article-body .box-author .box-text-right {
  width: calc(100% - 100px - 20px);
  margin-bottom: 20px;
}

.article-body .box-author .box-text-right .box-title {
  margin: 0 0 14px;
}

.article-body .box-author hr {
  clear: both;
  margin: 0;
  border: none;
}

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

.article-body .module-pagination ul li {
  line-height: 40px;
}

.article-body .module-pagination ul li a,
.article-body .module-next-button a {
  text-decoration: none;
}

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

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

.article-body .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;
}

.article-body .box-normal .link-basic a {
  color: #333;
}

.article-body .link-basic a p {
  margin-top: 0;
}

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

.article-body .ambassador-link h3 {
  margin: 0 0 5px;
}

.article-body .ambassador-link .button {
  margin: 20px 0 0;
}

.article-body .ambassador-link .link-button {
  width: 74.67%;
}

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

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

.article-body .moon-link .link-button {
  width: 74.67%;
}

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

.article-body .magazine-buy {
  margin: 50px auto ;
}

.article-body .magazine-buy 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-bottom:18px;
  margin-top: 30px;
}

.article-body .magazine-buy .pr {
  position: relative;
}

.article-body .magazine-buy .pr:after {
  content: '【PR】';
  display: inline-block;
}

.article-body .magazine-buy ul {
  margin-top: 0;
  font-size: 0;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom:30px;
}

.article-body .magazine-buy ul li {
  display: inline-block;
  width: 166px;
  margin: 0;
}

.article-body .purchase {
  margin-top: 20px;
}

.article-body .purchase ul {
  font-size: 0;
  margin: 0 0 0 -1.1%;
}

.article-body .purchase ul li {
  display: inline-block;
  width: 32.21%;
  margin: 5px 0 0 1.1%;
  border: 1px solid #e6e6e6;
}

.article-body .purchase ul.digital li {
  width: 23.9%;
}

.article-body .purchase ul li img {
  width: 100%;
}

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

.article-body .psychology-answer+p {
  margin-top: 10px;
  text-align: center;
}

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

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

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

.article-body .psychology-share .inner a+a {
  margin-left: 30px;
}

.article-body .psychology-share .inner .facebook img {
  width: 34px !important;
}

.article-body .psychology-share .inner .twitter img {
  width: 40px !important;
}

.article-body .psychology-share .inner .x_psychology img {
  width: 30px !important;
}

.article-body .feature {
  margin: 40px auto 0;
}

.article-body .feature h5 {
  font-size: 16px;
  font-size: 1.6rem;
  margin-bottom: 18px;
}

.article-body .feature .item {
  padding-bottom: 0;
}

.article-body .feature .item+.item {
  border-top: none;
}

.article-body .feature .item:nth-child(4) {
  /* margin-bottom: 30px;*/
}

.article-body .feature .item a {
  color: #333;
}

.article-body .feature .item a .image {
  width: 17.91%;
  padding-top: 17.91%;
}

.article-body .feature .item a .text {
  width: calc(100% - 17.91% - 10px);
  padding-top: 0;
}

.article-body .feature .item a .text p {
  margin-top: 0;
  padding-bottom: 6px;
}

.article-body .feature .item a .text li {
  margin-top: 0;
}

.article-body .feature .item a .text .title {
  font-size: 13px;
  font-weight: normal;
}

.article-body .column-box {
  margin:30px auto;
  padding: 15px;
  background: var(--color-primary);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.article-body .column-box .image {
  width: 30%;
  padding-top: 22.33%;
  background: top center no-repeat;
  background-size: contain;
}

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

.article-body .column-box .text .genre {
  margin: 0;
  line-height: 18px;
  font-size: 12px;
  font-size: 1.2rem;
  font-weight: bold;
}

.article-body .column-box .text .title {
  margin: 0 0 6px;
  line-height: 21px;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: bold;
}

.article-body .column-box .detail {
  clear: both;
  padding-top: 3px;
  margin-bottom: 4px;
  line-height: 18px;
  font-size: 10px;
  font-size: 1.0rem;
}

.article-body .column-box .detail > p{
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 21px;
  margin-bottom: 0;
}

.article-body .column-box .link-button {
  margin: 0;
  width: 100%;
}

.article-body .column-box .link-button a{
  line-height: 26px;
  color: #000;
  width: 100%;
}

/*next*/
.article-body .link-button.next {
  margin-bottom: 0;
}

.article-body .link-button.next a {
  border-radius: initial;
}

/*author*/
.link-button.author,
.article-body .link-button.author{
  max-width: 268px;
  margin: 30px 0 0 auto;
}

.link-button.author a,
.article-body .link-button.author a{
  line-height: 120%;
  color: #000;
}

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

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

.article-body .box-yt iframe {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

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

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

.article-body .box-yt iframe {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

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

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

.article-body .module-sanmeigaku .col .item {
  margin: 0;
}

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

/* ----------------------------------------------------------------------------------------------------------------------------
.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 a.flex-col {
  flex-direction: column;
}

.list-normal .item .image {
  position: relative;
  float: left;
  width: 25.37%;
  padding-top: 25.37%;
  background: center center no-repeat;
  background-size: cover;
  height: 0;
  aspect-ratio: 1 / 1;
}
.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-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
---------------------------------------------------------------------------------------------------------------------------- */
.member-text{
  width: 89.33%;
  margin-left: auto;
  margin-right: auto;
}

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

.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;
  border: 1px solid #707070;
}

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

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


.comic-essay-bottom .box .box-bottom {
  clear: both;
  padding-top: 20px;
}

.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%;
  padding: 20px;
  border: 1px solid var(--color-black);
  width: calc(100% - 24px);
}

.box-mail-magazine .headline {
  margin-bottom: 15px;
  font-size: 22px;
  font-size: 2.2rem;
  font-weight: bold;
  text-align: center;
}

.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);
}


/* ============================================================================================================================
.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 .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.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: 89.33%;
  margin: 0 auto 40px;
  padding: 30px;
  background-color: #EFEFEF;
}

.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 .box-color a {
  color: #666;
}

#temp-static-contact .article-body .box-color li+li {
  margin-top: 14px;
}

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

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

#temp-static-moon .box-normal .box-title {
  width: calc(100% + 40px);
  margin: 0 0 0 -20px;
  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;
  width: calc(100% + 30px);
  margin: 0px 0px 0px -15px;
}

#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;
  width: calc(100% + 30px);
  margin: 0px 0px 0px -15px;
}

#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;
  width: calc(100% + 30px);
  margin: 0px 0px 0px -15px;
}

#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;
  width: calc(100% + 30px);
  margin: 0px 0px 0px -15px;
}

#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-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: 0;
  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 {
  display: block;
  width: 100%;
  height: 100%;
  padding: 16px 24px;
  border-top: 1px solid var(--color-black);
  text-align: center;
  background: #FFF;
  position: relative;
  color: var(--link-active);
  text-decoration: underline;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 600;
}

.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 {
  overflow: hidden;
  width: 100%;
  background-color: var(--color-primary);
  border-radius: 8px;
  margin:0 0 50px;
}

.article-body figure:has(+ .toc) {
  margin-bottom: 50px;
}

.toc__header {
  position: relative;
  display: flex;
  align-items: center;
  padding: 16px 19px 13px;
  color: var(--color-black);
  border-bottom:solid 1px var(--color-white);
}

.article-body p.toc__title,
.toc__title {
  margin: 0;
  color: var(--color-black);
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 100%; 
  font-family: var(--font-josefin-sans);
}

.toc__toggle {
  display:flex;
  align-items: center;
  gap:6px;
  width: auto;
  background: none;
  position: absolute;
  cursor: pointer;
  right: 18px;
  top: 0;
  bottom: 0;
  transition: transform 0.3s ease;
}

.toc__toggle::before {
  content: '\25BC';
  display: inline-block;
  text-align: center;
  color: var(--color-black);
  font-size: 10px;
  font-size: 1.0rem;
  width: 10px;
  height: 10px;
  line-height: 1;
}

.toc__toggle::after {
  content: '閉じる';
  display: inline-block;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 600 ;
  line-height: 100%;
  color: var(--link-active);
  opacity: 1;
}

.toc__checkbox:not(:checked) + .toc__header .toc__toggle::before {
  content: '\25B2';
}

.toc__checkbox:not(:checked) + .toc__header .toc__toggle::after {
  content: '開く';
}

.toc__footer {
  max-height: 500px;
  transition: max-height 0.3s ease;
}

.toc__checkbox:not(:checked) ~ .toc__footer {
  max-height: 0;
}
.article-body ul.toc__list,
.toc__list {
  list-style: none;
  padding: 8px 19px;
  margin: 0 0 0 19px;
}

.article-body ul li.toc__item ,
.toc__item {
  list-style: disc;
}

.article-body a.toc__link,
.toc__link {
  display: block;
  color: var(--link-active);
  font-family: var(--font-hiragino-kaku-gothic);
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: 150%; 
  padding: 4px 0;
  text-decoration: underline;
  color: var(--link-active);
  transition: background-color 0.3s ease;
}

.toc__link:hover {
  background-color: #f0f0f0;
}

.toc-top {
  background: url(/common/crea/images/v1_1/icon/ico_toc.svg) no-repeat;
  background-color: var(--color-quaternary);
  display: block;
  width: 66px;
  height: 66px;
  border-radius: 50px;
  background-size: 26px;
  background-position: 50% 53%;
  position: fixed;
  right: 14px;
  bottom: 14px;
  z-index:100;
}

.toc-top:hover {
  background-color: var(--link-active);
  opacity:1;
}

/* ----------------------------------------------------------------------------------------------------------------------------
.module-fortune-search
---------------------------------------------------------------------------------------------------------------------------- */
.module-fortune-search {
  width: 89.33%;
  position: relative;
  margin: 24px auto 24px;
  padding: 4px;
  height: auto;
  background-repeat: no-repeat;
  background-image: 
    url(/common/crea/images/v1/fortune/frame01_top_l.png), 
    url(/common/crea/images/v1/fortune/frame01_top_r.png),
    url(/common/crea/images/v1/fortune/frame01_bottom_l.png),
    url(/common/crea/images/v1/fortune/frame01_bottom_r.png);
  background-position: top left, top right, bottom left, bottom right;
  background-size: 29px;
}

.module-fortune-search::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 3px;
  border: solid 1px #AB9F9F;
  outline: solid 1px #AB9F9F;
  outline-offset: 2px;
  z-index: -1;
}

.module-fortune-search__inner {
  position: relative;
  margin: 0;
  padding: 23px 10px;
  text-align: center;
}

.module-fortune-search__ico {
  width: calc(234 / 320* 100%);
  margin: 0 auto 14px;
}

.module-fortune-search__title {
  color: #333;
  text-align: center;
  font-size: 18px;
  font-weight: 600;
  line-height: 23px;
  margin-bottom: 10px;
}

.module-fortune-search__subtitle {
  color: #333;
  text-align: center;
  font-size: 14px;
  font-weight: 600;
  line-height:18px;
  margin-bottom: 16px;
}

.module-fortune-search__col {
  display: inline-grid;
  grid-column-gap: 9px;
  grid-row-gap: 18px;
}

.module-fortune-search__item {
  position:relative;
  width: 84px;
  display: flex;
  align-items: flex-end;
  text-align: center;
  font-size: 16px;
  font-weight: 600;
  line-height:  20.8px;
}

.module-fortune-search__item:after {
  content: '';
  position: absolute;
  background: #999;
  height: calc(10px / 2 * tan(60deg));
  width: 10px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  right: 30px;
  top: 50%;
  font-size: 24px;
  pointer-events: none;
  margin-top: -2px;
}

.module-fortune-search__item--year {
  width: 126px;
}

.module-fortune-search__item select {
  width:100%;
  padding: 11px;
  font-size:16px;
  text-align:center;
  background:#fff;
  border:solid 1px #ccc;
  -webkit-appearance: none;
   -moz-appearance: none;
  appearance: none;
  border-radius: 6px;
  margin-right: 5px;
}

.module-fortune-search__submit {
  width:124px;
  margin: 0 auto;
  padding: 11px;
  font-size:16px;
  text-align:center;
  color:#fff;
  background:#E54C78;
  border-radius: 6px;
  cursor: pointer;
  grid-area: 2 / 1 / 3 / 4; 
  border: 0;
}

.module-fortune-search__submit:hover {
    opacity: 0.6;
}

.module-fortune-search__result {
  background: #F8F2EF;
  margin:20px auto 0;
  padding: 14px;

}

.module-fortune-search__result--title {
  color: #000;
  text-align: center;
  font-size: 16px;
  font-weight: 600;
  line-height:28px;
}

.module-fortune-search__result--title span {
  font-size: 10px;
  font-weight: 600;
  line-height: 180%;
}

.module-fortune-search .result {
  position: relative;
  display: none;
  padding: 40px 20px;
  background: #EFEFEF;
}

.module-fortune-search .result:before {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 100px;
  height: 100px;
  background: url('/common/crea/images/v1/icon/loader.gif') no-repeat;
  background-size: 100%;
  pointer-events: none;
  opacity: 0;
  transition: opacity .1s ease-in-out;
}

.module-fortune-search .result.loader:before {
  opacity: 1;
}

.module-fortune-search .result.loader .col {
  opacity: 0;
}

.module-fortune-search .result .col {
  position: relative;
  margin: 0;
  opacity: 1;
  transition: opacity .1s ease-in-out;
}

.module-fortune-search .result .col .image {
  width: 420px;
}

.module-fortune-search .result .col .text {
  width: 335px;
}

.module-fortune-search .result .col .text .title {
  margin: 0 0 20px;
  line-height: 1.3;
  text-align: left;
}

.fortune-swiper {
  overflow: hidden;
}

.fortune-slider .slick-slide {
  margin:0 10px;
}

@media only screen and (max-width: 389px) {
  .module-fortune-search__inner {
      padding: 23px 5px;
  }
  .module-fortune-search__item {
    width: 75px;
    font-size: 13px;
    line-height:  18px;
  }

  .module-fortune-search__item:after {
      height: calc(8px / 2* tan(60deg));
      width: 8px;
      right: 25px;
  }

  .module-fortune-search__item--year {
    width: 95px;
  }
}

/* ----------------------------------------------------------------------------------------------------------------------------
.module-from-editors
---------------------------------------------------------------------------------------------------------------------------- */

.module-from-editors {
  margin: 40px auto;
}

.module-from-editors .item .image {
  border-radius: 100%;
}


/* ----------------------------------------------------------------------------------------------------------------------------
.module-information
---------------------------------------------------------------------------------------------------------------------------- */

.module-information {
  margin: 40px auto;
}

