@charset "UTF-8";

:root {
    --main-collor: #00c9db;
    --accent: #ff3e9d;
    --content-background: #ffffff;
}

* {
    box-sizing: border-box;
}

*:before,
*:after {
    box-sizing: inherit;
}

html,
body,
p,
h1,
h2,
h3,
h4,
ul,
ol {
    margin: 0;
    padding: 0;
}

body {
    min-width: 1200px;
    background-color: #a1eefc;
    font-family: 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
    font-size: 16px;
    line-height: 1.4;
    font-feature-settings: 'palt';
    text-size-adjust: 100%;
}

ul {
    margin-left: 1em;
    list-style-position: outside;
}

img {
    max-width: 100%;
    vertical-align: top;
}

a {
    color: #1846de;
    text-decoration: none;
}

.result-header,
.underline-heading {
    width: fit-content;
    margin: 0 auto 36px;
    padding: 0 152px 7px;
    background-image: linear-gradient(to bottom, rgba(255, 255, 255, 0) 19px, rgba(0, 201, 219, 0.31) 19px);
    font-size: 34px;
    font-weight: bold;
    line-height: 1;
}

h3,
.ranking-header {
    margin-bottom: 16px;
    padding: 8px 0;
    border-top: solid 5px #c3f1f7;
    border-bottom: solid 5px #c3f1f7;
    color: #333333;
    font-size: 28px;
    font-weight: bold;
    line-height: 1;
    text-align: center;
}

h4 {
    margin-bottom: 16px;
    color: var(--accent);
    font-size: 22px;
    line-height: 1;
    text-align: center;
}

section.section:first-of-type {
    padding-top: 138px;
}

section.section {
    padding: 80px calc(50% - 480px);
}

.wrapper--after-count-begin section.section {
    margin-bottom: 32px;
    padding: 0;
}

.text-accent {
    color: #ff3e9d;
    font-weight: bold;
}

.heading-back-ribbon,
.award-header {
    display: flex;
    position: relative;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
    padding: 12px 32px;
    background: var(--accent);
    color: #ffffff;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.1;
    clip-path: polygon(0 0, 16px 50%, 0 100%, 100% 100%, calc(100% - 16px) 50%, 100% 0);
}

.award-header {
    margin-bottom: 24px;
    font-size: 30px;
}

.sns-buttons {
    display: flex;
    gap: 8px;
}

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

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

.tag {
    display: inline-block;
    margin-right: 5px;
    padding: 5px 10px;
    border: 1px solid #aaaaaa;
    border-radius: 20px;
    background-color: #ddfcff;
    font-size: 15px;
    font-weight: bold;
    line-height: 1;
}


.indent {
    padding-left: 1em;
    text-indent: -1em;
}

.icon {
    height: 100%;
    color: #2f57ff;
}

.icon.arrow {
    font-size: 14px;
}

.icon.pdf {
    font-size: 16px;
}

.icon:before {
    content: '';
    display: inline-block;
    font-family: FontAwesome, serif;
}

.icon.arrow:before {
    content: '\f0a9';
    margin-right: 2px;
    color: #a5a5a5;
}

.icon.pdf:before {
    content: url('/v2/img/novel_cup/icon-pdf.png');
}

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

.header {
    position: relative;
    margin-bottom: -208px;
    overflow: hidden;
}

.key-visual {
    background: #a1eefc;
}

.key-visual__image {
    width: 1458px;
    min-width: 1458px;
    height: 800px;
    margin: 0 calc(50% - 729px);
}

.sns-after-count-begin {
    position: absolute;
    top: 15px;
    left: calc(50% + 380px);
}

.content {
    position: relative;
    width: 100%;
    min-width: 1200px;
    margin: 0 auto;
    color: #333333;
    font-size: 16px;
}

.content--after-count-begin {
    padding-bottom: 32px;
    background-image: url('/v2/img/novel_cup/2407/background-pattern.webp');
    background-size: cover;
}

