@charset "UTF-8";

:root {
    --main-collor: #003089;
}

body {
    min-width: 1080px;
    font-size: 16px;
    line-height: 1.4;
}

a:hover {
    text-decoration: none;
}

.icon.arrow::before {
    color: #ffb320;
}

.no-break-word {
    display: inline-block;
}

.red {
    color: #ff0000;
    font-weight: bold;
}

.blue {
    color: #1208ff;
    font-weight: bold;
}

.section {
    margin-bottom: 60px;
}

.inner {
    padding: 0 30px;
}

.heading {
    margin-bottom: 24px;
    padding: 5px;
    background-color: var(--main-collor);
    color: #ffffff;
    font-size: 22px;
    text-align: center;
}

.ribbon {
    margin-bottom: 16px;
    padding: 5px 8px;
    border-left: 8px solid;
    color: #079ae8;
    font-size: 22px;
    font-weight: bold;
    line-height: 1.27;
}

/* `#comeback`が付いていたときに高さをpaddingで調整するので、borderの付け方を変更 */
.ribbon--comeback {
    position: relative;
    padding: 5px 8px 5px 16px;
    border-left: none;

    &:before {
        content: "";
        display: inline-block;
        position: absolute;
        bottom: 0;
        left: 0;
        width: 8px;
        height: 38px;
        background-color: #079ae8;
    }
}

.ribbon--comeback-position {
    margin-top: -80px;
    padding-top: 80px;
}

.icon:hover {
    text-decoration: underline;
}

.icon.yellow-arrow:before {
    content: '\f0a9';
    height: 6px;
    border-radius: 6px;
    background-color: #ffffff;
    color: #ffb320;
    line-height: 6px;
}

.content {
    position: relative;
    width: 1080px;
    margin: 0 auto;
    padding: 0 60px;
    overflow: hidden;
    background: #ffffff;
    color: #000000;
}

.header {
    position: relative;
    overflow: hidden;
}

.key-visual {
    background-color: var(--main-collor);
}

.terms__detail {
    background-color: #ff8800;
}

.bet-count {
    background-color: var(--main-collor);
}

.bet-count__text {
    border-color: #ff8800;
}

.bet-count__text b {
    color: #ff8800
}

.sns-after-count-begin {
    position: relative;
    width: 960px;
    height: 36px;
    margin: 10px auto;
}

.sns-buttons {
    display: flex;
    position: absolute;
    top: 0;
    right: 0;
    gap: 10px;
}

.x-share,
.facebook-share,
.line-share {
    width: 36px;
    height: 36px;
}

.menu {
    height: 80px;
    overflow: hidden;
    background-color: #ffffff;
    text-align: center;
}

.menu .menu-content {
    position: relative;
    width: 960px;
    margin: 20px auto;
}

.menu .menu-content .link {
    display: inline-block;
    padding-top: 5px;
}

.menu .menu-content .link a {
    margin-right: 10px;
    padding-right: 10px;
    border-right: solid 1px #000000;
    color: #1208ff;
    font-size: 20px;
    font-weight: bold;
}

.menu .menu-content .link a:last-child {
    margin-right: 0;
    padding-right: 0;
    border-right: none;
}

.menu .menu-content .link a:hover {
    color: #7569ff;
    text-decoration: none;
}

.menu.menu--following {
    position: sticky;
    z-index: 5;
    top: 0;
    width: 100%;
    border-bottom: solid 1px #1208ff;
}

.abstract {
    position: relative;
}

.abstract__heading {
    margin-bottom: 16px;
    color: #ff8800;
    font-size: 18px;
    font-weight: bold;
}

.abstract-text {
    width: 600px;
    margin-bottom: 24px;
}

.abstract__chara {
    position: absolute;
    z-index: 2;
    top: 52px;
    right: 0;
    width: 268px;
    height: 293px;
}

.abstract__subhead {
    margin-bottom: 20px;
    padding-bottom: 4px;
    border-bottom: solid 1px #079ae8;
    font-size: 22px;
    font-weight: bold;
    text-align: center;
}

.prize-list {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    margin-bottom: 32px;
    gap: 8px;
}

