@charset "UTF-8";

/*================================================================================================
    common.css
================================================================================================*/

body {
  margin: 0;
  padding: 0;
}

div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, figure, input, textarea, p, blockquote, table, th, td, address {
  -webkit-text-size-adjust: none;
  margin: 0;
  padding: 0;
  color: #000;
  font-style: normal;
  font: 13px/160% verdana, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック",  Osaka, sans-serif;
}

.protect {
    -webkit-user-drag: none;
    user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    -webkit-touch-callout: none;
    pointer-events: none;
}

select,
input,
button,
textarea {
  font-size: 99%;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
  font-size: inherit;
  font: 100%;
}

textarea, input {
  margin: 0;
  padding: 0;
}

caption, th {
  text-align: left;
}

td, th {
  vertical-align: top;
}

fieldset, img, abbr {
  border: none;
}

li {
  list-style-type: none;
}

hr {
  display: none;
}

strong {
  font-weight: bold;
}

.clearfix:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}

article > div,
article p,
article ul,
article dl,
article ol,
article h2,
article h3,
article h4,
article table {
  margin: 0 0 20px;
}

a, a:link {
  color: #4059b3;
}

a:visited {
  color: #4059b3;
}

a:hover {
  color: #4059b3;
}

/*マージン*/
.mt0 {
  margin-top: 0!important;
}
.mt10 {
  margin-top: 10px!important;
}
.mt18 {
  margin-top: 18px!important;
}
.mt20 {
  margin-top: 20px!important;
}
.mt25 {
  margin-top: 25px!important;
}
.mt30 {
  margin-top: 30px!important;
}

.mb10 {
  margin-bottom: 10px!important;
}
.mb11 {
  margin-bottom: 11px!important;
}
.mb15 {
    margin-bottom: 15px!important;
}
.mb20 {
  margin-bottom: 20px!important;
}

.menuOver {
  display: none;
  background: rgba(0, 0, 0, 0.8);
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 1000;
}

.spMenu {
  position: fixed;
  left: -275px;
  width: 275px;
  background: #D7D7D7;
  height: 100%;
  top: 0;
  z-index: 1001;
}

.spMenu .inner {
  height: 100%;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

.spMenu header {
  position: relative;
  height: 19px;
  background: #E84D19 url(image/common/bg_h2.png);
  background-size: 5px 5px;
  padding: 15px 15px;
}

.spMenu header h2 {
  color: #fff;
}

#topic .spMenu header h2 {
  border-bottom: none;
  background: none;
  padding: 0;
  font-weight: normal;
  line-height: normal;
}

.spMenu header .close {
  position: absolute;
  right: 10px;
  top: 15px;
}

.spMenu ul li {
  border-bottom: #969696 1px solid;
  background: #D7D7D7;
}

.spMenu ul li.login a {
  background: #F8DFD6 url(image/common/icon_arrow04.png) no-repeat 95% 50%;
  background-size: 7px 11px;
  color: #E94D19;
}

.spMenu ul li a {
  text-decoration: none;
  background: url(image/common/icon_arrow02.png) no-repeat 95% 50%;
  background-size: 7px 11px;
  display: block;
  color: #000;
  padding: 15px;
}

.spMenu ul li a.expand {
  background: url(image/common/icon_arrow03.png) no-repeat 95% 50%;
  background-size: 11px 7px;
  border-bottom: #969696 1px solid;
}

.spMenu ul li.accordion > a {
  background: url(image/common/icon_plus.png) no-repeat 95% 50%;
  background-size: 12px 12px;
}

.spMenu ul li.accordion > a.expand {
  background: url(image/common/icon_minus.png) no-repeat 95% 50%;
  background-size: 12px 12px;
}

.spMenu ul li ul {
  display: none;
  margin: 0;
}

.spMenu ul li ul li {
  border-bottom: #D7D7D7 1px solid;
}

.spMenu ul li ul li:last-child {
  border-bottom: none;
}

.spMenu ul li ul li a {
  background: #fff;
  padding: 10px 15px;
}

.spMenu ul li ul li.more {
  padding: 4px;
  background: #fff;
}

.spMenu ul li ul li.more a {
  display: block;
  background: #212121 url(image/common/icon_arrow.png) no-repeat 95% 50%;
  padding: 10px;
  color: #FFF;
  text-align: center;
  text-decoration: none;
  font-weight: bold;
  background-size: 7px 11px, auto auto;
}

body .outline {
  width: 100%;
  overflow: hidden;
}

body.show .wrapper {
  position: fixed;
  transition: left 0.1s linear;
  left: 275px;
}

body.show .spMenu {
  transition: left 0.1s linear;
  left: 0;
}

.wrapper {
  min-width: 320px;
}

.wrapper > header {
  position: relative;
  background: #EB4C00;
  padding-top: 65px;
}

.wrapper > header a {
  display: block;
}

.wrapper > header .menu {
  position: absolute;
  top: 18px;
  left: 9px;
}

.wrapper > header .logo {
  position: absolute;
  top: 9px;
  left: 53px;
}

.wrapper > header .search {
  position: absolute;
  top: 20px;
  right: 10px;
}

.wrapper > header .btnLogin {
  position: absolute;
  top: 18px;
  right: 46px;
}

.wrapper > header .search-box {
  display: none;
}

.wrapper > header .search-box .inner {
  width: 100%;
  background: #fff;
  padding: 3px 2px;
  width: 100%;
}

.wrapper > header .search-box .inner form {
    display: table;
    margin: 0 auto;
}

.wrapper > header .search-box .inner input[type="text"] {
  display: table-cell;
  background: url(image/common/bg-search.png) no-repeat 5px 5px;
  background-size: 23px 28px;
  border: #ccc 1px solid;
  padding: 10px;
  box-sizing: border-box;
  width: 100%;
}

.wrapper > header .search-box .inner .btn {
  display: table-cell;
  width: 62px;
  padding-left: 5px;
}

.wrapper > header .search-box .inner .btn button {
  background: #555;
  border: none;
  color: #CFCFCF;
  padding: 12px;
  font-size: 15px;
  font-weight: bold;
}

.wrapper main .banner {
  text-align: center;
}

.campaign-text {
    background: #eb9e1a;
    text-align: center;
    padding: 4px 0 5px;
}
.campaign-text a {
    color: #ffffff;
}
.campaign-text a:hover {
    text-decoration: none;
}

.wrapper main nav.gnav {
    padding: 5px 5px 0;
    background: #ffffff;
}
.wrapper main nav.gnav,
.wrapper main nav.cate-nav {
    overflow: scroll;
    width: 100%;
}

