@charset "UTF-8";
@import url(//fonts.googleapis.com/earlyaccess/notosansjp.css);

#sp_navi {
	z-index: 2147483647;
}

body #container {
	margin-left: 0;
	margin-right: 0;
 position: relative;
 z-index: 1;
}

/* =================================================================
	common
================================================================= */


@font-face {
 font-family:'Noto Serif Japanese';
 font-style:normal;
 font-weight:400;
 src:url("/syohin/rwd/fonts/NotoSerifCJKjp-Regular-sub.woff2") format("woff2"),url("/syohin/rwd/fonts/NotoSerifCJKjp-Regular-sub.woff") format("woff")
}

@font-face {
 font-family:'Noto Serif Japanese';
 font-style:normal;
 font-weight:500;
 src:url("/syohin/rwd/fonts/NotoSerifCJKjp-Medium-sub.woff2") format("woff2"),url("/syohin/rwd/fonts/NotoSerifCJKjp-Medium-sub.woff") format("woff")
}

@font-face {
 font-family:'Noto Serif Japanese';
 font-style:normal;
 font-weight:700;
 src:url("/syohin/rwd/fonts/NotoSerifCJKjp-SemiBold-sub.woff2") format("woff2"),url("/syohin/rwd/fonts/NotoSerifCJKjp-SemiBold-sub.woff") format("woff")
}

#container .img-fluid {
	max-width: 100%;
	height: auto;
}

#container table.hanging .hanging_icon {
	white-space: nowrap;
	vertical-align: top;
	min-width: 2em;
}

#container #product_outline {
  border-top: 1px solid #dddddd;
}

@media print, screen and (min-width: 769px){
	body {
		min-width: 960px;
		overflow-x: auto;
	}

	#container {
		min-width: 960px;
		width: 100%;
		padding-top: 0 !important;
		margin-top: 25px !important;
		overflow: hidden;
		position: relative;
		font-size: 16px;
		line-height: 1.875;
		font-family: "游ゴシック Medium", YuGothic, "游ゴシック", Meiryo, "メイリオ", "ＭＳ Ｐゴシック", sans-serif;
		font-weight: 400;
	}

	#container .pc-hide {
		display: none !important;
	}

	#container .content_inner {
		width: 960px;
		margin-left: auto;
		margin-right: auto;
	}

	#container table.hanging {
		font-size: 14px;
		line-height: 1.571;
	}

	#container #product_outline {
		padding: 0;
		border-bottom: solid 1px #dddddd;
	}

	#container #product_outline .content_inner {
		box-sizing: border-box;
		padding: 0;
		display: flex;
		justify-content: space-between;
		align-items: center;
	}

	#container #product_outline .content_inner #outline_logo {
		width: 320px;
		padding: 0 50px;
		box-sizing: border-box;
	}

	#container #product_outline .content_inner .outline_select {
		display: flex;
		border-left: 1px solid #cccccc;
	}

	#container #product_outline .content_inner .outline_select li {
		border-right: 1px solid #cccccc;
	}

	#container #product_outline .content_inner .outline_select li a:before,
	#container #product_outline .content_inner .outline_select li a:after {
		content: "";
		display: block;
		width: 0;
		height: 3px;
		background: #202020;
		position: absolute;
		right: 0;
		left: 0;
		margin: auto;
		transition: .3s .1s ease-in-out;
		pointer-events: none;
	}

	#container #product_outline .content_inner .outline_select li a:before {
		top: 0;
	}

	#container #product_outline .content_inner .outline_select li a:after {
		bottom: 0;
	}

	#container #product_outline .content_inner .outline_select li:hover a:before,
	#container #product_outline .content_inner .outline_select li:hover a:after {
		width: 100%;
	}

	#container #product_outline .content_inner .outline_select li a {
		display: block;
		z-index: 1;
		cursor: pointer;
		position: relative;
	}

	.share_area ul {
		max-width: 960px;
		margin: 0 auto;
		padding: 10px 0 30px;
		display: flex;
		justify-content: flex-end;
	}

	.share_area ul li {
		margin: 0 8px;
		width: 40px;
		height: 40px;
	}
}