.prize-detail {
    width: 150px;
    background-image: url('/v2/img/novel_cup/prize-leef-left.svg'), url('/v2/img/novel_cup/prize-leef-right.svg');
    background-repeat: no-repeat;
    background-position: left, right;
    background-size: contain;
    font-weight: bold;
    line-height: 1;
    text-align: center;
}

.prize-detail--grandprix {
    width: 300px;
    font-size: 20px;
}

.prize-name {
    margin-bottom: 4px;
    font-size: 1.5em;
    font-weight: bold;
}

.cushion {
    padding: 16px 42px 24px;
    background-color: #ffffe6;
}

.cushion__headline {
    margin-bottom: 16px;
    padding-bottom: 4px;
    border-bottom: solid 1px;
    color: var(--main-collor);
    font-size: 22px;
    font-weight: bold;
    line-height: 25px;
    text-align: center;
}

.cushion__info {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
}

.cushion__theme {
    width: calc(50% - 12px);
}

.cushion__title {
    margin-bottom: 8px;
    color: var(--main-collor);
    font-size: 22px;
    font-weight: bold;
    line-height: 1;
}

.explanation-header {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    padding: 5px 10px;
    border-width: 1px 1px 0;
    border-style: solid;
    color: #ffffff;
    font-size: 26px;
    font-weight: bold;
    gap: 0 24px;
}

.explanation-header.author {
    border-color: #079ae8;
    background-color: #079ae8;
}

.explanation-header.reader {
    border-color: #eb4598;
    background-color: #eb4598;
}

.explanation-header__sub {
    font-size: 22px;
    font-weight: normal;
}

.explanation-body {
    position: relative;
    margin-bottom: 24px;
    padding: 16px 30px;
    border-width: 1px;
    border-style: solid;
}

.explanation-body.author {
    border-color: #079ae8;
}

.explanation-body.reader {
    border-color: #eb4598;
}

.explanation-body.reader p {
    font-size: 20px;
    font-weight: bold;
    text-align: center;
}

.explanation-body b {
    font-size: 20px;
}

.rank-reward {
    position: relative;
    width: 568px;
    margin: 0 auto 60px;
}

.how-to-entry {
    margin-bottom: 16px;
    font-weight: bold;
}

.tag {
    font-weight: bold;
}

.explanation-bonustime {
    display: inline-block;
    position: relative;
    max-width: 580px;
    height: 284px;
    margin: 0 auto 0 24px;
    vertical-align: top;
}

.explanation-bonustime .indent {
    margin-top: 8px;
    margin-bottom: 16px;
    font-size: 14px;
}

.last-time-button {
    display: inline-block;
    padding: 12px 16px;
    border-radius: 7px;
    background-color: #1208ff;
    color: #ffffff;
}

.last-time-button:hover {
    opacity: 0.8;
    text-decoration: none;
}

.bonustime-image {
    position: absolute;
    top: 380px;
    right: 42px;
    width: 309px;
}

.bonustime-image__magnification {
    position: absolute;
    bottom: 45px;
    left: -110px;
    width: 130px;
}

.bonustime-image__annotation {
    position: absolute;
    bottom: 0;
    left: 20px;
    font-size: 10px;
}

.explanation-comeback {
    margin-left: 24px;
}

.explanation-comeback__wrap {
    margin-bottom: 24px;
}

.explanation-comeback__subhead {
    margin-bottom: 8px;
    font-weight: bold;
}

.comeback {
    text-align: center;
}

.comeback__button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 570px;
    height: 80px;
    margin-right: auto;
    margin-bottom: 8px;
    margin-left: auto;
    border-width: 0;
    background-color: #1208ff;
    color: white;
    font-size: 22px;
    font-weight: bold;

    &:hover {
        opacity: 0.8;
    }
}

.comeback__button--disabled {
    background-color: #b4b4b4;

    &:hover {
        opacity: 1;
    }
}

.comeback__hidden {
    display: none;
}

#afterCheck {
    font-size: 18px;
}

.sub-header {
    margin-top: 16px;
    margin-bottom: 32px;
}

.sub-header__speech-bubble {
    position: relative;
    bottom: 12px;
    left: 180px;
}

.sub-header__speech-bubble-text {
    position: absolute;
    z-index: 1;
    width: 144px;
    padding: 11px 0;
    color: #ffffff;
    font-size: 22px;
    font-weight: bold;
    line-height: 1;
    text-align: center;
}

