@charset "utf-8";

html,
body {
    height: auto;
}

body {
    font-family: 'Noto Sans JP', sans-serif;
    font-family: 'Noto Serif JP', serif;
    font-size: 16px;
    line-height: 1.8em;
    color: #333333;
    /* text-shadow: 1px 2px 2px rgba(0, 0, 0, 0.3);*/
    -webkit-text-size-adjust: 100%;
}

.d {
    font-family: 'M PLUS Rounded 1c', sans-serif;
    transform: rotateZ(0.03deg);
}


/*
.wrap {
    background: url(../img/bg.png) repeat-y;
}
*/

.wrap {}

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

.mt {
    margin-top: 20px;
}

.mtx4 {
    margin-top: 80px;
}

.pt {
    padding-top: 20px;
}

.ptm {
    padding-top: 10px;
}

.ptx2 {
    padding-top: 40px;
}

.pb {
    padding-bottom: 20px;
}

.pbm {
    padding-bottom: 10px;
}

.pbx2 {
    padding-bottom: 40px;
}

.mb02 {
    margin-bottom: 20px;
}

.mb {
    margin-bottom: 40px;
}

.mbi {
    margin-bottom: 40px !important;
}

.mbx2 {
    margin-bottom: 40px;
}

.mbx3 {
    margin-bottom: 60px;
}

.mbx4 {
    margin-bottom: 80px;
}

.cen {
    text-align: center;
}

.rel {
    position: relative;
}

.pcpt {
    margin-top: -10px;
    padding-top: 0px;
    padding-bottom: 10px;
}

.pw {
    padding-left: 2%;
    padding-right: 2%;
    box-sizing: border-box;
}

.pw02 {
    padding-left: 6%;
    padding-right: 6%;
    box-sizing: border-box;
}

.ph100 {
    padding-top: 100px;
    padding-bottom: 100px;
    box-sizing: border-box;
}

.right {
    text-align: right;
}

.fontb {
    font-weight: bold;
}


/**Page Section*/

header {
    background-color: #000000;
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
    padding: 10px 0;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #ffffff;
}

header a {
    margin: 0 5%;
}

pre {
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.inner {
    width: 1000px;
    margin: 0 auto;
    position: relative;
}

.inner_big {
    width: 1200px;
    margin: 0 auto;
    position: relative;
}

.inner02 {
    width: 800px;
    margin: 0 auto;
    position: relative;
}

h1 {
    font-size: 16px;
    font-weight: normal;
}

h2 {
    width: 100%;
    color: #333333;
    font-size: 45px;
    font-weight: 800;
    line-height: 1.2em;
    display: inline-block;
}

h2 .sub {
    font-size: 30px;
    font-weight: 800;
    padding-bottom: 0px;
    display: inline-block;
}

.fontw {
    color: #ffffff;
}

.fonts {
    font-size: 80%;
}

.ttl {
    display: flex;
    justify-content: center;
}

.ttl img {
    margin: 2px 5px;
}

.nav {
    display: flex;
    justify-content: space-between;
}

.is-fixed {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    z-index: 99;
}

.nav li {
    width: 19%;
}

.nav li a {
    text-decoration: none;
    color: #ffffff;
    font-size: 19px;
    font-weight: 900;
    padding-bottom: 5px;
    border-bottom: 5px solid #ff0000;
    line-height: 1.0em;
    height: 30px;
    align-items: center;
    display: flex;
    justify-content: center;
}

.nav li:nth-child(1) > a {
    border-color: #fff600;
}

.nav li:nth-child(2) > a {
    border-color: #e8314f;
}

.nav li:nth-child(3) > a {
    border-color: #31c8e8;
}

.nav li:nth-child(4) > a {
    border-color: #2abd16;
}

.nav li:nth-child(5) > a {
    border-color: #a41ee2;
}

.footer-bnr {
    padding: 2% 0;
}

.footer-bnr ul {
    display: flex;
    justify-content: center;
}

.footer-bnr ul li {
    width: 38%;
    text-align: center;
}

footer {
    border-top: 0px solid #006cba;
    padding: 30px 0;
    background-color: #000000;
}

.copy {
    color: #ffffff;
    background: #345796;
}

.flexb {
    display: flex;
    justify-content: space-between;
}

.flexc {
    display: flex;
    justify-content: center;
}

.flexc.col04 {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    width: 77%;
    margin: 0 auto;
}

.flexc.col04 li {
    width: 22%;
    text-align: center;
}

#top_btn {
    position: fixed;
    right: 18%;
    bottom: 10%;
}

.w90 {
    width: 90%;
    margin: 0 auto;
}

.w70 {
    width: 70%;
    margin: 0 auto;
}

.w50 {
    width: 48%;
}

.w30 {
    width: 30%;
}

.youtube {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}

.youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
}

.twitter-tweet {
    border: 2px solid #e2b310;
    border-radius: 14px;
    box-shadow: 5px 5px 4px #33333355;
}

.twitter-tweet .r-y54riw {
    border: 0px;
}


