﻿@charset "UTF-8";
.you-be {
    background: -moz-linear-gradient(to bottom, #0A001E, #140A28 30%, #2D3232 48%, #321E14 56%, #000000 64%, #0A0A14 67%, #101018);
    background: -webkit-linear-gradient(to bottom, #0A001E, #140A28 30%, #2D3232 48%, #321E14 56%, #000000 64%, #0A0A14 67%, #101018);
    background: linear-gradient(to bottom, #0A001E, #140A28 30%, #2D3232 48%, #321E14 56%, #000000 64%, #0A0A14 67%, #101018);
    color: #fff;
}
.you-be > .center-block {
    margin-top: 80px;
}
.you-be > .center-block:first-child {
    margin-top: 20px;
}
@media screen and (min-width:1700px){
    .you-be > .center-block {
        margin-top: 60px;
    }
}

@media screen and (min-width:1700px){
    .you-be > .center-block {
        width: 1670px;
    }
}
@media screen and (min-width:1400px){
    .you-be > .center-block {
        width: 1370px;
    }
}
@media screen and (min-width:1200px){
    .you-be > .center-block {
        width: 1170px;
    }
}
@media screen and (min-width:992px){
    .you-be > .center-block {
        width: 970px;
    }
}
@media screen and (min-width:768px){
    .you-be > .center-block {
        width: 750px;
    }
}

.page-wrapper .you-be .container.fixed-width-900 {
    width: 100%;
}
@media screen and (min-width: 992px) {
    .page-wrapper .you-be .container.fixed-width-900 {
        width: 900px;
    }
}

.you-be h2 {
    color: #fff;
    font-size: 40px;
    font-weight: bold;
    border-bottom: none;
    line-height: 1.3;
}

.you-be h2 span {
    display: block;
    font-size: 19px;
    font-weight: normal;
    line-height: 1.2;
    color: #ccc;
}
.leadcopy p {
    font-size: 16px;
    line-height: 1.8;
    margin-top: 20px;
}
@media screen and (max-width:767px) {
    .you-be h2 {
        font-size: 24px;
    }
    .you-be h2 span {
        font-size: 10px;
    }
    .leadcopy p {
        font-size: 14px;
    }
}
.leadcopy p img {
    width: 100%;
}

/* 表示／非表示 */
.grad-item {
  position: relative;
  overflow: hidden;
  height: 0px; /*隠した状態の高さ*/
}
.grad-item::before {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0px; /*グラデーションで隠す高さ*/
  background: -webkit-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,0.9) 50%, rgba(255,255,255,0.9) 50%, #fff 100%);
  background: linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,0.9) 50%, rgba(255,255,255,0.9) 50%, #fff 100%);
  content: "";
}
.grad-trigger {
  display: none; /*チェックボックスは常に非表示*/
}
.grad-trigger:checked + .grad-btn {
  display: none; /*チェックされていたら、grad-btnを非表示にする*/
}
.grad-trigger:checked ~ .grad-item {
  height: auto; /*チェックされていたら、高さを戻す*/
}
.grad-trigger:checked ~ .grad-item::before {
  display: none; /*チェックされていたら、grad-itemのbeforeを非表示にする*/
}
/* ギャラリー */
#Gallery .container-flex > div {
    border: 1px solid #fff;
    -webkit-flex-basis: calc(20% - 10px);
    -ms-flex-basis: calc(20% - 10px);
    flex-basis: calc(20% - 10px);
    margin-left: 5px;
    margin-right: 5px;
    margin-bottom: 10px;
    padding: 5px;
}
@media screen and (max-width:767px){
#Gallery .container-flex > div {
    -webkit-flex-basis: calc(33% - 6px);
    -ms-flex-basis: calc(33% - 6px);
    flex-basis: calc(33% - 6px);
    margin-left: 3px;
    margin-right: 3px;
    margin-bottom: 6px;
    padding: 3px;
}
}
#Gallery .container-flex > div a img {
    width: 100%;
    height: 100%;
}