.terms {
    display: flex;
    position: absolute;
    top: -76px;
    justify-content: center;
    width: 100%;
    margin-top: 20px;
}

.terms__content {
    display: flex;
    justify-content: center;
    gap: 20px;
}

.terms__detail {
    padding: 10px 30px;
    background-color: var(--main-collor);
    color: #ffffff;
    font-size: 20px;
    font-weight: bold;
    line-height: 1;
}

.menu {
    margin-top: 16px;
    text-align: center;
}

.menu--following {
    position: sticky;
    z-index: 5;
    top: 0;
    width: 100%;
}

.menu__content {
    display: flex;
    position: relative;
    align-items: center;
    width: 960px;
    height: 60px;
    margin: 0 auto;
    padding: 0 30px;
    border-radius: 30px;
    opacity: 0.8;
    background-color: #ffffff;
}

.menu__link-wrap {
    display: flex;
    flex-grow: 1;
    justify-content: center;
    font-size: 20px;
}

.menu__link-wrap a {
    padding: 0 16px;
    color: #ff813e;
    font-weight: bold;
}

.menu__link-wrap a:not(:last-child) {
    border-right: solid 1px #000000;
}

.menu__link-wrap a:hover {
    color: var(--accent);
    text-decoration: none;
}

.bet-count {
    margin-top: 13px;
    padding: 15px 0;
    opacity: 0.8;
    background-color: #0093ff;
}

.bet-count__inner {
    width: 900px;
    margin: auto;
}

.bet-count__text {
    margin-bottom: 8px;
    padding-left: 5px;
    border-left: 11px solid #fff715;
    color: #ffffff;
    font-size: 18px;
    line-height: 1;
}

.bet-count__text--total {
    display: inline-block;
    float: left;
}

.bet-count__text--condition {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    float: right;
    gap: 0 20px;
}

.bet-count__text b {
    color: #fff715;
    font-size: 1.4em;
}

.bet-gauge {
    position: relative;
    width: 900px;
    padding: 12px 20px;
    clear: both;
    border-radius: 10px;
    background: #ffffff;
}

.bet-gauge__scale {
    display: block;
    width: 100%;
    margin: 0 auto;
}

.bet-gauge__bar-wrap {
    position: absolute;
    top: 36px;
    left: 61px;
    width: 800px;
    height: 26px;
    overflow: hidden;
    border-radius: 5px;
}

