/* RESET */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}
html {
    font-size: 62.5%;
    font-family: 'Noto Sans JP', sans-serif;
    color: #1E1E1E;
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}
@media screen and (max-width: 767px) {
  html {
    font-size: 1.3327vw;
  }
}

article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
    display:block;
}

blockquote, q {
    quotes:none;
}

blockquote:before, blockquote:after,
q:before, q:after {
    content:'';
    content:none;
}

a {
    margin:0;
    padding:0;
    vertical-align:baseline;
    background:transparent;
}

/* change colours to suit your needs */
ins {
    background-color:#ff9;
    color:#000;
    text-decoration:none;
}

/* change colours to suit your needs */
mark {
    background-color:#ff9;
    color:#000;
    font-style:italic;
    font-weight:bold;
}

del {
    text-decoration: line-through;
}

abbr[title], dfn[title] {
    border-bottom:1px dotted;
    cursor:help;
}

table {
    border-collapse:collapse;
    border-spacing:0;
}

/* change border colour to suit your needs */
hr {
    display:block;
    height:1px;
    border:0;
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}

input, select {
    vertical-align:middle;
}

ul {
	list-style-type:none;
}
ol {
	list-style-type:decimal;
}



.forPC {
	display:block;
}
.forSP {
	display:none;
}

/*
@font-face {
  font-family: 'fot-tsukubrdgothic-std';
  src: url('../fonts/TsukushiBRoundGothicRegula.woff') format('woff');
}
*/

body {
	font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "メイリオ", Meiryo, "ＭＳＰゴシック", sans-serif;
}
body.is-fixed {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
}
header {
	width:100vw;
	height:110px;
	background:#fff;
}
.headerBody {
	width:83vw;
	height:60px;
	margin:auto;
	position:relative;
}
.linkBnrBox {
	width:100vw;
	height:50px;
	background:url("../images/bg_linkbnrbox.png") top center ;
	display:flex;
	justify-content: center;
	align-items: center;
	position:relative;
	z-index:3;
	padding-top: 12px;
}
.linkBnrBox a {
	height:50px;
	width:320px;
}
.linkBnrBox a img {
	width:100%;
	height:auto;
}
.linkBnrBox img {
	transition:all .3s ease;
}
.linkBnrBox a:hover img {
	opacity:0.7;
}
h1.logo {
	position:absolute;
	top:17px;
	left:0;
	width:118px;
}
h1.logo img {
	width:100%;
	height:auto;
}

/*
スライドメニュー
================================================ */
/* 開閉ボタン */
.nemuBtn {
	position:absolute;
	top:20px;
	right:0;
	cursor: pointer;
	width: 95px;
    height: 27px;
}
.nemuBtn img {
	width: 100%;
    height: auto;
}
.btn-menu {
    position: fixed;
    right: 40px;
    top: 30px;
    z-index: 4;
    padding: 0 0;
    border: none;
    height: 4rem;
    width: 4rem;
    transition: all .3s ease;
}
/* 閉じるボタン */
#menu-close {
    border: 1px solid var(--light-green);
	background:url("../images/menu-close.svg") no-repeat;
	background-size:100%;
	width:min(10vw, 120px);
	height:min(2.5vw, 30px);
	cursor: pointer;	
}
#menu-close svg {
    fill: var(--light-green);
}
/* スライドメニューパネル */
#menu-panel {
	display: flex;
	justify-content: center;
    align-items: center;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 20;
    padding: 8rem 4vw 2rem;
    width: min(25vw, 300px);
    height: 100vh;
	box-sizing: border-box;
    translate: 100vw;
	background: transparent linear-gradient(180deg, #2652B9 0%, #E591D0 100%) 0% 0% no-repeat padding-box;
	background: linear-gradient(180deg, rgba(38,82,185,0.8687850140056023) 0%, rgba(229,145,208,0.8687850140056023) 100%);
	backdrop-filter: blur(13px) ;
	-webkit-backdrop-filter: blur(13px) brightness(19%) opacity(87%);	
}
.menu-list {
    list-style: none;
}
.menu-list li {
    margin: 0 0 min(3.3vw, 40px);
    opacity: 0;
}
.menu-list a {
    color: #fff;
    text-decoration: none;
    font-size: min(1.3vw, 1.6rem);
	font-weight:700;
	line-height: 1.0;
	position:relative;
}
.menu-list a::after {
    content: '';
    width: min(0.83vw,10px);
    height: 100%;
    background: url(../images/menu_arrow.svg) no-repeat center center;
    background-size: 70%;
    position: absolute;
    top: 0;
    right: -1.5em;
}
.menu-list a.insta::after {
    display:none;
}
article {
	height:auto;
	width:100vw;
	overflow:hidden;
}
.mv {
	width:100vw;
	height:45vw;
	position: relative;
	z-index:3;
}
.mv img {
	width:100%;
	height:auto;
}
.bnrCamp {
	position:absolute;
	top:15vw;
	left:62vw;
	width:14.8vw;
}
.bnrStory {
	position:absolute;
	top:31vw;
	left:66.5vw;
	width:13.6vw;
}
.bnrCamp img, .bnrStory img {
	width:100%;
	height:auto;
	transition:all .4s ease;
}
.bnrCamp a:hover img {
	opacity:0.7;
}
.scroll {
	position:fixed;
	bottom:0;
	left:22.5vw;
	width:33px;
	background-size:33px;
	transition:all .4s ease;
}
.scroll.bottomEnd {
	display:none;
}
.scrollFig {
	position:relative;
	bottom:0;
	left:0;
	width:33px;
	height:71px;
	background-size:33px;
}
.scrollFig::after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    transform: translateX(-50%);
    left: 16.2px;
    width: 13px;
    height: 13px;
    background-color: #fff;
    border-radius: 1000px;
    animation: circlemove 1.6s ease-in-out infinite, cirlemovehide 1.6s ease-out infinite;
}
@media screen and (max-width: 1300px) {
.scrollFig::after {
    left: 16px;
}	
}	
@keyframes circlemove {
  0% {
    bottom: 58%;
  }
  100% {
    bottom: 0;
  }
}
@keyframes cirlemovehide {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  80% {
    opacity: 0.9;
  }
  100% {
    opacity: 0;
  }
}
.newsArea {
	width:100%;
	height:40px;
	background:#fff;
	position: relative;
	z-index:3;
}
.newsAreaBox {
	width:800px;
	margin:auto;
	display: flex;
	justify-content: space-between;
	padding-top:0.8rem;
}
.newsAreaBox h2 {
	font-size:1.8rem;
	line-height: 1.3;
}
.newsAreaBox ul.slider  {
	width:max(45vw,630px);
	margin:auto;
	margin-left: 1.8rem;
}
.newsAreaBox ul.slider > li {
	width:max(45vw,630px);
	overflow:hidden;
	white-space: nowrap;
	font-size:1.4rem;
	color:#737373;
	opacity:0;
}
.newsAreaBox ul.slider > li.slick-active {
	opacity:1;
}
.newsAreaBox ul li span.date {
	font-size:1.4rem;
	margin-right:1rem;
}
.newsAreaBox ul li span.newsTtl {
	font-size:1.4rem;
}
.newsAreaBox ul li a {
	font-size:1.4rem;
	text-decoration:none;
	color:#737373;
}
.slick-prev:hover
{
    color:#737373;
    outline: none;
	background: url("../images/prev.jpg") no-repeat top center;
}
.slick-next:hover
{
    color:#737373;
    outline: none;
	background: url("../images/next.jpg") no-repeat top center;
}
.slick-prev:focus
{
    color:#737373;
    outline: none;
	background: url("../images/prev.jpg") no-repeat top center;
}
.slick-next:focus
{
    color:#737373;
    outline: none;
	background: url("../images/next.jpg") no-repeat top center;
}
.slick-prev {
    left:auto;
	right:-30px;
	background: url("../images/prev.jpg") no-repeat top center;
	width:25px;
	height:25px;
}
.slick-next {
    right: -55px;
	background: url("../images/next.jpg") no-repeat top center;
	width:25px;
	height:25px;	
}
.slick-prev:before, .slick-next:before {
    display:none;
}
.slick-prev.slick-disabled:before, .slick-next.slick-disabled:before
{
    display:none;
}
.slick-num {
	width:100%;
	text-align:center;
	font-family: 'Raleway', sans-serif;
	font-size:2rem;
	font-weight:700;
	color:#fff;
	margin-top:8px;
}
span.all-count {
	margin-left:-5px;
}
span.now-count {
	margin-right:-5px;
}
#news .slick-dots {
	display:none !important;
}
#news .slick-dotted.slick-slider {
	margin-top:3px;
    margin-bottom:0;
}
.demo {
	background: linear-gradient(0deg,#E591D0 0%, #264590 100%);
    height: 1500px;
    margin:0 auto 0;
	position:relative;
	width:100vw;
	overflow: hidden;
}
#star01 {
	position:fixed;
	top:290px;
	left:0; /*calc(calc(100% - 1166px) / 2)*/
	width:100%;
	text-align:center;
	opacity:1.0;
}
#star01 img {
	width:96.5vw;
	height:auto;
	margin:auto;
}
#element01 {
	position:absolute;/* fixed */
	top:100px;
	left:calc(min(25vw / 2));
	z-index:2;
	width:min(75vw,900px);
	height:61vw;
	text-align:center;
}
@media screen and (min-width: 1200px) {
#element01 {
	left:calc(calc(100vw - 900px) / 2);
}
}
figure.conceptImg {
	width:450px;
	margin:auto;
}
figure.conceptImg img {
	width:100%;
	height:auto;
}

