@charset "UTF-8";

/*
----------------------------------------*/
.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}

* html .clearfix {
	height: 0px !important;
}

body {
	margin: 0;
	padding: 0;
}

#special {
	/*overflow-x : hidden !important;*/
}

a {
	transition: .2s;
	border: 0 !important;
}

a:hover {
	text-decoration: none !important;
}

.special_fixed {
	position: fixed !important;
	top: -137px;
	z-index: 10000;
}

.special_fixed:hover {}

.hidden {
	overflow: hidden;
}

.block {
	display: block;
}

a {
	text-decoration: none !important;
}

#special {
	font-size: 14px;
	font-family: "游明朝体", "YuMincho", "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
	color: #000000 !important;
	list-style: none;
	line-height: 2.0em;
}

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

a img {
	border: 0;
}

ul {
	margin: 0;
	padding: 0;
}

li {
	list-style: none;
	margin: 0;
	padding: 0;
}

.pc {
	display: none;
}

.sp {
	display: block;
}

@media screen and (min-width: 1000px) {
	#special {
		width: 100% !important;
		margin: 0 auto !important;
	}

	.pc {
		display: block !important;
	}

	.sp {
		display: none !important;
	}
}


/* PCサイドナビ(通常)
------------------------------------------------------------*/
.side-nav {
	position: fixed;
	bottom: 0;
	z-index: 100 !important;
}

.side-nav ul {
	display: flex;
	flex-direction: row;
	padding: 0;
	margin: 0;
}

.side-nav ul li {
	margin: 0;
	padding: 10px 0 5px 0;
	height: 25px;
	list-style-type: none;
	width: calc(100% / 9);
	transition: all .3s;
}

.side-nav .special_sidenav li a img:hover {
	transform: scale(1.05, 1.05) !important;
}

@media screen and (min-width: 1000px) {
	.side-nav {
		top: 7%;
		right: 0px;
		z-index: 100;
		height: 320px;
	}

	.side-nav ul {
		flex-direction: column;
		margin: 0;
		padding: 0;
	}

	.side-nav ul li {
		width: 100%;
		margin-bottom: 15px;
	}

	.side-nav ul li:last-child {
		margin-bottom: 0 !important;
	}

	.side-nav ul a img {
		display: block;
		width: 90px;
		padding: 0 0 3px 0;
	}

	.side-nav ul li:hover {
		opacity: 0.5;
	}

	.side-nav .header__link.is-active img {
		opacity: 1
	}

	.side-nav .header__link.is-active::after {}
}


/* SPボトムナビ
----------------------------------------*/
.spnavbox {}

ul.spnav {
	position: fixed;
	bottom: 0;
	width: 100%;
	list-style: none;
	margin: 0;
	padding: 0;
	z-index: 200 !important;
}

ul.spnav li {
	width: 33.33333%;
	margin: 0;
	padding: 0;
	float: left;
}


/* MOVIE
----------------------------------------
.movie {
	position: relative;
	padding-bottom: 10%;
}
.movie .video-container {
	position: relative;
	width: 50vw; 
	height: calc(50vw * 16/ 9);
	overflow: hidden;
	margin: 0 auto !important;
	padding: 0 !important;
	z-index: 2;
}
.movie .video-container video {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.movie #videoPlaceholder {
	width: 100%;
	height: auto;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 1;
	display: none;
}

@media (min-width: 1000px) {
	.movie {
		padding-bottom: 20px;
	}
	.movie .video-container {
		position: relative;
		max-width: 500px;
		height: calc(500px * 9 / 16);
		overflow: hidden;
		margin: 0 auto !important;
		padding: 0 !important;
	}
	.movie .video-container video {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		width: 100%;
		height: 100%;
		object-fit: contain;
	}
}*/



