.book-box {
    margin: 10px -20px 40px;
    position: relative;
}

.book-box .cover-box {
    position: relative;
}

.book-box .cover {
    display: block;
    width: 100%;
    background: #283257;
    overflow: hidden;
    position: relative;
}

.book-box .cover::before {
    content: "";
    display: block;
    padding-top: 45.3333333333%;
}

.book-box .cover>img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 0;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}

.book-box .cover::after {
    content: "";
    display: block;
    width: 100%;
    height: 50px;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0), #141a31);
    opacity: 1;
    pointer-events: none;
    position: absolute;
    bottom: 0;
    right: 0;
    left: 0;
}

.book-box .data {
    padding: 10px 20px 20px;
}

.book-box .book-head {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0 0 13px;
}

.book-box .book-locale {
    display: inline-block;
    padding: 1px 5px;
    border: 1px solid #6f90cA;
    border-radius: 3px;
    font-size: 14px;
    font-weight: 700;
    line-height: 1;
    color: #6f90cA;
}

.book-box .book-submit-type {
    font-size: 14px;
    font-weight: 700;
    line-height: 1;
}

.book-box .one-shot {
    color: #ff6262;
}

.book-box .series {
    color: #f0af30;
}

.book-box .completed {
    color: #3f9af4;
}

.book-box .title {
    margin: 0 40px 5px 0;
    font-size: 22px;
    font-weight: 700;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.2;
    color: #fff;
}

.book-box .author {
    margin: 0 0 10px;
    font-size: 14px;
    font-weight: 700;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.2;
    color: #6f90cA;
}

.book-box .info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    margin: 0 0 10px;
}

.book-box .count {
    display: flex;
}

.book-box .view-box {
    display: flex;
    align-items: center;
}

.book-box .view-icon {
    display: inline-block;
    vertical-align: middle;
    width: 18px;
    height: 15px;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    color: #3f9af4;
    position: relative;
}

.book-box .view-icon::before {
    content: "\e91f";
    font-family: icomoon;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    height: 14px;
    font-size: 14px;
    line-height: 1;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-indent: 0;
}

.book-box .view-count {
    display: inline-block;
    vertical-align: middle;
    padding-left: 5px;
    border: 0;
    background-color: transparent;
    font-size: 14px;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.5;
    color: #fff;
}

.book-box .like-box {
    display: flex;
    align-items: center;
    margin-left: 10px;
}

.book-box .like-icon {
    display: inline-block;
    vertical-align: middle;
    width: 16px;
    height: 16px;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    color: #3f9af4;
    position: relative;
}

.book-box .like-icon::before {
    content: "\e713";
    font-family: icomoon;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    height: 14px;
    font-size: 14px;
    line-height: 1;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-indent: 0;
}

.book-box .like-count {
    display: inline-block;
    vertical-align: middle;
    padding-left: 5px;
    border: 0;
    background-color: transparent;
    font-size: 14px;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.5;
    color: #fff;
}

.book-box .favorite-box {
    display: flex;
    align-items: center;
    margin-left: 10px;
}

.book-box .favorite-icon {
    display: inline-block;
    vertical-align: middle;
    width: 16px;
    height: 16px;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    color: #3f9af4;
    position: relative;
}

.book-box .favorite-icon::before {
    content: "\e721";
    font-family: icomoon;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    height: 16px;
    font-size: 15px;
    line-height: 1;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-indent: 0;
}

.book-box .favorite-count {
    display: inline-block;
    vertical-align: middle;
    padding-left: 5px;
    border: 0;
    background-color: transparent;
    font-size: 14px;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.5;
    color: #fff;
}

.book-box .comment-box {
    display: flex;
    align-items: center;
    margin-left: 10px;
}

.book-box .comment-icon {
    display: inline-block;
    vertical-align: middle;
    width: 15px;
    height: 15px;
    border: 0;
    padding: 0;
    color: #3f9af4;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    position: relative;
}

.book-box .comment-icon::before {
    content: "\e96a";
    font-family: mdbn-iconfont;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    height: 14px;
    font-size: 15px;
    line-height: 1;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-indent: 0;
}