ul.conceptList {
	display:flex;
	justify-content: space-between;
	width:min(75vw, 900px);
	margin:55px auto 0;
}
ul.conceptList li {
	
	font-weight: 500;
	font-style: normal;	
	font-size:min(1.2vw, 13px);
	line-height:1.6;
	color:#262626;
	width:min(23.8vw, 286px);
	height:min(26.8vw,321px);
	padding-top:min(6vw,7.4rem);
}
ul.conceptList li span {
	display:block;
	margin-top:10px;
	font-size:min(0.83vw, 10px);
	line-height:1.6;
	color:#262626;
}
ul.conceptList li:nth-child(1) {
	background:url("../images/bg_pt01.png") no-repeat;	
	background-size:100%;	
}
ul.conceptList li:nth-child(2) {
	background:url("../images/bg_pt02.png") no-repeat;	
	background-size:100%;	
	padding-top:min(7.5vw,9rem);
}
ul.conceptList li:nth-child(3) {
	background:url("../images/bg_pt03.png") no-repeat;	
	background-size:100%;	
	padding-top:min(7.5vw,9rem);
}
ul.conceptList li h2 {
	
	font-weight: 700;
	font-style: normal;
	font-size:min(1.5vw,18px);
	line-height:1.4;
	margin-bottom:1.2rem;
}
ul.conceptList li:nth-child(2) h2, ul.conceptList li:nth-child(3) h2 {
	margin-bottom:2.2rem;
}
#element02 {
	position:absolute;
	top:920px;
	left:calc(calc(100% - 733px) / 2);
	opacity:1.0;
	z-index:2;
	width:733px;
}
#element02 img {
	width:100%;
	height:auto;
}
p.toDetail {
	margin:-121px 0 0 35px;
	width:320px;
	height:50px;
}
p.toDetail a {
	display:flex;
	align-items: center;
	justify-content: center;
	height:50px;
	font-size:1.8rem;
	font-weight:bold;
	color:#fff;
	background:transparent;
	border:1px solid #fff;
	border-radius:8px;
	text-align:center;
	text-decoration:none;
	box-sizing: border-box;
	text-indent:-1em;
	position:relative;
	z-index:3;
	transition:all .3s ease;
}
p.toDetail a:hover {
	background:#fff;
	color:#9B70B1;
}
p.toDetail a::after {
	content:'';
	background:url("../images/arrow_detail.svg") no-repeat;
	background-size:100%;
	width:6px;
	height:10px;
	position:absolute;
	top:20px;
	right:76px;
	transition:all .4s ease;
}
p.toDetail a:hover::after {
	background:url("../images/arrow_detail_on.svg") no-repeat;
}
h2.productName {
	position: absolute;
    top: 242px;
    left: 70px;
    font-size: 24px;
    font-weight: 700;
	letter-spacing:1px; 
    color: #fff;
}
p.productSpec {
	position: absolute;
    top: 288px;
    left: 75px;
    font-size: 15px;
    font-weight: 700;
    color: #fff;
}
#fruit01 {
	position:fixed;
	top:calc(600px + 41.6vw);
	left:-64px;
	opacity:1.0;
	z-index:1;	
	display:none;
}
#fl01 {
	position:absolute;
	top:420px;/*calc(620px + 41.6vw)*/
	left:-45px;
	opacity:1.0;
	z-index:2;	
}
#fl02 {
	position:absolute;
	top:580PX;
	left:-35px;
	opacity:1.0;
	z-index:2;	
}
#fl03 {
	position:absolute;
	top:640PX;
	left:-4px;
	opacity:1.0;
	z-index:1;	
}
#fl04 {
	position:absolute;
	top:720PX;
	left:0;
	opacity:1.0;
	z-index:1;	
}
#fl05 {
	position:absolute;
	top:950PX;
	left:-35px;
	opacity:1.0;
	z-index:1;	
}
#fl06 {
	position:absolute;
	top:1000PX;
	left:-5px;
	opacity:1.0;
	z-index:1;	
}
#fl07 {
	position:absolute;
	top:1150PX;
	left:-30px;
	opacity:1.0;
	z-index:3;	
}
#fl08 {
	position:absolute;
	top:1300PX;
	left:50px;
	opacity:1.0;
	z-index:2;	
}
#fl09 {
	position:absolute;
	top:1260PX;
	left:90px;
	opacity:1.0;
	z-index:2;	
}
#fl10 {
	position:absolute;
	top:1300PX;
	left:-20px;
	opacity:1.0;
	z-index:1;	
}
#fl11 {
	position:absolute;
	top:890PX;
	left:0;
	opacity:1.0;
	z-index:1;	
}