.bet-gauge__bar {
    max-width: 100%;
    height: 100%;
    transform-origin: left;
    transition: all 2s;
    background-image: linear-gradient(to right, #feb2d4, #ff439b);
    background-repeat: no-repeat;
    background-size: 800px;
    text-align: right;
}

.bet-count__about-bet {
    padding-top: 7px;
    font-size: 12px;
    font-weight: bold;
    text-align: right;
}

.bet-count__about-bet a {
    color: #ffffff;
}

.wrapper--after-count-begin {
    width: 960px;
    margin: 0 auto;
    padding-top: 48px;
}

.tabs {
    display: flex;
    margin-bottom: 20px;
}

.tab {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50%;
    height: 50px;
    transition: background 0.5s;
    background: #efefef;
    font-weight: bold;
    cursor: pointer;
}

.tab:hover {
    background: #cccccc;
}

.tab.selected {
    position: relative;
    background: var(--accent);
    color: #ffffff;
}

.tab.selected:after {
    content: '';
    position: absolute;
    right: 0;
    bottom: -10px;
    left: 0;
    width: 0;
    height: 0;
    margin: auto;
    border-top: 10px solid var(--accent);
    border-right: 5px solid transparent;
    border-left: 5px solid transparent;
}

.my-contents {
    margin: 0 0 16px;
    padding: 20px 30px;
    border: none;
    border-radius: 20px;
    background-color: var(--content-background);
}

.my-contents .my-notes {
    margin-bottom: 10px;
    font-size: 18px;
    font-weight: bold;
}

.my-contents .my-notes .name {
    color: #ff8106;
}

.my-contents .bet-term-reminder {
    font-size: 12px;
    font-weight: bold;
    line-height: 27px;
}

.my-contents .my-content {
    margin-top: 10px;
    clear: both;
    overflow: hidden;
    border: 1px solid #d5d5d5;
}

.my-contents .my-content .bet-number {
    padding: 0 10px;
    float: left;
    background: #ff489d;
    color: #ffffff;
    font-size: 20px;
    font-weight: bold;
    line-height: 50px;
}

.my-contents .my-content .vote-content {
    display: flex;
    padding: 0 10px;
    font-weight: bold;
    line-height: 50px;
    white-space: nowrap;
}

.my-contents .my-content .entried {
    background: #fffcec;
}

.my-contents .my-content .entry.entried {
    padding: 10px;
}

.my-contents .my-content .canceled {
    background: #ece9e9;
}

.my-contents .my-content .title {
    flex-grow: 1;
    padding-right: 10px;
    overflow: hidden;
    font-weight: bold;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.my-contents .my-content .title a {
    color: #ff813e;
}

.my-contents .my-content .title a:hover {
    text-decoration: underline;
}

.my-contents .my-notes .name {
    color: var(--accent);
}

.my-contents .my-content .current-rank {
    padding-right: 10px;
    font-size: 16px;
    font-weight: bold;
}

.my-contents .my-content .current-bet {
    font-size: 16px;
    font-weight: bold;
}

.my-contents .my-content .current-bet b {
    color: #e80000;
}

.my-contents .my-content .current-rank b {
    color: var(--main-collor);
}

.login {
    margin-bottom: 20px;
    padding: 24px 20px;
    border: none;
    border-radius: 20px;
    background-color: var(--content-background);
}

.login form {
    display: flex;
    position: relative;
    flex-direction: column;
    justify-content: center;
    width: 752px;
    margin: 0 auto;
}

.login .input {
    display: flex;
    width: 100%;
    height: 40px;
}

.login label {
    display: flex;
    flex-grow: 1;
    align-items: center;
    font-size: 16px;
    font-weight: bold;
}

.login .email {
    margin-bottom: 10px;
}

.login .password {
    margin-bottom: 36px;
}

.login .input input {
    width: 600px;
    padding: 5px;
    border: 1px solid #d5d5d5;
    border-radius: 5px;
    background: #f5f5f5;
}

.login .submit {
    margin-bottom: 8px;
    text-align: center;
}

.login .submit input {
    width: 182px;
    padding: 18px 0;
    transition: background 0.3s;
    border: 1px solid #ff8a0c;
    background: #ffc343;
    color: #ffffff;
    font-size: 24px;
    font-weight: bold;
}

.login .submit input:hover {
    background: #ff8a0c;
    cursor: pointer;
}

.login .reminder,
.login .register {
    font-size: 14px;
    font-weight: bold;
}

.login .reminder {
    position: absolute;
    right: 0;
    bottom: 112px;
}

.login .register {
    text-align: center;
}

.login .icon {
    height: 100%;
    color: #ff813e;
    font-weight: normal;
}

.overlay {
    display: none;
    position: fixed;
    z-index: 10;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: opacity 0.5s;
    opacity: 0;
    background: rgba(0, 0, 0, 0.3);
}

.overlay.open {
    display: block;
    opacity: 1;
}

.dialog {
    display: none;
    opacity: 0;
}

.dialog.open {
    display: block;
    opacity: 1;
}

.dialog form {
    position: fixed;
    z-index: 20;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 400px;
    height: 400px;
    margin: auto;
    padding: 30px 30px 15px;
    overflow: auto;
    border-radius: 20px;
    background: #ffffff;
    font-size: 26px;
    text-align: center;
    white-space: normal;
}

.dialog form .close {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 30px;
    height: 30px;
    border-radius: 15px;
    background: #737373;
    cursor: pointer;
}

.dialog form .close:before,
.dialog form .close:after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 15px;
    height: 2px;
    margin: auto;
    background: #ffffff;
}

.dialog form .close:before {
    transform: rotate(-45deg);
}

.dialog form .close:after {
    transform: rotate(45deg);
}

.dialog form p {
    font-size: 20px;
}

.dialog form .title {
    padding: 20px 0;
}

.dialog form .vote-count {
    padding-bottom: 30px;
    color: #ff3d9d;
    font-weight: bold;
}

.dialog form .select-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding-bottom: 20px;
}