#index .wrapper main nav.cate-nav { background-color: #E92222; padding: 5px 0;}
.gen-news .wrapper main nav.cate-nav { background-color: #2B67B0; padding: 5px 0;}
.gen-geino .wrapper main nav.cate-nav { background-color: #D14AAD; padding: 5px 0;}
.gen-sports .wrapper main nav.cate-nav { background-color: #2BA414; padding: 5px 0;}
.gen-life .wrapper main nav.cate-nav { background-color: #CE910E; padding: 5px 0;}
.gen-money .wrapper main nav.cate-nav { background-color: #FFCC00; padding: 5px 0;}
.gen-health .wrapper main nav.cate-nav { background-color: #00bfff; padding: 5px 0;}
.gen-book .wrapper main nav.cate-nav { background-color: #C05520; padding: 5px 0;}
.gen-other .wrapper main nav.cate-nav { background-color: #EB4C00; padding: 5px 0;}

.wrapper main nav.gnav ul,
.wrapper main nav.cate-nav ul {
  display: table;
  padding-right: 15px;
}

.wrapper main nav.gnav ul li,
.wrapper main nav.cate-nav ul li {
  display: table-cell;
  white-space: nowrap;
  text-align: center;
}

.wrapper main nav.gnav ul li a {
  background: #020202;
  display: block;
  width: 70px;
  color: #fff;
  font-size: 12px;
  padding: 10px 0;
  text-decoration: none;
  font-weight: bold;
  box-shadow:0 -5px 5px -5px rgba(0,0,0,0.3) inset;
  border-radius: 5px 5px 0 0;
}
#index .wrapper main nav.gnav ul li a.nav01,
.gen-news .wrapper main nav.gnav ul li a.nav02,
.gen-geino .wrapper main nav.gnav ul li a.nav03,
.gen-sports .wrapper main nav.gnav ul li a.nav04,
.gen-life .wrapper main nav.gnav ul li a.nav05,
.gen-money .wrapper main nav.gnav ul li a.nav10,
.gen-health .wrapper main nav.gnav ul li a.nav09,
.gen-book .wrapper main nav.gnav ul li a.nav06 { box-shadow:0 1px 5px 0 rgba(0,0,0,0.3); padding: 13px 0 10px; }

.wrapper main nav.cate-nav ul li a {
  background: #cccccc;
  display: block;
  color: #fff;
  font-size: 12px;
  padding: 3px 10px;
  text-decoration: none;
  font-weight: bold;
  border-radius: 10px;
  margin: 0 2px;
}

#index .wrapper main nav.cate-nav ul li a { background-color: #b51b1b;}
.gen-news .wrapper main nav.cate-nav ul li a { background-color: #1e497d;}
.gen-geino .wrapper main nav.cate-nav ul li a { background-color: #9e3783;}
.gen-sports .wrapper main nav.cate-nav ul li a { background-color: #1e700d;}
.gen-life .wrapper main nav.cate-nav ul li a { background-color: #b5800d;}
.gen-money .wrapper main nav.cate-nav ul li a { background-color: #FFAA00;}
.gen-health .wrapper main nav.cate-nav ul li a { background-color: #1a73e8;}
.gen-book .wrapper main nav.cate-nav ul li a { background-color: #8c3f18;}
.gen-other .wrapper main nav.cate-nav ul li a { background-color: #b51b1b;}

.wrapper main nav.cate-nav ul li.selected a {
  background: #ffffff;
  color: #EB4C00;
}

#index .wrapper main nav.cate-nav ul li.selected a { color: #b51b1b;}
.gen-news .wrapper main nav.cate-nav ul li.selected a { color: #1e497d;}
.gen-geino .wrapper main nav.cate-nav ul li.selected a { color: #9e3783;}
.gen-sports .wrapper main nav.cate-nav ul li.selected a { color: #1e700d;}
.gen-life .wrapper main nav.cate-nav ul li.selected a { color: #b5800d;}
.gen-money .wrapper main nav.cate-nav ul li.selected a { color: #FFCC00;}
.gen-health .wrapper main nav.cate-nav ul li.selected a { color: #1a73e8;}
.gen-book .wrapper main nav.cate-nav ul li.selected a { color: #8c3f18;}

.wrapper main nav.gnav ul li a.nav01 {
  background: #E92222;
}
.wrapper main nav.gnav ul li a.nav01.g-hover {
  background: #b51b1b;
  background-size: 4px 4px;
}

.wrapper main nav.gnav ul li a.nav02 {
  background: #2B67B0;
}
.wrapper main nav.gnav ul li a.nav02.g-hover {
  background: #1e497d;
  background-size: 4px 4px;
}

.wrapper main nav.gnav ul li a.nav03 {
  background: #D14AAD;
}
.wrapper main nav.gnav ul li a.nav03.g-hover {
  background: #9e3783;
  background-size: 4px 4px;
}

.wrapper main nav.gnav ul li a.nav04 {
  background: #2BA414;
}
.wrapper main nav.gnav ul li a.nav04.g-hover {
  background: #1e700d;
  background-size: 4px 4px;
}

.wrapper main nav.gnav ul li a.nav05 {
  background: #CE910E;
}
.wrapper main nav.gnav ul li a.nav05.g-hover {
  background: #9c6e0b;
  background-size: 4px 4px;
}

.wrapper main nav.gnav ul li a.nav06 {
  background: #C05520;
}
.wrapper main nav.gnav ul li a.nav06.g-hover {
  background: #8c3f18;
  background-size: 4px 4px;
}

.wrapper main nav.gnav ul li a.nav07 {
  background: #82B80D;
}
.wrapper main nav.gnav ul li a.nav07.g-hover {
  background: #5e8509;
  background-size: 4px 4px;
}

.wrapper main nav.gnav ul li a.nav08 {
  background: #E47474;
}
.wrapper main nav.gnav ul li a.nav08.g-hover {
  background: #b05a5a;
  background-size: 4px 4px;
}

.wrapper main nav.gnav ul li a.nav09 {
  background: #00bfff;
}
.wrapper main nav.gnav ul li a.nav09.g-hover {
  background: #1e90ff;
  background-size: 4px 4px;
}

.wrapper main nav.gnav ul li a.nav10 {
  background: #FFCC00;
}
.wrapper main nav.gnav ul li a.nav10.g-hover {
  background: #FFA500;
  background-size: 4px 4px;
}

/* コクハク */
.wrapper main nav.gnav ul li a.nav11 {
    background: #e40b7f;
}

.wrapper main nav.gnav ul li a.nav12 {
    background: #808080;
}
/* ボートレース */
.wrapper main nav.gnav ul li a.nav13 {
    background: #1e90ff;
    width: 90px;
}

.swipe-navi {
    position: fixed;
    top: 50%;
    margin-top: -40px;
    width: 80px;
    height: 80px;
    background-color: rgba(235,76,0,.8);
    color: #fff;
    -webkit-transition: .15s;
    transition: .15s;
    z-index: 10000;
}
.swipe-navi span {
    position: absolute;
    text-indent: -9999px;
    overflow: hidden;
    white-space: nowrap;
}
.swipe-navi::before {
    position: absolute;
    top: 50%;
    margin-top: -.5em;
    width: 1em;
    height: 1em;
    text-align: center;
}
.swipe-navi-prev {
    left: -80px;
    border-top-right-radius: 80px;
    border-bottom-right-radius: 80px;
    -webkit-transform: translateX(-80px);
    transform: translateX(-80px);
}
.swipe-navi-prev::before {
    speak: none;
    font-style: normal;
    font-weight: 400;
    text-transform: none;
    line-height: 1;
    content: "◀";
    right: 10px;
}
.swipe-navi-next {
    right: -80px;
    border-top-left-radius: 80px;
    border-bottom-left-radius: 80px;
    -webkit-transform: translateX(80px);
    transform: translateX(80px);
}
.swipe-navi-next::before {
    speak: none;
    font-style: normal;
    font-weight: 400;
    text-transform: none;
    line-height: 1;
    content: "▶";
    left: 10px;
}
.swipe-navi.show {
    -webkit-transform: translateX(0);
    transform: translateX(0);
}

.time-select {
    position: relative;
    font-size: 0;
}
.time-select li {
    position: relative;
    display: inline-block;
    height: 40px;
    line-height: 40px;
    font-size: 15px;
    font-weight: bold;
    text-align: center;
    background: url(../images/bg_Rnavi_tab.png) #2a2a2a;
    color: #fff;
    cursor: pointer;
    -webkit-transition: background-color .2s linear, opacity .08s linear;
    transition: background-color .2s linear, opacity .08s linear;
}
.time-select li:hover {
    background-color: #ea4e19;
    opacity: .5;
}

.time-select .yesterday {
    width: 65%;
}
.time-select .week {
    width: 35%;
}
.time-select .selected {
    background-color: #ea4e19;
}
.time-select .selected:hover {
    opacity: 1;
}

.wrapper main ul.topicList li {
  border-bottom: #D4D4D4 1px solid;
}

.wrapper main ul.topicList li a {
  text-decoration: none;
  display: block;
}

.genre-list-wrap {
  display: table;
  width: 100%;
  padding: 2px;
  position: relative;
}

.wrapper main ul.topicList li a figure, .wrapper main ul.topicList li a p {
  display: table-cell;
  vertical-align: middle;
}

.wrapper main ul.topicList li a figure {
  width: 1%;
}

.wrapper main ul.topicList li a figure img {
  display: block;
}

.wrapper main ul.topicList li a p {
  padding-left: 7px;
  font-size: 15px;
  font-weight: bold;
  line-height: 130%;
  margin-bottom: 0;
  padding-right: 7px;
}

.wrapper main ul.topicList li a p span {
  display: inline-block;
  vertical-align: middle;
}

.wrapper main ul.topicList li a div.ranking {
  display: block;
  position: absolute;
  left: 2px;
  top: 2px;
  padding: 0;
}

.wrapper main ul.topicList li a div.ranking span {
  display: block;
  margin-left: 0;
  background: #000;
  color: #fff;
  font-weight: bold;
  text-align: center;
  height: 20px;
  line-height: 16px;
  width: 22px;
}

.wrapper main ul.topicList li.banner a {
  padding: 0;
  text-align: center;
  background: none;
}

.wrapper main ul.topicList li.banner a img {
  display: block;
  margin: 0 auto;
}
.wrapper main ul.topicList.accesslank li a div.ranking span {
    background-color: #d8d6d6;
    color: #242424;
}
.wrapper main ul.topicList.accesslank li.lank-1 {
    background-color: #F6F4DB;
}
.wrapper main ul.topicList.accesslank li.lank-1 a div.ranking span {
    background-color: #DBAD00;
    color: #ffffff;
}
.wrapper main ul.topicList.accesslank li.lank-2 {
    background-color: #EFEFEF;
}
.wrapper main ul.topicList.accesslank li.lank-2 a div.ranking span {
    background-color: #A0A0A0;
    color: #ffffff;
}
.wrapper main ul.topicList.accesslank li.lank-3 {
    background-color: #EFE2D1;
}
.wrapper main ul.topicList.accesslank li.lank-3 a div.ranking span {
    background-color: #B36E2B;
    color: #ffffff;
}

.wrapper main ul.pageNate {
  margin: 0 12px 20px;
  text-align: center;
  zoom: 1;
}

.wrapper main ul.pageNate:before,
.wrapper main ul.pageNate:after {
  display: block;
  height: 0;
  visibility: hidden;
  content: "\0020";
}

.wrapper main ul.pageNate:after {
  clear: both;
}

.wrapper main ul.pageNate li {
  display: inline-block;
  vertical-align: middle;
}

.wrapper main ul.pageNate li a {
  background: #9E9E9E;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  padding: 5px 10px;
}

.wrapper main ul.pageNate li.current a {
  background: #E94D19;
}

.wrapper main ul.pageNate li.prev a, .wrapper main ul.pageNate li.next a {
  background: none;
  color: #E94D19;
  font-size: 12x;
  padding: 0;
}

.wrapper main ul.pageNate li.prev {
  float: left;
  min-width: 55px;
  min-height: 1px;
}

.wrapper main ul.pageNate li.prev a {
  background: #EB4C00 url(image/common/icon_next_l.png) no-repeat 10% 50%;
  background-size: 6px 9px;
  padding: 10px;
  padding-left: 20px;
  color: #ffffff;
  border-radius: 5px;
}

.wrapper main ul.pageNate li.next {
  float: right;
  min-width: 55px;
  min-height: 1px;
}

.wrapper main ul.pageNate li.next a {
  background: #EB4C00 url(image/common/icon_prev_l.png) no-repeat 90% 50%;
  background-size: 6px 9px;
  padding: 10px;
  padding-right: 20px;
  color: #ffffff;
  border-radius: 5px;
}

/* 記事詳細 ページネーション */
.wrapper main .pageNate-02 {
    text-align: center;
}
.wrapper main .pageNate-02 ul {
    display: inline-block;
    font-size: 0;
    margin-bottom: 10px;
}
.wrapper main .pageNate-02 ul li {
    display: inline-block;
    font-size: 14px;
    line-height: 1;
    border: #EB4C00 1px solid;
    margin-right: 3px;
}
.wrapper main .pageNate-02 ul li a {
    text-decoration: none;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 36px;
    width: 36px;
    background-color: #EB4C00;
    color: #ffffff;
}
.wrapper main .pageNate-02 ul li.arrow a {
    font-weight: bold;
}
.wrapper main .pageNate-02 ul li.current,
.wrapper main .pageNate-02 ul li.disable {
    height: 36px;
    line-height: 36px;
    width: 36px;
    border: #d8d6d6 1px solid;
}
.wrapper main .pageNate-02 ul li.current {
    background-color: #ffffff;
    color: #EB4C00;
    font-weight: bold;
}
.wrapper main .pageNate-02 ul li.disable {
    background-color: #d8d6d6;
    color: #242424;
    font-weight: normal;
}
.wrapper main .pageNate-02 .info {
    text-align: center;
}
.wrapper main .pageNate-02 .info span {
    font-weight: bold;
    font-size: 15px;
}

.wrapper footer {
  background: url(image/common/bg_footer.png);
  background-size: 5px 5px;
}

.wrapper footer .pageTop {
  background: #E94D19 url(../../img/sp/common/logo.png) no-repeat 12px 10px;
  padding: 1px;
  text-align: right;
  background-size: 76px 30px;
  height: 47px;
}

.wrapper footer dl {
  text-align: center;
  margin: 6px 0 0;
}

.wrapper footer dl dt, .wrapper footer dl dd {
  display: inline-block;
  vertical-align: middle;
}

.wrapper footer dl dt {
  color: #B1B0B0;
  font-weight: bold;
  margin-right: 30px;
}

.wrapper footer .copy {
  background: #000;
  text-align: center;
  color: #B1B0B0;
  font-size: 10px;
  padding: 10px 10px 140px 10px;
}

#index .wrapper main section {
  margin-bottom: 25px;
}
#index #accessRanking {
  margin-bottom: 0px;
}

#index .wrapper main section h2,
#accessRanking h2,
.genre-ranking h2,
.category-ranking h2,
#pickup h2,
#topic h2 {
  color: #fff;
  border-bottom: #000 4px solid;
  background: #E84D19 url(image/common/bg_h2.png);
  background-size: 5px 5px;
  padding: 10px;
  font-weight: bold;
  font-size: 13px;
  line-height: 100%;
}

.wrapper main section ul.genre-list li {
  border-bottom: #D4D4D4 1px solid;
}

.wrapper main section ul.genre-list li.banner a {
  padding: 0;
}

.wrapper main section ul.genre-list li.banner a img {
  display: block;
  margin: 0 auto;
}

.wrapper main section ul.genre-list li a {
  display: block;
  text-decoration: none;
}

.wrapper main section ul.genre-list li a figure,
.wrapper main section ul.genre-list li a .cont {
  display: table-cell;
  vertical-align: middle;
}

.wrapper main section ul.genre-list li a figure {
  width: 1%;
}

.wrapper main section ul.genre-list li a figure img {
  display: block;
  width: 70px;
  height: 70px;
}
.wrapper main section ul.genre-list li a figure img.oblong {
  display: block;
  width: 124px;
  height: 70px;
}

.wrapper main section ul.genre-list li a .cont {
  font-size: 13px;
  font-weight: bold;
  margin-bottom: 0;
  padding: 7px;
}

.wrapper main section ul.genre-list li a .cont .column-name {
  color: #D46D4C;
  font-size: 12px;
  font-weight: bold;
}

.wrapper main section ul.genre-list li a .cont p {
  font-size: 15px;
  font-weight: bold;
  line-height: 130%;
}

.wrapper main section ul.genre-list li a .cont p span {
  display: inline-block;
  vertical-align: middle;
}

.wrapper main section ul.genre-list li a .cont .date {
  font-size: 9px;
}

.wrapper main .more-btn {
  margin: 7px;
}

.wrapper main .more-btn a {
  display: block;
  background: #212121 url(image/common/icon_arrow.png) no-repeat 95% 50%;
  padding: 10px;
  color: #fff;
  text-align: center;
  text-decoration: none;
  font-weight: bold;
  background-size: 7px 11px;
}

#topic .wrapper main article {
  border-top: #d4d4d4 1px solid;
  border-bottom: #d4d4d4 1px solid;
}

#topic .wrapper main article header {
  padding: 10px;
  position: relative;
}

#topic .wrapper main article header h1 {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 10px;
}

#topic .wrapper main article header h1 .pay {
  display: inline-block;
  vertical-align: middle;
  margin-left: 5px;
}

#topic .wrapper main article header .date {
  position: absolute;
  right: 20px;
  bottom: 20px;
  text-align: right;
  margin-bottom: 0;
  font-size: 12px;
}

#topic .wrapper main article .article-cont {
  display: table;
  width: 100%;
  margin: 0 0 30px;
}

#topic .wrapper main article .article-cont figure, #topic .wrapper main article .article-cont .cont {
  display: table-cell;
  vertical-align: top;
}

#topic .wrapper main article .article-cont figure {
  padding-left: 5px;
  width: 1%;
}

#topic .wrapper main article .article-cont figure span {
  display: table-cell;
  background: #ccc;
  vertical-align: middle;
  text-align: center;
  width: 123px;
  height: 123px;
}

#topic .wrapper main article .article-cont figure a {
  text-decoration: none;
  color: #000;
}

#topic .wrapper main article .article-cont .cont {
  padding: 0 5px 0 15px;
}

#topic .wrapper main article .article-cont2 {
  zoom: 1;
  margin: 0 0 30px;
}

#topic .wrapper main article .article-cont2:before,
#topic .wrapper main article .article-cont2:after {
  display: block;
  height: 0;
  visibility: hidden;
  content: "\0020";
}

#topic .wrapper main article .article-cont2:after {
  clear: both;
}

#topic .wrapper main article .article-cont2 figure {
  margin-right: 10px;
  margin-bottom: 5px;
  margin-left: 5px;
  width: 125px;
}
#topic .wrapper main article .article-cont2.photo-left figure {
  float: left;
}
#topic .wrapper main article .article-cont2.photo-right figure {
  float: right;
}

#topic .wrapper main article .article-cont2 figure span {
  display: table-cell;
  background: #ccc;
  vertical-align: middle;
  text-align: center;
  width: 123px;
  height: 123px;
}

#topic .wrapper main article .article-cont2 figure a {
  text-decoration: none;
  color: #1D3994;
}
#topic .wrapper main article .article-cont2 figure a:hover {
  text-decoration: underline;
  color: #CC3434;
}