#fruit02 {
	display:none;
	position:fixed;
	top:calc(600px + 41.6vw);
	right:-98px;
	opacity:1.0;
	z-index:1;
}
#fr01 {
	position:absolute;
	top:750PX;
	right:-55px;
	opacity:1.0;
	z-index:2;	
}
#fr02 {
	position:absolute;
	top:580PX;
	right:-98px;
	opacity:1.0;
	z-index:1;	
}
#fr03 {
	position:absolute;
	top:700PX;
	right:-58px;
	opacity:1.0;
	z-index:1;	
}
#fr04 {
	position:absolute;
	top:880PX;
	right:-80px;
	opacity:1.0;
	z-index:1;	
}
#fr05 {
	position:absolute;
	top:1200PX;
	right:-20px;
	opacity:1.0;
	z-index:1;	
}
#fr06 {
	position:absolute;
	top:1000PX;
	right:-40px;
	opacity:1.0;
	z-index:1;	
}
#fr07 {
	position:absolute;
	top:1150PX;
	right:-20px;
	opacity:1.0;
	z-index:3;	
}
#fr08 {
	position:absolute;
	top:1200PX;
	right:-50px;
	opacity:1.0;
	z-index:2;	
}
#fr09 {
	position:absolute;
	top:1400PX;
	right:-60px;
	opacity:1.0;
	z-index:2;	
}
#fr10 {
	position:absolute;
	top:1350PX;
	right:-98px;
	opacity:1.0;
	z-index:1;	
}
#fruitSP {
	display:none;
}
section#story {
	width:100vw;
	background:url("../images/bg_story.jpg") no-repeat top center;
	padding:10rem 0;
	position:relative;
	z-index: auto;
}
section#story .sectionBody {
	width:min(83vw,1000px);
	margin:auto;
	background:#FDFDF7;
	padding:min(7.1vw, 8.5rem) 10rem 4.1vw;
	box-sizing: border-box;
	border-radius:20px;
	position: relative;
    z-index: 3;
}
section#story h2 {
	background:url("../images/h2_story.svg") no-repeat top center;
	height:84px;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
	margin-bottom:4rem;
}
p.h2Sub {
	
    font-weight: 700;
    font-style: normal;
	font-size:2rem;
	line-height:1.6;
	width:100%;
	text-align:center;
	letter-spacing:0.1em;
	margin-bottom:2.8rem;	
}
p.leadTxt {
	
    font-weight: 700;
    font-style: normal;
	font-size: min(1.4vw, 1.6rem);
	line-height:2.2;
	text-align:center;
	margin-bottom:1.2em;		
}
p.leadTxt.togai {
	margin-bottom:0;		
}
p.attentionFin {
	
    font-weight: 700;
    font-style: normal;
	font-size:1.2rem;
	margin-top:-2em;
	text-align:center;
	position:relative;
	margin-bottom:3rem;
}
p.attentionFin::after {
	content:'';
	background:url("../images/after_att.svg") no-repeat top center;
	background-size:18px;
	width:100%;
	height:10px;
	position:absolute;
	bottom:-1em;
	left:0;
	text-align:center;
}
p.attention {
	font-size:min(1.5vw,1.5rem);
	font-weight:700;
	text-align:center;
	margin-top:3.5rem;
	margin-bottom:5.5rem;
	height:7rem;
	line-height:1.0;
	display:flex;
	align-items: center;
	justify-content: center;
	border-top:2px solid #70716C;
	border-bottom:2px solid #70716C;	
}
h3.prizeGold {
	
    font-weight: 700;
    font-style: normal;
	font-size:2.8rem;
	line-height:1.0;
	letter-spacing:0.1em;
	text-align:center;
	background:url("../images/crown_g.svg") no-repeat top center;
	background-size:50px;
	padding-top:5.3rem;
	margin-bottom:2.8rem;
}
figure.toContest {
	width:260px;
	margin:auto;
}
figure.toContest img {
	width:100%;
	height:auto;
	transition:all .3s ease;
}
figure.toContest a:hover img {
	opacity:0.7;
}
h4.workTtl {
	
}
h4.workTtl.gold {
	width:min(100%, 800px);
	height:auto;
	/*
	background:url("../images/bg_prize.png") no-repeat top right;
	border-radius:20px;
	display:flex;
	justify-content: center;
	align-items: center;
	*/
	margin:0 auto 3.2rem;
}
h4.workTtl.gold img {
	width:100%;
	height:auto;
}
/* 受賞作品モーダル */
p.modal-open {
	width: 320px;
	height: 70px;
	margin:auto auto 2.7rem;
	
}
p.modal-open a {
	display: block;
	
    font-weight: 700;
    font-style: normal;
	font-size: 2.2rem;
	width: 320px;
	height: 70px;
	line-height:70px;
	color: #fff;
	background-size:50px;
	border: none;
	border-radius:35px;
	margin:auto;
	text-align:center;
	position:relative;
	z-index:3;
	margin-bottom:3rem;
	cursor:pointer;
}
p.modal-open a span {
	display:block;
	width:10px;
	height:15px;
	position:absolute;
	top:29px;
	right:22px;
	background: url(../images/bg_arrow.svg) no-repeat;
	background-size:8px;
}
p.modal-open a::before {
	content:'';
	width:100%;
	height:100%;
	position:absolute;
	top:0;
	left:0;
	z-index:-1;
	background: #D08ACD;
	border-radius:35px;
	transition:all .4s ease;
}
p.modal-open a::after {
	content:'';
	width:100%;
	height:100%;
	position:absolute;
	top:0;
	left:0;
	z-index:-2;
	background: linear-gradient(180deg, #2652B9 0%, #E591D0 100%) ;/*  */
		border-radius:35px;
}
p.modal-open a:hover::before {
	opacity:0; ;
}
/* モーダルと背景の指定 */
.modal{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	text-align: center;
	background: url(../images/bg_story.jpg) no-repeat top center;
	padding: 40px 20px;
	overflow: hidden;
	opacity: 0;
	visibility: hidden;
	transition: .3s;
	box-sizing: border-box;
	z-index:100;
}
/* モーダルの擬似要素の指定 */
.modal:before{
	content: "";
	display: inline-block;
	vertical-align: middle;
	height: 100%;
	margin-left: -0.2em;
}
/* クラスが追加された時の指定 */
.modal.is-active{
	opacity: 1;
	visibility: visible;
}
/* モーダル内側の指定 */
.modal-container{
	position: relative;
	display: inline-block;
	vertical-align: middle;
}
/* モーダルを閉じるボタンの指定 */
.modal-close{
	position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    top: -40px;
    right: 0;
    width: 100px;
    height: 25px;
    color: #fff;
    border-radius: 0;
    cursor: pointer;
    background: url(../images/menu-close.svg) no-repeat;
	background-size: 100px;
}
/* モーダルのコンテンツ部分の指定 */
.modal-content{
	text-align: left;
	line-height: 1.8;
	padding: 0 0 0 0;
	height:60vh;
}
/* モーダルのコンテンツ部分のテキストの指定 */
.modal-content p{
	margin: 1em 0;
}
.slick-prev.slick-disabled, .slick-next.slick-disabled {
	display:none !important;
}
ul.sliderRead li {
	writing-mode: vertical-rl;
	font-size:2rem;
	line-height:2.2;
	-webkit-text-orientation: upright; 
	text-orientation: upright; 
}
section#story ul.sliderRead {
	width: min(90vw, 1000px) !important;
}
section#story .slick-slide { 
	width:min(90vw, 1000px) !important;
	height:min(45vw,490px);
	padding:0 0 0 0;
	display:flex !important;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	margin: auto 0;
}
.sldInner {
	width:100%;
	height:auto;
	padding:0 5px 0 0;
	box-sizing: border-box;
}
section#story .slick-slide img {
	width:100%;
	height:auto;
}
section#story .slick-prev {
	top: calc(calc(90% - 25px) / 2);
    left: auto;
	right: -40px;
	transform: rotate(180deg);
	z-index: 2;
	background: url(../images/next.svg) no-repeat top center;
}
section#story .slick-next {
	top: calc(calc(90% - 25px) / 2);
    right: auto;
	left:-40px;
	transform: rotate(180deg);
	z-index: 2;
	background: url(../images/prev.svg) no-repeat top center;	
}
section#story ul.slick-dots {
	bottom:0;
	left:0;
	width:100px;
}
section#story ul.slick-dots li {
	display:none;
}
section#story ul.slick-dots li:first-child {
	display:inline-block;
	opacity:1.0;
	transition:all 0.8s ease;
}
section#story ul.slick-dots li.slick-active:first-child {
	opacity:0;
}
section#story .slick-dots li button:before {
    font-family: inherit;
    font-size: 14px;
    line-height: 1.0;
    position: absolute;
    top: 0;
    left: 0;
    width: 100px;
    height: auto;
    content: '最初に戻る';
    text-align: center;
    opacity: 1.0;
    color: #fff;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
	writing-mode: horizontal-tb;
	border:1px solid #fff;
	box-sizing: border-box;
	padding:0.4em 1em;
	transition:all 0.5s ease;
}
section#story .slick-dots li:hover button:before {
	background:#2342AB;
	color:#fff;
}
section#story .slick-num {
	width:50%;
	margin:auto;
}
.fadeIn {
	opacity:0;
}
h4.author {
    font-size:min(1.3vw,1.6rem);
	font-weight:700;
	margin-bottom:1rem;
}
p.comentTxt {
    font-size:min(1.2vw, 1.4rem);
	border-top: 2px solid #A5A6A1;
    border-bottom: 2px solid #A5A6A1;
	padding:1.1rem 0;
	line-height:1.5;
	margin-bottom: 4.1vw;
	min-height:105px;
}
p.comentTxt.gold {
	min-height:auto;
}
.prizeOther {
	margin-top: min(6.1vw, 7.4rem);
	width:100%;
}
.prizeOther ul {
	width:100%;
	display:flex;
	justify-content: space-between;
}
.prizeOther ul li {
	width:min(48%, 380px)

}
h3.prizeOtr {
	
    font-weight: 700;
    font-style: normal;
    font-size: 2.4rem;
    line-height: 1.0;
    letter-spacing: 0.1em;
    text-align: center;
    padding-top: 4.5rem;
    margin-bottom: 4.5rem;
}
h3.prizeOtr.slv {
    background: url(../images/crown_s.svg) no-repeat top center;
	background-size:37px;
}
h3.prizeOtr.brz {
    background: url(../images/crown_b.svg) no-repeat top center;
	background-size:37px;
}
.prizeOther h4.workTtl {
	
    font-weight: 700;
    font-style: normal;
	font-size:min(2.4vw, 2.8rem);
	letter-spacing:0;
	width:100%;
	text-align:center;
	line-height:1.0;
	margin-bottom: 10px;
}
p.authorName {
	
    font-weight: 500;
    font-style: normal;
	font-size:2.0rem;
	letter-spacing:0.1em;
	width:100%;
	text-align:center;
	margin-bottom:3.9rem;
}
p.extLink a {
    display: block;
	
    font-weight: 700;
    font-style: normal;
    font-size: 2.2rem;
    width:min(84%,320px);
    height: 70px;
	line-height:70px;
    color: #fff;
    background: linear-gradient(90deg, rgba(209,140,207,1) 0%, rgba(208,137,205,1) 100%);
    border: none;
    border-radius: 35px;
    cursor: pointer;
    margin: auto;
    position: relative;
	margin-top:4.5rem;
    margin-bottom: 3rem;
	text-decoration:none;
	text-align:center;
}
p.extLink {
	width: min(26.6vw, 320px);
	height: 70px;
	margin:auto auto 2.2vw;
	
}
p.extLink a {
	display: block;
	
    font-weight: 700;
    font-style: normal;
	font-size: 2.2rem;
	width: 100%;
	height: 70px;
	line-height:70px;
	color: #fff;
	background-size:50px;
	border: none;
	border-radius:35px;
	margin:auto;
	text-align:center;
	position:relative;
	z-index:3;
	margin-bottom:0;
	cursor:pointer;
}
p.extLink a span {
	display:block;
    width: 25px;
    height: 22px;
	position:absolute;
    top: 25px;
    right: 22px;
	background: url(../images/bg_file.png) no-repeat;
	background-size:22px;
}
p.extLink a::before {
	content:'';
	width:100%;
	height:100%;
	position:absolute;
	top:0;
	left:0;
	z-index:-1;
	background: #D08ACD;
	border-radius:35px;
	transition:all .4s ease;
}
p.extLink a::after {
	content:'';
	width:100%;
	height:100%;
	position:absolute;
	top:0;
	left:0;
	z-index:-2;
	background: linear-gradient(180deg, #2652B9 0%, #E591D0 100%) ;/*  */
		border-radius:35px;
}
p.extLink a:hover::before {
	opacity:0; ;
}

@media screen and (max-width: 960px) {
p.extLink a {
    font-size: 1.4rem;
}
}

footer {
	width:100vw;
	height:83.3vw;
	background:url("../images/bg_footer.png") bottom center no-repeat;
	background-size:100vw;
	position: relative;
    margin-top: max(-29.1vw,-350px);
    z-index: 1;
}
.bnrInsta {
	position:absolute;
	/*
	top: calc(280px + 0.01vw);
	*/
	bottom:40.5vw;
	left:calc(calc(100vw - min(24.8vw, 298px)) / 2);
	width:min(25.8vw, 310px);
}
.bnrInsta img {
	width:100%;
	height:auto;
}
p.instaLead {
	position:absolute;
	/*
	top:calc( 280px + 22vw);
	*/
	bottom:27.5vw;
	left:0;
	width:100vw;
	text-align:center;
}
p.instaLead span {
	display:block;
	color:#ffffff;
}
.instaLead01 {
	font-size:min(2vw, 2.4rem);
	font-weight:500;
	margin-bottom:0;
}
.instaLead02 {
	font-size: min(2vw, 2.4rem);
    font-weight: 500;
    margin-bottom: 1em;
    background: url(../images/min_moon.png) no-repeat bottom 0.7vw right 2.5em;
    background-size: min(2vw, 2.4rem);
    display: inline-block !important;
    padding: 0 3.8em;
}
.instaLead03 {
	font-size:min(17.5vw, 2.1rem);
	font-weight:500;	
}
.logoFoot {
	position:absolute;
	bottom:min(9.3vw, 112px);
	left:calc(calc(100vw - min(22vw,263px)) / 2);
	width:min(22vw,256px);
}
ul.footLink {
	position:absolute;
	bottom:min(4.9vw, 59px);
	left:0;
	display:flex;
	justify-content:center;
	width:100vw;
	margin: auto;
}
ul.footLink li {
	display:inline-block;
}

ul.footLink li a {
	font-size:min(1.08vw,13px);
	text-decoration:none;
	color:#fff;
	padding:0 1.4em;
	position:relative;
}
ul.footLink li a::after {
	content:'';
	display:inline-block;
	width:1px;
	height:min(0.83vw,10px);
	position:absolute;
	top:6px;
	right:0;
	border-right:1px solid #fff;
}
ul.footLink li:last-child a::after {
	display:none;
}
.moon {
	position:absolute;
	/*
	top: calc(280px + 0.01vw);
	*/
	bottom:47.5vw;
	left: calc(calc(100vw - min(24.8vw, 298px)) / 3);
	width:6.7vw;
}

.logoFoot img, .moon img {
	width:100%;
	height:auto;
}
p.rights {
	position:absolute;
	bottom:min(2.4vw, 29px);
	left:0;
	width:100vw;
	text-align:center;
	font-family: 'Raleway', sans-serif;
	font-size:min(1vw, 1.2rem);
	color:#fff;
}
#back-top {
    position: fixed;
    bottom: 5vw;
    right: 2vw;
    z-index: 4;
}
#back-top a {
    display: block;
    height: 60px;
    width: 60px;
    background: url(../images/to_top.svg) no-repeat;
	background-size:100%;
}