/* アコーディオン(ブランドで見る＆サイズで見る)
----------------------------------------*/
.linkarea {
	margin-bottom: 10%;
}
.accordion {
	width: 100%;
	text-align: center !important;
}
.accordion2 {
	width: 100%;
	text-align: center !important;
}
.acmenu {
	margin-left: 5% !important;
	width: 90%;
	font-size: 15px;
	text-align: center;
	margin-bottom: 5%;
	border: 1px solid #4eb3cf;
}
.acmenu ul {
	padding: 0 !important;
	margin: 0 !important;
}
.acmenu ul li {
	list-style: none !important;
	border: 1px solid #fffffff !important;
	background: #4eb3cf !important;
	color: #fff !important;
}
.acmenu ul li:first-child,
.acmenu ul li:nth-child(2),
.acmenu ul li:nth-child(3),
.acmenu ul li:nth-child(4),
.acmenu ul li:nth-child(5),
.acmenu ul li:nth-child(6) {
	background: #bababa;
	border: none !important;
}
.acmenu ul li a {
	display: block;
	color: #ffffff !important;
	cursor: pointer;
	line-height: 50px;
	font-size: 15px;
	text-align: center !important;
}
.acmenu li a:after,
.acmenu li a.active:after {
	position: absolute;
	color: #fff !important;
}
.acmenu li a:after {}

.acmenu ul li a:hover {
	background: #cccccc !important;
}
.acmenu li a.active:after {}

.acmenu>ul>li>ul {
	display: none;
}
.acsubmenu li {
	width: 100%;
	display: block;
	height: 50px;
	position: relative;
	line-height: 50px;
	font-size: 14px;
	margin-bottom: 1px;
	text-align: center !important;
}
@media screen and (min-width: 1000px) {
	.linkarea {
		width: 1000px;
		height: 150px;
		position: relative;
		margin: 0 auto !important;
	}
	.linkarea .link1 {
		position: absolute;
		left: 50px;
		width: 400px;
	}
	.linkarea .link2 {
		position: absolute;
		right: 50px;
		width: 400px;
	}
	.acmenu {
		margin-left: 0 !important;
		width: 400px;
		font-size: 14px;
		text-align: center;
	}
	.acmenu ul li a {
		display: block;
		color: #fff !important;
		cursor: pointer;
		line-height: 50px;
		font-size: 16px;
		text-align: center !important;
	}
}


/* FOOTER
----------------------------------------*/
.btnarea {
    width: 90%;
    margin: 0 5% 20% 5%;
    letter-spacing: 0.5px;
}

.button {
    margin: 0 auto 5% auto;
    width: 100%;
    padding: 3% 0;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1em;
    color: #000000;
    cursor: pointer;
    position: relative;
    font-weight: 400;
    font-style: normal;
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif !important;
}

.btnarrow {
    position: absolute;
    right: 20px;
    top: 17px;
    width: 35px;
    height: 8px;
    border-bottom: 1px solid #000;
    border-right: 1px solid #000;
    transform: skew(45deg) translateX(0);
    transition: transform 0.4s ease;
}

.btnarrow.short {
    width: 20px;
}

.btnarrow.sustainablearrow {
    top: 27px;
}

.button:hover .btnarrow {
    transform: skew(45deg) translateX(8px); /* 右に柔らかくずれる */
}

.button.comingsoon:hover {
    cursor: default;
    background: #fff !important;
}

.btnarea .button {
    border: none !important;
}

.itembtnarea .button {
    width: 97% !important;
    margin: 0 auto;
    border-bottom: 10px solid #eeeeee !important;
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
    text-align: left !important;
    padding-bottom: 0 !important;
    justify-content: inherit !important;
    padding-left: 3% !important;
    font-size: 1.2em;
    line-height: 0.8em;
    font-feature-settings: "palt";
    letter-spacing: 1px;
}

@media screen and (min-width: 1000px) {
    .btnarea {
        margin: 160px auto 80px auto !important;
    }

    .button {
        margin: 20px auto 0 auto;
        width: 500px;
        height: 50px;
        font-size: 16px;
        padding: 0;
    }

    .btnarrow {
        right: 40px;
        top: 17px;
        width: 50px;
    }

    .btnarrow.sustainablearrow {
        top: 27px;
    }

    .button:hover {
        background: #ffffff;
    }

    .itembtnarea .button {
        width: 380px !important;
        line-height: 0.5em !important;
        margin: 0 auto !important;
        height: 30px !important;
    }
}