/*contents*/

#main {
    background: url(../img/bg01.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: cover;
}

#main .bg {
    max-width: 1200px;
    overflow: hidden;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    background-size: cover;
    min-height: 460px;
}

#main .bg img {
    position: absolute;
    bottom: -15%;
    left: 0%;
}

#main .bg img#main_key01 {
    left: 29%;
    width: 40%;
    bottom: 15%;
    opacity: 0;
    transform: scale3d(.1, .1, 1);
    transform-origin: center;
    animation: zoom-animation1 .6s ease-out .2s 1 forwards;
}

#main .bg img#main_key02 {
    left: 5%;
    opacity: 0;
}

#main .bg img#main_key03 {
    left: 62%;
    opacity: 0;
}

#main .bg img#main_key04 {
    left: 41%;
    width: 17%;
    opacity: 0;
    bottom: 5%;
    filter: drop-shadow(4px 4px 2px #333);
    animation-duration: 0.8s;
}

#main .bg img#main_key01.fadein {
    opacity: 1;
}

@keyframes zoom-animation1 {
    0% {
        opacity: 0;
        transform: scale3d(.1, .1, 1)
    }

    50% {
        opacity: 1;
        transform: scale3d(1.2, 1.2, 1)
    }

    80% {
        transform: scale3d(.9, .9, 1)
    }

    to {
        opacity: 1;
        transform: scaleX(1)
    }
}

.fadein {
    animation-name: fadein;
    animation-duration: 0.5s;
    animation-fill-mode: forwards;
    opacity: 0;
}

@keyframes fadein {
    from {
        opacity: 0;
        transform: translateY(0px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

nav.global_nav {
    background-image: -moz-linear-gradient(90deg, rgb(245, 247, 250) 0%, rgb(195, 207, 226) 100%);
    background-image: -webkit-linear-gradient(90deg, rgb(245, 247, 250) 0%, rgb(195, 207, 226) 100%);
    background-image: -ms-linear-gradient(90deg, rgb(245, 247, 250) 0%, rgb(195, 207, 226) 100%);
}

nav.global_nav ul {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0;
}

nav.global_nav ul li {
    margin: 0 0px;
}


.final nav.global_nav ul {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 10px 0;
}

.final nav.global_nav ul li {
    margin: 0 6px;
}


/**SECTION*/

#sec01 {
    background: url(../img/bg02.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: cover;
}

#sec01 .inner {
    background: url(../img/sec01_bg01.jpg) no-repeat;
    background-position: bottom center;
    width: 1000px;
    height: 770px;
}

#sec01_box {
    border-style: solid;
    border-width: 4px;
    border-color: rgb(0, 0, 0);
    background-color: rgb(255, 255, 255);
    max-width: 800px;
    margin: 0 auto;
    position: relative;
}

#sec01_box p {
    z-index: 1;
    position: relative;
    padding-top: 15px;
    padding-bottom: 15px;
    font-size: 17px;
    font-weight: 800;
    margin-top: 0;
}

#sec01_box p span {
    background: linear-gradient(transparent 50%, rgba(255, 252, 107, .69) 50%);
}

#sec01_icon01 {
    position: absolute;
    top: 21%;
    width: 23%;
    left: 4%;
}

#sec01_icon02 {
    position: absolute;
    top: 24%;
    width: 19%;
    right: 4%;
}

#sec01_icon03 {
    position: absolute;
    bottom: 26%;
    width: 16%;
    left: 5%;
}

#sec01_icon04 {
    position: absolute;
    top: 62%;
    width: 23%;
    right: 4%;
}

#sec01_box img {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
}

#sec02 {
    background: url(../img/bg03-02.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: cover;
}

#sec02.sec02_02 {
    background: url(../img/20231207/bg03-02.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: cover;
}

#sec03 {
    background: url(../img/bg04.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: cover;
}

#sec03 .entrylist {
    flex-wrap: wrap;
    width: 90%;
    margin-left: auto;
    margin-right: auto;
}

#sec03 .entrylist li {
    width: 30%;
    margin-bottom: 40px;
}

#sec_names {
    background: url(../img/third_bg02.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: cover;
}

#sec_names ul li {
    width: 15%;
}

#sec04 {
    background: url(../img/bg05.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: 100% 100%;
}

#sec04.sec04_04 {
    background: url(../img/third_bg01.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: 100% 100%;
}

#sec05 {
    background: url(../img/bg06.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: cover;
}

#sec06 {
    background: url(../img/bg07.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: cover;
    z-index: 0;
}

#sec06icon01 {
    position: absolute;
    top: 34%;
    left: -5%;
    z-index: 1;
    width: 23%;
}

#sec06icon02 {
    position: absolute;
    top: 56%;
    left: 85%;
    z-index: 1;
}

#sec07 {
    background: url(../img/bg08.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: 100% 100%;
    z-index: 0;
}

#sec08 {
    background-image: url(../img/bg09.jpg);
    background-repeat: repeat;
    overflow: hidden;
    position: relative;
    z-index: 0;
}