.centering img {
	margin:auto;
}
.story_h2 img {
	width:min(49.75%,398px);
	height:auto;
}
.story_lead1 img {
	width:min(82%,656px);
	height:auto;
}
.story_lead2 img {
	width:min(61.5%,492px);
	height:auto;
	margin-bottom:5px;
}
.story_lead3 img {
	width:min(47.75%,382px);
	height:auto;
	margin-bottom:5px;
}
.story_lead4 img {
	width:min(42%,320px);
	height:auto;
	margin-bottom:5px;
}
.prizeGold a {
	padding-top:1.1em;
	box-sizing: border-box;
}
.prizeGold a img {
	width:175px;
	margin:0 auto 0;
}
.prizeOther li img {
	margin:0 auto 0;
}
.extLink a {
	padding-top:min(3vw,25px);
	box-sizing: border-box;
}
.extLink a img {
	width:min(52%,175px);
	margin:0 auto 0;
}
.conceptList li img {
	margin:0 auto 0;
}
.conceptList li img.point1_copy {
	width:min(80%,222px);
	margin-top: min(3vw,25px);
}
.conceptList li img.point2_copy {
	width:min(80%,222px);
	margin-top: min(-1.6vw,-1px);
}
.conceptList li img.point3_copy {
	width:min(80%,222px);
	margin-top: min(-2.2vw,-6px);
}
h3.prizeGold img {
	margin:auto;
}
.prizeOther ul li img{
	margin:auto;
}
.prizeOther ul li img.award_shiomi_h4 {
    width:min(42.29%,140px);
	margin-top:5px;
}
.prizeOther ul li img.award_itoen_h4 {
    width:min(93%,308px);
	margin-bottom:5px;
}