/* 商品ラインアップ */
#Lineup .container-flex.pc4-sp1 .flex-item {
    border: 1px solid #fff;
    -webkit-flex-basis: calc(25% - 10px);
    -ms-flex-basis: calc(25% - 10px);
    flex-basis: calc(25% - 10px);
    margin-left: 5px;
    margin-right: 5px;
    margin-bottom: 10px;
    padding: 5px;
}
@media screen and (max-width:767px){
    #Lineup .container-flex.pc4-sp1 .flex-item {
        -webkit-flex-basis: 100%;
        -ms-flex-basis: 100%;
        flex-basis: 100%;
        margin-left: 3px;
        margin-right: 3px;
        margin-bottom: 6px;
    }
}

#Lineup .container-flex {
    -webkit-justify-content: center;
    justify-content: center;
}

#Lineup .container-flex .flex-item a img {
    width: 100%;
    height: auto;
}
#Lineup .container > .container-flex > div {
    border: 1px solid #fff;
    padding: 5px;
}
#Lineup .container .container-flex div .genre {
    background: #947F5C;
    font-weight: bold;
    font-size: 16px;
    margin-bottom: 5px;
}
#Lineup .container .container-flex div .item-name-eng {
    font-size: 22px;
    line-height: 1.2;
    margin-top: 10px;
}
#Lineup .container .container-flex div .item-name {
    font-size: 12px;
}
#Lineup .container .container-flex div p {
    font-size: 15px;
    margin-top: 10px;
    border-top: 1px dotted #666;
    padding-top: 10px;
    word-break: break-all;
}

/* 倉下部長 */
#Founder .container > .container-flex {
    border: 1px solid #fff;
    padding: 5px;
}
#Founder .container .container-flex .picture img {
    width: 100%;
}
#Founder .container .container-flex .picture {
    -webkit-flex-basis: 30%;
    -ms-flex-basis: 30%;
    flex-basis: 30%;
}
@media screen and (max-width:767px){
#Founder .container .container-flex .picture {
    -webkit-flex-basis: 100%;
    -ms-flex-basis: 100%;
    flex-basis: 100%;
}
}
#Founder .container .container-flex .details {
    -webkit-flex-basis: calc(70% - 10px);
    -ms-flex-basis: calc(70% - 10px);
    flex-basis: calc(70% - 10px);
    margin-left: 10px;
}
@media screen and (max-width:767px){
#Founder .container .container-flex .details {
    -webkit-flex-basis: 100%;
    -ms-flex-basis: 100%;
    flex-basis: 100%;
    margin-top: 10px;
}
}
#Founder .container .container-flex .name {
    font-size: 24px;
}
#Founder .container .container-flex .name-eng {
    font-size: 12px;
}
#Founder .container .container-flex p {
    font-size: 15px;
    margin-top: 5px;
}

/* リンクボタン共通 */
.container .container-flex .calltoaction {
    text-align: right;
}
@media screen and (max-width:767px){
    .container .container-flex .calltoaction {
        text-align: center;
    }
}