.dialog form .select-buttons button {
    width: 160px;
    padding: 0 40px;
    border: 1px solid #d5d5d5;
    background: #8f8f8f;
    color: #ffffff;
    font-size: 18px;
    line-height: 50px;
    cursor: pointer;
}

.dialog form .select-buttons button:hover {
    opacity: 0.8;
}

.dialog form button.submit {
    border-color: #d5d5d5;
    background: #ff489d;
}

.dialog form ul {
    clear: both;
    font-size: 14px;
    text-align: left;
}

.button-group {
    text-align: center;
}

.button-group .button {
    display: inline-block;
    box-sizing: border-box;
    width: 900px;
    max-width: 100%;
    height: 80px;
    padding-top: 12px;
    border: solid 3px rgba(255, 255, 255, 0.51);
}

.button-group .button:hover {
    opacity: 0.8;
    color: #ffffff;
    text-decoration: none;
}

.button-group .novel-button {
    background-image: linear-gradient(to bottom, #56ddb5, #06a27d);
    color: #ffffff;
    font-size: 30px;
    font-weight: bold;
}

.button-group .novel-button:before {
    content: ' ';
    display: inline-block;
    width: 62px;
    height: 52px;
    margin-right: 5px;
    background: url('/v2/img/novel_cup/icon-novel.png') no-repeat;
    background-size: contain;
    vertical-align: middle;
}

.next-bonustime {
    position: relative;
    padding: 32px;
    border-radius: 20px;
    background-color: #fffcb2;
    font-size: 30px;
    font-weight: bold;
    line-height: 1.2;
    text-align: center;
}

.next-bonustime b {
    color: var(--accent);
    font-size: 1.2em;
}

.bonustime {
    position: relative;
    margin-top: 20px;
    margin-bottom: 8px;
    border: 6px solid rgba(227, 194, 134, 0.8);
    border-radius: 20px;
    background-color: var(--content-background);
    box-shadow: 0 0 10px #ffffff;
}

.bonustime-now {
    position: relative;
    border-top-left-radius: 14px;
    border-top-right-radius: 14px;
    background: rgba(227, 194, 134, 0.8);
}

.bonustime-now:after {
    content: '順位\Aアップの\A大チャンス！';
    display: flex;
    position: absolute;
    top: -20px;
    right: -30px;
    align-items: center;
    justify-content: center;
    width: 130px;
    height: 130px;
    padding: 0 0 4px 2px;
    transform: rotate(10deg);
    border-radius: 50%;
    background-color: var(--accent);
    color: #ffffff;
    font-size: 19px;
    font-weight: bold;
    line-height: 1;
    text-align: center;
    white-space: pre;
}

.bonustime p {
    padding: 15px;
    color: inherit;
    font-size: 28px;
    font-weight: bold;
    line-height: 1.4;
    text-align: center;
}

.bonustime p b {
    color: var(--accent);
    font-size: 32px;
}

.what-is-bonus {
    margin-bottom: 16px;
    font-size: 14px;
    font-weight: bold;
    text-align: right;
}

.entries,
.award {
    margin-top: 20px;
    padding: 40px 80px 32px;
    border-radius: 20px;
    background-color: var(--content-background);
}

.entries .paginator {
    margin-top: 20px;
    text-align: center;
}

.entries .paginator .current,
.entries .paginator a {
    display: inline-block;
    width: 30px;
    margin-left: 6px;
    border: 1px solid #cccccc;
    color: #545454;
    line-height: 30px;
    text-align: center;
}

.entries .paginator .current {
    font-weight: bold;
}

.entries .entry {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -56px;
    padding: 20px 0;
    overflow: hidden;
    border-bottom: 1px solid #cccccc;
}

.entries .entry .info {
    display: flex;
    justify-content: space-between;
    width: 830px;
    float: left;
}

.entries .entry .info .content-info {
    max-width: 614px;
}

.entries .entry .info .content-tag {
    color: #ffffff;
    font-size: 11px;
    line-height: 20px;
    white-space: nowrap;
}

.entries .entry .info .content-tag span {
    display: inline-block;
    padding: 0 13px;
}

.entries .entry .info .content-tag.youth span {
    background: var(--main-collor);
}

.entries .rank {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 70px;
    margin-right: 8px;
    padding-top: 20px;
    font-weight: bold;
    gap: 16px;
}

.entries .rank .rank-number {
    color: #ff7805;
    font-size: 22px;
}

.entries .rank .rank-number--1,
.entries .rank .rank-number--2,
.entries .rank .rank-number--3 {
    display: block;
    width: 60px;
    height: 55px;
    padding-top: 27px;
    color: #ffffff;
    font-size: 15px;
    text-align: center;
    clip-path: polygon(15% 100%, 0 30%, 33% 45%, 50% 0, 67% 45%, 100% 30%, 85% 100%);
}

.entries .rank .rank-number--1:first-letter,
.entries .rank .rank-number--2:first-letter,
.entries .rank .rank-number--3:first-letter {
    font-size: 19px;
}

.entries .rank .rank-number--1 {
    background-color: #f4c349;
}

.entries .rank .rank-number--2 {
    background-color: #a8a8a8;
}

.entries .rank .rank-number--3 {
    background-color: #b1714f
}

.ranking-arrow {
    width: 25px;
    height: 25px;
}

.entries .entry .info .title {
    font-size: 20px;
    line-height: 24px;
    font-weight: bold;
    margin: 8px 0;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.entries .entry .info .author,
.entries .entry .info .favorite-and-count {
    font-size: 14px;
}

.entries .entry .bet {
    flex-grow: 1;
    padding-top: 24px;
    font-weight: bold;
    line-height: 1.3;
    text-align: right;
}

.entries .entry .bet .total-bonus-pt {
    font-size: 20px;
}

.entries .entry .bet .total-bonus-pt span {
    color: #e80000;
}

.entries .entry .bet .total-bet {
    font-size: 16px;
}

.entries .entry .bet .total-bet span {
    color: #ff489d;
    font-size: 20px;
}

.entries .entry .buttons {
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding: 6px 0 0 82px;
    gap: 8px;
}

.entries .entry .read-button {
    margin-right: auto;
}

.entries .entry .read-button,
.entries .entry .cheer-button,
.entries .entry .bet-button {
    width: fit-content;
}

.entries .entry .read-button a,
.entries .entry .cheer-button a,
.entries .entry .bet-button a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 170px;
    height: 50px;
    border-radius: 5px;
    color: #ffffff;
    font-size: 24px;
    font-weight: bold;
    line-height: 1;
    text-align: center;
    cursor: pointer;
}

.entries .entry .read-button a,
.entries .entry .read-button a:active {
    background: #ff813e;
}

.entries .entry .cheer-button a,
.entries .entry .cheer-button a:active {
    background: #000000;
    font-size: 19px;
}

.entries .entry .bet-button a,
.entries .entry .bet-button a:active {
    background: var(--accent);
}

.entries .entry .read-button a:active,
.entries .entry .cheer-button a:active,
.entries .entry .bet-button a:active {
    opacity: 0.8;
}

.aggregate {
    position: relative;
    margin-bottom: 137px;
    padding: 32px;
    border: 6px solid rgba(227, 194, 134, 0.8);
    border-radius: 20px;
    background-color: var(--content-background);
    font-size: 28px;
    font-weight: bold;
    line-height: 1.2;
    text-align: center;
}

.aggregate span {
    color: #e80000;
    font-size: 1.2em;
}

.inner {
    width: 100%;
    padding: 40px 80px;
    border-radius: 41px;
    background-color: rgba(255, 255, 255, 0.8);
}

.header-part {
    position: relative;
    z-index: 1;
    width: 100%;
    margin: 24px 0 -120px;
}

.wrapper--after-count-begin .header-part {
    margin-bottom: 16px;
}

.header-part .abstract-header,
.award__info {
    margin-bottom: 16px;
    color: #0011aa;
    font-size: 30px;
    font-weight: bold;
    line-height: 32px;
    text-align: center;
}

.award__info {
    margin-bottom: 16px;
    color: #0011aa;
    font-size: 30px;
    font-weight: bold;
    line-height: 1.07;
    text-align: center;
}

.header-part .abstract-text {
    width: 800px;
    margin: 0 auto;
    color: #333333;
    font-size: 16px;
}

.abstract {
    position: relative;
}

.abstract .image-grandprix {
    display: block;
    width: 520px;
    margin: 0 auto;
}

.abstract .image-grandprix + .indent {
    margin: 8px auto 32px;
    color: #000000;
    text-align: center;
}

.abstract .profile-image {
    width: 210px;
    float: right;
}

.abstract .profile-image .image-hiiragi {
    width: 210px;
    margin-bottom: 8px;
}

.abstract .profile-image .profile-link {
    display: flex;
}

.abstract .profile-image .profile-link a {
    margin-right: 8px;
}

.abstract .profile-image .profile-link a:hover {
    opacity: 0.8;
}

.abstract .profile-image .profile-link a:first-child {
    margin-left: 40px;
}

.abstract .profile-image .profile-link a:last-child {
    margin-right: 0;
}

.abstract .profile-image .profile-link a img {
    width: 38px;
}

.abstract .profile-text {
    width: 573px;
    color: #000000;
}

.abstract .profile-text div {
    margin-bottom: 16px;
}

.abstract .profile-text .accordion {
    position: relative;
    max-height: 60px;
    margin-bottom: 30px;
    overflow: hidden;
    cursor: pointer;
}

.abstract .profile-text .accordion:after {
    content: '▼もっと見る';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding-top: 20px;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0), #e9f7fc 50%);
    color: #ff813e;
    font-size: 14px;
    text-align: center;
}