@media screen and (max-width: 750px) {
  .forPC {
    display: none !important; }

  .forSP {
    display: block !important; }
	
html {
  -webkit-overflow-scrolling: touch;
}	
header {
	height:auto;	
}	
.headerBody {
    width: 84vw;
	height:14vw;	
}	
h1.logo {
    position: absolute;
    top: 4.7vw;
    left: 0;
    width: 20.5vw;
	height:4.6vw;
}	
.nemuBtn {
    top: 4.82vw;
    width: 19.1vw;
    height: 4.36vw;
}	
.linkBnrBox {
	width:100vw;
    height: auto;
    background: none;
    padding-top: 0;
}
.linkBnrBox a {
	width: 100vw;
    height: 13.3vw;
}
.linkBnrBox img {
	width:100%;
	height:auto;
}	
.mv {
    height: 150.6vw;
}	
.bnrCamp {
    top: 65.6vw;
    left: auto;
	right:-1vw;
    width: 30.1vw;
}	
.bnrStory {
    top: 125.6vw;
    left: auto;
	right:2vw;
    width: 25vw;
}	
.scroll {
    left: 10vw;
    width: 8.8vw;
    transition: all .4s ease;
}	
.scrollFig {
    position: relative;
    bottom: 0;
    left: 0;
    width: 8.8vw;
    height: 71px;
	background:url("../images/scroll_sp.png");
    background-size: 8.8vw;
}	
.scrollFig img {
	display:none;	
}	
.scrollFig::after {
	left:calc(calc(100% - 3vw) / 2 ); 
    width: 3vw;
    height:2.9vw;
    border-radius:50%;
    animation: circlemove 1.6s ease-in-out infinite, cirlemovehide 1.6s ease-out infinite;
	transform:none;
}	

#menu-panel {
    display: flex;
    justify-content: center;
	align-items: flex-start;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 20;
    padding: 31.6vw 5vw 2rem 0;
    width: 53.6vw;
    height: 100vh;
}	
#menu-close {
    border: 1px solid var(--light-green);
    background: url(../images/menu-close.svg) no-repeat;
    background-size: 100%;
    width: 21.2vw;
    height: 5.6vw;
    cursor: pointer;
}	
.btn-menu {
    position: fixed;
    right: 6.6vw;
    top: 5.3vw;
    z-index: 4;
    padding: 0 0;
    border: none;
    height: 4rem;
    width: 4rem;
    transition: all .3s ease;
}
.menu-list li {
    margin: 0 0 8vw;
}	
.menu-list a {
    font-size: 3.4vw;
}	
.menu-list a::after {
    content: '';
    width: 1vw;
    height: 100%;
    background: url(../images/menu_arrow.svg) no-repeat center center;
    background-size: 100%;
    position: absolute;
    top: 0;
    right: -1.5em;
}	
a.insta img {
	width:6.6vw;
	height:auto;
}	
.demo {
    background: linear-gradient(0deg,#E591D0 0%, #264590 100%);
    height: 560vw;
    margin: 0 auto 0;
    position: relative;
    width: 100vw;
}	
#star01 {
    position: fixed;
    top: 180.2vw;
    left: 0;
    opacity: 1.0;
	width:100vw;
	height:auto;
}
#star01 img {
	width:100vw;
	height:auto;
}	
#element01 {
    top: 50px;
    left: 15vw;
    z-index: 2;
    width: 70vw;
    height: auto;
}	
figure.conceptImg {
	width:70vw;
	margin:auto;
}	
	
ul.conceptList {
    display: flex;
    justify-content: space-between;
	align-items: center;
	flex-wrap:wrap;
    width: 70vw;
    margin: 17.6vw auto 0;
}	
ul.conceptList li {
    
    font-weight: 500;
    font-style: normal;
    font-size:3.3vw;
    line-height: 1.6;
    color: #262626;
    width: 70vw;
    padding-top: 19vw;
	box-sizing: border-box;
}	
ul.conceptList li:nth-child(1) {
    background: url(../images/bg_pt01sp.png) no-repeat;
    background-size: 100%;
    height: 98vw;
}	
ul.conceptList li:nth-child(2) {
    background: url(../images/bg_pt02sp.png) no-repeat;
    background-size: 100%;
    padding-top: 19vw;
    height: 91vw;
}
ul.conceptList li:nth-child(3) {
    background: url(../images/bg_pt03sp.png) no-repeat;
    background-size: 100%;
    padding-top: 19vw;
    height: 91vw;
}	
	
ul.conceptList li h2 {
    font-size: 4.8vw;
    line-height: 1.4;
    margin-bottom: 5vw;
}	
ul.conceptList li:nth-child(2) h2 {
    margin-bottom: 5vw;
}	
ul.conceptList li:nth-child(3) h2 {
    margin-bottom:8vw;
}		
	
ul.conceptList li span {
    display: block;
    margin-top: 2vw;
    font-size: 2.6vw;
    line-height: 1.6;
    color: #262626;
}	

#fruit01, #fruit02 {
    display:none !important;
}
img.elements.forSP {
	width:100%;
	height:auto;
}	
	