.vol2 {
	width: 90%;
	margin: 0 5% 20% 5% !important;
	border: 1px solid #000;
	text-align: center;
	/*padding:2% 0;
	font-size:1rem;
	line-height:2;
	background:#fff;*/

}

.vol2-label {
	font-size: 1em;
	margin: 0 auto 10px auto !important;
	text-align: center;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif !important;
}


@media screen and (min-width: 1000px) {
	.vol2 {
		/*width:480px;
		padding:10px 0;
		font-size:18px;*/
		width: 520px;
		margin: 0 auto 40px auto !important;
	}
}

#otherarea {
	width: 100%;
	margin: 0 auto !important;
	padding-top: 10% !important;
	padding-bottom: 30px !important;
}

@media screen and (min-width: 1000px) {
	#otherarea {
		width: 100%;
		margin: 0 auto !important;
		padding-top: 0 !important;
		padding-bottom: 0 !important;
	}
}

.infoarea {
	text-align: center;
	width: 100%;
	color: #000;
}

.infoarea p {
	margin: 5% auto 3% auto;
	text-align: center;
	width: 100%;
}

.infoarea .btnarea .button {
	color: #000;
	background-color: transparent !important;
	border: 1px solid #000 !important;
}

.infoarea .btnarea .btnarrow {
	right: 15px !important;
}

@media screen and (min-width: 1000px) {
	.infoarea {
		width: 1000px;
		margin: 0 auto !important;
	}

	.infoarea .ttl {
		width: 500px;
		margin: 0 auto !important;
	}

	.infoarea p {
		margin: 20px auto 0 auto;
		text-align: center;
		width: 100%;
		font-size: 16px;
	}

	.infoarea .btnarea {
		margin: 0 auto 80px auto !important;
	}

	.infoarea .btnarea .btnarrow {
		right: 40px !important;
	}
}

.sustainable {
	background: #f6f6f6;
	text-align: center;
	padding: 10% 5% 1% 5%;
}

.sustainable p {
	font-size: 1.1em;
	margin: 5% 0 5% 0;
	line-height: 1.8em;
}

.sustainable .btnarea {
	margin-bottom: 10% !important;
}

.sustainable .button {
	font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho Pro', serif !important;
	padding: 3% 0 0 0 !important;
	border-bottom: 7px solid #c5e4c7 !important;
}

.instagram {
	background: #f6f6f6;
	text-align: center;
	padding: 10% 5% 1% 5%;
	margin-top: 10%;
	margin-bottom: 10%;
}

.instagram .instagramttl {
	width: 25%;
	margin: 0 auto 5% auto;
}

.instagram p {
	font-size: 1.2em;
	margin: 5% 0;
	line-height: 1.8em;
}

.instagram .btnarea {
	margin-bottom: 10% !important;
}

.instagram .button {
	background: #ffffff !important;
	border: 1px solid #ffffff !important;
	font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho Pro', serif !important;
}

@media screen and (min-width: 1000px) {
	.rp-footer-flex {
		display: flex;
		justify-content: center;
		align-items: flex-start;
		gap: 60px;
		max-width: 1190px;
		margin: 0 auto;
		padding: 40px 0;
	}

	.sustainable,
	.instagram {
		width: 48%;
		height: 200px;
		margin: 0 auto 50px auto;
		padding: 40px 0 0 0;
	}

	.sustainable {
		padding-top: 30px;
		height: 210px;
	}

	.sustainable img {
		width: 80%;
		margin: 0 50px;
	}

	.sustainable p {
		font-size: 18px;
		margin: 20px 0 0 0;
	}

	.sustainable .btnarea {
		margin: 0 auto !important;
	}

	.sustainable .button {
		padding-top: 1.5% !important;
		padding-bottom: 0;
		width: 25rem;
	}

	.instagram .instagramttl {
		width: 100px;
		margin: 0 150px;
	}

	.instagram p {
		font-size: 18px;
		margin: 20px 0 0 0;
	}

}

.page-top a {
	width: 40px;
	position: fixed;
	bottom: calc(10px + env(safe-area-inset-bottom));
	right: 25px;
	/*padding: 10px;*/
	display: block;
	z-index: 1000;
}