#sec08_inner {
    background-image: url(../img/bg09over.png);
    background-position: center bottom;
    background-repeat: no-repeat;
    background-size: 100%;
    z-index: 1;
}

.txt03 {
    font-size: 20px;
    color: rgb(255, 255, 255);
    font-weight: bold;
    line-height: 2;
    text-align: center;
    text-shadow: 0px 0px 7px rgb(7 7 7);
}

.txt04 {
    font-size: 20px;
    color: rgb(255, 255, 255);
    font-weight: bold;
    line-height: 2;
    text-align: center;
    text-shadow: 4px 1px 5px rgb(62 58 54 / 95%);
}

#sec08 .title02 {
    font-size: 61px;
    color: rgb(254, 245, 227);
    font-weight: bold;
    line-height: 1.638;
    text-align: center;
    text-shadow: 9px -1.5px 7px rgb(2 20 132);
}

.box02 {
    border-style: solid;
    border-width: 7px;
    border-color: rgb(0, 0, 0);
    background-color: rgb(255, 255, 255);
}

.box02 .txt {
    font-size: 20px;
    font-weight: 800;
    line-height: 1.6em;
}

.box02 .txt02 {
    line-height: 2em;
    font-size: 30px;
    font-weight: 800;
}

.box02 .txt02 span {
    font-size: 42px;
    font-weight: 800;
}

.box02 .txt02 em {
    color: #f82bff;
    text-decoration: none;
    font-style: normal;
}

.box03 {
    background-color: rgb(255, 255, 255, 0.4);
    position: relative;
    border-radius: 10px;
    border-top: 35px solid #000000;
}

.box03 .title {
    top: -50px;
    font-size: 36px;
    color: #ffffff;
    text-align: center;
    position: absolute;
    width: 100%;
    text-shadow: 4px 4px 1px #000000, -4px 4px 1px #000000, 4px -4px 1px #000000, -4px -4px 1px #000000, 4px 0px 1px #000000, 0px 4px 1px #000000, -4px 0px 1px #000000, 0px -4px 1px #000000;
    font-weight: 900;
}

.box03 p {
    font-size: 25px;
    color: rgb(255, 255, 255);
    font-weight: bold;
    line-height: 2;
    text-align: center;
    text-shadow: 0px 2px 0px rgba(62, 58, 54, 0.88);
    -moz-transform: matrix(0.8004118851198, 0, 0, 0.8004118851198, 0, 0);
    -webkit-transform: matrix(0.8004118851198, 0, 0, 0.8004118851198, 0, 0);
    -ms-transform: matrix(0.8004118851198, 0, 0, 0.8004118851198, 0, 0);
}

.voice_box {
    background: url(../img/voice_bg.png) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: 100% 100%;
    height: 779px;
    padding-top: 222px;
    box-sizing: border-box;
    padding-left: 60px;
    padding-right: 60px;
    font-size: 19px;
    font-weight: 800;
    line-height: 1.8em;
}

.section_border {
    min-height: 25px;
    width: 100%;
    background: url(../img/border_bg01.png) repeat;
}

.acc01 {
    border-radius: 50px;
    background: #aa3a3c;
    color: #ffffff;
    display: inline-block;
    padding: 2px 30px;
}

#secound_sec01 {
    background: #76161b;
    display: flex;
    align-items: stretch;
    justify-content: center;

    background-image: -moz-linear-gradient(90deg, rgb(50, 0, 0) 0%, rgb(191, 0, 0) 100%);
    background-image: -webkit-linear-gradient(90deg, rgb(50, 0, 0) 0%, rgb(191, 0, 0) 100%);
    background-image: -ms-linear-gradient(90deg, rgb(50, 0, 0) 0%, rgb(191, 0, 0) 100%);
}

#secound_sec01 .left_bg {
    background: url(../img/secound_sec01_01.png);
    background-position: right;
    width: 100%;
    max-width: 400px;
    margin-left: auto;
}

#secound_sec01 .right_bg {
    background: url(../img/secound_sec01_02.png);
    background-position: left;
    width: 100%;
    max-width: 400px;
    margin-right: auto;
}

#secound_sec01 .inner {
    background-image: -moz-linear-gradient(90deg, rgb(0, 0, 0) 0%, rgb(255, 255, 255) 100%);
    background-image: -webkit-linear-gradient(90deg, rgb(0, 0, 0) 0%, rgb(255, 255, 255) 100%);
    background-image: -ms-linear-gradient(90deg, rgb(0, 0, 0) 0%, rgb(255, 255, 255) 100%);
    margin: 0;
    min-width: 1000px;
}

.ranking {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
}

.ranking article {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-bottom: 20px;
}

.ranking article .icon {
    margin-right: 20px;
    text-align: center;
    width: 150px;
}

.ranking article .books {
    width: 100%;
}

.ranking article .books .title {
    font-size: 34px;
    font-weight: 700;
    color: #ffffff;
    line-height: 1.2em;
}

