/*--------------------------------------------------------*/
/* 過去の受賞作品 */
.contents-box {
    background-color: var(--white);
    /*width: min(82vw, 1000px);*/
    width: min(98%, 1000px);
    margin: 0 auto 3em;
    border-radius: 0.5em;
    overflow: hidden;
}

.contents-box h3 {
    color: #af6b03;
    /*    border-bottom: dotted 0.15em;*/
    width: fit-content;
    margin: min(1vw, 0.5em) auto min(10vw, 2.4em);
    font-size: min(4.5vw, 1.6em);
    padding-bottom: min(0.3vw, 0.15em);
}

.contents-box h3.h3 {
    color: #f06591;
    font-size: min(4.5vw, 2em);
    padding-bottom: min(0.6vw, 0.3em);
}

.contents-box h3 span {
    display: flex;
    line-height: 1;
    align-items: center;
    justify-content: center;
}

.contents-box h3.h3::before,
.contents-box h3.h3::after {
    display: block;
    content: "";
    width: 100%;
    height: 10px;
    background: url(../result/img/deco_line.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center center;
}

.contents-box h3.h3::before {
    padding: 0.5em 0;
}

.contents-box h3.h3::after {
    padding: 0.65em 0;
    transform: scale(1, -1);
}

.contents-box h3 span::before,
.contents-box h3 span::after {
    display: block;
    content: "";
    width: 0.75em;
    height: 0.75em;
    background: url(../past/img/deco_star.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center center;
    padding: 0 0.2em;
}

.contents-box h3 span::after {
    transform: scale(-1, 1);
}

.contents-box .tag-year {
    width: min(18vw, 140px);
    margin-left: 5%;
    line-height: 5.5em;
    background: url(../past/img/tag2.png);
    background-size: contain;
    background-position: center top;
    background-repeat: no-repeat;
    color: #fff;
    text-align: center;
}

.contents-box .award-box {
    width: 90%;
    margin: 0 auto min(10vw, 4em);
    border-radius: 0.5em;
    position: relative;
    padding-top: min(5vw, 1.5em);
}

.contents-box .gold {
    border: solid 0.2em #bea657;
    background: #fffded;
}

.contents-box .pink {
    border: solid 0.2em #f06591;
    background: #fff0f5;
}

.contents-box .blue {
    border: solid 0.2em var(--lightblue);
    background: #eefeff;
}

.contents-box .green {
    border: solid 0.2em #90ee90;
    background: #eafaea;
}

/*
.contents-box .gold .icon img,
.contents-box .pink .icon img {
	position: absolute;
	width: min(20vw, 185px);
	width: min(22vw, 8em);
	left: 3%;
	top: -3%;
	top: max(-6vw, -2em);
}

.contents-box .blue .icon img {
	position: absolute;
	width: min(20vw, 185px);
	width: min(22vw, 8em);
	left: 3%;
	top: -4%;
	top: max(-6vw, -2em);
}

.contents-box .green .icon img {
	position: absolute;
	width: min(20vw, 185px);
	width: min(22vw, 8em);
	left: 3%;
	top: -4%;
	top: max(-6vw, -2em);
}
*/

.contents-box .icon {
    width: min(20vw, 190px);
    padding: 1.5em 0;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: min(2.5vw, 22px);
    color: rgba(0, 0, 0, 0.8);
    position: absolute;
    top: -4vw;
    left: 3vw;
    font-weight: 900;
}

.contents-box img {
    width: min(4vw, 40px);
    margin-right: 0.2em;
}

.contents-box .blue .icon {
    background: url(../result/img/icon_blue_2025.png);
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

.contents-box .green .icon {
    background: url(../result/img/icon_green_2025.png);
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

.contents-box .pink .icon {
    background: url(../result/img/icon_pink_2025.png);
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

.contents-box .gold .icon {
    background: url(../past/img/icon-gold2.png);
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}



.contents-box .works-ttl {
    font-size: min(4.2vw, 1.5em);
    border-bottom: solid 0.2em #bea657;
    width: min(90%, 650px);
    margin: 0.5em auto 0.2em;
    padding-bottom: 0.2em;
}

.works-ttl span {
    color: #584611;
    font-size: 0.7em;
    vertical-align: baseline;
    opacity: 0.6;
}

.contents-box .recipient {
    font-size: min(4vw, 1.2em);
}

.recipient .san {
    display: inline-block;
    font-size: 0.8em;
    letter-spacing: -0.1em;
    margin-left: 0.2em;
    vertical-align: baseline;
}

.youtube_movie {
    width: min(90%, 650px) !important;
    margin: 4% auto !important;
}

.contents-box .works-ttl,
.contents-box .recipient,
.contents-box .detail {
    font-weight: 900;
    text-align: center;
}

.contents-box .recipient {
    margin: 0.5em auto -0.2em;
}

dl.scenario {
    background: var(--white);
    border-radius: 0.5em;
    margin: min(2vw, 1.5em);
    padding: min(2vw, 1.5em);
    font-weight: 500;
}

dl.scenario dt {
    background: #eee;
    border-radius: 0.5em;
    color: #666;
    font-size: min(5vw, 0.98em) !important;
    padding: 0 0.2em 0 0.5em;
    width: fit-content;
    margin-bottom: min(2vw, 0.3em);
}

dl.scenario dd {
    font-size: min(5vw, 0.98em) !important;
    line-height: 1.4em;
    padding-bottom: min(2vw, 0.6em);
    /*    word-break: auto-phrase;*/
}

dl.scenario dd span {
    display: inline-block;
    /*    word-break: auto-phrase;*/
}

dl.scenario dd span.togaki {
    display: inline-block;
    font-style: italic;
    margin: min(1vw, 0.5em) 0;
    /*	opacity: 0.4;*/
    vertical-align: baseline;
    /*    word-break: auto-phrase;*/
    color: #6c6c6c;
}

.brackets {
    text-indent: -1em;
    margin: 0 0 0.5em 1em !important;
}

dl.scenario dd span.choices {
    display: block;
}

.contents-box a.btn {
    margin: 0 auto 3%;
    width: min(84%, 600px);
    text-align: center;
    background: #3e77c1;
    color: var(--white) !important;
    text-decoration: none;
    font-size: min(3.5vw, 22px);
    padding: 0.2em 0;
    display: block;
    border-radius: 0;
}

.link-box {
    margin: max(-5vw, -1.5em) auto 5%;
}

#contents a.btn_archive {
    width: min(80%, 550px);
    margin: 2% auto 0;
    display: block;
    background: url(../past/img/btn-archive.png);
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
    text-decoration: none;
    color: #fff;
    text-align: center;
    line-height: 3.5em;
}

#contents a.btn_archive img {
    width: 100%;
}

section.award_info {
    margin-bottom: 0;
}

section.award_info div {
    width: min(98%, 1000px);
    margin: 0 auto;
    box-sizing: border-box;
    padding: 1.5em min(5vw, 1.5em);
    background-color: rgba(255, 255, 255, 0.9);
    border-radius: 0.5em;
    text-align: center;
    font-size: min(3.2vw, 1em);
}

section.award_info small {
    font-size: 0.75em;
}

/*250509追加文*/

main#box_apply h3 {
    margin: min(1vw, 0.5em) auto min(10vw, 2.4em);
    width: fit-content;
    background-color: transparent;
    border-radius: 0;
    display: block;
    color: #f06591 !important;
    font-size: min(4.5vw, 2em);
    padding: 0.2em 0 min(0.6vw, 0.3em) 0;
    font-weight: 900;
}

main section #contents h3.h3 {
    margin: min(1vw, 0.5em) auto min(10vw, 2.4em);
    width: 6.5em;
    background-color: transparent;
    border-radius: 0;
    display: block;
    color: #f06591 !important;
    font-size: min(4.5vw, 2em);
    padding: 0.2em 0 min(0.6vw, 0.3em) 0;
    font-weight: 900;
    text-align: center;
}

main#box_apply .youtube_movie {
    width: min(90%, 650px) !important;
    margin: 0 auto 4% !important;
}

main#box_apply .youtube_sec {
    color: #cc3363;
    text-align: center;
    display: block;
}

#box_apply .title {
    border-color: var(--purple);
    margin-bottom: 1em;
}

.onlySp {
    display: none;
}

#contents {
    padding-top: 0;
}

.result_photo {
    display: block;
    width: min(90%, 600px);
    border: 6px solid var(--lightyellow);
    margin: 0 auto 1em;
    box-shadow: 0 0 4px #ccc;
}

.noto {
    font-weight: 600;
}

.flex-box{
    display: flex;
    align-items: center;
}

dl.scenario .flex-box dd{
    padding:0;
    line-height: 2;
}

@media screen and (max-width:900px) {
    .onlySp {
        display: block;
    }

    contents-box h3.h3::before {
        padding: 0.2em 0;
    }
}