.page-top a:hover {
	bottom: calc(10px + env(safe-area-inset-bottom));
}

.copyright {
	text-align: center;
	font-size: 10px;
	padding-bottom: 50px;
	margin: 40px auto 0 auto;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}

@media screen and (min-width: 1000px) {
	.page-top a {
		width: 40px;
		position: fixed;
		bottom: 15px;
		right: 30px;
		/*padding: 10px;*/
		display: block;
	}

	.page-top a:hover {
		bottom: 20px;
	}

	.copyright {
		padding-bottom: 20px;
	}
}



/* クレジット関係
-------------------------------------------------*/
.creditlist {
	margin: 0;
	padding: 0;
	width: 100%;
}

/*.flex .creditlist{
	margin:calc(100vw*0.25) 5% 0 5%;
	padding:0;
}*/
.creditlist ul {
	margin: 0;
	padding: 0;

}

.creditlist li {
	display: flex;
	margin: 0;
	padding: 0 0 10px 0;
	align-items: center;
}

.creditlist li .item_name {
	flex: 1;
	text-align: left !important;
}

.creditlist li .item_brand {
	width: 24%;
	text-align: left !important;
}

.creditlist li .item_price {
	width: 32%;
	text-align: center;
	/*width: 28%;
	text-align: right;*/
}

.creditlist li .item_name,
.creditlist li .item_brand,
.creditlist li .item_price {
	font-size: 0.9em;
}

.creditlist li .item_price small {
	font-size: 0.7em;
}

.creditlist li .item_name {}

@media screen and (min-width: 1000px) {
	.creditlist {
		margin: 0 auto;
		width: 90%;
		max-width: 400px;
	}

	.flex .creditlist {
		margin: calc(100vw*0.33) 0 0 0;
		padding: 0;
		width: 380px;
	}

	.creditlist li {}

	.creditlist li .item_name,
	.creditlist li .item_brand,
	.creditlist li .item_price {
		font-size: 1em;
	}
}

/*buybtnbox
----------------------------------------*/
.creditlist .buybtnbox {
    background-color: transparent;
    width: 25%;
    border: 1px solid #000;
}

.buybtnbox {
    display: block;
    width: 6em;
    margin: 0 0 0 2%;
    color: #004850;
}

.buybtn {
    position: relative;
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 1.6em;
    background-color: transparent;
    color: #000000;
}

.buybtn:hover {
    color: #000000;
}

/* テキスト：初期はセンター、ホバーで矢印分だけ左へ */
.buybtnText {
    color: #000000;
    font-size: 12px;
    letter-spacing: 0 !important;
    transform: translateX(0);
    transition: transform 0.5s;
    margin: 0;
    text-align: center;
}

.buybtnText.buybtnText01 {
    color: #000000 !important;
}

.buybtn:hover .buybtnText {
    transform: translateX(-3px);
}

/* 矢印：初期は非表示、ホバーでスライドイン */
.buybtnArrow {
    overflow: hidden;
    width: 0;
    opacity: 0;
    transition: width 0.5s, opacity 0.5s;
}

.buybtnArrow img {
    display: block;
    width: 20px;
    transform: translateX(-100%);
    transition: transform 0.5s;
}

.buyarrow {
    width: 20px;
}

.buybtn:hover .buybtnArrow {
    width: 20px;
    opacity: 1;
}

.buybtn:hover .buybtnArrow img {
    transform: translateX(0);
}

@media screen and (max-width: 999px) {
    .creditlist .buybtnbox {
        background-color: transparent;
        border: 1px solid #000;
    }

    .buybtnbox {
        width: 5.5em;
    }

    .buybtn {
        height: 2em;
    }

    .buybtnText {
        font-size: 0.8em;
        line-height: 1.25;
        letter-spacing: 0;
    }

    .buybtnArrow {
        margin-top: 10px;
    }
}