.ranking article .books .author {
    font-size: 29px;
    font-weight: 700;
    color: #ffffff;
    padding-left: 0.6em;
    line-height: 1.2em;
    text-align: right;
}

.ranking article:first-child .title {
    font-size: 38px;
}

#secound_sec02 {
    background: url(../img/bg06.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: cover;
}

.ranking.fourth {
    font-size: 38px;
    font-weight: 700;
    color: #ffffff;
    line-height: 1.6em;
}

.ranking.fourth span {
    color: #ffec16;
}

#final_sec02 {
    background: url(../img/final/bg01.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: cover;
}

#final_sec03 {
    background: url(../img/final/bg02.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: 100% 100%;
}

#final_sec04 {
    background: url(../img/final/bg03.jpg) no-repeat;
    overflow: hidden;
    position: relative;
    background-size: cover;
}

.close {
    pointer-events: none;
    position: relative;
}

.close:after {
    content: "投票期間外です";
    width: 100%;
    height: 110px;
    background: rgba(0, 0, 0, 0.7);
    position: absolute;
    z-index: 2;
    display: flex;
    top: -10px;
    left: 0;
    padding: 10px 0;
    color: #ffffff;
    font-size: 45px;
    align-items: center;
    text-align: center;
    justify-content: center;
    font-family: 'Noto Sans JP', sans-serif;
}

.close02 {
    pointer-events: none;
    position: relative;
}

.close02:after {
    content: "プレゼントは終了しました";
    width: 100%;
    height: 450px;
    background: rgba(0, 0, 0, 0.7);
    position: absolute;
    z-index: 2;
    display: flex;
    top: -10px;
    left: 0;
    padding: 10px 0;
    color: #ffffff;
    font-size: 45px;
    align-items: center;
    text-align: center;
    justify-content: center;
    font-family: 'Noto Sans JP', sans-serif;
}


.close03 {
    pointer-events: none;
    position: relative;
}

.close03:after {
    content: "プレゼントは終了しました";
    width: 100%;
    height: 565px;
    background: rgba(0, 0, 0, 0.7);
    position: absolute;
    z-index: 2;
    display: flex;
    top: -10px;
    left: 0;
    padding: 10px 0;
    color: #ffffff;
    font-size: 45px;
    align-items: center;
    text-align: center;
    justify-content: center;
    font-family: 'Noto Sans JP', sans-serif;
}

/*==================================================
スライダーのためのcss
===================================*/

.slider {
    width: 100%;
    margin: 0 auto;
}

.slider .sliderimg {
    width: 60vw;
    /*スライダー内の画像を60vwにしてレスポンシブ化*/
    height: auto;
}

.slider .slick-slide {
    transform: scale(0.85);
    /*左右の画像のサイズを80%に*/
    transition: all .5s;
    /*拡大や透過のアニメーションを0.5秒で行う*/
    opacity: 1;
    /*透過50%*/
}

.slider .slick-slide.slick-center {
    transform: scale(1);
    /*中央の画像のサイズだけ等倍に*/
    opacity: 1;
    /*透過なし*/
}

.slick-slide img {
    display: block;
    text-align: center;
    margin: 0 auto;
}


/*戻る、次へ矢印の位置*/

.slick-prev,
.slick-next {
    position: absolute;
    top: 42%;
    cursor: pointer;
    outline: none;
    height: 15px;
    width: 15px;
}

.slick-prev {
    left: 18%;
    color: transparent;
    z-index: 2;
}

.slick-next {
    right: 19%;
    color: transparent;
    z-index: 2;
}

.slick-next:before {
    content: '▶';
    color: #fb6181;
}

.slick-prev:before {
    content: '◀';
    color: #fb6181;
}

.sec02_02 .slick-next:before {
    content: '▶';
    color: #0cff00;
}

.sec02_02 .slick-prev:before {
    content: '◀';
    color: #0cff00;
}