#fl01sp {
	display:block;
    position: absolute;
    top: 380.7vw;
    left: -4.8vw;
    opacity: 1.0;
    z-index: 2;
    width: 12.4vw;	
}	
#fl02sp {
	display:block;
    position: absolute;
    top: 332.8vw;
    left: -5.6vw;
    opacity: 1.0;
    z-index: 2;
    width: 34.8vw;	
}	
#fl03sp {
	display:block;
    position: absolute;
    top: 353.1vw;
    left: -1.9vw;
    opacity: 1.0;
    z-index: 2;
    width: 16.9vw;	
}		
#fl04sp {
	display:block;
    position: absolute;
    top: 368.9vw;
    left: -5.16vw;
    opacity: 1.0;
    z-index: 3;
    width: 16.5vw;	
}		
#fl05sp {
	display:block;
    position: absolute;
    top: 383vw;
    left: -8.6vw;
    opacity: 1.0;
    z-index: 2;
    width: 37.8vw;	
}		
#fl06sp {
	display:block;
    position: absolute;
    top: 410.8vw;
    left: -2.2vw;
    opacity: 1.0;
    z-index: 2;
    width: 16.2vw;	
}		
#fl07sp {
	display:block;
    position: absolute;
    top: 421.6vw;
    left: -4.2vw;
    opacity: 1.0;
    z-index: 2;
    width: 26.9vw;	
}	
#fl08sp {
	display:none !important;
    position: absolute;
    top: 450.5vw;
    left: -7.2vw;
    opacity: 1.0;
    z-index: 2;
    width: 31.1vw;	
}		
#fl09sp {
	display:block;
    position: absolute;
    top: 458.3vw;
    left: -0.59vw;
    opacity: 1.0;
    z-index: 2;
    width: 32.9vw;	
}		
#fl10sp {
	display:block;
    position: absolute;
    top: 450vw;
    left: -1.79vw;
    opacity: 1.0;
    z-index: 2;
    width: 26.5vw;	
}		
#fl11sp {
	display:block;
    position: absolute;
    top: 505.1vw;
    left: -5.65vw;
    opacity: 1.0;
    z-index: 2;
    width: 18.06vw;	
}		
#fl12sp {
	display:block;
    position: absolute;
    top: 510.3vw;
    left: -17.7vw;
    opacity: 1.0;
    z-index: 2;
    width: 66.4vw;	
}	
#fl13sp {
	display:block;
    position: absolute;
    top: 580.7vw;
    left: -5.65vw;
    opacity: 1.0;
    z-index: 2;
    width: 21vw;	
}		
#fl14sp {
	display:block;
    position: absolute;
    top: 588.3vw;
    left: -7.45vw;
    opacity: 1.0;
    z-index: 2;
    width: 17.2vw;	
}	
#fl15sp {
	display:block;
    position: absolute;
    top: 470.5vw;
    left: -11.1vw;
    opacity: 1.0;
    z-index: 1;
    width:35vw;	
}
#fl16sp {
	display:block;
    position: absolute;
    top: 633.2vw;
    left: -13.49vw;
    opacity: 1.0;
    z-index: 2;
    width:41.35vw;	
}	
#fl17sp {
	display:block;
    position: absolute;
    top: 651.1vw;
    left: -1.84vw;
    opacity: 1.0;
    z-index: 2;
    width:33.4vw;	
}		
#fl18sp {
	display:block;
    position: absolute;
    top: 689.7vw;
    left: -10.8vw;
    opacity: 1.0;
    z-index: 2;
    width:26.19vw;	
}			
#fl19sp {
	display:block;
    position: absolute;
    top: 561.9vw;
    left: 0;
    opacity: 1.0;
    z-index: 2;
    width: 16.8vw;	
}		
#fl20sp {
	display:none !important;
    position: absolute;
    top: 674.5vw;
    left: -2.2vw;
    opacity: 1.0;
    z-index: 2;
    width: 11.6vw;	
}		
#fr01sp {
	display:block;
    position: absolute;
    top: 308.4vw;
    left: 78vw;
    opacity: 1.0;
    z-index: 2;
    width: 33.59vw;	
}	
#fr02sp {
	display:block;
    position: absolute;
    top: 408vw;
    left: 77.2vw;
    opacity: 1.0;
    z-index: 2;
    width: 25.74vw;	
}		
#fr03sp {
	display:block;
    position: absolute;
    top: 352.5vw;
    left: 75.6vw;
    opacity: 1.0;
    z-index: 2;
    width: 36.3vw;	
}		
#fr04sp {
	display:block;
    position: absolute;
    top: 383.7vw;
    left: 87.3vw;
    opacity: 1.0;
    z-index: 2;
    width: 16.9vw;	
}	
#fr05sp {
	display:block;
    position: absolute;
    top: 633vw;
    left: 80vw;
    opacity: 1.0;
    z-index: 2;
    width: 21.7vw;	
}		
#fr06sp {
	display:block;
    position: absolute;
    top: 424.4vw;
    left: 75vw;
    opacity: 1.0;
    z-index: 1;
    width: 39.46vw;	
}		
#fr07sp {
	display:block;
    position: absolute;
    top: 458.5vw;
    left: 83vw;
    opacity: 1.0;
    z-index: 2;
    width: 25.6vw;	
}		
#fr08sp {
	display:block;
    position: absolute;
    top: 473.2vw;
    left: 86.1vw;
    opacity: 1.0;
    z-index: 2;
    width: 14.68vw;	
}		
#fr09sp {
	display:block;
    position: absolute;
    top: 482.8vw;
    left:83vw;
    opacity: 1.0;
    z-index: 2;
    width: 27.4vw;
}		
#fr10sp {
	display:block;
    position: absolute;
    top: 481.5vw;
    left:76.5vw;
    opacity: 1.0;
    z-index: 2;
    width: 25.4vw;	
}		
#fr11sp {
	display:block;
    position: absolute;
    top: 512.9vw;
    left:70.2vw;
    opacity: 1.0;
    z-index: 1;
    width: 40vw;	
}		
#fr12sp {
	display:block;
    position: absolute;
    top: 546vw;
    left:79.1vw;
    opacity: 1.0;
    z-index: 2;
    width: 20.88vw;	
}	
#fr13sp {
	display:block;
    position: absolute;
    top: 558.89vw;
    left:80.3vw;
    opacity: 1.0;
    z-index: 2;
    width: 17.2vw;	
}		
#fr14sp {
	display:block;
    position: absolute;
    top: 574.1vw;
    left:79.5vw;
    opacity: 1.0;
    z-index: 2;
    width: 40.9vw;	
}	
#fr15sp {
	display:block;
    position: absolute;
    top: 612.5vw;
    left:74.97vw;
    opacity: 1.0;
    z-index: 2;
    width: 25.48vw;	
}		
#fr16sp {
	display:block;
    position: absolute;
    top: 619.9vw;
    left:80vw;
    opacity: 1.0;
    z-index: 2;
    width: 21.4vw;	
}		
#fr17sp {
	display:block;
    position: absolute;
    top: 647.8vw;
    left:74.29vw;
    opacity: 1.0;
    z-index: 2;
    width: 14.7vw;	
}	
#fr18sp {
	display:block;
    position: absolute;
    top: 647.8vw;
    left:69.89vw;
    opacity: 1.0;
    z-index: 1;
    width: 47.3vw;	
}		
#fr19sp {
	display:block;
    position: absolute;
    top: 686.7vw;
    left:84.97vw;
    opacity: 1.0;
    z-index: 2;
    width: 16.97vw;	
}		
#fr20sp {
	display:block;
    position: absolute;
    top: 698.39vw;
    left:80vw;
    opacity: 1.0;
    z-index: 2;
    width: 30.5vw;	
}	
#fruitSP {
	display:block;
    position: fixed;
    top: 400vw;
    left: -20vw;
    opacity: 1.0;
    z-index: 2;
    width: 139.1vw;
}	
#element02 {
    position: absolute;
    top: 410vw;
    left: 17.8vw;
    opacity: 1.0;
    z-index: 2;
    width: 64.5vw;
}
#element02.smartPhone {
    top: 1970vw;
}
#element01.pc750 {
    top: 1000px;
}
#element02.pc750 {
    top: 2000px !important;
}	
h2.productName {
    top: 102vw;
    left: 0;
    font-size: 3.2vw;
	text-align:center;
	width: 100%;
}	
p.productSpec {
    top: 108vw;
    left: 0;
    font-size: 2vw;
	text-align:center;
	width: 100%;
}	
p.toDetail {
    margin: 0 0 0 0;
	position:absolute;
	top: 120vw;
	left:11vw;
	width: 42vw;
    height: 10.6vw;
}	
p.toDetail a {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 10.6vw;
    font-size: 3.4vw;
    font-weight: bold;
}	
p.toDetail a::after {
    width: 1.2vw;
    height: 5vw;
    top: 4.2vw;
    right: 5vw;
}
section#story {
    width: 100vw;
    background: url(../images/bg_story.jpg) repeat top center;
	background-size:400vw;
    padding: 10vw 0;
    position: relative;
}	
section#story h2 {
    background: url(../images/h2_story.svg) no-repeat top center;
	background-size:100%;
    height: 9.6vw;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
	margin:auto;
    margin-bottom: 7vw;
	width:25.3vw;
}	
section#story .sectionBody {
    width:88vw;
    margin: auto;
    background: #fff;
    padding: 9.8vw 6vw 9vw;
    box-sizing: border-box;
    border-radius: 2.1vw;
    position: relative;
    z-index: 3;
}
p.h2Sub {
    font-size: 3.2vw;
    line-height: 1.6;
    width: 100%;
    text-align: center;
    letter-spacing: 0;
    margin-bottom: 2vw;
}	
p.leadTxt {
    font-size:2.6vw; /* 2.4vw */
    line-height: 1.6;
    text-align: center;
    margin-bottom: 1.2em;
	font-feature-settings: "palt";
}	
p.leadTxt.togai {
    margin-bottom:2vw;
}	
p.attentionFin {
    font-size: 2vw;
    margin-top: -4vw;
    text-align: center;
    position: relative;
    margin-bottom: 3rem;
}	
p.attentionFin::after {
    content: '';
    background: url(../images/after_att.svg) no-repeat top center;
    background-size: 2.4vw;
    width: 100%;
    height: 3vw;
    position: absolute;
    bottom: -3.5vw;
}
figure.toContest {
    width: 34.6vw;
    margin: auto;
	margin-bottom: 2vw;
}	
p.attention {
    font-size: 2.6vw;
    margin-top: 7vw;
    margin-bottom: 8vw;
    height: 7rem;
    line-height: 1.8;
    display: flex;
    align-items: center;
    justify-content: center;
    border-top: 1px solid #70716C;
    border-bottom: 1px solid #70716C;
    padding: 3vw 0;
}	
h3.prizeGold {
    
    font-weight: 700;
    font-style: normal;
    font-size: 4.6vw;
    line-height: 1.0;
    letter-spacing: 0.1em;
    text-align: center;
    background: url(../images/crown_g.svg) no-repeat top center;
    background-size: 8vw;
    padding-top: 5.3rem;
    margin-bottom: 2.8rem;
}	
p.modal-open {
    width: 51.4vw;
    height: 10.6vw;
    margin: auto auto 10vw;
}	
p.modal-open a {
    display: block;
    
    font-weight: 700;
    font-style: normal;
    font-size: 3.4vw;
    width: 51.4vw;
    height: 10.6vw;
    line-height: 10.6vw;
    color: #fff;
    background-size: 50px;
    border: none;
    border-radius: 35px;
    margin: auto;
    text-align: center;
    position: relative;
    z-index: 3;
    margin-bottom: 3rem;
    cursor: pointer;
}	
h4.workTtl.gold {
    width: 100%;
    height: auto;
    margin: 0 auto 5vw;
}	
p.modal-open a span {
    display: block;
    width: 1.5vw;
    height: 3.0vw;
    position: absolute;
    top: 4.2vw;
    right: 4vw;
    background: url(../images/bg_arrow.svg) no-repeat;
    background-size: 100%;
}	
h4.author {
    font-size:3.6vw;
    font-weight: 700;
    margin-bottom: 1vw;
	text-align:center;
}
p.comentTxt {
    font-size: 3vw;
    border-top: 1px solid #A5A6A1;
    border-bottom: 1px solid #A5A6A1;
    padding: 3vw 0;
    line-height: 1.5;
    margin-bottom: 4.1vw;
    min-height: auto;
}	
.prizeOther {
    margin-top: 10vw;
    width: 100%;
}	
.prizeOther ul {
    width: 100%;
    flex-wrap: wrap;
}	
.prizeOther ul li {
    width:100%;
}
h3.prizeOtr {
    
    font-weight: 700;
    font-style: normal;
    font-size: 4.6vw;
    line-height: 1.0;
    letter-spacing: 0.1em;
    text-align: center;
    padding-top: 8vw;
    margin-bottom: 4.5rem;
}		
h3.prizeOtr.slv {
    background-size: 8vw;
}	
.prizeOther h4.workTtl {
    font-size: 5.2vw;
	font-weight:700;
    letter-spacing: 0;
    width: 100%;
    text-align: center;
    line-height: 1.0;
    margin-bottom: 0.5rem;
}
p.authorName {
    
    font-weight: 500;
    font-style: normal;
    font-size: 3.3vw;
    letter-spacing: 0.1em;
    width: 100%;
    text-align: center;
    margin-bottom: 3.9rem;
}		
.prizeOther h4.author {
    text-align: left;
}	
p.extLink {
    width: 51.4vw;
    height: 10.6vw;
    margin: 6vw auto 2.2vw;
}	
.prizeOther p.extLink a {
    font-size: 3.4vw;
    width: 51.4vw;
    height: 10.6vw;
    line-height: 10.6vw;
    color: #fff;
    background-size: 50px;
    border: none;
    border-radius: 40px;
    margin: auto;
    text-align: center;
    position: relative;
    z-index: 3;
    margin-bottom: 0;
    cursor: pointer;
}	
p.extLink a span {
    display: block;
    width: 4.2vw;
    height: 3.7vw;
    position: absolute;
    top: 3.5vw;
    right: 4vw;
    background: url(../images/bg_file.png) no-repeat;
    background-size: 100%;
}	
h3.prizeOtr.brz {
	margin-top:10vw;
    background-size: 8vw;
}	
	