/* MV
----------------------------------------*/
.logo {
	width: 40%;
	margin:2% 30%; 
}
#special_head {
	margin: 0 !important;
	padding: 0 !important;
	width: 100%;
	height: calc(100vw* 0.947);
	position: relative;
	overflow: hidden;
}
#special_head .mv1{
	position:absolute;
	width:32.3%;
}
#special_head .mv2{
	position:absolute;
	width: 47.9%;
    left: 20.3%;
}
#special_head .mv3{
	position:absolute;
	width:47.4%;
	right:0
}
#special_head .mvsub1{
		position:absolute;
		    width: 76.5%;
    top: calc(100vw * 0.55);
}
#special_head .mvsub2{
		position:absolute;
		    width: 97.3%;
    right: 0;
    top: calc(100vw * 0.61);
}
#special_head .mvsub3{
		    position: absolute;
    width: 28.5%;
    left: 39%;
    top: calc(100vw * 0.62);
}
#special_head .mvunfilo{
		position:absolute;
		    width: 58%;
    left: 3%;
    top: calc(100vw * 0.8);
}
#special_head .mvunfilo2{
		position:absolute;
		    width: 12%;
    right: 3%;
    top: calc(100vw * 0.82);
}
.attention {
	margin-top: 3%;
}

@media screen and (min-width: 1000px) {
	.logo {
		width: 20%;
		margin:10px 40%;
	}
	.mv {
		width: 100%;
		height: calc(100vw*0.596);
		display: block;
		overflow: hidden;
	}
	#special_head {
		margin: 0 !important;
		padding: 0 !important;
		width: 100%;
		height: calc(100vw*0.63);
		position: relative;
	}
	#special_head .mv1{
		position:absolute;
		width:34.7%;
	}
	#special_head .mv2{
		position:absolute;
		        width: 39.6%;
        left: 27%;
	}
	#special_head .mv3{
		position:absolute;
		width:43.1%;
		right:0
	}
	#special_head .mvsub1{
		position:absolute;
		        width: 59.5%;
        top: calc(100vw * 0.325);
	}
	#special_head .mvsub2{
		position:absolute;
		        width: 74.3%;
        right: 0;
        top: calc(100vw * 0.354);
    }
	#special_head .mvsub3{
		position:absolute;
		width: 21%;
        left: 54%;
        top: calc(100vw * 0.36);
    }
	#special_head .mvunfilo{
		position:absolute;
		width: 48%;
        left: 5%;
        top: calc(100vw * 0.496);
    }
	#special_head .mvunfilo2{
		position:absolute;
		        width: 9%;
        left: 60%;
        top: calc(100vw * 0.514);
    }
	.attention {
		width: 600px;
		margin: 20px auto 0 auto !important;
	}
}