.sub-header__speech-bubble-img {
    position: absolute;
}

.sub-header__text {
    padding-left: 152px;
    font-size: 22px;
    font-weight: bold;
    line-height: 1.15;
    text-align: center;
}

.explanation-body.reader .reader-bet {
    width: fit-content;
    margin: 0 auto 8px;
}

.entry-tag {
    margin-bottom: 12px;
    font-weight: bold;
}

#entry ul {
    margin-bottom: 16px;
}

#entry b {
    display: block;
    margin: 16px 0 8px;
    line-height: 1;
}

.entry-attention {
    color: #ff0000;
    font-weight: bold;
    text-decoration-line: underline;
}

.novel-post-button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 840px;
    max-width: 100%;
    height: 60px;
    margin: 24px auto 0;
    border: solid 3px rgba(255, 255, 255, 0.51);
    background-image: linear-gradient(to bottom, #ffb000, #ff6c00);
    color: #ffffff;
    font-size: 26px;
    font-weight: bold;
    text-align: center;
}

.novel-post-button:before {
    content: '';
    display: inline-block;
    width: 42px;
    height: 32px;
    margin-right: 5px;
    background: url('/v2/img/novel_cup/icon-novel.png') no-repeat;
    background-size: contain;
}

.novel-post-button:hover {
    opacity: 0.8;
}

#schedule {
    font-size: 14px;
}

#schedule .schedule-img {
    margin: 0 60px 16px;
}

#schedule .inner {
    padding: 0 60px;
}

#schedule .additional {
    display: block;
    margin-bottom: 10px;
    font-size: 16px;
    line-height: 1;
}

#schedule .ranking {
    margin-bottom: 24px;
}

#schedule .point {
    margin-top: 20px;
}

.published__ribbon {
    margin-bottom: 24px;
}

.past-prize {
    margin-bottom: 32px;
}

.past-prize__heading {
    display: block;
    margin-bottom: 20px;
    border-bottom: solid 1px #707070;
    text-align: center;
}

.published-simple-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 24px 16px;
    margin-bottom: 8px;
}

.published-simple {
    width: 198px;
}

.published-simple__prize {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 30px;
    margin-bottom: 8px;
    padding: 4px 8px;
    background-color: #079ae8;
    color: white;
    font-size: 15px;
    font-weight: bold;
}

.published-simple__prize--hidden {
    opacity: 0;
}

.published-simple__cover {
    display: inline-block;
    width: 100%;
    margin-bottom: 8px;
}

.published-simple__cover:hover {
    opacity: 0.8;
}

.published-simple__cover-image {
    width: inherit;
}

.result-button {
    display: block;
    width: 184px;
    margin-left: auto;
    padding: 8px 16px;
    border: solid 1px;
    border-radius: 7px;
    color: #1208ff;
    font-size: 14px;
    font-weight: bold;
    text-align: center;
}

.result-button:hover {
    opacity: 0.8;
    text-decoration: none;
}

#notice {
    font-size: 14px;
}

#notice .inner {
    margin-bottom: 0;
    padding: 0 60px;
}

#notice .inner div {
    margin-bottom: 24px;
}

#notice h3 {
    margin-bottom: 16px;
    padding: 4px;
    background-color: #ffffe6;
    color: var(--main-collor);
    text-align: center;
}

.banner {
    display: block;
    width: 735px;
    margin: 0 auto 60px;
}

.banner:hover {
    opacity: 0.8;
}

.dialog form ul {
    color: #707070;
}

.result .result-header:after,
.entries .ranking-header:after {
    height: 2px;
}

.result .award {
    border-color: #1f69b4;
}

.result .award.grand-prize .award-header {
    background-image: linear-gradient(to right, #a48305, #e5a63f);
}

.result .award .award-header {
    background-image: linear-gradient(to right, var(--main-collor), #0045ff);
}

.result .award .award-header > p > span {
    margin-left: 10px;
    font-size: 0.9rem;
}

.result .award .award-body > a:hover {
    text-decoration: underline;
}

.entries .paginator {
    color: #545454;
}

.entries .entry .info .title {
    font-size: 22px;
    line-height: 1.2;
}

.entries .entry .cheer-button a {
    font-size: 18px;
}

.footer {
    min-width: 1080px;
}