footer {
    width: 100vw;
    height: 145vw;
    background: url(../images/bg_footer_sp.png) bottom center no-repeat;
    background-size: 100vw;
    position: relative;
    margin-top: -23.3vw;
    z-index: 2;
}	
.moon {
	display:none;	
}
.bnrInsta {
    bottom: 88vw;
    left: 30.1vw;
    width: 39.8vw;
}	
p.instaLead {
    position: absolute;
    bottom: 67vw;
    left: 0;
    width: 100%;
    text-align: center;

}	
.instaLead01 {
    font-size:3.6vw;
	font-feature-settings: "palt";
}	
.instaLead02 {
    font-size: 3.6vw;
    margin-bottom: 1.5vw;
    background: url(../images/min_moon.png) no-repeat bottom 1vw right 3.6vw;
    background-size: 3.6vw;
    display: inline-block !important;
    padding: 0 8vw;
	font-feature-settings: "palt";
}	
.instaLead03 {
    font-size:2.8vw;
}	
.logoFoot {
    bottom: 25vw;
    left: 33.4vw;
    width: 33.2vw;
}
	
ul.footLink {
    position: absolute;
    bottom: 11vw;
    left: 7vw;
    display: flex;
    justify-content: center;
	flex-wrap: wrap;
    width: 86vw;
    margin: auto;
}	
ul.footLink li {
	margin-bottom:2vw;
	line-height:1.0;
	padding:0 0 0 0;
}	
ul.footLink li a {
    font-size:2.4vw;
	font-weight:400;
	font-feature-settings: "palt";
	padding:0 1.9em;
	line-height:1.0;
	display: inline-block;
}	
p.rights {
    bottom: 5vw;
    font-size:2.4vw;
}	
#back-top {
    bottom: 5vw;
    right: 4vw;
}	
#back-top a {
    height: 10vw;
    width: 10vw;
    background: url(../images/to_top.svg) no-repeat;
    background-size: 10vw;
	line-height:1.0;
}	
ul.footLink li a::after {
    content: '';
    display: inline-block;
    width: 1px;
    height: 2vw;
    position: absolute;
    top: 0.3vw;
    right: 0;
    border-right: 1px solid #fff;
}	
/* ものがたり */	
section#story ul.sliderReadSP {
    width:80vw !important;
	margin-top: 11vw;
}
section#story ul.sliderReadSP.iPad {
    width:450px !important;
}	
section#story .slick-slide {
    width:80vw !important;
    height: 100%;
    display: flex !important;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    margin: auto 0;
	padding: 0 0;
    box-sizing: border-box;
}
section#story ul.sliderReadSP.iPad .slick-slide {
    width:450px !important;
}
.modal {
    width: 100%;
	height:100%;
	padding:0 0 0 0;
	min-height: 100vh; /* カスタムプロパティ未対応ブラウザ用のフォールバック */
	min-height: calc(var(--vh, 1vh) * 100);
}
.modal:before {
    content: "";
    display: inline-block;
    vertical-align: middle;
    height: 0;
    margin-left: -0.2em;
}
.modal-content {
    text-align: left;
    line-height: 1.8;
    padding: 0 0 0 0;
    height: 100vh;
	margin-top: 0;
}	
.modal-close {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    top: 4vw;
    right: 10vw;
    width: 18vw;
    height: 6vw;
    color: #fff;
    border-radius: 0;
    cursor: pointer;
    background: url(../images/menu-close.svg) no-repeat;
    background-size: 18vw;
	z-index: 5;
}	
section#story .slick-num {
    width: 100%;
    text-align: center;
    font-family: 'Raleway', sans-serif;
    font-size: 4.5vw;
    font-weight: 700;
    color: #fff;
    margin-top: 0;
	position:absolute;
	bottom: -8vw;
	left:0;
}
section#story ul.slick-dots {
    bottom: auto;
    left: 0;
    width: 40%;
    text-align: left;
    top: -8vw;
}	
section#story .slick-dots li button:before {
    font-size: 3vw;
    line-height: 1.0;
    position: absolute;
    top: 0;
    left: 0;
    width: 20vw;
    height: auto;
    content: '最初に戻る';
    text-align: center;
    opacity: 1.0;
    color: #fff;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    writing-mode: horizontal-tb;
    border: 1px solid #fff;
    box-sizing: border-box;
    padding: 0.3em 0.4em;
    transition: all 0.5s ease;
	z-index:5;
}	
section#story .slick-next {
    top: 50%;
    right: auto;
    left: -8vw;
    transform: rotate(180deg);

}	
section#story .slick-prev {
    top: 50%;
    left: auto;
    right: -8vw;
    transform: rotate(180deg);
}	
.modal-container {
    display: flex;
    align-items: center;
    justify-content: center;
}	
.newsArea {
    height: 21.3vw;
	width:100%;
	padding:2vw 8vw;
	box-sizing: border-box;
}	
.newsAreaBox {
	width:100%;
	height: auto;
    margin: auto;
    display: flex;
    justify-content: space-between;
	align-items: center;
    padding-top: 0;
	box-sizing: border-box;
}
.newsAreaBox h2 {
    font-size: 4vw;
	height:9.6vw;	
    line-height: 9.6vw;
}
#news .slick-dotted.slick-slider {
    margin-top: 0;
	height:9.6vw;
    width: 70vw;
    margin: auto;
    margin-left: 1.8rem;
}	
.newsAreaBox ul li {
    width: 100%;
    overflow:visible;
    white-space: nowrap;
    color: #737373;
}
.newsAreaBox ul li span.newsTtl {
	width: 50vw;
    height: 9vw;
    font-size: 3.2vw;
    float: right;
	white-space: normal;
	font-feature-settings: "palt";
    display: flex;
	align-items: center;
}
.newsAreaBox ul li span.date {
	width:18.4vw;
	height:9.6vw;	
    line-height: 9.6vw;	
	display: inline-block;
    font-size: 3.2vw;	
}	
#news .slick-dots {
    display: block !important;
    position: absolute;
    bottom: -9.7vw;
	left:-21vw;;
    width: 100vw;
	height:8.7vw;
    padding: 0;
    margin: 0;
	margin-left: 0;
    list-style: none;
    text-align: center;
	background:#465C9A;
}	
#news .slick-dots li {
    position: relative;
    display: inline-block;
    width: 20px;
    height: 8.7vw;
    margin: 0 5px;
    padding: 0;
    cursor: pointer;
}
#news .slick-dots li button::before {
    content: '';
    height: 8.7vw;
	display:flex;
	align-items: center;
	background:url("../images/bg_dot.jpg") no-repeat center center;
	background-size:2.6vw;
}
#news .slick-dots li.slick-active button::before {
	background:url("../images/bg_dot_active.jpg") no-repeat center center;
}
#news .slick-prev {
	top:15.5vw;
    left: -12.1vw;
    right: auto;
    background: url(../images/bg_prev.jpg) no-repeat top center;
	background-size:2.4vw;
    width: 2.4vw;
    height: 3.7vw;
	z-index:3;
}
#news .slick-next {
	top:15.5vw;
    left: auto;	
    right: 0;
    background: url(../images/bg_next.jpg) no-repeat top center;
	background-size:2.4vw;
    width: 2.4vw;
    height: 3.7vw;
	z-index:3;
}	
	
