@charset "UTF-8";
/* CSS Document */

.about-raise {
    margin: -200px auto 0;
    padding: 0 0 100px;
    overflow: visible;
    z-index: 10;
}

.concours-top {
	width: 98%;
	margin: 0 auto;
	padding: 0;
	position: relative;
	overflow: visible;
}

.con-top {
 	width: 100%;
	margin: 0 auto;
	padding: 0;
	position: relative;
	overflow: hidden;
	z-index: 1;
}

.con-top-logo {
	width: 80%;
	max-width: 500px;
	margin: 0 auto 100px;
	padding: 0;
	position: relative;
	overflow: hidden;
    z-index: 10;
}

.con-top-l,.con-top-r {
	width: 30%;
	position: absolute;
	top: 0;
	z-index: 10;
}

.con-top-l {
	left: 1%;
}

.con-top-r {
	right: 1%;
}
    
.cresults-2023 .concours-top {
    margin: 0 auto 100px;
}

.cr-left,.cr-right {
	width: 20%;
	position: absolute;
	top: 0;
	z-index: 10;
}

.cr-left {
    left: 7%;
}

.cr-right {
    right: 7%;
}

ul.cr-img-list {
    width: 100%;
    margin: 0;
    padding: 0;
    position: relative;
    overflow: hidden;
    list-style: none;
}

ul.cr-img-list li {
    width: 100%;
    margin: 0 0 10px;
    padding: 0;
    position: relative;
    overflow: hidden;
}

/**2024 selection top images**/

ul.res-img-list {
    width: 100%;
    margin: -80px 0 0;
    padding: 0;
    list-style: none;
    position: absolute;
    top: 0;
    left: 0;
}

ul.res-img-list li {
    width: 20%;
    position: absolute;
    z-index: 10;
    left: 0;
}

ul.res-img-list li#sel-01 {
    width: 30%;
    top: -100px;
    left: 15%;
}
ul.res-img-list li#sel-02 {
    top: 0;
    right:0;
    left: unset;
}
ul.res-img-list li#sel-03 {
    width: 40%;
    top: 150px;
    left: -5%;
}
ul.res-img-list li#sel-04 {
    width: 15%;
    top: 300px;
    right:-3%;
    left: unset;
}
ul.res-img-list li#sel-05 {
    width: 18%;
    top: 450px;
    left: 15%;
}
ul.res-img-list li#sel-06 {
    top: 450px;
    right:10%;
    left: unset;
}




@media screen and (min-width: 641px) and (max-width: 1305px) {
	
.con-top-logo {
	width: 50%;
	max-width: 500px;
	margin: 0 auto 100px;
	padding: 0;
	position: relative;
	overflow: hidden;
}
	
.con-top-l,.con-top-r {
	width: 23%;
	position: absolute;
	top: 100px;
	z-index: 10;
}

.con-top-l {
	left: 1%;
}

.con-top-r {
	right: 1%;
}

.cr-left,.cr-right {
    width: 15%;
}

}

.ct-btn-area {
	width: 50%;
	max-width: 500px;
	margin: 30px auto;
	padding: 0;
	position: relative;
	overflow: visible;
}

.ct-end {
	max-width: 800px !important;
}

.ct-btn-area .ct-btn {
	width: 100%;
	margin: 0 auto 30px;
	padding: 0;
	position: relative;
	overflow: hidden;
	background-color: #E35B7E;
	border-radius: 50px;
	font-size: 140%;
	
	transition: ease-in-out 0.3s;
}

.ct-btn-area .ct-btn:hover {
    background-color: #000 !important;
}

.ct-pink {
	background-color: #E35B7E !important;
}

.ct-blue {
	background-color: #00A6B2 !important
}

.ct-btn-area .ct-qa {
	margin: 60px auto 0;
	background-color: #FFE900;
}

.ct-yel {
    background-color: #FFE900 !important
}


.ct-yel a {
    color: #000 !important;
    transition: ease-in-out 0.3s;
}

.ct-yel:hover a {
    color: #FFF !important;
}