/* =========================
   textbox
========================= */
.textbox {
	position: relative;
	width: 100%;
	margin: 10vw auto 0;
	padding: 0;
}
.textbox .movie {
	width: 62%;
	margin: 16vw auto 0;
	position: relative;
	z-index: 1;
}
.textbox .scenecontent {
	width: 100%;
	margin-top: 8vw;
}
.textbox .scenecontent p{
	text-align:center;
}
.textbox .scenecontent span.pink{
	color:#ff7f82;
}
.textbox p {
	width: 90%;
	margin: 9% auto 10% auto;
	font-size: 0.9em;
	line-height: 2;
	font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho Pro', serif !important;
}
.textbox .subttlbox{
	position:relative;
	width:90%;
	margin:0 auto 1% auto;
	aspect-ratio: 690 / 75;
}
.textbox .subttlbox .subttlbg1{
	width:100%;
	position:absolute;
	top:24%;
}
.textbox .subttlbox .subttl_s{
	position: absolute;
    width: 5.5%;
    left: 4%;
}
.textbox .subttlbox .subttl_m{
	    position: absolute;
    width: 10.5%;
    left: 12%;
}
.textbox .subttlbox .subttl_l{
	position: absolute;
    width: 4.5%;
    left: 25%;
}
.textbox .subttlbox .subttl1{
	position: absolute;
    width: 62%;
    right: 7%;
    top: 42%;
}
.textbox .subttlbox2{
	position:relative;
	width:53%;
	margin:0 auto 2% auto;
	aspect-ratio: 390 / 57;
}
.textbox .subttlbox2 .subttlbg2{
	width:100%;
	position:absolute;
	z-index:1;
}
.textbox .subttlbox2 .subttl2{
	position: absolute;
    width: 85%;
   left:7%;
	z-index:2;
	top: 19%;
}
.textbox .subttlbox3{
	position:relative;
	width:80%;
	margin:5% auto;
	aspect-ratio: 580 / 160;
}
.textbox .subttlbox3 .subttl3{
	width:100%;
	position:absolute;
}
.textbox .subttlbox3 .subttlline{
	width:70%;
	position:absolute;
	margin-left:19%;
	top:37%;
}
.textbox .subttlbox3 .subttl4{
	width:60%;
	position:absolute;
	margin-left:20%;
	top:50%;
}
@media screen and (min-width: 1000px) {
	.textbox {
		width: 80%;
		max-width: 1190px;
		margin: 6% auto 7%;
		padding: 0;
	}
	.textbox .subttlbox{
		width:80%;
		max-width:900px;
		margin:0 auto 1% auto;
	}
	.textbox .subttlbox2{
		width:45%;
		max-width:700px;
		margin:0 auto 1% auto;
	}
	.textbox .subttlbox3{
		margin:2% auto 0 auto;
		width:100%;
		max-width:1000px;
		aspect-ratio: 800 / 65;
	}
	.textbox .subttlbox3 .subttl3{
		width:61%;
		left:0;
		position:absolute;
		top:0;
	}
	.textbox .subttlbox3 .subttl4{
		width:37%;
		right:0;
		position:absolute;
		top:0;
	}
	.textbox .subttlbox3 .subttlline {
		width: 44%;
		position: absolute;
		margin-left: 11%;
		top: 77%;
	}
	.textbox .scenecontent {
		width: 100%;
		margin-top: 0;
	}
	
	.textbox p {
		width: 100%;
		margin: 3% 0 0;
		font-size: 18px;
		line-height: 2.2;
	}
}