#topic .wrapper main article .article-cont2 figure img {
  margin-left: 2px;
}

#topic .wrapper main article .article-cont2 figure figcaption {
  margin-top: 5px;
  font-size: 10px;
  line-height: 130%;
}

#topic .wrapper main article .article-cont2 .cont {
  padding: 0 5px 0 5px;
}

#topic .wrapper main article .article-cont2 p{
  font-size: 16.25px;
  line-height: 1.7;
}

/* 記事内広告の余白を調整 */
div.uae_outstreamplayer {
    display: inline-block;
}

.wrapper main article .announce {
  border-top: #d4d4d4 1px solid;
  padding: 12px;
  margin-bottom: 0;
}

.wrapper main article .announce dt {
  font-size: 11px;
  margin-bottom: 10px;
}

.wrapper main article .announce dd ul {
  margin-bottom: 0;
  text-align: center;
}

.wrapper main article .announce dd ul li {
  display: inline-block;
}

.wrapper main article .announce dd ul li:last-child {
  margin-left: 2px;
}

.wrapper main article .announce dd ul li a {
  display: inline-block;
  color: #fff;
  text-decoration: none;
  font-weight: bold;
  padding: 13px 0;
  width: 144px;
  line-height: 1;
}

.wrapper main article .announce dd ul li.regist a {
  background: #E92323 url(image/common/icon_arrow.png) no-repeat 95% 50%;
  background-size: 7px 11px;
}

.wrapper main article .announce dd ul li.login a {
  background: #EF815B url(image/common/icon_arrow.png) no-repeat 95% 50%;
  background-size: 7px 11px;
}

.wrapper main article .login-menu {
  border-top: #d4d4d4 1px solid;
  padding: 12px;
  margin-bottom: 0;
  text-align: center;
}

.wrapper main article .login-menu dt {
  font-size: 11px;
  margin-bottom: 10px;
}

.wrapper main article .login-menu dt span {
  color: #D40C0C;
  font-weight: bold;
}

.wrapper main article .login-menu dd ul {
  margin-bottom: 0;
}

.wrapper main article .login-menu dd ul li:first-child {
  margin-bottom: 12px;
}

.wrapper main article .login-menu dd ul li a {
  display: inline-block;
  color: #fff;
  text-decoration: none;
  font-weight: bold;
  padding: 13px 0;
  width: 238px;
  box-sizing: border-box;
  line-height: 1;
}