.book-box .comment-count {
    display: inline-block;
    vertical-align: middle;
    padding-left: 5px;
    border: 0;
    background-color: transparent;
    font-size: 14px;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.5;
    color: #fff;
}

.book-box .more-button-wrap {
    display: block;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: -20px;
}

.book-box .more-button {
    display: block;
    background-color: transparent;
    padding: 0 15px 0 0;
    border: 0;
    font-size: 14px;
    font-weight: 700;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.5;
    color: #67adff;
    position: relative;
}

.book-box .more-button::after {
    content: "";
    display: block;
    width: 8px;
    height: 8px;
    margin: -2px 0 0;
    border-right: 2px solid #67adff;
    border-bottom: 2px solid #67adff;
    cursor: pointer;
    pointer-events: none;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%) rotate(45deg);
    z-index: 1;
}

.book-box .more-button.is-open::after {
    transform: translateY(-50%) rotate(-135deg);
    margin: 2px 0 0;
}

.book-box .author-follow {
    display: block;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: -90px;
}

.book-box .menu {
    display: block;
    width: 22px;
    height: 22px;
    padding: 0;
    border: 0;
    background-color: transparent;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    position: relative;
}

.book-box .menu::before {
    content: "\e653";
    font-family: icomoon;
    font-weight: normal;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 15px;
    line-height: 1;
    color: #6f90cA;
    text-indent: 0;
    transform: translate(-50%, -50%);
    position: absolute;
    top: 50%;
    left: 50%;
}

.book-box .more {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    padding: 0 20px;
    margin: 0 0 10px;
    position: relative;
}

.book-box .more-content {
    display: none;
    width: 100%;
}

.book-box .genre {
    display: block;
    margin: 0 0 10px;
}

.book-box .box-recommend {
    margin: 0 -20px 20px;
    background: #283257;
}