.abstract .profile-text .accordion.opened {
    max-height: none;
    padding-bottom: 20px;
}

.abstract .profile-text .accordion.opened:after {
    content: '▲閉じる';
    background: none;
}

.abstract .youtube {
    width: 390px;
    height: 232px;
    margin: 0 auto 40px;
    clear: both;
}

.abstract .youtube iframe {
    width: 100%;
    height: 100%;
}

.abstract .image-prizes {
    display: block;
    width: 620px;
    margin: 16px auto;
}

.abstract .themes {
    position: relative;
    padding: 16px 24px;
    background-color: #ebf9ff;
}

.abstract .themes .headline {
    margin-bottom: 17px;
    padding-bottom: 4px;
    border-bottom: solid 1px #00a3d5;
    color: #00a3d5;
    font-size: 22px;
    font-weight: bold;
    line-height: 1;
    text-align: center;
}

.abstract .themes .info {
    display: flex;
    flex-wrap: wrap;
}

.abstract .themes .info .theme {
    width: calc(50% - 12px);
    margin-right: 24px;
    margin-bottom: 24px;
}

.abstract .themes .info .theme:nth-child(even) {
    margin-right: 0;
}

.abstract .themes .info .theme:last-child {
    margin-bottom: 0;
}

.abstract .themes .info .theme .title {
    padding-bottom: 5px;
    color: #00a3d5;
    font-size: 22px;
    font-weight: bold;
    line-height: 1;
}