.wrapper main article .login-menu dd ul li.disp a {
  background: #212121;
  color: #fff;
  font-weight: bold;
  line-height: 1;
}

.wrapper main article .login-menu dd ul li.disp a span {
  background: url(image/topic/icon_key.png) no-repeat 0 50%;
  background-size: 7px 9px;
  padding-left: 14px;
}

.wrapper main article .login-menu dd ul li.regist a {
  background: #E92323 url(image/common/icon_arrow.png) no-repeat 95% 50%;
  background-size: 7px 11px;
  line-height: 100%;
}

#topic .wrapper main article .btn,
#columnTopic .wrapper main article .btn {
  text-align: center;
}

#topic .wrapper main article .btn a,
#columnTopic .wrapper main article .btn a {
  display: inline-block;
  text-decoration: none;
}

.btn-read-articles {
    text-align: center;
    margin-top: 16px;
}
.btn-read-articles a {
    text-decoration: none;
    display: inline-block;
    background: #292929;
    color: #fff;
    font-weight: bold;
    padding: 13px 0;
    min-width: 240px;
    line-height: 1;
}

#topic .wrapper main article .btn.type-a a,
#columnTopic .wrapper main article .btn.type-a a {
  background: #292929;
  color: #fff;
  font-weight: bold;
  padding: 13px 0;
  min-width: 240px;
  line-height: 1;
}

#list .wrapper main .column-header {
  background-size: 5px 6px;
  padding: 5px 10px;
  margin-bottom: 5px;
}

#list .wrapper main .column-header h1 {
  font-weight: bold;
  margin-bottom: 6px;
  border-bottom: #9C9C9C 1px dotted;
  padding-bottom: 14px;
}

#list .wrapper main .column-header .profile-ttl {
  color: #fff;
  border-bottom: #000 4px solid;
  background: #E84D19 url(image/common/bg_h2.png);
  background-size: 5px 5px;
  padding: 10px;
  font-weight: bold;
  font-size: 13px;
  line-height: 100%;
  margin-left: -10px;
  margin-right: -10px;
  margin-top: -5px;
  margin-bottom: 15px;
}

#list .wrapper main .column-header .cont {
  display: table;
  width: 100%;
  border-bottom: #9C9C9C 1px dotted;
  margin-bottom: 1px;
}

#list .wrapper main .column-header .cont figure, #list .wrapper main .column-header .cont .profile {
  display: table-cell;
  vertical-align: middle;
  padding-bottom: 6px;
}

#list .wrapper main .column-header .cont figure {
  width: 1%;
}

#list .wrapper main .column-header .cont .profile {
  padding-left: 13px;
}

#list .wrapper main .column-header .cont .profile dl {
  margin-bottom: 5px;
}

#list .wrapper main .column-header .cont .profile dl dt {
  font-weight: bold;
  font-size: 19px;
}

#list .wrapper main .column-header .cont .profile dl dd {
  font-size: 8px;
}

#list .wrapper main .column-header .cont .profile .link a {
  display: inline-block;
  background: #F6A58A;
  text-decoration: none;
  color: #000;
  font-size: 10px;
  padding: 5px 15px;
  font-weight: bold;
  border-bottom: #9c9c9c 1px solid;
}

#list .wrapper main .column-header .profileBlock {
  background: #F4F4F4;
  font-size: 10px;
  padding: 5px;
}

#list .wrapper main section h1 {
  color: #fff;
  border-bottom: #000 4px solid;
  background: #E84D19 url(image/common/bg_h2.png);
  background-size: 5px 5px;
  padding: 10px;
  font-weight: bold;
  font-size: 13px;
  line-height: 100%;
  margin-bottom: 5px;
}

#list .wrapper main section nav.genre-nav {
  margin-bottom: 12px;
}

#list .wrapper main section nav.genre-nav div {
  border-top: #fff 1px solid;
  display: table;
  width: 100%;
  table-layout: fixed;
}

#list .wrapper main section nav.genre-nav div a {
  display: table-cell;
  text-align: center;
  vertical-align: middle;
  background: url(image/list/bg_gener_nav.png) no-repeat 100% 100%, -webkit-linear-gradient(270deg, #4d4d4d 0%, #3e3e3e 100%);
  background: url(image/list/bg_gener_nav.png) no-repeat 100% 100%, linear-gradient(180deg, #4d4d4d 0%, #3e3e3e 100%);
  border-bottom: #E94D19 3px solid;
  background-size: 10px 8px, auto auto;
  border-left: #fff 1px solid;
  color: #fff;
  text-decoration: none;
  height: 52px;
  line-height: 130%;
}

#list .wrapper main section nav.genre-nav div a:first-child {
  border-left: none;
}

#list .wrapper main section section {
  margin-bottom: 5px;
}

#list .wrapper main section section h2.column-ttl,
#author .wrapper main section section h2.column-ttl {
  background: #474747;
  border-bottom: #000000 4px solid;
  padding: 5px 10px;
  line-height: 100%;
  color: #fff;
  font-weight: bold;
}

#list .wrapper main section section header,
.users-wrap section h3 {
  background: #474747;
  padding: 8px 10px 5px;
  position: relative;
  line-height: 100%;
}

#list .wrapper main section section header a {
    display: block;
}

#list .wrapper main section section header h2,
.users-wrap section h3 {
  color: #fff;
  line-height: 100%;
  font-weight: bold;
}

#list .wrapper main section section header a,
.users-wrap section a {
  text-decoration: none;
}

#list .wrapper main section section header span {
  position: absolute;
  top: 8px;
  right: 5px;
  color: #fff;
  text-decoration: none;
  background: url(image/common/icon_arrow.png) no-repeat 100% 50%;
  background-size: 7px 11px;
  padding-right: 15px;
}

#list .wrapper main section section ul.genre-list li {
  border-bottom: #D4D4D4 1px solid;
}

#list .wrapper main section section ul.genre-list li.banner a {
  padding: 0;
}

#list .wrapper main section section ul.genre-list li.banner a img {
  display: block;
  margin: 0 auto;
}

#list .wrapper main section section ul.genre-list li a {
  display: block;
  text-decoration: none;
}

#list .wrapper main section section ul.genre-list li a .genre-list-wrap {
  display: table;
  width: 100%;
  padding: 2px;
  position: relative;
}

#list .wrapper main section section ul.genre-list li a figure, #list .wrapper main section section ul.genre-list li a .cont {
  display: table-cell;
  vertical-align: middle;
}

#list .wrapper main section section ul.genre-list li a figure {
  width: 1%;
}

#list .wrapper main section section ul.genre-list li a figure img {
  display: block;
}

#list .wrapper main section section ul.genre-list li a .cont {
  padding-left: 7px;
  font-size: 13px;
  margin-bottom: 0;
  padding-right: 7px;
}

#list .wrapper main section section ul.genre-list li a .cont .author-name {
  font-weight: normal;
  font-size: 12px;
}

#list .wrapper main section section ul.genre-list li a .cont .column-name {
  color: #D46D4C;
  font-size: 12px;
  font-weight: bold;
}

#list .wrapper main section section ul.genre-list li a .cont .column-name.authors {
  font-size: 15px;
}

#list .wrapper main section section ul.genre-list li a .cont p,
#list .wrapper main section section ul.genre-list li a .cont h2 {
    font-size: 15px;
    font-weight: bold;
    line-height: 130%;
}

#list .wrapper main section section ul.genre-list li a .cont p.detail-txt {
  font-weight: normal;
  font-size: 11px;
}
#list .wrapper main section section ul.genre-list li a .cont p span,
#list .wrapper main section section ul.genre-list li a .cont h2 span {
  display: inline-block;
  vertical-align: middle;
}

#list .wrapper main section section ul.genre-list li a .cont .date {
  font-size: 9px;
}

#list .wrapper main section ul.pageNate {
  margin-top: 12px;
}

#pict .wrapper main article header {
  border-top: #d4d4d4 1px solid;
  padding: 10px;
  padding-bottom: 5px;
  position: relative;
  background-color: black;
  color: white;
}

#pict .wrapper main article header h1 {
  font-size: 14px;
  font-weight: bold;
  margin-bottom: 10px;
  color: white;
}

#pict .wrapper main article header h1 .pay {
  display: inline-block;
  vertical-align: middle;
  margin-left: 5px;
}

#pict .wrapper main article header .date {
  text-align: right;
  margin-bottom: 0;
  font-size: 12px;
}

#pict .wrapper main article .pict-area {
  position: relative;
  width: 100%;
  margin-bottom: 5px;
  padding-bottom: 5px;
  background-color: black;
  color: white;
}

#pict .wrapper main article .pict-area ul {
  text-align: center;
  position: relative;
  width: 210px;
  margin: 0 auto;
}

#pict .wrapper main article .pict-area .pict {
  width: 100%;
}
.pict img {
  width: 98%;
  height: auto;
}

#pict .wrapper main article .pict-area .pict figure {
  display: table;
  text-align: center;
  margin: 0 auto;
}
#pict .wrapper main article .pict-area .pict figure a {
  display: table-cell;
  background: #ccc;
  text-align: center;
  vertical-align: middle;
  width: 250px;
  height: 250px;
}

#pict .wrapper main article .pict-area .pict p.caption {
  margin-top: 4px;
  font-size: 13px;
  text-align: center;
  margin-bottom: 10px;
  color: white;
  width: 98%;
}

#pict .wrapper main article .pict-area .prev,
#pict .wrapper main article .pict-area .next {
  position: absolute;
}