.book-box .recommend-text {
    padding: 10px;
    background: linear-gradient(90deg, #1F59EE 6.67%, #1F97EE 100%);
    font-size: 14px;
    font-weight: 700;
    line-height: 1.5;
    color: #fff;
    text-align: center;
    position: relative;
}

.book-box .icon-recommend {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    max-width: 375px;
    padding: 20px 10px;
    margin: 0 auto;
}

.book-box .recommend {
    flex-shrink: 0;
    width: 63px;
    position: relative;
    cursor: pointer;
    z-index: 0;
}

.book-box .recommend.on::before {
    content: "";
    width: 53px;
    height: 53px;
    border: 1.5px solid #6f90cA;
    border-image: linear-gradient(111.87deg, #4181CA 13.02%, #B3EDFF 39.27%, #4181CA 75.23%);
    border-image-slice: 1;
    position: absolute;
    top: 45%;
    left: 45%;
    transform: translate(-50%, -50%);
    z-index: -1;
}

.book-box .more-summary-button {
    display: none;
}

.book-box .list-update {
    font-size: 12px;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.5;
    color: #6f90cA;
}

.book-box .item-update {
    display: flex;
    align-items: flex-start;
}

.book-box .item-update dt {
    width: 10em;
}

.book-box .btn-report {
    display: inline-block;
    width: 100%;
    padding: 0;
    border: 0;
    background-color: transparent;
    margin: 0 0 20px;
    font-size: 14px;
    font-weight: 700;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 1.5;
    color: #67adff;
    text-align: right;
}

.book-box .btn-book-fav {
    display: block;
    width: 34px;
    height: 34px;
    padding: 0;
    margin: 0;
    border: 0;
    border-radius: 3px;
    background-color: #283257;
    text-align: center;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    position: absolute;
    right: 20px;
    bottom: -34px;
    transition-property: border, background-color, color;
    transition-duration: 0.3s;
    transition-timing-function: ease;
    transition-delay: 0s;
}

.book-box .btn-book-fav::after {
    content: "\e967";
    font-family: mdbn-iconfont;
    font-weight: normal;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 20px;
    line-height: 1;
    color: #f0af30;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-indent: 0;
}

.book-box .btn-book-fav.faved {
    border: 1px solid #f0af30;
    background-color: #f0af30;
    color: #fff;
}

.book-box .btn-book-fav.faved::after {
    content: "\e721";
    font-family: icomoon;
    color: #fff;
}

.book-box .btn-book-fav:disabled,
.book-box .btn-book-fav.disabled {
    border: 1px solid #283257 !important;
    background-color: #283257 !important;
    color: #6f90cA !important;
}

.book-box .btn-book-fav:disabled::after,
.book-box .btn-book-fav.disabled::after {
    color: #6f90cA !important;
}

.book-box .book-share {
    display: block;
    width: 100%;
    height: 36px;
    margin: 0 0 20px;
}

@media screen and (min-width: 1024px) {
    .book-box {
        padding: 0;
        margin: 0 0 20px;
    }

    .book-box .cover-box {
        width: 335px;
        margin: 0 auto 40px;
    }

    .book-box .cover {
        height: 335px;
        margin: 0 0 10px;
        position: relative;
    }

    .book-box .cover::before {
        content: "";
        display: block;
        padding-top: 100%;
    }

    .book-box .cover::after {
        content: none;
    }

    .book-box .data {
        display: flex;
        flex-direction: column;
        padding: 0;
    }

    .book-box .book-head {
        margin: 0 0 10px;
    }

    .book-box .book-locale {
        padding: 2px 7px;
        font-size: 16px;
    }

    .book-box .book-submit-type {
        font-size: 18px;
    }

    .book-box .title {
        margin: 0 0 10px;
        font-size: 26px;
    }

    .book-box .view-count,
    .book-box .like-count,
    .book-box .favorite-count,
    .book-box .comment-count {
        font-size: 16px;
    }

    .book-box .info {
        margin: 0 0 15px;
    }

    .book-box .more-button-wrap {
        display: none;
    }

    .book-box .genre-area {
        margin-right: 150px;
    }

    .book-box .btn-book-fav {
        width: 100%;
        height: auto;
        padding: 8px 10px;
        border: 1px solid #f0af30;
        background-color: transparent;
        font-size: 16px;
        font-weight: 700;
        line-height: 1.5;
        letter-spacing: 0.05em;
        color: #f0af30;
        text-indent: 0;
        position: relative;
        top: auto;
        right: auto;
        bottom: auto;
    }

    .book-box .btn-book-fav::after {
        left: auto;
        right: 15px;
        transform: translate(0, -50%);
    }

    body:not(.touch-device) .book-box .btn-book-fav:not(.faved):hover {
        background-color: #f0af30;
        color: #141a31;
    }

    body:not(.touch-device) .book-box .btn-book-fav:not(.faved):hover::after {
        color: #141a31;
    }

    .book-box .btn-book-fav.faved {
        border: 1px solid #3f9af4;
        background-color: #3f9af4;
    }

    .book-box .btn-book-fav.faved::after {
        content: "\e91b";
        font-family: mdbn-iconfont;
        font-size: 10px;
    }

    .book-box .more {
        padding: 0;
    }

    .book-box .more-content {
        display: contents;
    }

    .book-box .genre {
        order: -1;
        margin: 0 0 15px;
    }

    .book-box .summary {
        overflow: hidden;
        transition: height 0.3s ease 0s;
    }

    .book-box .summary.shrink {
        height: 67.5px;
    }

    .book-box .box-recommend {
        margin: 0 0 20px;
    }

    .book-box .recommend-text {
        font-size: 16px;
    }

    .book-box .more-summary-button {
        display: block;
        padding: 0;
        margin: -25px 0 20px auto;
        border: 0;
        background: transparent;
        font-size: 15px;
        font-weight: 700;
        line-height: 1.5;
        color: #67adff;
        text-align: right;
        position: relative;
        z-index: 0;
    }

    .book-box .more-summary-button::before {
        content: "";
        display: block;
        width: 148px;
        height: 100%;
        background: linear-gradient(to right, rgba(20, 26, 49, 0) 0%, #141a31 48.65%);
        filter: blur(10px);
        position: absolute;
        right: 0;
        bottom: 0;
        pointer-events: none;
        z-index: -1;
    }

    .book-box .thumb {
        width: 40px;
        height: 40px;
    }

    .book-box .list-update {
        font-size: 14px;
    }

    .book-box .btn-report {
        font-size: 15px;
    }
}

.mod-ct-series {
    margin: 0 -20px 20px;
}

@media screen and (min-width: 1024px) {
    .mod-ct-series {
        margin: 0 0 20px;
    }
}

.mod-item-series {
    display: block;
    background-color: #283257;
    position: relative;
}

.mod-item-series:not(:last-of-type) {
    border-bottom: 1px solid #3b5481;
}

.mod-item-series .lyt-image {
    display: flex;
    align-items: flex-start;
}

.mod-item-series .image-area {
    display: block;
    width: 86px;
    background: #283257;
    position: relative;
}

.mod-item-series .image-area::before {
    content: "";
    display: block;
    padding-top: 100%;
}

.mod-item-series .image {
    display: block;
    width: 100%;
    height: 100%;
    border: 0;
    opacity: 0.4;
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}

.mod-item-series .image>img {
    max-width: 100%;
    vertical-align: middle;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 0;
}

.mod-item-series .image>img.mod-no-image {
    width: 100% !important;
    padding: 0 10px;
    border: 1px solid #3b5481;
}

.mod-item-series .column {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 10px 0;
    margin-left: 12px;
    overflow: hidden;
}

.mod-item-series .grid {
    display: grid;
    grid-auto-flow: column dense;
    grid-auto-columns: 1fr;
    grid-auto-rows: 1fr;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto auto auto;
    grid-gap: 0 20px;
    grid-template-areas: "data count" "award award" "first first-update" "latest latest-update";
    width: 100%;
    padding-right: 40px;
}

.mod-item-series .data {
    grid-area: data;
    display: flex;
    flex-flow: row nowrap;
    align-items: center;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    word-wrap: normal;
}

.mod-item-series .number {
    display: block;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.2;
    color: #6f90cA;
}

.mod-item-series .new {
    display: block;
    padding: 2px 5px;
    margin-left: 5px;
    border-radius: 10px;
    background-color: #3f9af4;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    color: #fff;
}

.mod-item-series .award-area {
    grid-area: award;
    min-height: 18px;
}

.mod-item-series .award {
    display: block;
    font-size: 12px;
    font-weight: 400;
    line-height: 1.5;
    color: #f0af30;
}

.mod-item-series .info {
    display: flex;
    align-items: center;
    width: 100%;
}

.mod-item-series .count {
    grid-area: count;
    display: flex;
}

.mod-item-series .view-box {
    display: flex;
    align-items: center;
}

.mod-item-series .view-icon {
    display: inline-block;
    vertical-align: middle;
    width: 16px;
    height: 15px;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    color: #6f90cA;
    position: relative;
}

.mod-item-series .view-icon::before {
    content: "\e91f";
    font-family: icomoon;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    height: 12px;
    font-size: 12px;
    line-height: 1;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-indent: 0;
}

.mod-item-series .view-count {
    display: inline-block;
    vertical-align: middle;
    padding: 0 0 0 2px;
    border: 0;
    background-color: transparent;
    font-size: 12px;
    font-weight: 400;
    line-height: 1.5;
    color: #6f90cA;
}

.mod-item-series .like-box {
    display: flex;
    align-items: center;
    margin-left: 5px;
}

.mod-item-series .like-icon {
    display: inline-block;
    vertical-align: middle;
    width: 15px;
    height: 15px;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    color: #6f90cA;
    position: relative;
}

.mod-item-series .like-icon::before {
    content: "\e713";
    font-family: icomoon;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    height: 12px;
    font-size: 12px;
    line-height: 1;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-indent: 0;
}

.mod-item-series .like-count {
    display: inline-block;
    vertical-align: middle;
    padding: 0 0 0 2px;
    border: 0;
    background-color: transparent;
    font-size: 12px;
    font-weight: 400;
    line-height: 1.5;
    color: #6f90cA;
}

.mod-item-series .award-area {
    color: #f0af30;
}

.mod-item-series .first {
    grid-area: first;
}

.mod-item-series .first-update {
    grid-area: first-update;
}

.mod-item-series .latest {
    grid-area: latest;
}

.mod-item-series .latest-update {
    grid-area: latest-update;
}

.mod-item-series .first,
.mod-item-series .first-update,
.mod-item-series .latest,
.mod-item-series .latest-update {
    font-size: 12px;
    font-weight: 400;
    line-height: 1.2;
    color: #6f90cA;
}

.mod-item-series.unread .image {
    opacity: 1;
}

.mod-item-series.unread .number {
    color: #fff;
}

.mod-item-series.unread::after {
    display: none;
}

.mod-item-series::after {
    content: "\e91b";
    font-family: mdbn-iconfont;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 13px;
    line-height: 1;
    color: #6f90cA;
    position: absolute;
    top: 50%;
    right: 15px;
    transform: translate(0, -50%);
    text-indent: 0;
}

@media screen and (min-width: 1024px) {
    .mod-item-series {
        padding: 10px;
        transition: background-color 0.3s;
    }

    .mod-item-series .image-area {
        width: 90px;
        transition: transform 0.3s;
    }

    .mod-item-series .column {
        padding: 0;
        margin-left: 20px;
    }

    .mod-item-series .number {
        font-size: 18px;
    }

    .mod-item-series .grid {
        grid-gap: 0 40px;
    }

    .mod-item-series .new {
        padding: 2px 8px;
        font-size: 14px;
    }

    .mod-item-series .award-area {
        min-height: 21px;
        margin: 0 0 4px;
    }

    .mod-item-series .award {
        font-size: 14px;
    }

    .mod-item-series .first,
    .mod-item-series .first-update,
    .mod-item-series .latest,
    .mod-item-series .latest-update {
        font-size: 14px;
        line-height: 1.4;
    }

    .mod-item-series .like-box,
    .mod-item-series .favorite-box {
        margin-left: 15px;
    }

    .mod-item-series .view-count,
    .mod-item-series .like-count,
    .mod-item-series .favorite-count {
        font-size: 16px;
    }

    .mod-item-series::after {
        right: 30px;
    }

    .mod-item-series:hover {
        background-color: #141a31;
    }

    .mod-item-series:hover .image-area {
        transform: translate(-10px, 0);
    }
}

@media screen and (min-width: 1024px) {
    .book-contents {
        display: flex;
        flex-direction: row-reverse;
        justify-content: space-between;
        width: 100%;
        max-width: 1200px;
        margin: 80px auto 0;
    }

    .book-main {
        width: 36.2068965517%;
        max-width: 420px;
    }

    .book-side {
        width: 53.4482758621%;
        max-width: 620px;
    }

    .book-side .continue {
        max-width: 335px;
        margin: 0 auto 40px;
    }

}

.mod-btn-box {
    margin: 0 0 30px;
    text-align: center;
}

.mod-btn-send {
    display: block;
    width: 100%;
    max-width: 425px;
    padding: 10px;
    margin: 0 auto 20px;
    border: 1px solid #3f9af4;
    border-radius: 3px;
    background-color: #3f9af4;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: 0.05em;
    color: #fff;
    text-align: center;
    position: relative;
    transition: opacity 0.3s ease 0s;
}

@media screen and (min-width: 1024px) {
    .mod-btn-send {
        padding: 10px;
        font-size: 16px;
    }
}

.mod-btn-send:disabled {
    border: 1px solid #283257;
    background-color: #283257;
    color: #6f90cA;
}

.mod-btn-send.dark:disabled {
    border: 1px solid #3b5481;
    background-color: #283257;
    color: #6f90cA;
}

.mod-btn-send:hover {
    opacity: 0.5;
}

@media screen and (min-width: 1024px) {
    .mod-visible-sp {
        display: none;
    }

    .mod-visible-pc {
        display: inherit;
    }
}

.mod-label-prize {
    display: block;
    width: 100%;
    max-width: 420px;
    padding: 8px 10px 8px 40px;
    margin: 0 0 15px;
    border-radius: 3px;
    background-color: #3f9af4;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.2;
    color: #fff;
    position: relative;
}

.mod-label-prize::before {
    content: "\e943";
    font-family: icomoon;
    font-weight: normal;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 12px;
    line-height: 1;
    color: #fff;
    transform: translateY(-50%);
    position: absolute;
    top: 50%;
    left: 10px;
}

.mod-label-prize.type2 {
    background-color: #283257;
}

.mod-text {
    margin: 20px 0;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.5;
    color: #fff;
}

@media screen and (min-width: 1024px) {
    .mod-text {
        font-size: 15px;
    }

    .mod-text .label {
        font-size: 15px;
    }
}

.mod-text em {
    font-style: normal;
    color: #6f90cA;
}

.mod-text strong {
    font-weight: 700;
    color: #ff6262;
}

.mod-text a {
    color: #67adff;
    text-decoration: none;
}

.mod-text a:hover {
    color: #67adff;
}

.mod-text a.emphasis {
    font-weight: 700;
}

.mod-text a .icon-link {
    display: inline-block;
    width: 11px;
    height: 11px;
    margin-left: 4px;
    overflow: hidden;
}

.mod-text a .icon-link::before {
    content: "\e61b";
    font-family: icomoon;
    vertical-align: top;
    font-size: 11px;
    font-weight: 400;
    line-height: 1;
}

.mod-text .label {
    display: inline-block;
    vertical-align: middle;
    margin: 0 0 0 5px;
    font-size: 14px;
    font-weight: 700;
    color: #f43f4a;
    text-align: center;
}

.mod-btn-profile {
    display: flex;
    flex-flow: row nowrap;
    align-items: center;
    margin: 0 0 20px;
}

.mod-btn-profile .name-group {
    flex: 1;
    display: flex;
    flex-flow: row nowrap;
    align-items: center;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.2;
    color: #fff;
}

.mod-btn-profile .thumb {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    margin: 0 10px 0 0;
    border: 0;
    border-radius: 50%;
    background-color: #fff;
    position: relative;
}

.mod-btn-profile .thumb>img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 0;
    border-radius: 50%;
}

.mod-btn-profile .name {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.2;
    color: #fff;
    overflow-wrap: break-word;
    word-break: break-word;
}

.mod-btn-profile .btn-box {
    min-width: 115px;
    margin-left: 10px;
}

@media screen and (min-width: 1024px) {
    .mod-btn-profile .thumb {
        width: 40px;
        height: 40px;
    }
}

.btn-box {
    min-width: 115px;
    margin-left: 10px;
}

.mod-btn-follow {
    display: block;
    width: 100%;
    padding: 7px 32px 7px 15px;
    margin: 0 auto;
    border: 1px solid #f0af30;
    border-radius: 3px;
    background-color: transparent;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: 0.05em;
    color: #f0af30;
    text-align: center;
    cursor: pointer;
    position: relative;
    transition-property: border, background-color, color;
    transition-duration: 0.3s;
    transition-timing-function: ease;
    transition-delay: 0s;
}

@media screen and (min-width: 1024px) {
    .mod-btn-follow {
        font-size: 15px;
    }
}

.mod-btn-follow::after {
    content: "\e711";
    font-family: icomoon;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 18px;
    line-height: 1;
    position: absolute;
    top: 50%;
    right: 15px;
    transform: translate(0, -50%);
    text-indent: 0;
}

.mod-btn-follow:disabled,
.mod-btn-follow.disabled {
    border: 1px solid #283257;
    background-color: #283257;
    color: #6f90cA;
    opacity: 1;
    cursor: default;
}

.mod-btn-follow:not(:disabled):not(.disabled):not(.followed):hover {
    background-color: #f0af30;
    color: #141a31;
    outline: none;
}

.mod-btn-follow.followed {
    border: 1px solid #3f9af4;
    background-color: #3f9af4;
    color: #fff;
}

.mod-btn-follow.followed::after {
    content: "\e91b";
    font-family: mdbn-iconfont;
    font-size: 10px;
    right: 10px;
}

.mod-list-award {
    margin: 0 0 20px;
}

.mod-list-award .record {
    display: block;
    padding: 2px 0;
    border-bottom: 1px solid #fff;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.5;
    color: #fff;
}

.mod-list-award .record::before {
    content: "\e943";
    font-family: icomoon;
    font-weight: normal;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    display: inline-block;
    vertical-align: middle;
    height: 17px;
    padding-right: 5px;
    font-size: 14px;
    line-height: 1;
    color: #3f9af4;
}

.mod-list-award .record.no-icon::before {
    content: none;
}

.mod-list-award .item-record,
.mod-list-award .mom-award,
.mod-list-award .mom-rank,
.mod-list-award .contest-award {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 0;
}

.mod-list-award .item-record:not(:last-of-type),
.mod-list-award .mom-award:not(:last-of-type),
.mod-list-award .mom-rank:not(:last-of-type),
.mod-list-award .contest-award:not(:last-of-type) {
    border-bottom: 1px solid #3b5481;
}

@media screen and (min-width: 1024px) {

    .mod-list-award .item-record:not(:last-of-type),
    .mod-list-award .mom-award:not(:last-of-type),
    .mod-list-award .mom-rank:not(:last-of-type),
    .mod-list-award .contest-award:not(:last-of-type) {
        padding: 7px 0;
        border-bottom: 2px solid #3b5481;
    }
}

.mod-list-award .item-record dt,
.mod-list-award .mom-award dt,
.mod-list-award .mom-rank dt,
.mod-list-award .contest-award dt {
    font-size: 14px;
    font-weight: 700;
    line-height: 1.5;
    color: #6f90cA;
}

.mod-list-award .item-record dd,
.mod-list-award .mom-award dd,
.mod-list-award .mom-rank dd,
.mod-list-award .contest-award dd {
    display: block;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.5;
    color: #969696;
}

.mod-list-award .first,
.mod-list-award .gold {
    background: linear-gradient(90deg, #E8DE7E 4.64%, #FDFBA4 52.82%, #C9B447 105.19%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.mod-list-award .second,
.mod-list-award .silver {
    background: linear-gradient(90deg, #B3B3B3 0%, #E3E1E1 26.44%, #9D9C9C 65.07%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.mod-list-award .third,
.mod-list-award .bronze {
    background: linear-gradient(112.47deg, #EDBD90 2.71%, #D76642 69.22%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.mod-list-award .shueisha,
.mod-list-award .management {
    background: linear-gradient(111.87deg, #4181CA 13.02%, #B3EDFF 39.27%, #4181CA 75.23%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.mod-list-award .other-rank {
    color: #6f90cA;
}

@media screen and (min-width: 1024px) {
    .mod-list-award .record {
        padding: 4px 0;
        font-size: 18px;
    }

    .mod-list-award .item-record dt,
    .mod-list-award .mom-award dt,
    .mod-list-award .mom-rank dt,
    .mod-list-award .contest-award dt,
    .mod-list-award .item-record dd,
    .mod-list-award .mom-award dd,
    .mod-list-award .mom-rank dd,
    .mod-list-award .contest-award dd {
        font-size: 16px;
    }
}

.mod-btn-share {
    display: flex;
    justify-content: center;
    width: 100%;
    height: 100%;
    min-height: 36px;
    max-width: 500px;
    margin: 0 auto 20px;
}

.mod-btn-share>li {
    flex: 1;
    height: 100%;
    border-radius: 3px;
    overflow: hidden;
}

.mod-btn-share>li:not(:first-child) {
    margin-left: 10px;
}

.mod-btn-share>li>a {
    display: block;
    width: 100%;
    height: 100%;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    cursor: pointer;
    position: relative;
    transition: opacity 0.3s ease 0s;
}

.mod-btn-share>li>a::before {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-indent: 0;
}

.mod-btn-share>li>a.icon-reddit {
    background-color: #ff4500;
}

.mod-btn-share>li>a.icon-reddit::before {
    content: "\e91b";
    font-family: "icomoon";
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    display: block;
    font-size: 18px;
    line-height: 1;
    color: #fff;
}

@media screen and (min-width: 1024px) {
    .mod-btn-share>li>a.icon-reddit::before {
        font-size: 20px;
    }
}

.mod-btn-share>li>a.mdbn-icon-facebook {
    background-color: #3c568f;
}

.mod-btn-share>li>a.mdbn-icon-facebook::before {
    content: "\e95d";
    font-family: "mdbn-iconfont";
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    display: block;
    font-size: 18px;
    line-height: 1;
    color: #fff;
}

@media screen and (min-width: 1024px) {
    .mod-btn-share>li>a.mdbn-icon-facebook::before {
        font-size: 20px;
    }
}

.mod-btn-share>li>a.icon-tw {
    background-color: #37a6de;
}

.mod-btn-share>li>a.icon-tw::before {
    content: "\e699";
    font-family: "icomoon";
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    display: block;
    font-size: 18px;
    line-height: 1;
    color: #fff;
}

@media screen and (min-width: 1024px) {
    .mod-btn-share>li>a.icon-tw::before {
        font-size: 21px;
    }
}

.mod-tag-genre {
    display: block;
    margin: 0 -6px;
    font-size: 0;
}

@media screen and (min-width: 1024px) {
    .mod-tag-genre {
        margin: 0 -6px 5px;
    }
}

.mod-tag-genre .tag-genre {
    display: inline-block;
    padding: 5px 8px;
    margin: 0 6px 10px;
    border-radius: 3px;
    background-color: #8c8c8c;
    /* Default: --color-others */
    font-size: 11px;
    font-weight: 700;
    line-height: 1;
    color: #fff;
    transition: background-color 0.3s ease 0s;
}

@media screen and (min-width: 1024px) {
    .mod-tag-genre .tag-genre {
        padding: 6px 10px;
        font-size: 14px;
    }
}

/* Genre-specific styles */
.mod-tag-genre .fantasy {
    background-color: #23cb14;
}

.mod-tag-genre .fantasy:hover {
    background-color: #118107;
}

.mod-tag-genre .action {
    background-color: #f43f4a;
}

.mod-tag-genre .action:hover {
    background-color: #af151e;
}

.mod-tag-genre .romance {
    background-color: #f43fe2;
}

.mod-tag-genre .romance:hover {
    background-color: #841378;
}

.mod-tag-genre .horror {
    background-color: #a651ea;
}

.mod-tag-genre .horror:hover {
    background-color: #5f06a5;
}

.mod-tag-genre .slice_of_life {
    background-color: #1cc1b7;
}

.mod-tag-genre .slice_of_life:hover {
    background-color: #0a7b74;
}

.mod-tag-genre .comedy {
    background-color: #f4963f;
}

.mod-tag-genre .comedy:hover {
    background-color: #984f0b;
}

.mod-tag-genre .sports {
    background-color: #a5bc1b;
}

.mod-tag-genre .sports:hover {
    background-color: #72830a;
}

.mod-tag-genre .sf {
    background-color: #587bf6;
}

.mod-tag-genre .sf:hover {
    background-color: #2544b1;
}

.mod-tag-genre .mystery {
    background-color: #b58235;
}

.mod-tag-genre .mystery:hover {
    background-color: #734a0c;
}

.mod-tag-genre .others {
    background-color: #8c8c8c;
}

.mod-tag-genre .others:hover {
    background-color: #5f5f5f;
}

@media screen and (max-width: 767px) {

    /* スマホ版のスタイル */
    .mod-container {
        margin-top: 30px;
        padding: 0 20px 30px;
    }
}

@media screen and (min-width: 768px) and (max-width: 1024px) {

    /* タブレット版のスタイル */
    .mod-container {
        margin: 30px auto 0 !important;
        padding: 0 20px 30px;
    }
}

@media screen and (min-width: 768px) {

    .mod-container {
        width: 100%;
        max-width: 1200px;
        margin: 0 auto;
        position: relative;
    }

    .mod-container.col2 {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }

    .mod-main-contents {
        width: 100%;
    }

    .mod-container.col2 .mod-main-contents {
        width: calc((840 / 1200) * 100%);
        max-width: 840px;
    }

    .mod-side-contents {
        width: calc((300 / 1200) * 100%);
        max-width: 300px;
    }
}