.slick-prev:before,
.slick-next:before {
    font-family: 'slick';
    font-size: 47px;
    line-height: 1;
    opacity: .75;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.overlayclick {
    cursor: pointer;
}

.overlayclick:hover {
    opacity: 1;
    -webkit-animation: flash 1.5s;
    animation: flash 1.5s;
}

.voice_q {
    background: #530808;
    color: #ffffff;
    padding: 10px;
    margin: 20px 0;
}

.modal_div {
    display: none;
}

.modaal-container {
    box-shadow: 0 0px 0px rgb(0 0 0 / 20%) !important;
}

.modal_01 {
    border-radius: 70px;
    background-size: contain;
    background-repeat: no-repeat;
    max-width: 1400px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.modal_01 .box01_wrap {
    width: 80%;
    margin: 0 auto;
    padding: 7px;
    border-radius: 40px;
    border-width: 0px;
    border-color: rgb(185, 165, 97);
    border-style: solid;
    background-size: auto;
    background-image: url(../img/bg02.jpg);
}

.modal_01 .box01_inner {
    padding: 4px;
    border-radius: 40px;
    border-width: 6px;
    border-color: rgb(185, 165, 97);
    border-style: solid;
}

.modal_01 .box01_inner02 {
    padding: 3% 3% 3% 3%;
    border-radius: 30px;
    border-width: 3px;
    border-color: rgb(185, 165, 97);
    border-style: solid;
}

.modal_01 .box01_inner02 .w50.img {
    width: 53%;
}

.modal_01 .box01_inner02 .w50.content {
    width: 44%;
}

.modal_01 .box01_inner02 .title {
    text-align: center;
    padding: 15px 0;
}

.modal_01 .box01_inner02 .title .name {
    font-size: 32px;
}

.modal_01 .box01_inner02 .sakuhin {
    display: flex;
    justify-content: flex-start;
    font-size: 14px;
}

.modal_01 .box01_inner02 .sakuhin dt {
    width: 70px;
}

.modal_01 .box01_inner02 .sakuhin dd {
    width: calc(100% - 70px);
}


/**Hover*/

a:hover,
a:hover img,
.nav li:hover,
.nav2 li:hover,
.nav3 li:hover {
    opacity: 1;
    -webkit-animation: flash 1.5s;
    animation: flash 1.5s;
}

a:hover {
    opacity: 1;
    -webkit-animation: none 1.5s;
    animation: none 1.5s;
}

@-webkit-keyframes flash {
    0% {
        opacity: .4;
    }

    100% {
        opacity: 1;
    }
}

@keyframes flash {
    0% {
        opacity: .4;
    }

    100% {
        opacity: 1;
    }
}


/**Scroll Anime*/

.scroll_up {
    transition: 0.8s ease-in-out;
    transform: translateY(30px);
    opacity: 0;
}

.scroll_up.on {
    transform: translateY(0);
    opacity: 1.0;
}

.box04 {
    background-image: linear-gradient(90deg, rgba(32, 156, 255, 1), rgba(104, 244, 207, 0.87));
    box-sizing: border-box;
    padding: 10px;
}

.box04_inner {
    background: #ffffff;
    padding: 20px 40px;
}

.box04_inner .flexb {
    align-items: center;
}

.box04 .title {
    color: #0054a7;
    font-size: 36px;
    font-weight: bold;
    line-height: 1.4em;
}

.box04 .author {
    color: #0054a7;
    font-size: 28px;
    font-weight: normal;
    line-height: 1.8em;
}

.box04 .point {
    color: #0054a7;
    font-size: 16px;
    font-weight: normal;
    line-height: 1.4em;
}

.inner03 {
    margin-left: auto;
    margin-right: auto;
    padding: 0px 100px;
}

.inner03 .box02 {
    padding: 20px 20px 10px 20px;
}

.font02 {
    font-size: 20px;
    font-weight: bold;
    line-height: 1.6em;
}

.box05 {
    background: #ffffff;
    padding: 20px 80px;
    border-radius: 30px;
}

.font03 {
    color: #ffffff;
    font-size: 34px;
    font-weight: bold;
    line-height: 1.2em;
}

.box02_01 {
    border-style: solid;
    border-width: 7px;
    border-color: rgb(0, 0, 0);
    background-color: #4542bd;
    color: #ffffff;
    font-size: 22px;
    text-decoration: underline;
    cursor: pointer;
    line-height: 1.6em;
    font-weight: bold;
}

.box02_01 .txt {
    font-size: 20px;
    font-weight: 800;
    line-height: 1.6em;
}

.box02_01 .txt02 {
    line-height: 2em;
    font-size: 30px;
    font-weight: 800;
}

.box02_02 {
    border-style: solid;
    border-width: 7px;
    border-color: rgb(0, 0, 0);
    background-color: #aaa8ee;
    border-top: 0px;
    padding-top: 20px;
}

.box02_02.close {
    display: none;
}

.box02_02 .nameclose {
    display: inline-block;
    background-color: rgb(198 198 198);
    color: #000000;
    font-size: 22px;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
    padding: 5px 30px;
    cursor: pointer;
}

.box02_02 .txt {
    font-size: 20px;
    font-weight: 800;
    line-height: 1.6em;
}

.box02_02 .txt02 {
    line-height: 2em;
    font-size: 30px;
    font-weight: 800;
}


body.final #sec03 .entrylist {
    flex-wrap: wrap;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

body.final #sec03 .entrylist li {
    width: 15%;
}

body.final #final_sec01 {
    background: url(../img/final/final_bg01.jpg);
    background-size: 100% 100%;
}

@media screen and (min-width: 1200px) {
    .pconly {
        display: block;
    }

    .sponly {
        display: none;
    }

    .pcbr {
        display: block;
    }
}