@media screen and (max-width: 768px){
	body #container {
		position: relative;
		margin: 0 auto;
	}

	body #container.gnav-have {
    padding-top: 57px;
    position: relative;
    margin: 0 auto;
    font-size: 12px;
    line-height: 1.6;
  }

	body #container:not(.gnav-have) {
		margin-top: -65px;
		padding-top: 65px;
	}

	body #container .content_inner {
		max-width: 500px;
		margin-left: auto;
		margin-right: auto;
	}

	#container .sp-hide {
		display: none !important;
	}

	#container table.hanging {
		font-size: 10px;
		line-height: 1.1;
	}

	#container #product_outline {
		border-bottom: solid 1px #dddddd;
	}

	#container #product_outline .content_inner {
		box-sizing: border-box;
	}

	#container #product_outline #outline_logo {
		max-width: 210px;
		margin: 15px auto;
		text-align: center;
	}

	#container #product_outline .content_inner #outline_logo {
		padding: 0 80px;
	}

	#container #product_outline .content_inner .outline_select {
		display: flex;
	}

	#container #product_outline .content_inner .outline_select li {
		position: relative;
		flex: 100%;
	}

	.share_area ul {
		margin: 0 8px;
		padding: 10px 0 30px;
		display: flex;
		justify-content: center;
	}

	.share_area ul li {
		margin: 0 10px;
		width: 40px;
		height: 40px;
	}
}


/* anchor_link */
@media print, screen and (min-width: 769px){
	#container .anchor_link {
		padding-top: 70px !important;
		margin-top: -70px !important;
	}
}


/* link_detail */
@media print, screen and (min-width: 769px){
	#container .link_detail {
		padding-top: 58px;
		background: url(../img/common/bg_detail.jpg) repeat;
	}

	#container .link_detail h3 {
		width: 290px;
		height: 40px;
		margin: 0 auto 40px;
		text-indent: -9999px;
		background: url(../img/common/detail_title.png) repeat;
	}

	#container .link_detail ul {
		display: flex;
		justify-content: space-between;
		padding: 0 0 29px;
	}

	#container .link_detail ul li:nth-child(odd) {
		width: 428px;
	}

	#container .link_detail ul li:nth-child(even) {
		width: 416px;
	}

	#container .link_detail ul li.fadein {
		opacity: 0;
	}

	#container .link_detail ul a {
		transition: .2s;
	}

	#container .link_detail ul a:hover {
		opacity: .7;
	}

}

@media screen and (max-width: 768px){
	#container .link_detail {
		background: url(../img/common/bg_detail.jpg) repeat;
		background-size: cover;
	}

	#container .link_detail h3 {
		font-family: 'Noto Serif Japanese', serif;
		font-size: 26px;
		color: #fff;
		text-align: center;
		padding: 40px 0 0;
	}

	#container .link_detail ul {
		padding: 30px 20px 0;
		text-align: center;
	}

	#container .link_detail ul li {
		padding-bottom: 40px;
	}

	#container .link_detail ul li.fadein {
		opacity: 0;
	}

	#container .link_detail ul a {
		display: block;
		text-align: center;
	}

}

@media screen and (max-width: 500px){
	#container .link_detail h3 {
		font-size: 5.3vw;
	}
}