#pict .wrapper main article .pict-area .prev a,
#pict .wrapper main article .pict-area .next a {
  display: block;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  width: 17px;
  height: 28px;
}

#pict .wrapper main article .pict-area .prev {
  left: 5px;
  top: 38%;
  background: url(image/pict/icon_prev2.png) no-repeat;
  background-size: 17px 28px;
}

#pict .wrapper main article .pict-area .next {
  right: 5px;
  top: 38%;
  background: url(image/pict/icon_next2.png) no-repeat;
  background-size: 17px 28px;
}

#pict .wrapper main article .btn {
  text-align: center;
}

#pict .wrapper main article .btn a {
  display: inline-block;
  text-decoration: none;
  background: #292929;
  color: #fff;
  font-weight: bold;
  padding: 13px 0;
  min-width: 240px;
  line-height: 1;
}

#pict .wrapper main article ul.horizontal {
    text-align: center;
}
#pict .wrapper main article ul.horizontal li {
    display: inline-block;
    margin-right: 5px;
    width: 50px;
    height: 50px;
}
#pict .wrapper main article ul.horizontal img {
    height: auto;
    max-width: 100%;
    vertical-align: middle;
    border: 0px none;
}
#pict .wrapper main article ul.horizontal a {
    display: block;
}

#pict .wrapper main section.latest-pic-list {
  margin-bottom: 10px;
}

#pict .wrapper main section.latest-pic-list h2 {
  color: #fff;
  border-bottom: #000 4px solid;
  background: #E84D19 url(image/common/bg_h2.png);
  background-size: 5px 5px;
  padding: 10px;
  font-weight: bold;
  font-size: 13px;
  line-height: 100%;
  margin-bottom: 8px;
}

#pict .wrapper main .latest-pic-list ul {
  display: block;
  width: 100%;
  text-align: center;
}

#pict .wrapper main .latest-pic-list ul li {
  display: inline-block;
  width: calc(100% / 5 - 6px);
  line-height: 0;
  text-align: center;
  vertical-align: top;
  margin: 0 0 4px;
}

#pict .wrapper main .latest-pic-list ul li a {
  display: inline-block;
  margin: 0 auto;
}

#pict .wrapper main .latest-pic-list ul li a span {
  display: table-cell;
  width: 100%;
  vertical-align: middle;
  text-align: center;
  overflow: hidden;
}

#pict .wrapper main .latest-pic-list ul li a span img {
  width: 90px;
  max-width: 100%;
  height: auto;
  object-fit: contain;
}

#column .wrapper main section h1 {
  color: #fff;
  border-bottom: #000 4px solid;
  background: #E84D19 url(image/common/bg_h2.png);
  background-size: 5px 5px;
  padding: 10px;
  font-weight: bold;
  font-size: 13px;
  line-height: 100%;
  margin-bottom: 0;
}

#column .wrapper main section section {
  margin-bottom: 5px;
}

#column .wrapper main section section ul.column-list > li.accordion > a {
  border-top: #fff 1px solid;
  border-bottom: #969696 1px solid;
  text-decoration: none;
  background: #D7D7D7 url(image/common/icon_plus.png) no-repeat 95% 50%;
  background-size: 12px 12px;
  display: block;
  color: #000;
  padding: 15px;
  font-weight: bold;
}

#column .wrapper main section section ul.column-list > li.accordion > a.expand {
  background: #D7D7D7 url(image/common/icon_minus.png) no-repeat 95% 50%;
  background-size: 12px 12px;
}

#column .wrapper main section section ul.genre-list {
  display: none;
}

#column .wrapper main section section ul.genre-list li {
  border-bottom: #D4D4D4 1px solid;
}

#column .wrapper main section section ul.genre-list li.banner a {
  padding: 0;
}

#column .wrapper main section section ul.genre-list li.banner a img {
  display: block;
  margin: 0 auto;
}

#column .wrapper main section section ul.genre-list li a {
  display: block;
  text-decoration: none;
}

#column .wrapper main section section ul.genre-list li a .genre-list-wrap {
  display: table;
  width: 100%;
  padding: 2px;
  position: relative;
}

#column .wrapper main section section ul.genre-list li a figure, #column .wrapper main section section ul.genre-list li a .cont {
  display: table-cell;
  vertical-align: middle;
}

#column .wrapper main section section ul.genre-list li a figure {
  width: 1%;
}

#column .wrapper main section section ul.genre-list li a figure img {
  display: block;
}

#column .wrapper main section section ul.genre-list li a .cont {
  padding-left: 7px;
  font-size: 13px;
  font-weight: bold;
  margin-bottom: 0;
}

#column .wrapper main section section ul.genre-list li a .cont .column-name {
  color: #D46D4C;
  font-size: 12px;
  font-weight: bold;
}

#column .wrapper main section section ul.genre-list li a .cont p {
  font-weight: bold;
  line-height: 130%;
}

#column .wrapper main section section ul.genre-list li a .cont p span {
  display: inline-block;
  vertical-align: middle;
  margin-left: 5px;
}

#column .wrapper main section section ul.genre-list li a .cont .date {
  font-size: 9px;
}

#column .wrapper main section section ul.genre-list li.btn {
  padding: 4px;
  background: #fff;
}

#column .wrapper main section section ul.genre-list li.btn a {
  display: block;
  background: #212121 url(image/common/icon_arrow.png) no-repeat 95% 50%;
  padding: 10px;
  color: #FFF;
  text-align: center;
  text-decoration: none;
  font-weight: bold;
  background-size: 7px 11px, auto auto;
}

#column .wrapper main section section ul.genre-list li.btn a.expand {
  background: url(image/common/icon_minus.png) no-repeat 95% 50%;
  background-size: 12px 12px;
}

#columnTopic .wrapper main article {
  border-top: #d4d4d4 1px solid;
}

#columnTopic .wrapper main article .column-header {
  background-size: 5px 6px;
  padding: 5px 10px;
  margin-bottom: 5px;
}

#columnTopic .wrapper main article .column-header h1 {
  font-weight: bold;
  margin-bottom: 6px;
  border-bottom: #9C9C9C 1px dotted;
  padding-bottom: 14px;
}

#columnTopic .wrapper main article .column-header .cont {
  display: table;
  width: 100%;
  border-bottom: #9C9C9C 1px dotted;
  margin-bottom: 1px;
}

#columnTopic .wrapper main article .column-header .cont figure, #columnTopic .wrapper main article .column-header .cont .profile {
  display: table-cell;
  vertical-align: middle;
  padding-bottom: 6px;
}

#columnTopic .wrapper main article .column-header .cont figure {
  width: 1%;
}

#columnTopic .wrapper main article .column-header .cont figure img {
    object-fit: contain;
    max-width: 130px;
    max-height: 130px;
}

#columnTopic .wrapper main article .column-header .cont .profile {
  padding-left: 13px;
}

#columnTopic .wrapper main article .column-header .cont .profile dl {
  margin-bottom: 5px;
}

#columnTopic .wrapper main article .column-header .cont .profile dl dt {
  font-weight: bold;
  font-size: 19px;
}

#columnTopic .wrapper main article .column-header .cont .profile .link {
  margin-bottom: 0;
}

#columnTopic .wrapper main article .column-header .cont .profile dl dd {
  font-size: 8px;
}

#columnTopic .wrapper main article .column-header .cont .profile .link a {
  display: inline-block;
  background: #F6A58A;
  text-decoration: none;
  color: #000;
  font-size: 10px;
  padding: 5px 15px;
  font-weight: bold;
  border-bottom: #9c9c9c 1px solid;
}

#columnTopic .wrapper main article .column-header .profileBlock {
  background: #F4F4F4;
  font-size: 10px;
  padding: 5px;
  margin-bottom: 0;
}

#columnTopic .wrapper main article header {
  background-size: 5px 6px;
  padding: 5px 10px;
  position: relative;
}

#columnTopic .wrapper main article header .column-name {
    font-size: 14px;
    margin-bottom: 0;
    padding-right: 4em;
}

#columnTopic .wrapper main article header .column-name a {
    text-decoration: none;
    color: #D46D4C;
    font-weight: bold;
}

#columnTopic .wrapper main article header h1 {
  font-weight: bold;
  margin-bottom: 10px;
  margin-top: 3px;
  font-size: 18px;
  line-height: 1.3;
}

#columnTopic .wrapper main article header:nth-of-type(2) h1 {
  font-size: 16px;
}

#columnTopic .wrapper main article header h1 .pay {
  display: inline-block;
  vertical-align: middle;
  margin-left: 5px;
}

#columnTopic .wrapper main article header .date {
  font-size: 12px;
  margin-top: -5px;
  margin-bottom: 5px;
  text-align: right;
  color: #878787;
}

#columnTopic .wrapper main article ul.social {
  text-align: left;
}

#columnTopic .wrapper main article ul.social.mb {
  margin-bottom: 0;
}

#columnTopic .wrapper main article ul.social li {
  display: inline-block;
  margin-left: 8px;
}

#columnTopic .wrapper main article ul.social li:first-child {
  margin-left: 0;
}

#columnTopic .wrapper main article ul.social li dl {
  vertical-align: middle;
  margin-bottom: 0;
}

#columnTopic .wrapper main article ul.social li dl dt {
  display: inline-block;
  vertical-align: top;
}

.article-cont2 figure.photo-box .expansion {
    display: inline-block;
    text-align: center;
    margin: 10px 0 0 0;
    background-color: silver;
}

.article-cont2 figure.photo-box .expansion span {
    display: inline-block;
    color: #000;
    padding: 10px 20px;
    font-size: 15px;
}