@media screen and (max-width: 1200px) {
    body {
        background-attachment: fixed;
        font-size: 14px;
        background: #000000;
    }

    .inner {
        width: 100% !important;
        margin: 0 auto;
        position: relative;
        padding: 0 2%;
        box-sizing: border-box;
    }

    .inner_big {
        width: 100%;
        margin: 0 auto;
        position: relative;
        padding: 0 2%;
        box-sizing: border-box;
    }

    .inner02 {
        width: 100%;
        margin: 0 auto;
        position: relative;
        padding: 0 2%;
        box-sizing: border-box;
    }

    .spb {
        display: block;
    }

    .spbr {
        display: block;
    }

    .flexc.col04 {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        width: 100%;
        margin: 0 auto;
    }

    .flexc.col04 li {
        width: 25%;
        text-align: center;
    }

    .pcpt {
        padding-top: 10px;
        padding-bottom: 0px;
        margin-top: -10px;
    }

    .sppt {
        padding-top: 20px;
    }

    .sppw {
        padding-left: 2%;
        padding-right: 2%;
        box-sizing: border-box;
    }

    .pconly {
        display: none;
    }

    .sponly {
        display: block;
    }

    .ptx2 {
        padding-top: 20px;
    }

    .pbx2 {
        padding-bottom: 20px;
    }

    .ttl {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
    }

    header {
        background: linear-gradient(rgba(0, 0, 0, 1), rgba(0, 0, 0, 0));
        display: block;
        text-align: center;
    }

    .nav {
        display: flex;
        justify-content: space-around;
        flex-wrap: wrap;
    }

    .nav li {
        width: 45%;
        margin: 10px 5px;
    }

    .nav li a {
        font-size: 16px;
    }

    nav.global_nav.is-fixed {
        display: none;
    }

    #menusp ul {
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    #menusp ul li {
        margin-bottom: 10px;
    }

    .mfp-bg {
        background: none;
        opacity: 1;
    }

    .mfp-auto-cursor .mfp-content {
        cursor: auto;
        padding: 40px 0;
        background-color: #000000a0;
        backdrop-filter: blur(3px);
        -webkit-backdrop-filter: blur(3px);
    }

    .mfp-close-btn-in .mfp-close {
        color: #fff;
        font-size: 60px;
    }

    .footer-bnr ul {
        display: flex;
        justify-content: space-around;
    }

    .footer-bnr ul.link {
        display: flex;
        flex-direction: column;
        margin-bottom: 20px;
    }

    .footer-bnr ul.link li {
        width: 90%;
        text-align: center;
        margin-bottom: 40px;
        margin-left: auto;
        margin-right: auto;
    }

    .footer-bnr ul.bnr {
        width: 90% !important;
    }

    #top_btn {
        position: fixed;
        right: 0%;
        bottom: 5%;
        width: 15%;
        opacity: 1;
    }

    .section_border {
        min-height: 10px;
    }

    /*contents*/
    nav.global_nav ul {
        padding: 5px 0;
        flex-wrap: wrap;
        align-items: baseline;
        justify-content: center;
    }

    nav.global_nav ul li {
        margin: 1px 3px;
        width: 30%;
    }

    nav.global_nav ul.fourth li {
        margin: 0 0px;
        width: 43%;
    }

    nav.global_nav ul li:first-child {
        margin-bottom: 10px;
    }

    .headersp {
        display: none;
    }

    .headersp.is-fixed {
        display: block;
        position: fixed;
        z-index: 99;
        width: 100%;
        min-height: 50px;
        background: url(../img/menu_barsp.jpg) no-repeat;
        background-size: 100% 100%;
        text-align: right;
    }

    .headersp.is-fixed a img {
        height: 50px;
        padding: 10px;
        display: inline-block;
    }

    h2 {
        font-size: 19px;
    }

    h2 .sub {
        font-size: 18px;
    }

    .slider01 {
        margin: 0 auto;
        width: 85%;
    }

    .slider02 {
        margin: 0 auto;
        width: 85%;
    }

    .slick-next {
        right: -28px;
    }

    .slick-prev {
        left: -25px;
    }

    .slick-prev:before,
    .slick-next:before {
        font-family: 'slick';
        font-size: 20px;
        line-height: 1;
        opacity: .75;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }

    .acc01 {
        border-radius: 50px;
        background: #aa3a3c;
        color: #ffffff;
        display: inline-block;
        padding: 2px 15px;
        letter-spacing: -1px;
    }

    #sec01 .inner {
        background: none;
        width: 100%;
        height: auto;
    }

    #sec01_box {
        margin: 0 auto;
        position: relative;
        width: 80%;
    }

    #sec01_box p {
        z-index: 1;
        position: relative;
        padding-top: 15px;
        padding-bottom: 15px;
        font-size: 14px;
        font-weight: 800;
        margin-top: 0;
    }

    #sec01_icon01 {
        position: absolute;
        top: 15%;
        width: 28%;
        left: 1%;
        z-index: 1;
    }

    #sec01_icon02 {
        position: absolute;
        top: 17%;
        width: 24%;
        right: 1%;
        z-index: 1;
    }

    #sec01_icon03 {
        position: absolute;
        bottom: 25%;
        width: 17%;
        left: 1%;
        z-index: 1;
    }

    #sec01_icon04 {
        position: absolute;
        top: 58%;
        width: 25%;
        right: 0%;
        z-index: 1;
    }

    #sec02 {
        background: url(../img/bg03sp-02.jpg) no-repeat;
        background-size: 100% 100%;
    }

    #sec02.sec02_02 {
        background: url(../img/20231207/bg03sp-02.jpg) no-repeat;
        background-size: 100% 100%;
    }

    .box02 {
        padding-left: 2%;
        padding-right: 2%;
        box-sizing: border-box;
    }

    .sec_black {
        background: #000000;
    }

    #sec03 .flexb {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        padding: 0 2%;
        box-sizing: border-box;
    }

    #sec03 .flexb li {
        width: 48%;
        margin-bottom: 20px;
    }

    #sec_names {
        background: url(../img/third_bg02sp.jpg) no-repeat;
    }

    #sec_names ul {
        flex-wrap: wrap;
    }

    #sec_names ul li {
        width: 31%;
        margin-bottom: 20px;
    }

    #sec_names ul li .mt {
        margin-top: 10px;
    }

    .name_popup {
        background: #ffffff;
        padding: 20px;
        border: 4px solid #000000;
        box-sizing: border-box;
        max-width: 96%;
    }

    .name_popup .title {
        padding-bottom: 10px;
        font-weight: bold;
    }

    .name_popup a {
        display: block;
        margin-bottom: 10px;
    }

    #sec04 {
        background: url(../img/third_bg01sp.jpg) no-repeat;
        background-size: 100% 100%;
    }

    h2 {
        padding-left: 2%;
        padding-right: 2%;
        box-sizing: border-box;
    }

    .txt03 {
        font-size: 13px;
        color: rgb(255, 255, 255);
        font-weight: bold;
        line-height: 2;
        text-align: center;
        text-shadow: 0px 0px 7px rgb(7 7 7);
    }

    .voice_box {
        background: url(../img/voice_bgsp.png) no-repeat;
        overflow: hidden;
        position: relative;
        background-size: 100% 100%;
        height: auto;
        padding-top: 120px;
        box-sizing: border-box;
        padding-left: 0px;
        padding-right: 0px;
        font-size: 13px;
        font-weight: 800;
        line-height: 1.3em;
        padding-bottom: 40px;
    }

    .voice_box .flexb {
        flex-direction: column;
    }

    .voice_box .flexb .w50 {
        width: 100%;
    }

    .voice_box .flexb .w50 img {
        width: 57%;
    }

    #sec07 {
        background: url(../img/bg08sp.jpg) no-repeat;
        background-size: 100% 100%;
        z-index: 0;
    }

    #sec08 .title02 {
        font-size: 30px;
    }

    .txt04 {
        font-size: 13px;
    }

    .box03 .title {
        top: -45px;
        font-size: 24px;
        text-shadow: 2px 2px 1px #000000, -2px 2px 1px #000000, 2px -2px 1px #000000, -2px -2px 1px #000000, 2px 0px 1px #000000, 0px 2px 1px #000000, -2px 0px 1px #000000, 0px -2px 1px #000000;
    }

    .box03 p {
        font-size: 17px;
    }

    .mbx3 {
        margin-bottom: 25px;
    }

    .mbx4 {
        margin-bottom: 40px;
    }

    .slider .sliderimg {
        width: 100vw;
        height: auto;
    }

    .slick-prev:before,
    .slick-next:before {
        font-size: 26px;
    }

    .slick-prev {
        left: 6px;
    }

    .slick-next {
        right: 15px;
    }

    /**secound*/
    #secound_sec01 {
        background-image: -moz-linear-gradient(90deg, rgb(50, 0, 0) 0%, rgb(191, 0, 0) 100%);
        background-image: -webkit-linear-gradient(90deg, rgb(50, 0, 0) 0%, rgb(191, 0, 0) 100%);
        background-image: -ms-linear-gradient(90deg, rgb(50, 0, 0) 0%, rgb(191, 0, 0) 100%);
        background-size: 100% 100%;
        display: block;
    }

    #secound_sec01 .left_bg,
    #secound_sec01 .right_bg {
        display: none;
    }

    #secound_sec01 .inner {
        background: none;
        margin: 0;
        min-width: inherit;
    }

    #secound_sec02 {
        padding: 20px 0;
    }

    .ranking {
        width: 100%;
        max-width: 95%;
        margin: 0 auto;
        padding-top: 0px;
    }

    .ranking article {
        display: flex;
        justify-content: flex-start;
        align-items: center;
        margin-bottom: 20px;
    }

    .ranking article .icon {
        margin-right: 10px;
        text-align: center;
        width: 20%;
    }

    .ranking article .icon img {
        width: 90%;
    }

    .ranking article .books {
        width: 90%;
    }

    .ranking article .books .title {
        font-size: 16px;
        font-weight: 700;
        color: #ffffff;
        line-height: 1.2em;
    }

    .ranking article .books .author {
        font-size: 18px;
        font-weight: 700;
        color: #ffffff;
        padding-left: 0.5em;
        line-height: 1.2em;
    }

    .ranking article:first-child .icon img {
        width: 100%;
    }

    .ranking article:first-child .title {
        font-size: 18px;
    }

    .ranking.fourth {
        font-size: 23px;
        font-weight: 700;
        color: #ffffff;
        line-height: 1.6em;
    }

    .ranking.fourth span {
        color: #ffec16;
    }

    #sec01.final #sec01_icon03 {
        position: absolute;
        bottom: -3%;
        width: 19%;
        left: 1%;
        z-index: 1;
    }

    #sec01.final #sec01_icon04 {
        position: absolute;
        top: 72%;
        width: 28%;
        right: 0%;
        z-index: 1;
    }

    #final_sec02 {
        background: url(../img/final/bg01_sp.jpg) no-repeat;
        overflow: hidden;
        position: relative;
        background-size: cover;
    }

    .box04_inner {
        background: #ffffff;
        padding: 20px 2%;
    }

    .box04_inner .flexb {
        align-items: center;
        flex-direction: column;
    }

    .box04_inner .flexb .w30,
    .box04_inner .flexb .w70 {
        width: 100%;
    }

    .box04_inner .flexb .w30 img {
        max-width: 30%;
        padding-bottom: 20px;
    }

    .box04 .title {
        color: #0054a7;
        font-size: 25px;
        font-weight: bold;
        line-height: 1.4em;
    }

    .box04 .author {
        color: #0054a7;
        font-size: 25px;
        font-weight: normal;
        line-height: 1.8em;
    }

    .box04 .point {
        color: #0054a7;
        font-size: 16px;
        font-weight: normal;
        line-height: 1.4em;
    }

    .box04.comment .box04_inner {
        padding: 20px 40px;
    }

    .box04.comment .box04_inner .flexb {
        align-items: center;
        flex-direction: column-reverse;
    }

    .box04.comment .box04_inner .flexb .w50 {
        width: 100%;
        margin-bottom: 20px;
    }

    .box04.comment .box04_inner .flexb .w50.img {
        text-align: center;
    }

    .box04.comment .box04_inner .flexb .w50.img img {
        max-width: 80%;
    }

    .sp80 {
        width: 80%;
        margin: auto;
    }

    #final_sec03 {
        background: url(../img/final/bg02_sp.jpg) no-repeat;
        overflow: hidden;
        position: relative;
        background-size: 100% 100%;
    }

    .inner03 {
        margin-left: auto;
        margin-right: auto;
        padding: 0px 0px;
    }

    .inner03 .box02 {
        border: 0px solid #ffffff;
        padding: 2%;
    }

    .inner03 .box02 > div {
        margin-top: 0px;
    }

    #final_sec04 h2 img {
        height: 50px;
    }

    .box05 {
        background: #ffffff;
        padding: 20px 2%;
        border-radius: 30px;
    }

    .box05 > div {
        text-align: left !important;
    }

    .font03 {
        color: #ffffff;
        font-size: 26px;
        font-weight: bold;
        line-height: 1.4em;
    }

    .box02_01 {
        font-size: 17px;
    }

    .close:after {
        content: "投票期間外です";
        width: 100%;
        height: 70px;
        background: rgba(0, 0, 0, 0.7);
        position: absolute;
        z-index: 2;
        display: flex;
        top: -10px;
        left: 0;
        padding: 10px 0;
        color: #ffffff;
        font-size: 30px;
        align-items: center;
        text-align: center;
        justify-content: center;
        font-family: 'Noto Sans JP', sans-serif;
    }

    .close02:after {
        content: "プレゼントは終了しました";
        width: 100%;
        height: 210px;
        background: rgba(0, 0, 0, 0.7);
        position: absolute;
        z-index: 2;
        display: flex;
        top: -10px;
        left: 0;
        padding: 10px 0;
        color: #ffffff;
        font-size: 30px;
        align-items: center;
        text-align: center;
        justify-content: center;
        font-family: 'Noto Sans JP', sans-serif;
    }

    .close03:after {
        content: "プレゼントは終了しました";
        width: 100%;
        height: 210px;
        background: rgba(0, 0, 0, 0.7);
        position: absolute;
        z-index: 2;
        display: flex;
        top: -10px;
        left: 0;
        padding: 10px 0;
        color: #ffffff;
        font-size: 30px;
        align-items: center;
        text-align: center;
        justify-content: center;
        font-family: 'Noto Sans JP', sans-serif;
    }

    body.final #sec03 .entrylist li {
        width: 31%;
    }

    body.final .box05 {
        background: #ffffff;
        padding: 20px 1%;
        border-radius: 30px;
    }

    body.final .box05 > div {
        text-align: center !important;
        font-size: 12px;
    }

    #final_sec02 .comment {
        font-size: 12px;
    }

    body.final #final_sec01 {
        background: url(../img/final/final_bg01sp.jpg);
        background-size: 100% 100%;
    }
}