/* nav
----------------------------------------*/
.navbox{
	background:#f6f6f6;
	padding:2rem 5% 3rem 5%;
}
.navttl{
	width:30%;
	margin:0 35% 3% 35%;
}
ul.special_nav {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
ul.special_nav li {
	width: 30% !important;
	position: relative;
}
ul.special_nav li img {
  display: block;
  width: 100%;
  box-sizing: border-box;
}
ul.special_nav li .navphoto {
	display: block;
	width: 100%;
	box-sizing: border-box;
}

ul.special_nav li:nth-child(1) .navphoto{
	border:1px solid #feb0b2;
}
ul.special_nav li:nth-child(2) .navphoto{
	border:1px solid #4eb3cf;
}
ul.special_nav li:nth-child(3) .navphoto{
	border:1px solid #32d01d;
}

ul.special_nav li .navno {
	position: absolute;
    width: 70%;
    left: 15%;
    bottom: -18%;
    z-index: 2;
}

@media screen and (min-width: 1000px) {
	.navbox{
		padding: 2rem 0 5rem 0;
	}
	.navttl{
		width:20%;
		margin:0 40% 1% 40%;
	}
	ul.special_nav {
		max-width: 900px;
		width: 80%;
		margin: 0 auto;
	}

	ul.special_nav li {
		height: auto !important;
		width: 31% !important;
		margin-bottom: 1%;
	}

	ul.special_nav li a {
		display: block;
		position: relative;
		width: 100%;
		line-height: 0;
	}

	ul.special_nav li .navphoto {
		position: relative !important;
		/* staticでも可 */
		width: 100%;
		height: auto;
		display: block;
	}
	ul.special_nav li .navno {
		position: absolute;
		width: 60%;
		left: 20%;
		bottom: -12%;
		z-index: 2;
	}
}

/* animation
----------------------------------------*/

/*fadeRightLeftMV(右→左)*/
.fadeRightLeftMV.wow.animated {
	animation-name: fadeRightLeftMV;
	animation-duration: 1.8s;
	animation-timing-function: ease;
	animation-delay: 0.4s;
	animation-iteration-count: 1;
	animation-direction: normal;
	animation-fill-mode: forwards;
	opacity: 0;
	will-change: opacity;
}

.fadeRightLeftMV {
	opacity: 0;
}

@keyframes fadeRightLeftMV {
	0% {
		opacity: 0;
		filter: blur(6px);
		transform: translateX(30%);
	}

	100% {
		opacity: 1;
		filter: blur(0);
		transform: translateX(0);
	}
}

/*fadeLeftRightMV(左→右)*/
.fadeLeftRightMV.wow.animated {
	animation-name: fadeLeftRightMV;
	animation-duration: 1.8s;
	animation-timing-function: ease;
	animation-delay: 0.4s;
	animation-iteration-count: 1;
	animation-direction: normal;
	animation-fill-mode: forwards;
	opacity: 0;
	will-change: opacity;
}

.fadeLeftRightMV {
	opacity: 0;
}

@keyframes fadeLeftRightMV {
	0% {
		opacity: 0;
		filter: blur(6px);
		transform: translateX(-30%);
	}

	100% {
		opacity: 1;
		filter: blur(0);
		transform: translateX(0);
	}
}


/* itemarea
----------------------------------------*/
.modelbox {
	margin: 30% auto 10% auto;
}
.modelbox .modelphoto a {
	display: block;
}
.modelbox .modelsize {
	width: 90%;
	text-align: right;
	padding: 2% 5%;
	font-size: 0.8rem;
}
.modelbox .creditlist {
	width: 80%;
	margin: 0 auto;
	margin-top: 5%;
}
.modelttlbox{
	width:60%;
	position:relative;
	aspect-ratio: 486 / 186;
	margin:0 20% 5% 20%;
}
.modelttlbox .modelttl{
	width:100%;
	position:absolute;
	z-index:2;
}
.modelttlbox p{
	position:absolute;
	z-index:3;
	text-align:center;
	letter-spacing:2px;
	width:100%;
	bottom:0;
	padding:0;
	margin:0;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif !important;
	font-weight:bold;
}
.modelttlbox p span{
	font-size:1.1rem;
}
.modelttlsubbox{
	font-size:1.15rem;
	text-align:center;
	width:100%;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif !important;
	font-weight:bold;
	margin-bottom:5%;
	letter-spacing:0.5px;
}
#ssize .modelttlsubbox{
	border-bottom:1px solid #ff7f82;
	color:#ff7f82;
}
.modeltext{
	font-size: clamp(12px, 2vw, 20px);
	line-height:1.8;
	margin:0 5% 10% 5%;
}
.modelphoto{
	width:90%;
	margin:0 auto;
}
.modelphoto .photoright{
	margin-top:5%;
}
.modelphoto::after {
  content: "";
  display: block;
  clear: both;
}
.setphoto{
	width:90%;
	margin:0 auto;
}
.setphoto .recommend{
	width:22%;
	margin:0 auto -12% 3%;
	position:relative;
	aspect-ratio: 77 / 81;
	z-index: 100;
}
.setphoto .recommend .recommend1{
	position:absolute;
}
.setphoto .recommend .recommend2{
	position:absolute;
}
.setphoto .setmodel{
}
@media screen and (min-width: 1000px) {
	.modelbox {
		width: 90%;
		margin: 100px auto 80px auto;
	}
	.modelttlbox{
		width:50%;
		max-width:500px;
		position:relative;
		aspect-ratio: 486 / 186;
		margin:0 auto 40px auto;
	}
	.modelttlbox .modelttl{
		width:100%;
		position:absolute;
		z-index:2;
	}
	.modelttlbox p{
		position:absolute;
		z-index:3;
		text-align:center;
		letter-spacing:2px;
		width:100%;
		bottom:0;
		padding:0;
		margin:0;
		font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif !important;
		font-weight:bold;
		font-size:1.4rem;
	}
	.modelttlbox p span{
		font-size:1.5rem;
	}
	.modelttlsubbox{
		font-size:1.7rem;
		border-bottom:none !important;
		margin-bottom:40px;
	}
	#ssize .modelttlsubbox p {
	  display: inline-block;
	  border-bottom: 1px solid #ff7f82;
	  padding-bottom: 4px;
		margin:0;
	}
	.modeltext{
		font-size:1rem;
		margin-bottom:40px;
		text-align:center;
	}
	.modelbox .modelphoto {
		display: flex;
		width:100%;
		max-width:1280px;
	}
	.modelbox .modelphoto img,
	.setphoto img{
		width: 100%;
		/*margin-bottom:20px;*/
	}
	.modelbox .modelphoto .photoleft{
		width:48%;
		margin-right:4%;
	}
	.modelbox .modelphoto .photoright{
		width:48%;
		margin:0;
	}
	.modelbox .modelsize {
		width: 100%;
		text-align: right;
		padding: 10px 10px 0 0;
	}
	.modelbox .creditlist {
		width: 300px;
		margin: 0 auto;
		margin-top: 20px;
	}
	.setphoto{
		width:48%;
		margin: 5% auto 0 auto;
			max-width:640px;
	}
	.setphoto .recommend {
		width: 25%;
		margin: 0 auto -14% -9%;
		position: relative;
		aspect-ratio: 77 / 81;
	}
}