.users-wrap {
    margin-bottom: 25px;
}

.header-sns-button-list {
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    align-items: center;
}
.twitter-x-icon{
    background: #000;
    border-radius: 20%;
    padding: 4px;
    box-sizing: border-box;
}
.header-sns-button-list ul.social {
    margin-right: auto;
}
.header-sns-button-list div.free-onlynow {
    font-size: 12px;
    padding: 2px 8px;
    background: #B4DB00;
    color: #ffffff;
}
.header-sns-button-list div.icon-pr {
    font-size: 12px;
    margin-left: 8px;
    background-color: #999999;
    border-radius: 4px;
    color: #ffffff;
    text-decoration: none;
    padding: 4px;
    line-height: 1;
}

.vendor-banner {
    text-align: right;
    line-height: 0;
    padding-left: 10px;
    padding-right: 10px;
    margin-bottom: 10px;
}
.vendor-banner a {
    display: inline-block;
}
.vendor-banner img {
    height: 40px;
    width: auto;
}

#columnTopic .wrapper main article .article-cont {
  display: table;
  width: 100%;
  margin: 0 0 30px;
}

#columnTopic .wrapper main article .article-cont figure, #columnTopic .wrapper main article .article-cont .cont {
  display: table-cell;
  vertical-align: top;
}

#columnTopic .wrapper main article .article-cont figure {
  padding-left: 5px;
  width: 1%;
}

#columnTopic .wrapper main article .article-cont figure span {
  display: table-cell;
  background: #ccc;
  vertical-align: middle;
  text-align: center;
  width: 123px;
  height: 123px;
}

#columnTopic .wrapper main article .article-cont figure a {
  text-decoration: none;
  color: #000;
}

#columnTopic .wrapper main article .article-cont .cont {
  padding: 0 5px 0 15px;
}

#columnTopic .wrapper main article .article-cont2 {
  zoom: 1;
  margin: 0 0 30px;
}

#columnTopic .wrapper main article .article-cont2:before,
#columnTopic .wrapper main article .article-cont2:after {
  display: block;
  height: 0;
  visibility: hidden;
  content: "\0020";
}

#columnTopic .wrapper main article .article-cont2:after {
  clear: both;
}

.article-cont2 figure.photo-box {
  margin-right: 10px;
  margin-bottom: 15px;
  margin-left: 10px;
  width: auto;
  float: none;
  text-align: center;
}

.article-cont2 figure.photo-box span {
  display: block;
  vertical-align: middle;
  text-align: center;
  width: auto;
  height: auto;
}
.article-cont2 figure.photo-box a {
  text-decoration: none;
  color: #666;
}
.article-cont2 figure.photo-box a:hover {
  text-decoration: underline;
}

.article-cont2 figure.photo-box img {
  text-align: center;
  width: 100%;
  height: auto;
  max-width: 100%;
  max-height: 250px;
  object-fit: contain;
}

.article-cont2 figure.photo-box figcaption {
  margin-top: 5px;
  font-size: 10px;
  line-height: 130%;
}

.article-cont2 figure.photo-box-full {
  margin-right: 10px;
  margin-bottom: 15px;
  margin-left: 10px;
  max-width: 100%;
  height: auto;
  float: none;
  text-align: center;
}

.article-cont2 figure.photo-box-full span {
  display: block;
  vertical-align: middle;
  text-align: center;
  width: auto;
  height: auto;
}
.article-cont2 figure.photo-box-full a {
  text-decoration: none;
  color: #666;
}
.article-cont2 figure.photo-box-full a:hover {
  text-decoration: underline;
}

.article-cont2 figure.photo-box-full img {
  text-align: center;
  max-width: 100%;
  height: auto;
  object-fit: contain;
}

.article-cont2 figure.photo-box-full figcaption {
  margin-top: 5px;
  font-size: 10px;
  line-height: 130%;
}

#columnTopic .wrapper main article .article-cont2 .cont {
  padding: 0 5px 0 5px;
}

#columnTopic .wrapper main article .article-cont2 .cont p {
  font-size: 16.25px;
  line-height: 1.7;
  margin: 0;
}

#columnTopic .wrapper main article .article-cont2 .cont h2 {
  font-size: 16.25px;
  font-weight: bold;
  margin-bottom: 30px;
  display: flex;
  border-left: 18px solid #ea4d00;
  border-bottom: 1px solid #7e7e7e;
  padding: 0 0 0 9px;
  line-height: 1.5;
}

#columnTopic .wrapper main article .article-cont2 .cont p a {
    color: #D46D4C;
    text-decoration: underline;
}
#columnTopic .wrapper main article .article-cont2 .cont p a.tag-link {
    color: inherit;/* #000; */
    text-decoration: none;
    padding-bottom: 1px;
    border-bottom: 1px dashed;
}
#columnTopic .wrapper main article .article-cont2 .cont p .more-text {
    color: #EA4E19;
}

/* ボタン状リンク */
a.button-link {
    display: table;
    border: 1px solid #0aabff;
    border-radius: 4px;
    background-color: #0aabff;
    color: #ffffff !important;
    margin: 0 auto;
    padding: 10px;
    padding-left: 15px;
    float: initial;
    font-weight: bold;
    text-align: center;
    text-decoration: none !important;
    width: 80%;
    box-shadow: 0 4px 4px rgba(0,0,0,0.4);
}
a.button-link:hover {
    text-decoration: underline;
    box-shadow: 0 0 2px rgba(0,0,0,0.3);
}

/* 次ページ見出し */
.title-next-page {
    border: 1px solid #eb4e19;
    border-radius: 4px;
    background-color: #ffffff;
    margin: 0 auto;
    padding: 10px;
    padding-left: 15px;
    text-align: center;
    width: 80%;
    box-shadow: 0 4px 4px rgba(0,0,0,0.4);
    font-size: 16px;
}
.title-next-page a {
    text-decoration: none;
}
.title-next-page a .fixed-text {
    color: #000;
}
.title-next-page a .link-text {
    color: #eb4e19;
    font-weight: bold;
}
.title-next-page:hover {
    box-shadow: 0 0 2px rgba(0,0,0,0.3);
    cursor: pointer;
}
.title-next-page:hover a .link-text {
    text-decoration: underline;
}

/* 最新の記事詳細ページへのリンクのタブ化 */
.tab-wrap {
    margin-bottom: 10px;
}
.tab-header {
    margin-bottom: 0;
    border-bottom: 2px #eb4e19 solid;
    overflow-x: auto;
}
.tab-select {
    display: flex;
}
.tab-select li {
    margin-right: 1px;
}
.tab-select li a {
    display: inline-block;
    white-space: nowrap;
    color: #fff;
    background-color: #2a2a2a;
    transition: background-color .1s linear;
    font-size: 13px;
    padding: 10px;
    text-decoration: none;
}
.tab-select li.selected a {
    background-color: #eb4e19;
}
.tab-body ul li {
    font-size: 15px;
    font-weight: bold;
    line-height: 130%;
    margin-bottom: 0;
    border-bottom: #D4D4D4 1px solid;
    color: #000;
}
.tab-body ul li a {
    color: #000;
    padding: 10px;
    text-decoration: none;
    display: block;
}
.hidden {
    display: none !important;
}

#author .wrapper main section h1 {
  color: #fff;
  border-bottom: #000 4px solid;
  background: #E84D19 url(image/common/bg_h2.png);
  background-size: 5px 5px;
  padding: 10px;
  font-weight: bold;
  font-size: 13px;
  line-height: 100%;
  margin-bottom: 15px;
}

#author .wrapper main section section {
  margin-bottom: 15px;
}

#author .wrapper main section section nav {
  display: table;
  width: 100%;
  margin-bottom: 10px;
}

#author .wrapper main section section nav a {
  display: table-cell;
  text-align: center;
  background: #9E9E9E;
  color: #fff;
  font-size: 12px;
  text-decoration: none;
  padding: 10px 0;
  border-left: #fff 1px solid;
  font-weight: bold;
}

#author .wrapper main section section nav a:first-child {
  border-left: none;
}

#author .wrapper main section section nav a.current {
  background: #E94D19;
}

ul.authorList {
  width: 100%;
  margin-bottom: 10px;
}

ul.authorList li {
  float: left;
  text-align: center;
  width: 25%;
}

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

ul.authorList li dl dt {
    height: 75px;
    overflow: hidden;
    display: inline-block;
}

ul.authorList li dl dd {
  font-size: 10px;
}

ul.authorList img {
    width: 75px;
    height: 75px;
    object-fit: cover;
}

.sns-list-lead {
    font-size: 16px;
    font-weight: bold;
    padding: 0 5px;
    margin-top: 15px;
}
.sns-list{
    height: 24px;
    padding: 0 5px;
    margin-bottom: 15px;
}
.sns-list li{
    display: inline-block;
    margin-left: 10px;
}

.sns-list li:first-child {
    margin-left: 0;
}
.sns-list li a {
    text-decoration: none;
    color: #242424;
}
.sns-list li a:hover img{
    opacity: .8;
}

.sns-list li .fukidashi {
    display: inline-block;
    position: relative;
    height: 18px;
    min-width: 26px;
    padding: 0 5px 2px;
    top: -6px;
    right: -3px;
    font-size: 12px;
    background-color: #ffffff;
    border-radius: 3px;
    border: 1px solid #cccccc;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
}
.sns-list li .fukidashi:after {
    right: 100%;
    top: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
    border-color: rgba(255, 255, 255, 0);
    border-right-color: #cccccc;
    border-width: 5px;
    margin-top: -5px;
}