/* brand_gnav */
@media print, screen and (min-width: 769px){
	#container #brand_gnav {
    width: 100%;
    /*padding: 30px 48px 40px 0;*/
    padding: 35px 35px 40px 0;
    background: linear-gradient(rgba(0,0,0,.5) 0%, transparent  70%);
    box-sizing: border-box;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
  }
 
  #container #brand_gnav .enbudaki_logo {
  width: 144px;
  position: absolute;
  left: 60px;
  top: 24px;
  z-index: 1;
 } 

  #container #brand_gnav #brand_gnav_btn {
    display: none;
  }

  #container #brand_gnav ul {
    display: flex !important;
    justify-content: flex-end;
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    box-sizing: border-box;
    position: relative;
  }

	#container #brand_gnav ul > li {
    margin-left: 43px;
  }

	#container #brand_gnav ul a {
    display: block;
    /*height: 20px;*/
    height: 34px;
    text-indent: -9999px;
    line-height: 1;
    transition: .3s;
  }

  #container #brand_gnav ul a:hover {
    opacity: .5;
  }

  #container #brand_gnav .gnav_top a {
    display: block;
    /*width: 55px;*/
    width: 64px;
    background: url("../img/common/menu_top.png") no-repeat center center;
    background-size: contain;
  }

  #container #brand_gnav .gnav_concept a {
    display: block;
    /*width: 140px;*/
    width: 88px;
    background: url("../img/common/menu_concept.png") no-repeat center center;
    background-size: contain;
  }
 
  #container #brand_gnav .gnav_feature a {
    display: block;
    width: 134px;
    background: url("../img/common/menu_feature.png") no-repeat center center;
    background-size: contain;
  }
 
  #container #brand_gnav .gnav_lineup a {
    display: block;
    width: 139px;
    background: url("../img/common/menu_lineup.png") no-repeat center center;
    background-size: contain;
  }
 
  #container #brand_gnav .gnav_recommend a {
    display: block;
    width: 156px;
    background: url("../img/common/menu_contents.png") no-repeat center center;
    background-size: contain;
  }

  #container #brand_gnav .gnav_library a {
    display: block;
    width: 70px;
    background: url("../img/common/menu_cm.png") no-repeat;
    background-size: contain;
  }

	#container #brand_gnav ul li .is-active {
    pointer-events: none;
	}

}
@media screen and (max-width: 768px){
	#container #brand_gnav {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		font-family: 'Noto Serif Japanese', serif;
		z-index: 100;
	}

  #container #brand_gnav .enbudaki_logo {
   display: none;
 } 
 
	#container #brand_gnav.is-fix {
		position: fixed;
		top: 65px;
	}

	#container #brand_gnav #brand_gnav_btn {
		position: relative;
		display: block;
		height: 57px;
		background: url(../img/common/gnav_bg.jpg) repeat;
		background-size: cover;
		line-height: 57px;
		font-size: 17px;
		color: white;
		padding-left: 1em;
	}

	#container #brand_gnav #brand_gnav_btn::before {
		content: "";
		width: 19.5px;
		height: 1px;
		background: #fff;
		position: absolute;
		right: 15px;
		top: 0;
		bottom: 0;
		margin: auto;
	}

	#container #brand_gnav #brand_gnav_btn::after {
		content: "";
		width: 1px;
		height: 19.5px;
		background: #fff;
		position: absolute;
		right: 24px;
		top: 0;
		bottom: 0;
		margin: auto;
		transition: all 0.3s ease;
	}

	#container #brand_gnav #brand_gnav_btn.is-active::after {
		height: 0;
	}


	#container #brand_gnav ul {
		display: none;
	}

	#container #brand_gnav ul li {
		border-bottom: solid 1px #404040;
		background: #34322f;
	}

	#container #brand_gnav ul li:first-child {
		border-top: solid 1px #404040;
	}

	#container #brand_gnav ul li a,
	#container #brand_gnav ul li span {
		letter-spacing: 0.05em;
		position: relative;
		padding: 15px 30px 15px 15px;
		font-size: 15px;
		display: block;
	}

	#container #brand_gnav ul li a {
		color: #FFF;
	}

	#container #brand_gnav ul li a::after {
		position: absolute;
		content: '';
		box-sizing: border-box;
		width: 12px;
		height: 12px;
		top: 0;
		bottom: 0;
		right: 14px;
		margin: auto 0;
		border: solid 1px #999;
		border-left-color: transparent;
		border-bottom-color: transparent;
		transform: rotate(45deg);
	}

	#container #brand_gnav ul li .is-active {
		color: #e5be5c;
    pointer-events: none;
	}


}