@media screen and (max-width: 375px) {}


/*================================================
スマホ版 特集商品一覧ボタン
================================================*/
.sp-tokushu-btn {
	position: fixed;
	bottom: calc(75px + env(safe-area-inset-bottom));
	right: 15px;
	z-index: 1000;
	display: block;
}
.sp-tokushu-btn a {
	display: block;
	width: 60px;
	padding-bottom: 10px;
	contain: paint;
}
.sp-tokushu-btn img {
	width: 100%;
	height: auto;
	display: block;
}
@media screen and (min-width: 1000px) {
	.sp-tokushu-btn {
		display: none;
	}
	.sp-tokushu-btn {
		position: fixed;
		bottom: 90px;
		right: 15px;
		z-index: 1000;
		display: block;
	}
	.sp-tokushu-btn a {
		display: block;
		width: 72px;
		/*padding: 10px;*/
		padding-bottom: 10px;
	}
	.sp-tokushu-btn img {
		width: 100%;
		height: auto;
		display: block;
	}
}

.itembtn{
	width:90%;
	margin:10% 5% 20% 5%;
	padding:2% 0;
	text-align:center;
	background:#ffdada;
	font-size:1rem;
	color:#000;
}
@media screen and (min-width: 1000px) {
	.itembtn{
		width:400px;
		margin:30px auto 0 auto;
		padding:10px 0;
	}
}

/*0420 temporary*/

#msize .modelttlsubbox {
    border-bottom: 1px solid #4eb3cf;
    color: #4eb3cf;
}

#lsize .modelttlsubbox {
    border-bottom: 1px solid #32d01d;
    color: #32d01d;
}

#msize .itembtn {
	background: #b4dbe8;
	color: #000;
}

#lsize .itembtn {
	background: #b9e5a5;
	color: #000;
}
#msize.modelbox .modelphoto .msize1 {
	margin-top:5%;
}

@media screen and (min-width: 1000px) {
	#msize.modelbox .modelphoto {
		flex-wrap: wrap;
		justify-content: center;
	}

	#msize.modelbox .modelphoto .msize1 {
		margin-right: 0;
		margin-top: 40px;
	}

	#lsize.modelbox .modelphoto {
		margin-right: none;
		margin-top: 40px;
	}

	#lsize.modelbox .modelphoto {
		justify-content: center;
	}

	#lsize.modelbox .modelphoto .photoleft {
		margin-right: 0;
	}

	#lsize.modelbox .setphoto-wrapper {
		display: flex;
		flex-wrap: nowrap;
		margin: 5% auto 0 auto;
		max-width:1280px;
	}

	#lsize.modelbox .setphoto-wrapper .setphoto {
		margin: inherit;
		max-width: inherit;
		width:48%;
	}

	#lsize.modelbox .setphoto-wrapper:first-child {
		margin-right: 4%;
	}

    #msize .modelttlsubbox p {
        display: inline-block;
        border-bottom: 1px solid #4eb3cf;
        padding-bottom: 4px;
        margin: 0;
    }

    #lsize .modelttlsubbox p {
        display: inline-block;
        border-bottom: 1px solid #32d01d;
        padding-bottom: 4px;
        margin: 0;
    }
}

@media screen and (min-width: 1000px) {
	#ssize,#msize,#lsize{
		margin-bottom:200px !important;
	}
}