.external-link-area,
.relation-link-area {
    padding: 0 5px;
}
.external-link-area h2 {
    font-size: 16px;
    font-weight: bold;
    margin-bottom: 3px;
}
.external-link-area ul {
    border-bottom: 1px solid #cccccc;
    padding-left: 10px;
}
.external-link-area li {
    font-size: 16px;
    margin-bottom: 5px;
    background: url(../../img/sp/arrow-category.png) right 10px top 3px no-repeat;
}
.external-link-area li a {
    text-decoration: none;
    color: #D46D4C;
    width: calc(100% - 22px);
    display: inline-block;
}
.external-link-area li span.title {
    font-weight: bold;
}
.relation-link-area h2 {
    font-size: 16px;
    font-weight: bold;
}
.relation-link-area li {
    font-size: 15px;
    margin-top: 5px;
    margin-bottom: 3px;
    border-bottom: 1px solid #eeeeee;
    line-height: 20px;
    padding-bottom: 4px;
}
.relation-link-area li a {
    font-weight: 700;
    color: #006ccc;
    text-decoration: none;
}

/* top お知らせ */
.announce-link-area {
    min-height: 26px;
    background-color: #E92222;
    padding: 5px 0;
    overflow: hidden;
}
.announce-link-area ul {
    min-height: 26px;
    background-color: #b51b1b;
    width: auto;
    white-space: nowrap;
}
.announce-link-area li a {
    color: #fff;
    text-decoration: none;
    display: block;
    font-size: 12px;
    padding: 3px 5px;
}

/*テキスト揃え*/
.text-l {
    text-align: left!important;
}
.text-r {
    text-align: right!important;
}
.text-c {
    text-align: center!important;
}

/* 引用 */
.blockquote {
    padding: 0 5px;
}

/* パンくずリスト */
div.breadcrumbs {
    padding: 4px 2px;
    margin: 10px 0 0;
}
ul.breadcrumb li {
    display: inline;
    list-style-type: none;
}
ul.breadcrumb li a:hover {
}
ul.breadcrumb li:after {
    content: " > ";
}
ul.breadcrumb li:last-child:after {
    content: "";
}

/* category & keyword */
.m-keyword-list {
    margin-top: 20px;
    margin-bottom: 10px;
}
.category-list {
    border-bottom: 1px solid #D4D4D4;
    margin: 10px 0 0;
    padding-bottom: 3px;
}
.m-keyword-list h2 {
    margin-bottom: 10px;
    background-color: #f6f6f6;
    padding: 5px 10px 4px;
    font-weight: bold;
}
.category-list ul,
.m-keyword-list ul {
    display: flex;
    flex-wrap: wrap;
}
.category-list ul.e-padding,
.m-keyword-list ul.e-padding {
    padding: 0 10px;
}
.category-list li,
.m-keyword-list li {
    margin-right: 7px;
    margin-bottom: 7px;
}
.category-list li a,
.m-keyword-list li a {
    background: #f9f9f9;
    border: 1px solid #e7e7e7;
    padding: 5px 6px 4px;
    line-height: 1;
    white-space: nowrap;
    text-decoration: none;
    display: inline-block;
    border-radius: 4px;
    color: #242424;
}
.m-keyword-list li a {
    font-weight: bold;
}
.category-list li a:hover,
.m-keyword-list li a:hover {
    background: #EA4E19;
    color: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0);
}

/* footer カテゴリーリンク */
.footer-category {
    background-color: #818181;
    padding: 10px;
}
.footer-category dt {
    color: #ffffff;
    font-weight: bold;
}
.footer-category ul {
    display: flex;
    flex-wrap: wrap;
}
.footer-category ul li {
    box-sizing: border-box;
    line-height: 1;
    width: 50%;
    margin-top: 10px;
    display: flex;
    align-items: center;
}
.footer-category ul li::before {
    content: '-';
    color: #ffffff;
}
.footer-category ul li a {
    color: #ffffff;
    text-decoration: none;
    display: inline-block;
    width: 100%;
    padding-left: 5px;
}

/*================================================================================================
    additions.css
================================================================================================*/

.r5_hidden {
    display: none !important;
}

.table-top img {
    max-width: 70px;
}

.member_navi {
    width: 100%;
    margin-bottom: 30px;
}

.member_navi a{
    display: block;
}

.member_navi td {
    vertical-align: middle;
    padding: 10px;
    border-bottom: 1px solid #cacac9;
    font-weight: bold;
    background:  url("../../img/sp/arrow-category.png") no-repeat scroll right 10px center;
}

.member_navi td.toggle {
    background:none;
}

.member_navi td.toggle ul{
    margin: 0;
    padding: 0;
}

.member_navi td.toggle a.press {
    display: block;
    padding-right: 20px;
}

.member_navi  li {
    background: url("../../img/sp/arrow-category.png") no-repeat scroll right center;
    display: block;
    border-bottom: solid 1px #ccc;
}

.member_navi  li:last-child {
    border-bottom: none;
}

.service_list dt a {
    color:#fff;
}

.service_list dt {
    width:95px;
    padding:5px;
    margin-bottom: 5px;
    color:#fff;
    text-align:center;
}

.service_list dd {
    margin-bottom: 5px;
}

.plan_info {
    width: 100%;
    margin-bottom: 20px;
}

.plan_info th ,
.plan_info td {
    vertical-align: middle;
    padding: 10px 0 10px 0;
    border: 1px solid #cacac9;
}

.plan_info th {

    font-weight: bold;
    color: #fff;
    background:#526e83;
}

.plan_info td {
    text-align:center;
}

.plan_info td.link {
    background: url("../../img/sp/arrow-category.png") no-repeat;
    background-position: right 10px center;
}

.member_plan_info .service {
    width:100%;
    border-collapse: collapse;
}

.member_plan_info .service caption {
    display: block;
    width: 100%;
    color: #fff;
    font-size: 18px;
    background: #12356d;
}

.member_plan_info .service caption p {
    padding: 5px 10px;
}

.member_plan_info .service th,
.member_plan_info .service td {
    display:block;
    width:100%;
}

.member_plan_info .service th p,
.member_plan_info .service td p {
    padding:10px 8px;
    text-align: left;
    font-size: 16px;
}

.member_plan_info .service a.button {
    display: block;
    width: 100%;
    padding: 10px 0;
    font-weight: bold;
    font-size: 16px;
    text-indent: 8px;
}

.member_plan_info .first_month_info {
    padding: 0 6px;
    margin-left: 8px;
    color: #fff;
    font-size: 18px;
    background: #d3c246;
}

.users-table-parent {
    margin-top: 10px;
}

.users-table-parent .users-table-child {
    width: 100%;
    background: #cccccc;
    border-collapse: separate;
    border-spacing: 1px;
    clear: both;
}
.users-table-parent .users-table-child thead th {
    border: 1px solid #ffffff;
    background: #EA4E19;
    color: #ffffff;
}
.users-table-parent .users-table-child thead td {
    text-align: center;
    width: 27%;
    font-weight: bold;
    padding: 10px;
    border: 1px solid #ffffff;
    background: #EA4E19;
    color: #ffffff;
}
.users-table-parent .users-table-child tbody th {
    text-align: center;
    vertical-align: middle;
    border: 1px solid #ffffff;
    background: #E89E86;
    color: #ffffff;
    line-height: 1.3;
}
.users-table-parent .users-table-child tbody th.heading {
    background: #EA4E19;
    padding-top: 5px;
    padding-bottom: 5px;
}
.users-table-parent .users-table-child tbody th span {
    font-weight: bold;
}
.users-table-parent .users-table-child tbody td {
    background: #ffffff;
    padding: 10px;
    vertical-align: middle;
}
.users-table-parent .users-table-child tbody td strong {
    font-weight: bold;
}
.users-table-parent .users-table-child tbody td a {
    color: #EA4E19;
}

.users-table-parent .users-table-child-v2 th,
.users-table-parent .users-table-child-v2 td {
    padding:15px 8px;
}

.supplement {
    display: block;
    font-size: 11px;
}
.supplement-v2 {
    display: block;
    font-size: 11px;
}

.users-table-parent a.button,
.users-table-parent .active {
    display: inline-block;
    line-height: 1.2;
    text-align: center;
    background: #EA0019;
    color: #ffffff !important;
    padding: 5px 8px;
    border-radius: 5px;
}

.users-table-parent .active {
    background: #666666;
}

.users-table-parent a.button:hover {
    text-decoration: none;
    background: #EA4E19;
}

.users-table-parent .first_month_info {
    width: 60px;
    padding: 6px;
    margin: 0 auto;
    color: #fff;
    background: #d3c246;
}

.users-table-parent .servie_info {
    margin-bottom: 10px;
    padding: 5px;
    border-left: solid 10px #12356d;
    font-size:18px;
    font-weight:bold;
    color:#333;
    border-bottom:solid 1px #12356d
}

.info_subscription_stop .info p {
    position: relative;
    padding-left: 40px;
    margin-bottom: 15px;
}

.info_subscription_stop .info .first_letter {
    position: absolute;
    left: 0px;
    display: inilne-block;
    padding: 5px 10px;
    color: #fff;
    background: #ea4e19;
}

.info_subscription_stop .resign_button a {
    overflow: hidden;
    display: block;
    margin: 0 0 20px;
    border: solid 1px #ea4e19;
    color: #fff;
    font-size: 16px;
    line-height: 30px;
    text-align: center;
    background: #ea4e19;
}

.info_subscription_stop .resign_button a.first {
    color: #fff;
    background: #ea4e19;
}