.btn-flex {
    width: 90%;
    max-width: 900px;
    margin: 60px auto;
    padding: 0;
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.btn-flex .bf-btn {
    width: 45%;
    background-color: #E35B7E;
	border-radius: 50px;
	font-size: 140%;
	
	transition: ease-in-out 0.3s;
}

.btn-flex .bf-btn:hover {
    background-color: #000 !important;
}

.btn-flex .bf-btn a {
    width: 100%;
    padding: 20px 0;
    display: block;
    text-align: center;
    color: #FFF;
}



.entry-end {	
	width: 80%;
	max-width: 1000px;
	margin: 60px auto;
	padding: 60px 10%;
	position: relative;
	overflow: hidden;
	text-align: center;
	font-size: 180%;
	font-weight: bold;
	line-height: 180%;
	color: #000;
	border: solid 2px #000;
	background-color: #FFF;
}

.ct-btn-area .ct-btn a {
	width: 100%;
	padding: 20px 0;
	display: block;
	text-align: center;
	color: #FFF;
}

.ct-btn-area .ct-qa a {
	color: #000;
	transition: ease-in-out 0.3s;
}

.ct-btn-area .ct-qa:hover a {
	color: #FFF;
}

.stars:before,.stars:after {
	content: "";
	width: 140px;
	height: 400px;
	display: block;
	position: absolute;
	top: 100px;
	z-index: 10;
	background-size: contain;
	background-repeat: no-repeat;
}

.stars:before {
	left: -200px;
	background-image: url("../img/concours/stars-left.png");
}
.cresults-2024 .stars:before {
    background-image: url("../img/concours/results/2024/hoshi-01.svg");
}

.stars:after {
	right:-200px;
	background-image: url("../img/concours/stars-right.png");
}
.cresults-2024 .stars:after {
	background-image: url("../img/concours/results/2024/hoshi-02.svg");
}

.concours-topwrap {
	padding: 0 0 100px;
}

.concours-main {
	width: 95%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 0;
	position: relative;
	overflow: visible;
}

.c-intro-txt {
	width: 90%;
    max-width: 800px;
	margin: 100px auto 0;
	padding: 0;
	position: relative;
	overflow: hidden;
	font-size: 120%;
	line-height: 240%;
}

.c-intro-memo {
	width: 90%;
    max-width: 800px;
	margin: 10px auto 0;
	padding: 0;
	position: relative;
	overflow: hidden;
	font-size: 90%;
	line-height: 240%;
}

section.conc-sec {
	width: 100%;
	margin: 0 0 60px;
	padding: 0;
	position: relative;
	overflow: visible;
}

section.conc-sec h2 {
	width: 95%;
    max-width: 1000px;
	margin: 0 auto 30px;
	padding: 10px 2.5%;
	position: relative;
	overflow: hidden;
	background-color: #F4D7DF;
	font-size: 160%;
	font-weight: bold;
	line-height: 180%;
}

section.conc-sec h4 {
    width: 100%;
    margin: 0 0 30px;
    padding: 0;
    position: relative;
    overflow: hidden;
    font-size: 140%;
    font-weight: bold;
    color: #454545;
}

section.conc-sec .conc-wrap {
	width: 95%;
    max-width: 1000px;
	margin: 0 auto;
	padding: 0;
	position: relative;
	overflow: hidden;
	font-size: 110%;
	line-height: 210%;
}

section.conc-sec .conc-txt {	
	font-size: 110%;
	line-height: 210%;
}

dl.obo-list {
    width: 100%;
    margin: 0;
    padding: 0;
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: flex-start;
}

dl.obo-list dt {
    width: 20%;
    margin: 0 0 20px;
    padding: 5px 0;
    background-color: #00A6B2;
    color: #FFF;
    text-align: center;
    font-weight: bold;
    font-size: 110%;
    letter-spacing: 0.1em;
}

dl.obo-list dd {
    width: 78%;
    margin: 0 0 20px;
    padding: 5px 0;
    line-height: 210%;
}

ul.entry-list {
	width: 100%;
	margin: 0;
	padding: 0;
	position: relative;
	overflow: hidden;
	list-style: none;
}

ul.entry-list > li {
	width: 90%;
	margin: 0 auto 20px;
	overflow: visible;
}

ul.entry-list > li:before {
	content: "●";
	font-size: 100%;
	color: #00A6B2;
	display: inline;
	width: 1.5em;
	margin: 0 0.2em 0 -1.5em;
}

ul.entry-list .li-hd {
	width: 100%;
	margin: 0;
	padding: 0 0 5px;
	display: inline-flex;
	position: relative;
	overflow: hidden;
	color: #00A6B2;
	font-weight: bold;
	font-size: 110%;
}

ul.entry-list .li-hd span {
	color: #454545;
	font-size: 90%;
}

ul.entry-list li > ul {
    list-style: disc;
}

.gift-example {	
	width: 98%;
	margin: 100px auto;
	padding: 0;
	position: relative;
	overflow: hidden;
}

ul.shokin-list {
	width: 100%;
	margin: 60px 0 0;
	padding: 0;
	position: relative;
	overflow: hidden;
	list-style: none;
}

ul.shokin-list > li {
	width: 100%;
	margin: 0 0 30px;
	padding: 0 0 30px;
	position: relative;
	overflow: hidden;
	border-bottom: solid 1px #707070;
}

ul.shokin-list li h3 {
	width: 100%;
	margin: 0 0 10px;
	padding: 0;
	position: relative;
	overflow: hidden;
	font-size: 160%;
	font-weight: bold;
	color: #454545;
}

ul.shokin-list li h3 span.shokin {
	font-size: 140%;
	color: #D91E7C;
	padding: 0 0 0 10px;
}

.jusho-main {
    width: 80%;
    max-width: 500px;
    margin: 30px auto;
    padding: 0;
    position: relative;
    overflow: hidden;
}

.jusho-flex {
    width: 100%;
    display: flex;
    justify-content: space-around;
}

.jusho-flex .jf-img {
    width: 45%;
    max-width: 400px;
}

.catalog-mds {
    width: 100%;
    margin: 0 0 60px;
    padding: 0;
    position: relative;
    overflow: hidden;
    font-size: 140%;
    font-weight: bold;
    text-align: center;
}

h3.pink-mds {
    width: 100%;
    margin: 0 0 30px;
    padding: 0;
    position: relative;
    overflow: hidden;
    font-size: 180%;
    font-weight: bold;
    color: #D91E7C;
}

/***concours-entry***/

.entry-wrap {
	width: 80%;
	margin: 0 auto 60px;
	padding: 0;
	position: relative;
	overflow: hidden;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.entry-wrap .ew-l {
	width: 40%;
}

.entry-wrap .ew-r {
	width: 55%;
}

.ew-r h2.ew-mds {
	width: 100%;
	margin: 0 0 20px;
	padding: 0;
	position: relative;
	overflow: hidden;
	font-size: 260%;
	font-weight: bold;
	line-height: 180%;
}

.ew-r .ew-txt {
	font-size: 110%;
	line-height: 180%;
}

.form-switch {
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 100px;
	padding: 0;
	position: relative;
	overflow: hidden;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.form-switch .fw-btn {
	width: 45%;
	border-radius: 40px;
	text-align: center;
	font-size: 140%;
	font-weight: bold;
	
	transition: all 0.3s;
}

.form-switch .fw-btn a:after {
	content: "";
	width: 50px;
	height: 30px;
	display: block;
	background-image: url("../img/concours/formswitch-arr.svg");
	background-size: contain;
	background-repeat: no-repeat;
	margin: 10px auto 0;
}

.form-switch .fw-kojin {
	background-color: #E35B7E;
}

.form-switch .fw-kojin:hover {
	background-color: #cd2c56;
}

.form-switch .fw-kigyo {
	background-color: #05A6B2;
}

.form-switch .fw-kigyo:hover {
	background-color: #057f88;
}

.form-switch .fw-btn a {
	width: 100%;
	display: block;
	padding: 20px 0 10px;
	color: #FFF;
}

.form-area {
	width: 90%;
	margin: 0 auto;
	padding: 0;
	position: relative;
	overflow: hidden;
}

section.form-sec {
	width: 100%;
	margin: 0 0 100px;
	padding: 0;
	position: relative;
	overflow: hidden;
}

.memo {
	font-size: 80%;
	font-weight: normal;
}

.col-img-box {
	border:none !important;
}

.col-img-box img {
	width: unset;
	
}

.giftimg-btn {
	display: inline-block;
	background-color: #E3E3E3;
	text-align: center;
	font-size: 110%;
	font-weight: bold;
	color: #454545;
	border-radius: 10px;
	padding: 10px;
	cursor: pointer;
	
	transition: all 0.3s;
}

.giftimg-btn:hover {
	
	background-color: #212121;
	color: #FFF;
}

/***SUBMIT***/


.concours-logo {
	width: 50%;
	max-width: 500px;
	margin: 0 auto 60px;
	padding: 0;
	position: relative;
	overflow: hidden;
}

.concours-mds {
	text-align: center;
	font-size: 280%;
	font-weight: bold;
	line-height: 210%;
	margin: 0 0 30px;
}

.concours-txt {
	font-size: 110%;
	text-align: center;
	line-height: 210%;
}

/***CONTACT***/

.contact-warning {
    width: 90%;
    margin: 60px auto 0;
    padding: 0;
    position: relative;
    overflow: hidden;
    text-align: center;
    font-size: 110%;
    line-height: 220%;
}

.contact-complete {
    width: 90%;
    margin: 0 auto;
    padding: 0;
    position: relative;
    overflow: hidden;
    text-align: center;
}

.cc-logo {
    width: 70%;
    max-width: 450px;
    margin: 0 auto 60px;
}

.cc-mds {
    font-size: 180%;
    line-height: 180%;
    font-weight: bold;
    margin: 0 0 30px;
}

.cc-txt {
    font-size: 120%;
    line-height: 210%;
}

/***コンクール：結果発表***/

.ct-results {
    width: 90%;
    margin: 0 auto 30px;
    padding: 0;
    position: relative;
    overflow: hidden;
    z-index: 10;
}

h3.res-bnr {
    width: 90%;
    height: 60px;
    margin: 0 auto;
    padding: 20px 0 30px;
    position: relative;
    overflow: hidden;
    background-image: url("../img/concours/results/banner_gold.png");
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 180%;
    line-height: 180%;
}

h3.res-bnr.rs-small {
    font-size: 120%;
}

.cresults-2023 h3.res-bnr {
    padding: 10px 0 30px;
    background-image: url("../img/concours/results/2023/banner_bk.svg");
}
.cresults-2024 h3.res-bnr {
    width: 100%;
    height: 100px;
    padding: 30px 0;
    background-image: url("../img/concours/results/2024/banner_bk.svg");
    font-size: 140%;
    color: #FFF;
    text-shadow: 0px 0px 5px rgba(0,0,0,0.4);
}


.cresults-2023 h3.res-bnr.rs-small {
    font-size: 140%;
}

.cresults-2024 h3.res-bnr.rs-small {
    font-size: 120%;
}

.past-selectbox-area {
    width: 85%;
    margin: 50px auto;
    padding: 0;
    position: relative;
    overflow: hidden;
    text-align: right;
    display: block;
    z-index: 20;
}
.past-selectbox {
    display: inline-flex;
    align-items: center;
    position: relative;
}
.past-selectbox:after {
    position: absolute;
    right: 15px;
    width: 10px;
    height: 7px;
    background-color: #D91E7C;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: '';
    pointer-events: none;
}
.past-selectbox select {
    appearance: none;
    min-width: 230px;
    height: 2.5em;
    padding: .4em calc(.8em + 30px) .4em .8em;
    border: 1px solid #D91E7C;
    border-radius: 3px;
    background-color: #fff;
    color: #D91E7C;
    font-size: 110%;
    font-weight: bold;
    cursor: pointer;
}


@media screen and (min-width: 641px) and (max-width: 1305px) {
    h3.res-bnr {
        font-size: 140%;
    }

}


.res-wrap {
    width: 100%;
    margin: 0;
    padding: 0;
    position: relative;
    overflow: visible;
    display: flex;
    justify-content: space-between;
}

.res-wrap .res-img {
    width: 43%;
}

.winner .res-img {
    width: 45%;
}

.res-wrap .ri-overlap {
    width: 20%;
    max-width: 200px;
    position: absolute;
    left: -5%;
    top: -80px;
}

.res-wrap .res-info {
    width: 55%;
}

.winner .res-info {
    width: 52%;
}

.res-info .res-main {
    width: 100%;
    margin: 0 0 20px;
    padding: 0;
    position: relative;
    overflow: hidden;
    font-weight: bold;
    font-size: 120%;
    line-height: 210%;
}

ul.blue-dot {
    width: 100%;
    margin: 0;
    padding: 0;
    position: relative;
    overflow: hidden;
    list-style: none;
    line-height: 160%;
}

ul.blue-dot li {
    width: 88%;
    margin: 0 auto 10px;
    overflow: visible;
}

ul.blue-dot li:before {
    content: "●";
    font-size: 100%;
    color: #00A6B2;
    display: inline;
    width: 1.5em;
    margin: 0 0.2em 0 -1.5em;
}

.bdot {
    content: "●";
    font-size: 100%;
    color: #00A6B2;
    display: inline;
    width: 1.5em;
    margin: 0 0.2em 0 0;
}

.res-title {
    width: 100%;
    margin: 0 0 10px;
    padding: 0 0 10px;
    position: relative;
    overflow: hidden;
    font-size: 140%;
    font-weight: bold;
    border-bottom: solid 1px #707070;
}

.res-info .res-det {
    width: 100%;
    margin: 0;
    padding: 0;
    position: relative;
    overflow: hidden;
    line-height: 210%;
}

.res-info .res-det:before {
    content: "【応募者のコメント】";
    display: block;
    margin: 0;
    padding: 0;
    position: relative;
    overflow: hidden;
    font-weight: bold;
}

.res-info .res-cont {
    width: 100%;
    margin: 0 0 20px;
    padding: 0;
    position: relative;
    overflow: hidden;
    font-weight: bold;
    font-size: 110%;
    line-height: 180%;
}


.res-info .res-desc {
    width: 100%;
    margin: 0;
    padding: 0;
    position: relative;
    overflow: hidden;
    line-height: 220%;
}


.btn-conc {
    background-color: #00A6B2 !important;
}

.btn-conc:hover {
    background-color: #00466f !important;
}


/***PRESENT CAMPAIGN***/


.pc-top-wrap {
    width: 100%;
    margin: 0;
    padding: 0;
    position: absolute;
    overflow: hidden;
    background-image: url("../img/present/bk_present_top.svg");
    background-repeat: no-repeat;
    background-size: cover;
    z-index: 10;
}

.pc-top-wrap-sp {
    display: none;
}

.pc-desc {
    width: 90%;
    margin: 0 auto 60px;
    padding: 0;
    position: relative;
    overflow: hidden;
    font-size: 120%;
    line-height: 210%;
    max-width: 700px;
}

.hd-pres {
    width: 90%;
    max-width: 800px;
    margin: 0 auto 20px;
    padding: 0;
    position: relative;
    overflow: hidden;
}

.pc-wrap {
    width: 98%;
    max-width: 1000px;
    margin: 0 auto;
    padding: 0;
    position: relative;
    overflow: hidden;
}

.pc-top {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto 30px;
    padding: 0;
    position: relative;
    overflow: hidden;
}

.pc-top-sp {
    display: none;
}

.pc-btnwrap {
    width: 100%;
    max-width: 800px;
    margin: 0 auto 30px;
    padding: 0;
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: space-between;
}

.bottom_100 {
    margin-bottom: 100px;
}

.pc-btn {
    width: 45%;
    max-width: 400px;
    background-color: grey;
    text-align: center;
    font-size: 120%;
    font-weight: bold;
    border-radius: 30px;
    
    transition: all 0.3s;
}

.pc-btn:hover {
    opacity: 0.5;
}

.pc-btn a {
    width: 100%;
    display: block;
    color: #FFF;
    padding: 15px 0;
}

.pc-shoplist {
    background-color: #E35B7E;
}

.pc-entry {
    background-color: #00A6B2;
}

.pc-shop {
    margin: 0 auto 60px;
    background-color: #4F4F4F;
}

.presenttop-wrapper .conc-sec h2 {
    background-color: #C1E9EB;
}

h3.orange {
    font-size: 140%;
    font-weight: bold;
    color: #F48700;
    margin: 0 0 10px;
}

.entry-flex {
    width: 100%;
    max-width: 1000px;
    margin: 30px auto;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.entry-flex .ef-img {
    width: 48%;
}

.form-desc {
    width: 90%;
    margin: 0 auto 60px;
    padding: 0;
    position: relative;
    overflow: hidden;
    max-width: 500px;
}

.form-imp {
    font-weight: bold;
}

.presenttop-wrapper #pagelink-qanda {
    max-width: 1000px;
    margin: 0 auto;
}

.presenttop-wrapper #pagelink-qanda > .conc-wrap {
    width: 100%;
}

/**SHOPLIST***/


.shop-search {
    width: 80%;
    max-width: 400px;
    margin: 0 auto 100px;
    padding: 0;
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: space-between;
}

.shop-search input {
    width: 70%;
}

.shop-search .ss-btn {
    width: 20%;
    margin: 0;
    padding: 10px 2%;
    text-align: center;
    color: #FFF;
    background-color: #00A6B2;
    font-size: 120%;
    font-weight: bold;
    cursor: pointer;
}

.present-shops {
    width: 95%;
    max-width: 800px;
    margin: 0 auto;
    padding: 30px 2.5%;
    position: relative;
    overflow: hidden;
     background-color: rgb(255 255 255 / 70%);
}

.ps-wide {
    max-width: 900px;
}


.sub-info {
    width: 95%;
    margin: 10px auto;
    padding: 0;
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: space-between;
}


ul.presentshop-list {
    width: 95%;
    margin: 0 auto;
    padding: 0;
    position: relative;
    overflow: hidden;
    list-style: none;
   
}

ul.presentshop-list li {
    width: 90%;
    margin: 0 auto;
    padding: 20px 5%;
    position: relative;
    overflow: hidden;
    border-bottom: solid 1px #454545;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

ul.presentshop-list li:first-child {
    border-top: solid 1px #454545;
}

ul.presentshop-list li .ps-name {
    width: 38%;
    font-size: 120%;
    font-weight: bold;
}

ul.presentshop-list li .ps-info {
    width: 60%;
}

.qanda-wrap {
    max-width: 1060px !important;
    width: 100% !important;
    
}