#news .slick-prev.slick-disabled, #news .slick-next.slick-disabled {
    display: block !important;
}
.sldInner {
	padding: 0 1vw 0 1vw;
}	

img.point1_h2_sp  {
	width:62%;
}		
img.point1_copy_sp  {
	width:78%;
}	
img.point2_h2_sp  {
	width:62%;
}		
.conceptList li img.point2_copy_sp  {
	width:78%;
	margin-top:-5vw;
}		
img.point3_h2_sp  {
	width:62%;
}		
.conceptList li img.point3_copy_sp  {
	width:78%;
	margin-top:-9vw;
}		
.prizeGold img	 {
	width:10vw;
}		
.prizeGold a img {
    width: 30vw;
}	
img.award_shiomi_h3_sp {
    width: 25vw;
}	
img.award_shiomi_h4_sp {
    width: 25vw;
	margin-bottom:2vw;
}	
img.award_shiomi_name_sp {
    width: 27vw;
}	
.prizeOther ul li img.award_shiomi_name_sp {
	margin-top:3vw;
}		
.prizeOther ul li img.award_itoen_name_sp {
    margin-top: 3vw;
}	
	
.extLink a img {
    width: 28vw;
	margin-top: 0.6vw;
}	
img.award_itoen_h3_sp {
    width: 30.5vw;
}	
img.award_itoen_h4_sp {
    width: 60vw;
}	
img.award_itoen_name_sp {
    width: 27vw;
	margin-top:1vw;
}	
	
.story_h2 img {
    width: 80%;
}	
.story_lead1 img {
    width: 88%;
	margin-top:3vw;
}	
.story_lead2 img {
    width: 70%;
    margin-bottom: 5px;
}	
.story_lead3 img {
    width: 70%;
}	
img.story_lead4_sp {
    width: 70%;
}	
	
	
	
	
	
	
	
	

}