.info_subscription_stop .resign_button a.second {
    color: #ea4e19;
    background: #fff;
}

.info_subscription_stop .resign_button a span {
    display: block;
    margin: 2px;
    border: 1px dotted;
}

.info_subscription_stop .sub_comparison {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 20px;
}

.info_subscription_stop .sub_comparison  th,
.info_subscription_stop .sub_comparison  td {
    padding: 10px;
    vertical-align: middle;
    text-align: center;
    border: solid 1px ;
    border-color: #ccc;
}

.info_subscription_stop .sub_comparison  th {
    color: #494949;
    background: #efefef;
}

.info_subscription_stop .sub_comparison  .th1 ,
.info_subscription_stop .sub_comparison  .th2 {
    font-size: 19px;
    font-weight: normal;
    color: #fff;
}

.info_subscription_stop .sub_comparison  .th1 {
    color: #2056a5;
    background: #fff;
}

.info_subscription_stop .sub_comparison  .th2 {
    color: #5b96c3;
    background: #fff;
}

.info_subscription_stop .sub_comparison_title {
    margin-bottom: 10px;
    padding-left :10px;
    border-bottom :1px solid #333;
    border-left : solid 10px #333;
    line-height: 30px;
    font-size: 20px;
}

.faq {
    margin-top: 10px;
}
.faq a {
    display: block;
}
.faq p a {
    display: inline;
    color: #EA4E19;
}
.faq .child {
    display: none;
    margin: 0 0 -1px;
    padding: 0;
    background: #fff;
    border: 1px solid #eaeaea;
}
.faq .child .toggle-menu {
    background: #eaeaea;
    color: #5e5e5e;
}
.faq .child .toggle-menu:hover {
    background: #d0d0d0;
}
.faq .child p {
    overflow-wrap: break-word;
}
.faq .child > li {
    margin: 4px 0;
    padding: 5px 16px;
    border-bottom: 1px dotted #dddddd;
}
.faq .child > li:last-child {
    border-bottom: 0;
}
.faq .child > li > p:first-child {
    font-weight: bold;
}

.switch .toggle-menu:after {
    position: absolute;
    top: 50%;
    right: 10px;
    margin-top: -0.6rem;
    content: '>';
    font-size: 1.4rem;
    font-weight: bold;
    -moz-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    -moz-transition: all, 0.25s, linear;
    -o-transition: all, 0.25s, linear;
    -webkit-transition: all, 0.25s, linear;
    transition: all, 0.25s, linear;
}
.switch .toggle-menu.active:after {
    -moz-transform: translate(0, 50%);
    -ms-transform: translate(0, 50%);
    -webkit-transform: translate(0, 50%);
    transform: translate(0, 50%);
    -moz-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg);
}

.toggle-menu {
    display: block;
    position: relative;
    margin: 1px 0 0;
    padding: 10px;
}
.source {
    margin: 0;
    padding: 30px 0 0;
}

.faq01 .toggle-menu {
    background: #0AABFF;
    color: #fff;
    cursor: pointer;
    font-weight: bold;
}
.faq01 .toggle-menu:hover {
    background: #088CCE;
    text-decoration: none;
}

.section-wrap {
    padding: 10px;
}

.annotation-list {
    text-indent: -2em;
    padding-left: 2em;
    margin-top: 5px;
}
.annotation-list li p {
    position: relative;
    margin-left: 40px;
    margin-bottom: 10px;
    line-height: 1.5;
}
.annotation-list li .first-letter {
    position: absolute;
    left: -50px;
}

.users-dl-list dt {
    font-weight: bold;
    font-size: 14px;
    padding: 10px 10px 5px 10px;
}
.users-dl-list dd {
    padding: 10px;
    overflow-wrap: break-word;
}

.users-ul-list li {
    font-weight: bold;
    padding: 10px;
}
.users-ul-list li span {
    font-weight: normal;
}

.users-submit,
.top-link {
    text-align: center;
    margin-top: 20px;
}
.users-submit input,
.users-submit a,
.top-link a {
    display: inline-block;
    border-radius: 3px;
    border: none;
    background-color: #EA0019;
    color: #ffffff;
    padding: 10px 10px;
    cursor: pointer;
    text-decoration: none;
    min-height: 21px;
}
.users-submit input.one-line,
.users-submit a.one-line,
.top-link a.one-line {
    vertical-align: bottom;
    padding-top: 20px;
    padding-bottom: 20px;
}
.users-submit button {
    border-radius: 3px;
    border: none;
    background-color: #999999;
    color: #ffffff;
    padding: 10px 30px;
    cursor: pointer;
    min-height: 43px;
}
.users-submit input:hover,
.users-submit a:hover,
.top-link a:hover {
    text-decoration: none !important;
    background-color: #EA4E19;
}

.your-info {
    font-size: 14px;
    font-weight: bold;
    padding: 10px;
}

.paid-features li {
    border-bottom: 1px dotted #cccccc;
    padding: 15px 10px;
}
.paid-features span {
    display: block;
    text-align: center;
}
.paid-features .features-title {
    font-weight: bold;
    font-size: 14px;
}
.paid-features .features-text {
}

.error-message {
    color: red;
    font-size: 0.9em;
}

/* YouTube埋め込み用 */
.article-cont2 .youtube-wrap {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    margin-bottom: 0;
}
.article-cont2 .youtube-wrap iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
}

div.policy.scroll {
    margin: 10px;
    height: 400px;
    overflow: scroll;
    background-color: #f6f6f6;
    border: dotted 1px #dfdfdf;
}
.policy h2 {
    font-weight: bold;
    margin-bottom: 10px;
}
.policy h3 {
    font-weight: bold;
}

.back-number {
    position: absolute;
    right: 10px;
    top: 5px;
    font-size: 12px;
    text-align: right;
    margin-bottom: 0px;
}
.back-number > a {
    text-decoration: none;
    color: #878787;
}

span.icon-pr.list {
    background-color: #999999;
    border-radius: 4px;
    color: #ffffff;
    text-decoration: none;
    padding: 0px 3px;
    margin-left: 2px;
    font-size: 10px;
    font-weight: normal;
    vertical-align: text-top !important;
    display: inline-block;
}

/* sitemap リンク */
.sitemap-wrap dl {
    border-bottom:#D4D4D4 1px solid;
    padding: 15px 10px;
}
.sitemap-wrap a {
    text-decoration: none;
}
.sitemap-wrap dt a {
    font-weight: bold;
}
.sitemap-wrap ul li a {
    display: inline-block;
    width: 100%;
    padding-left: 5px;
}
.sitemap-wrap ul {
    display: flex;
    flex-wrap: wrap;
}
.sitemap-wrap ul li {
    box-sizing: border-box;
    line-height: 1;
    width: 50%;
    margin-top: 10px;
    display: flex;
    align-items: center;
}
.sitemap-wrap ul li::before {
    content: '-';
}
.sitemap-caution {
    margin: 25px 0 0 0;
    text-align: center;
}

.latest {
    position: relative;
}
.latest::before {
    content: "NEW";
    position: absolute;
    top: 0px;
    left: 0px;
    border: 1px solid #c51822;
    padding: 0 2px;
    color: #c51822;
    background-color: #fff;
    border-radius: 3px;
    line-height: 1;
    vertical-align: middle;
    font-weight: bold;
}

/* 関連画像のギャラリー表示 */
.images_gallery-swiper {
    overflow: hidden;
}

#pict .wrapper main article .pict-area .swiper-button-next,
#pict .wrapper main article .pict-area .swiper-button-prev {
  position: absolute;
  display: block;
  width: 17px;
  height: 28px;
}

#pict .wrapper main article .pict-area .swiper-button-prev {
  left: 5px;
  top: 38%;
  background: url(image/pict/icon_prev2.png) no-repeat;
  background-size: 17px 28px;
}

#pict .wrapper main article .pict-area .swiper-button-next {
  right: 5px;
  top: 38%;
  background: url(image/pict/icon_next2.png) no-repeat;
  background-size: 17px 28px;
}

.images_thumbnail-wrapper {
    width: calc(100% - 8px);
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(70px, 1fr));
    grid-template-rows: auto;
    gap: 8px 8px;
    place-items: center;
    margin: 10px 0 20px 0;
    padding: 0 4px;
}

.images_thumbnail-wrapper .images_thumbnail {
    display: flex;
    flex-flow: row wrap;
    opacity: 1;
    cursor: pointer;
}

.images_thumbnail-wrapper .images_thumbnail-active {
    opacity: 0.4;
}

/* 画像詳細 */
.images-swiper {
    overflow: hidden;
}
.images-swiper .swiper-pagination-group {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 5px;
}
.images-swiper .swiper-pagination-group .swiper-button-prev,
.images-swiper .swiper-pagination-group .swiper-button-next {
    position: inherit;
    color: #fff;
    background-color: #303030;
    height: 24px;
    width: 48px;
    border-radius: 16px;
    text-align: center;
    margin: auto 0;
}
.images-swiper .swiper-pagination-group .swiper-pagination {
    position: inherit;
}
.images-swiper .swiper-pagination-group .swiper-pagination-bullet-active {
    background-color: #303030;
}
.swiper-button-prev:after, .swiper-rtl .swiper-button-next:after,
.swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
    content: none !important;
}

/* 記事コメント数 */
.icon-comment-wrapper {
    font-weight: 400;
    font-size: 14px;
    padding-left: 4px;
    display: inline-block;
}
img.icon-comment {
    display: inline-block;
    object-fit: contain;
    margin-right: 4px;
    width: 12px;
    height: 12px;
}