/* スタッフブログ */
#Staff_Blog .container > .container-flex {
    border: 1px solid #fff;
    padding: 5px;
    margin-bottom: 10px;
    background-color: #0A0A14;
}
#Staff_Blog .container .container-flex .picture img {
    width: 100%;
}
#Staff_Blog .container .container-flex .picture {
    -webkit-flex-basis: 30%;
    -ms-flex-basis: 30%;
    flex-basis: 30%;
}
@media screen and (max-width:767px){
#Staff_Blog .container .container-flex .picture {
    -webkit-flex-basis: 100%;
    -ms-flex-basis: 100%;
    flex-basis: 100%;
}
}
#Staff_Blog .container .container-flex .details {
    -webkit-flex-basis: calc(70% - 10px);
    -ms-flex-basis: calc(70% - 10px);
    flex-basis: calc(70% - 10px);
    margin-left: 10px;
}
@media screen and (max-width:767px){
#Staff_Blog .container .container-flex .details {
    -webkit-flex-basis: 100%;
    -ms-flex-basis: 100%;
    flex-basis: 100%;
    margin-left: 0;
    margin-top: 10px;
    padding: 5px;
}
}
#Staff_Blog .container .container-flex .blog-title {
    font-size: 20px;
    font-weight: bold;
    line-height: 1.2;
}
#Staff_Blog .container .container-flex .blog-date {
    font-size: 12px;
}
#Staff_Blog .container .container-flex p {
    font-size: 15px;
    margin-top: 5px;
    position: relative;
    overflow: hidden;
    height: 60px; /*隠した状態の高さ*/
}
#Staff_Blog .container .container-flex p::before {
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 20px; /*グラデーションで隠す高さ*/
    background: -moz-linear-gradient(to bottom, rgba(10, 10, 20, 0) 0%, rgba(10, 10, 20, 0.9) 50%, #0A0A14 100%);
    background: -webkit-linear-gradient(to bottom, rgba(10, 10, 20, 0) 0%, rgba(10, 10, 20, 0.9) 50%, #0A0A14 100%);
    background: linear-gradient(to bottom, rgba(10, 10, 20, 0) 0%, rgba(10, 10, 20, 0.9) 50%, #0A0A14 100%);
    content: "";
}
/* 共同開発企業 */
#Partner .container > .container-flex {
    border: 1px solid #fff;
    padding: 5px;
    margin-bottom: 10px;
}
#Partner .container .container-flex .picture img {
    width: 100%;
}
#Partner .container .container-flex .picture {
    -webkit-flex-basis: 30%;
    -ms-flex-basis: 30%;
    flex-basis: 30%;
}
@media screen and (max-width:767px){
#Partner .container .container-flex .picture {
    -webkit-flex-basis: 100%;
    -ms-flex-basis: 100%;
    flex-basis: 100%;
}
}
#Partner .container .container-flex .details {
    -webkit-flex-basis: calc(70% - 10px);
    -ms-flex-basis: calc(70% - 10px);
    flex-basis: calc(70% - 10px);
    margin-left: 10px;
}
@media screen and (max-width:767px){
#Partner .container .container-flex .details {
    -webkit-flex-basis: 100%;
    -ms-flex-basis: 100%;
    flex-basis: 100%;
    padding: 5px;
}
}
#Partner .container .container-flex .brand-name {
    font-size: 24px;
}
#Partner .container .container-flex .brand-name-eng {
    font-size: 12px;
}
#Partner .container .container-flex p {
    font-size: 15px;
    margin-top: 5px;
}

/* SNS情報部分 */
.container-flex .channel {
	-ms-flex-basis: calc(40% - 20px);
	-webkit-flex-basis: calc(40% - 20px);
	flex-basis: calc(40% - 20px);
	margin-left: 10px;
	margin-right: 10px;
}

.channel .box:hover .box-icon i.icon,
.channel .box:hover h3.box-title {
	color: #bb0000;
	opacity: 0.7;
}
.sns-large .box.hilander-black {
	display: block;
	background: #cccccc;
	padding: 20px;
}
.sns-large .box-icon i.icon.bg-shopping {
	margin-bottom: 5px;
	font-size: 50px;
	background: none;
    border: none;
    color: #545454;
}
.sns-large .box-title {
	font-size: 16px;
	text-transform: none;
	color: #545454;
}

@media screen and (max-width:480px) {
	.container-flex .channel {
		-ms-flex-basis: calc(90% - 20px);
		-webkit-flex-basis: calc(90% - 20px);
		flex-basis: calc(90% - 20px);
		margin-left: 10px;
		margin-right: 10px;
	}
}
.sns-large.container > .container-flex {
	-webkit-justify-content: center;
	justify-content: center;
}

/* youtubeのレスポンシブ表示 */
.youtube-responsive {
    position: relative;
    padding-bottom: 60%; /*アスペクト比 16:9の場合の縦幅*/
    height: 0;
    overflow: hidden;
}
.youtube-responsive iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.divider-lg {
    height: 50px;
}
.divider-sm {
    height: 20px;
  }