.abstract .themes .info .theme:first-child .title {
    color: var(--accent);
}

.abstract .themes .info .theme:first-child .text {
    color: #000000;
}

.abstract .character {
    position: absolute;
    top: -90px;
    right: -194px;
}

.abstract .character .image-character {
    width: 226px;
}

.abstract .character .speech-bubble {
    position: relative;
    bottom: 332px;
    left: -56px;
    width: 190px;
}

.abstract .character .speech-bubble img {
    position: absolute;
}

.explanation .explanation-header {
    position: relative;
}

.explanation .explanation-header .upper-left {
    position: absolute;
}

.explanation .explanation-header .upper-left .speech-bubble {
    position: relative;
    bottom: 52px;
    left: -32px;
    width: 144px;
}

.explanation .explanation-header .upper-left .speech-bubble div {
    position: absolute;
    z-index: 1;
    width: 100%;
    padding: 11px 0;
    color: #ffffff;
    font-size: 22px;
    font-weight: bold;
    line-height: 1;
    text-align: center;
}

.explanation .explanation-header .upper-left .speech-bubble img {
    position: absolute;
}

.explanation .explanation-body .image-score {
    display: block;
    width: 620px;
    margin: 0 auto 16px;
}

.explanation .explanation-body .explanation-bonustime {
    width: 490px;
    margin-bottom: 130px;
    float: left;
}