/* enbudaki_nav */
/*
@media print, screen and (min-width: 769px){
	#container #enbudaki_nav {
		background: #000000;
	}

	#container #enbudaki_nav ul {
		width: 960px;
		margin: 0 auto;
		display: flex;
		justify-content: flex-end;
	}

	#container #enbudaki_nav ul li.nav_concept {
		margin-left: 294px;
	}


	#container #enbudaki_nav ul li a {
		display: block;
		height: 80px;
		text-indent: -9999px;
	}

	#container #enbudaki_nav ul li.nav_top a {
		width: 219px;
		background: url(../img/common/nav_top.png) no-repeat;
		background-size: contain;
	}

	#container #enbudaki_nav ul li.nav_concept a {
		width: 270px;
		background: url(../img/common/nav_concept.png) no-repeat;
		background-size: contain;
	}

	#container #enbudaki_nav ul li.nav_library a {
		width: 177px;
		background: url(../img/common/nav_library.png) no-repeat;
		background-size: contain;
	}

	#container #enbudaki_concept #enbudaki_nav ul li.nav_concept a,
	#container #enbudaki_library #enbudaki_nav ul li.nav_library a,
	#container #enbudaki_nav ul li a:hover,
	#container #enbudaki_nav ul li.nav_library a:hover {
		background-color: #1f1f1f;
	}

}

@media screen and (max-width: 768px){
	#container #enbudaki_nav {
		background: #000000;
	}

	#container #enbudaki_nav ul {
		width: 100%;
		margin: 0 auto;
	}

	#container #enbudaki_nav ul li {
		border-top: 1px solid #eee;
		text-align: center;
	}

	#container #enbudaki_nav ul li a {
		display: block;
		width: 100%;
		height: 80px;
		text-indent: -9999px;
	}

	#container #enbudaki_nav ul li.nav_top a {
		background: url(../img/common/nav_top.png) no-repeat center;
		background-size: contain;
	}

	#container #enbudaki_nav ul li.nav_concept a {
		background: url(../img/common/nav_concept.png) no-repeat center;
		background-size: contain;
	}

	#container #enbudaki_nav ul li.nav_library a {
		background: url(../img/common/nav_library.png) no-repeat center;
		background-size: contain;
	}

	#container #enbudaki_concept #enbudaki_nav ul li.nav_concept a,
	#container #enbudaki_library #enbudaki_nav ul li.nav_library a {
		background-color: #1f1f1f;
	}


}


/* special_contents */
#container #special_contents {
}

@media print, screen and (min-width: 769px){
	#container #special_contents {
		padding: 70px 0 0;
	}

	#container #special_contents .special_header {
		width: 960;
		margin: 0 auto 47px;
	}

	#container #special_contents .special_header h3 {
		width: 480px;
		height: 30px;
		margin: 0 auto;
		text-indent: -9999px;
		background: url(../img/common/special_title.png) no-repeat;
		background-size: contain;
	}

	#container #special_contents .list-special {
		display: flex;
		flex-wrap: wrap;
		margin-bottom: 20px;
	}

	#container #special_contents .list-special > li {
		width: 460px;
		margin: 0 10px 30px;
	}

	#container #special_contents .list-special a:hover {
		opacity: .8;
		text-decoration: none;
	}


}

@media screen and (max-width: 768px){
	#container #special_contents .special_header {
		font-family: 'Noto Serif Japanese', serif;
		padding: 40px 0 25px;
	}

	#container #special_contents .special_header h3 {
		font-size: 27px;
    letter-spacing: 2px;
		text-align: center;
	}

	#container #special_contents .list-special {
		margin: 0 7px 20px;
	}

	#container #special_contents .list-special > li {
		padding: 0 7px;
		margin: 0 0 20px;
		font-size: 12px;
		box-sizing: border-box;
	}

}

@media screen and (max-width: 500px){
	#container #special_contents .special_header {
		padding: 8vw 0 6.6vw;
	}

	#container #special_contents .special_header h3 {
		font-size: 5.3vw;
	}

}