.explanation .explanation-body .explanation-bonustime .how-to-entry {
    margin: 53px auto 16px;
    font-weight: bold;
    line-height: 28px;
}

.explanation .explanation-body .explanation-bonustime .large-text {
    margin-bottom: 12px;
    font-size: 20px;
    font-weight: bold;
}

.explanation .explanation-body .explanation-bonustime .indent {
    margin-bottom: 16px;
    font-size: 14px;
    line-height: 1;
}

.explanation .explanation-body .explanation-bonustime .last-cup {
    width: fit-content;
}

.explanation .explanation-body .explanation-bonustime .last-cup a {
    padding: 12px 111px;
    border-radius: 20px;
    background-color: #ff813e;
    color: #ffffff;
    font-weight: bold;
    line-height: 1;
}

.explanation .explanation-body .explanation-bonustime .last-cup a:hover {
    opacity: 0.8;
    text-decoration: none;
}

.explanation .explanation-body .bonustime-image {
    position: relative;
    float: right;
}

.explanation .explanation-body .bonustime-image img {
    width: 309px;
}

.explanation .explanation-body .bonustime-image p {
    position: absolute;
    bottom: 0;
    left: 20px;
    font-size: 10px;
}

.explanation .explanation-header.reader {
    margin-bottom: 24px;
    clear: both;
}

.explanation .explanation-body .sub-header .speech-bubble {
    position: relative;
    bottom: 12px;
    left: 136px;
}

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

.explanation .explanation-body .sub-header .speech-bubble img {
    position: absolute;
}

.explanation .explanation-body .sub-header h4 {
    margin-bottom: 32px;
    padding-left: 170px;
}

.explanation .explanation-body.reader .large-text {
    margin-bottom: 8px;
    font-size: 20px;
    font-weight: bold;
    text-align: center;
}

.explanation .explanation-body .image-score-by-bet {
    width: 100%;
}

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

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

.entry ul .text-accent {
    text-decoration: underline;
}

.entry .indent {
    margin-bottom: 16px;
    color: #000000;
}

.entry .what-is-tag {
    margin-bottom: 8px;
    font-weight: bold;
    line-height: 1;
}

.entry .button-post {
    margin: 16px auto 0;
    text-align: center;
}

.entry .button-post .button,
.login .submit input {
    display: inline-block;
    width: 100%;
    padding: 22px 0;
    background-color: #ff813e;
    color: #ffffff;
    font-size: 26px;
    font-weight: bold;
    line-height: 1;
}

.login .email {
    margin-bottom: 24px;
}

.login .submit input {
    width: 300px;
    font-size: 20px;
}

.entry .button-post .button:hover,
.login .submit input:hover {
    opacity: 0.8;
    text-decoration: none;
}

.entry .schedule {
    margin-top: 32px;
}

.entry .image-schedule {
    width: 100%;
}

.notice h3 {
    padding: 7px 0;
    border: none;
    background-color: #f2f2f2;
    color: #666666;
    font-size: 16px;
}

.notice div:not(:last-child) {
    margin-bottom: 24px;
}

.notice p {
    font-size: 14px;
}

.notice ul {
    font-size: 14px;
}

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

.notice .banner:hover {
    opacity: 0.8;
}

.award {
    position: relative;
}

.decision {
    display: flex;
    position: absolute;
    top: 0;
    right: -28px;
    box-sizing: border-box;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 103px;
    height: 103px;
    border-radius: 50%;
    background-color: #00c9db;
    color: #ffffff;
    font-size: 20px;
    font-weight: bold;
}

.decision:before {
    content: '';
    position: absolute;
    bottom: 0;
    left: -5px;
    margin-top: -15px;
    transform: rotate(135deg);
    border: 8px solid transparent;
    border-left: 16px solid #00c9db;
}

.award-body .ranking-and-bet {
    display: flex;
    justify-content: right;
    padding: 10px 0;
    font-size: 16px;
    gap: 0 8px;
}

.award-body .ranking-and-bet .ranking:after {
    content: '/';
}

.award-content-title {
    color: #000000;
    font-size: 22px;
    font-weight: bold;
}

.award-content-title.none-of-content {
    text-align: center;
}

.award-author-name {
    color: #000000;
    font-size: 20px;
}

a.award-content-title:hover,
a.award-author-name:hover {
    color: inherit;
    text-decoration: underline;
}

.award-comment {
    width: 100%;
    margin-bottom: 16px;
}

.award-comment:last-child {
    margin-bottom: 0;
}

.award-comment__author {
    width: 100%;
    padding: 12px 20px;
    border-radius: 15px 15px 0 0;
    background: #9ce5f3;
    color: #333333;
    font-size: 20px;
    font-weight: bold;
}

.award-comment__author--guest {
    background: #707070;
    color: #ffffff;
}

.award-comment__text {
    position: relative;
    padding: 16px;
    border: solid 1px #acacac;
    border-top: none;
    border-radius: 0 0 15px 15px;
    font-size: 16px;
    gap: 16px;
}

.award-comment__image {
    float: right;
    width: 103px;
    height: 103px;
    margin-left: 8px;
}

.award__mv {
    padding: 16px;
    border-radius: 15px;
    background-color: #fffdcb;
    text-align: center;
}

.award__mv-text {
    margin-bottom: 16px;
    color: var(--accent);
    font-size: 30px;
    font-weight: bold;
    text-align: center;
    line-height: 1.07;
}

.award__mv-youtube {
    width: 390px;
    height: 232px;
}

.page-top-icon {
    position: fixed;
    z-index: 5;
    right: calc(50% - 572px);
    bottom: 10px;
    width: 110px;
    height: 110px;
    transition: all 0.5s;
}

.page-top-icon:hover {
    opacity: 0.7;
}

.message.error {
    margin-bottom: 20px;
    padding: 1em;
    border: solid 1px #fd8484;
    background: #ffdadc;
    color: #cc0000;
}

.footer {
    min-width: 1200px;
    padding: 20px 0;
    background: #000000;
    text-align: center;
}

.footer img {
    max-width: 100%;
}

.footer .copyright {
    padding-top: 10px;
    color: #eeeeee;
    font-size: 12px;
}
