@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Hammersmith+One&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Abril+Fatface&display=swap');

/*===========　レスポンシブ用基礎CSS　===========*/

/*ボックスモデルをborder-boxに変更*/
* {
	box-sizing: border-box;
}

/*フルードイメージ*/
img {
	max-width: 100%;
	height: auto;
}

/*回転時の文字調整封印*/
html{
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  background: #fff;
}

/*===========　スマホ用　通常時　===========*/

body {
	color: #333;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	font-weight: 500;
	position: relative;
	max-width: 640px;
	margin: 0 auto;
	line-height: 1.2;
	padding-bottom: 14vw;
	padding-top: 60px;
	scroll-padding-top: 200px;
	background: #fff;
}
#outer_block{
	margin: 10px;
	border: solid 1px #474A4D;
	border-top: none;
}
@media (min-width:768px){


	body {
		color: #333;
		position: relative;
		max-width: 1500px;
		margin: 0 auto;
		line-height: 1.2;
		padding-bottom: 5vw;
		padding-top: 110px;
		scroll-padding-top: 110px;
	}

	#outer_block{
		margin: 0px 10px 10px;
	}

}

/*===========　枠　===========*/

/*===========　ロゴ　===========*/
#header_logo{
	width: calc(100% - 20px);
	height: 60px;
	max-width: 640px;
	border: 1px solid #474A4D;
	background: transparent;
	position: fixed;
	z-index: 999;
	top: 10px;
	left: 10px;
	right: 10px;
	margin: 0 auto;
	display: block;
}

#header_logo:before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    backdrop-filter: blur(3px);
}

#header_logo a{
	display: block;
	width: 43vw;
	height: 100%;
	/* margin: 0 auto; */
	position: absolute;
	top: 0;
	left: 16vw;
	right: 0;
	background: url(../img/cs_logo.png) no-repeat center center/100%;
}


.header_rside{
	display: flex;
	position: absolute;
	top: 0;
	right: 0;
	height: 100%;
	width: 30vw;
}

.eng_header_rside {
  color: #fff;
  background: #474A4D;
  display: block;
  width: 50%;
  height: 100%;
  padding: 4%;
  text-align: left;
  line-height: 1.5;
  font-family: serif;
  font-size: 8px;
}
.jp_header_rside{
	display: block;
	width: 50%;
	height: 100%;
	padding: 13% 4% 4%;
	text-align: right;
	line-height: 1.5;
	letter-spacing: 1px;
	font-size: 9px;
}

@media (min-width:768px){
	#header_logo{
		height: 100px;
		width: calc(100% - 20px);
		max-width: 1480px;
	}
	#header_logo a{
		display: block;
		width: 25vw;
		height: 100%;
		margin: 0 auto 0 18%;
		position: absolute;
		top: 0;
		left: 100px;
		right: 0;
		background: url(../img/cs_logo.png) no-repeat center center/100%;
	}

	.header_rside{
		display: flex;
		position: absolute;
		top: 0;
		right: 0;
		height: 100%;
		width: 30vw;
		max-width: 500px;
	}

	.eng_header_rside{
		color: #fff;
		background: #474A4D;
		display: block;
		width: 50%;
		height: 100%;
		padding: 5% 8%;
		text-align: left;
		line-height: 1.5;
		font-family: serif;
		font-size: 13px;
		letter-spacing: 5px;
	}
	.jp_header_rside{
		display: block;
		width: 50%;
		height: 100%;
		padding: 4% 9% 4%;
		text-align: right;
		line-height: 1.5;
		letter-spacing: 10px;
		font-size: 14px;
	}

}
/*===========　ヘッダー　===========*/
#html_pc, #html_sp {
    margin: 0 auto;
    z-index: 1;
    display: none;
    width: 100%;
    position: relative;
}

#html_sp{height: 43vw;display: block;}


.slick-track{display: flex !important;}

.slider {
  position:relative;
	z-index: 1 !important;
	/*↑z-indexの値をh1のz-indexの値よりも小さくして背景に回す*/
	height: 43vw;/*スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
}

/*　PC　*/

#html_pc .slider-item01 {
    background:url(../img/top_slide1.png);
}

#html_pc .slider-item02 {
    background:url(../img/top_slide2.png);
}

#html_pc .slider-item03 {
    background:url(../img/top_slide3.png);
}

#html_pc:before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    content: "";
    display: block;
    width: 100%;
		height: 100%;
    background: url(../img/slide_cover.png) no-repeat center top/90%;
		border-bottom: solid 1px #474A4D;
}

/*　SP　*/
#html_sp:before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    content: "";
    display: block;
    width: 100%;
    height: 43vw;
    background: url(../img/slide_cover.png) no-repeat center top/100%;
		border-bottom: solid 1px #474A4D;
}

#html_sp .slider-item01 {
    background:url(../img/top_slide1.png);
}

#html_sp .slider-item02 {
    background:url(../img/top_slide2.png);
}

#html_sp .slider-item03 {
    background:url(../img/top_slide3.png);
}

.slick-prev,
.slick-next{display: none !important;}

.slider-item {
	width: 100% !important;
	height: 43vw !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
	background-size: 100% !important;
}


@media (min-width:768px){
	#html_pc{
		display: block;
		width: 100%;
		max-height: 686px;
		min-height: 506px;
		height: 45vw;
	}
	#html_sp{display: none;}

	#html_pc .slider {
		max-height: 686px;
		min-height: 500px;
		height: 100%;
	}

	#html_pc .slider-item {
		max-height: 686px !important;
		min-height: 500px !important;
		height: 45vw !important;
		}
}



/*===========　スライドテキスト　===========*/
#top_slide_txt{
	height: 80px;
	border-bottom: solid 1px #474A4D;
	display: flex;
}

#top_slide_txt .left_logo{
	display: block;
	width: 20vw;
	height: 20vw;
	background: url(../img/logo_bk.png) no-repeat center center/80%;
	animation: circle linear 60s infinite;
}

@keyframes circle {
    0% {transform: rotate(0deg);}
    100% {transform: rotate(-360deg);}
}

#top_slide_txt .right_slide{
	display: block;
	width: calc(100% - 20vw);
	height: 100%;
	border-left: solid 1px #474A4D;
	display: flex;
	flex-direction: column;
}

#top_slide_txt .right_slide .toleft{
	display: block;
	width: 100%;
	height: 70%;
	background: url(../img/slide_big.png) repeat-x center center/130%;
	animation: toleft 60s linear 0s infinite;
}
@keyframes toleft {
  0% { background-position-x: 0; }
  100% { background-position-x: -200vw; }
}

#top_slide_txt .right_slide .toright{
	display: block;
	width: 100%;
	height: 30%;
	background: url(../img/slide_small.png) repeat-x center top/120%;
	animation: toright 60s linear 0s infinite;
}
@keyframes toright {
  0% { background-position-x: 0; }
  100% { background-position-x: 200vw; }
}

@media (min-width:768px){
	#top_slide_txt{
		height: 16vw;
		border-bottom: solid 1px #474A4D;
		display: flex;
	}

	#top_slide_txt .left_logo{
		display: block;
		width: 20vw;
		height: 16vw;
		background: url(../img/logo_bk.png) no-repeat center center/60%;
		animation: circle linear 60s infinite;
	}

}
/*===========　ナビ　===========*/



#access {
  width: 60vw;
  height: 100vh;
  margin: 0;
  position: fixed;
  top: 0;
  left: -30vw;
  opacity: 0;
  background: rgba(71, 74, 77, 0.9);
  transition: .4s;
  z-index: 100;
}
#access.open {
    left: 0px;
    opacity: 1;
    transition: .4s;
    z-index: 100;
}
#access.close {/*隠れている時*/
  left: -40vw;
  opacity: 0;
  transition: .35s;
  z-index: 100;
}

#access ul{
	width: 80%;
	height: 20vw;
	margin: 130px auto 0;
	}

#access ul li a{
	color: #fff;
	font-size: 0.8em;
	display: block;
	margin: 0 0 3vw;
	letter-spacing: 1px;
}

.navitxt{
	font-size: 0.8em;
	color: #fff;
	padding-left: 0.5em;
}

.site-link{padding: 7% 0 0;}



#access ul li.layer{
	font-size:0.8em;
	padding-left: 1em;
}


#access > ul > li:nth-child(7){
	padding-bottom: 1em;
}

@media (min-width:768px){
	#access {
	  width:25vw;

	}
	#access ul{
		padding: 0;

	}

	/*ナビ下に線を出す*/
	#access ul li a{
		position: relative;
		display: block;
		padding: 0;
		line-height: 2vw;
		text-align: left;
		margin: 0 0 1vw;
		font-size: 1em;
	}
	#access ul li a:before {
		content: '';
		position: absolute;
		bottom: -4%;
		left: 0;
		display: block;
		background: none #fff;
		width: 80%;
		height: 1px;
		margin: 0 auto;
		transition: transform 0.3s cubic-bezier(0.4, 1, 0.8, 1) 0s;
		transform-origin: 100% 50%;
		transform: scale3d(0, 1, 1);
		pointer-events: none;
	}
	#access ul li a:hover:before {
	  transform-origin: 0% 50%;
	  transform: scale3d(1, 1, 1);
	}

}


/*===========　ハンバーガー・ナビ　===========*/
.hanNav	{
	position:fixed;
	top: 6vw;
	left: 7vw;
	z-index:9999;
	width: 5vw;
	height: 5vw;
	text-align:center;
	cursor:pointer;
}

.menu-trigger,
.menu-trigger span {
  display: inline-block;
  transition: all .4s;
  box-sizing: border-box;
}
.menu-trigger {
    position: relative;
    width: 100%;
    height: 100%;
    background: none;
    border: none;
    appearance: none;
    cursor: pointer;
}
.menu-trigger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #474A4D;
  border-radius: 4px;
}
.menu-trigger span:nth-of-type(1) {
  top: 0px;
}
.menu-trigger span:nth-of-type(2) {
  top: 46%;
}
.menu-trigger span:nth-of-type(3) {
  bottom: 0px;
}

.menu-trigger.open span:nth-of-type(1) {
  -webkit-transform: translateY(4px) rotate(-315deg);
  transform: translateY(1vw) rotate(-315deg);
  background: #fff;
}
.menu-trigger.open span:nth-of-type(2) {
  opacity: 0;
}
.menu-trigger.open span:nth-of-type(3) {
  -webkit-transform: translateY(-16px) rotate(315deg);
  transform: translateY(-3.5vw) rotate(315deg);
  background: #fff;
}

@media (min-width:768px){
	.hanNav	{
		position:fixed;
		top: 40px;
		left: 40px;
		z-index:9999;
		width: 50px;
		height: 40px;
		line-height:1.5em;
		text-align:center;
		cursor:pointer;
	}

	.menu-trigger,
	.menu-trigger span {
	  display: inline-block;
	  transition: all .4s;
	  box-sizing: border-box;
	}
	.menu-trigger {
	    position: relative;
	    width: 100%;
	    height: 100%;
	    background: none;
	    border: none;
	    appearance: none;
	    cursor: pointer;
	}
	.menu-trigger span {
	  position: absolute;
	  left: 0;
	  width: 100%;
	  height: 2px;
	  background-color: #474A4D;
	  border-radius: 4px;
	}
	.menu-trigger span:nth-of-type(1) {
	  top: 0px;
	}
	.menu-trigger span:nth-of-type(2) {
	  top: 46%;
	}
	.menu-trigger span:nth-of-type(3) {
	  bottom: 0px;
	}

	.menu-trigger.open span:nth-of-type(1) {
	  -webkit-transform: translateY(4px) rotate(-315deg);
	  transform: translateY(19px) rotate(-315deg);
	}
	.menu-trigger.open span:nth-of-type(2) {
	  opacity: 0;
	}
	.menu-trigger.open span:nth-of-type(3) {
	  -webkit-transform: translateY(-19px) rotate(315deg);
	  tra10ths sform: translateY(-18px) rotate(315deg);
	}
}

@media (min-width:1510px){
	.hanNav	{
		position:fixed;
		top: 30px;
		left: calc(50% - 720px);
		z-index:9999;
		width: 60px;
		height: 40px;
		line-height:1.5em;
		text-align:center;
		cursor:pointer;
	}
}


/*===========　=======　コンテンツ　=======　===========*/

.outer_block{overflow: hidden;}
/*  タイトル　・　記事
___________________________________________________*/

h2.headline-title
{
	font-size: 1.5em;
	text-align: center;
	padding-bottom: 10%;
	margin-bottom: 10%;
}



h3.sub-headline-title
{
	font-size: 1.2em;
	text-align: center;
	padding: 4% 2%;
	display: block;
	width: 100%;
	margin: 0 auto 5%;
}

p.common-content
{
	padding: 8% 0%;
	font-size: 0.8em;
	line-height: 1.5;
}

.readmore
{
	width: 80%;
	padding: 5% 2%;
	margin: 0 auto;
}
.readmore a.rm-link
{
	display: block;
	width: 100%;
	height: 5vw;
	line-height: 1vw;
	padding: 6vw 3vw;
	text-align: center;
	background: #BD0000;
	border-radius: 3em;
	letter-spacing: 1px;
}

.readmore a.rm-link:hover
{
	background: #00A1E9;
}

@media (min-width:768px){
	h2.headline-title
	{
		font-size: 2em;
		padding-bottom: 2%;
		margin-bottom: 2%;
	}
	.js_typing{
		font-size: 7em !important;
	}

	p.common-content
	{
		padding: 5% 2%;
		font-size: 100%;
	}

	.readmore
	{
		width: 40%;
		padding: 5% 2%;
		margin: 0 auto;
	}

	.readmore a.rm-link
	{
		height: 5vw;
		line-height: 3vw;
		padding: 1vw 3vw;
	}
}


/*  Aブロック
___________________________________________________*/
.block-a
{
	width: 100%;
	padding: 18% 15%;
}
@media (min-width:768px){
.block-a
{

	padding: 10% 15%;
}
}
/*  Bブロック
___________________________________________________*/
.block-b
{
	width: 100%;
	margin: 0 auto;
	padding: 10% 15%;
}

.b-inner
{
	width: 80%;
	padding: 5% 2%;
	margin: 0 auto;
}

.b-wrap
{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

/*  Dブロック
___________________________________________________*/

.block-d
{
	width: 100%;
	margin: 0 auto;
	padding: 10% 15%;
}

.bnr-inner
{
	width: 100%;
	padding: 0;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.bnr-1col
{
	width: 100%;
	height: 40vw;
}

.bnr-2col
{
	width: 26vw;
	height: 26vw;
	margin-bottom: 3.5vw;
	border: 1px solid #333;
}

.bnr-col a.bnr-link
{
	display: block;
	width: 100%;
	height: 100%;
	border:1px solid #333;
}


/*  Tブロック
___________________________________________________*/
.block-t
{
	width: 100%;
	margin: 0 auto;
	padding: 18% 15%;
}

.table-inner {
	display: flex;
	justify-content: center;
	margin-bottom: 2vw;

}

.table-inner table {
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
}

.table-inner table th,
.table-inner tbody td {
	border: 1px solid #474A4D;
	padding: 3vw 2vw;
	font-size: 0.7em;
}

.table-inner table th {
	background-color:#F5F5F5;
	width: 24%;
	color: #333;
}

.table-inner tbody td {
	vertical-align: middle;
}

.table-wrap{
	margin: 0 0 6%;
}

.table-wrap p small{font-size: 0.6em;}

@media (min-width:768px){
	.table-inner table th,
	.table-inner tbody td
	{font-size: 1.2em;padding: 3% 2%;}.table-inner table th{
    width: 35%;
}
}


/*===========　デザインブロック　共通　===========*/

.block-a h2.headline-title
{
	letter-spacing: 2px;
	border: 0;
	padding: 1vw 0;
	margin: 0;
	position: relative;
	z-index: 10;
	font-size: 1.8em;
}
.block-a h3.sub-headline-title
{
	text-align: center;
	font-size: 1.5em;
	background: none;
	padding: 3% 0;
	margin: 0;
}



/*  fade in
---------------------------------------------------------------------------------------------------- */

.f_down {
  opacity: 0;
  transform-origin: center;
  transition: 1s ease 0s;
	transform: translateY(100px);
}
.f_down.moved{
  opacity: 1;
	transform: translate(0px, 0px);
}

/*  marker
---------------------------------------------------------------------------------------------------- */

.marker{
	display: inline;
	background: linear-gradient(transparent 8%, rgb(0,0,0) 8%);
	background-repeat: no-repeat;
	background-size: 0.3em 100%;
	background-position: 0 100%;
	transition:background-size 1.5s;
	padding: 1% 0.8%;
	color: #fff;
	margin: 0 0.5%;
}

.marker.moved{
	background-size: 100% 100%;
}


/*  img scale
---------------------------------------------------------------------------------------------------- */

#img01.scale:before,
#img02.scale:before,
#img03.scale:before,
#img04.scale:before,
#img05.scale:before,
#img06.scale:before,
#img07.scale:before
{
  transform:  scale(1.3);
  opacity: 0;
  transform-origin: center;
  transition:3s ease 0s;
}
#img01.moved:before,
#img02.moved:before,
#img03.moved:before,
#img04.moved:before,
#img05.moved:before,
#img06.moved:before,
#img07.moved:before
 {
  transform:  scale(1.0);
  opacity: 1;
}



/*  text fadein span
---------------------------------------------------------------------------------------------------- */

h2.headline-title.txt_fade {
	font-size: 2.5em;
	line-height: 1.2em;
	font-family: "Abril Fatface", serif;
	font-weight: 400;
	margin-bottom: 0;
}
@media (min-width:768px){
	h2.headline-title.txt_fade {
		font-size: 5em;
		line-height: 1.4em;
	}
}

  .txt_fade span {
        display: inline-block;
        transition: all cubic-bezier(0.215, 0.61, 0.355, 1) 1s;
        opacity: 0;
        transform: translateY(50px);
        }
        .txt_fade.active span {
            opacity: 1;
            transform: translateY(0);
        }

/*  A business
---------------------------------------------------------------------------------------------------- */
#business{
	position: relative;
	border-bottom: 1px solid #474A4D;
	padding: 10% 5%;
}

#business p.small{
	font-size: 0.5em;
	margin: 0 auto;
	width: 50%;
	text-align: center;
	position: relative;
	padding: 2% 0;
}
#business p.small:before{
	content: '';
	position: absolute;
	top: 49%;
	bottom: 0;
	left: -10px;
	display: block;
	width: 50px;
	height: 1px;
	background: #474A4D;
}


#business p.small:after{
	content: '';
	position: absolute;
	top: 49%;
	bottom: 0;
	right: -10px;
	display: block;
	width: 50px;
	height: 1px;
	background: #474A4D;
}

#business h2{
	font-family: "Hammersmith One", serif;
	font-weight: 400;
	border-bottom: solid 1px #474A4D;
	width: 80%;
	margin: 0 auto;
	position: relative;
	font-size: 1.8em !important;
}
#business h2:before{
	content: '';
	position: absolute;
	bottom: -7px;
	left: 0;
	display: block;
	border-bottom: solid 3px #474A4D;
	width: 100%;
}

#business .text_block{
	width: 100%;
	height: 100%;
	padding-top: 20%;
	padding-bottom: 13%;
}

#business  .sub-headline-title{letter-spacing: 2px;margin-bottom: 3%;}

#business p.common-content{
	font-size: 0.7em;
	line-height: 2;
	margin: 0 auto;
	width: 90%;
	text-align: center;
	padding: 0;
}

span._bold{
	font-weight: bold;
}


#business p.common-content.pc{
	display: none;
}
#business p.common-content.sp{
	display: block;
}
@media (min-width:768px){
	#business p.common-content.pc{
		display: block;
	}
	#business p.common-content.sp{
		display: none;
	}
	#business{
		position: relative;
		border-bottom: 1px solid #474A4D;
		padding: 10% 5%;
	}

	#business p.small{
		font-size: 1.5em;
		letter-spacing: 2px;
		margin: 0 auto;
		width: 20%;
		text-align: center;
		position: relative;
		padding: 2% 0;
	}
	#business p.small:before{
		content: '';
		position: absolute;
		top: 49%;
		bottom: 0;
		left: -10px;
		display: block;
		width: 50px;
		height: 1px;
		background: #474A4D;
	}


	#business p.small:after{
		content: '';
		position: absolute;
		top: 49%;
		bottom: 0;
		right: -10px;
		display: block;
		width: 50px;
		height: 1px;
		background: #474A4D;
	}

	#business h2{
		font-family: "Hammersmith One", serif;
		font-weight: 400;
		border-bottom: solid 1px #474A4D;
		width: 50%;
		margin: 0 auto;
		position: relative;
		font-size: 4em !important;
	}
	#business h2:before{
		content: '';
		position: absolute;
		bottom: -7px;
		left: 0;
		display: block;
		border-bottom: solid 3px #474A4D;
		width: 100%;
	}

	#business .text_block{
		width: 100%;
		height: 100%;
		padding-top: 10%;
		padding-bottom: 5%;
	}

	#business  .sub-headline-title{letter-spacing: 2px;margin-bottom: 3%;font-size: 3em;}

	#business p.common-content{
		font-size: 1.5em;
		line-height: 2;
		margin: 0 auto;
		width: 90%;
		text-align: center;
		padding: 0;
	}

	}


	/*  A wine
	---------------------------------------------------------------------------------------------------- */
#bs_ttl{
	border-bottom: 1px solid #474A4D;
	padding: 3% 5%;
	position: relative;
}

#bs_ttl h2{
	border-bottom: solid 1px #474A4D;
	width: 80%;
	margin: 0 auto 0 0;
	text-align: left;
	border: 0;
	padding: 0;
}

#bs_ttl p.small{
	font-size: 0.5em;
	margin: 0 auto;
	width: auto;
	text-align: left;
	position: absolute;
	content: "";
	top: 27%;
	right: 5%;
	padding: 0;
}

@media (min-width:768px){

	#bs_ttl{
		padding: 1% 5%;
	}

	#bs_ttl h2{
		border-bottom: solid 1px #474A4D;
		width: 60%;
		margin: 0 auto 0 0;
		text-align: center;
		border: 0;
		padding: 0;
		font-size: 7em;
		letter-spacing: 15px;
	}

	#bs_ttl p.small{
		font-size: 2em;
		margin: 0 auto;
		width: auto;
		text-align: left;
		position: absolute;
		content: "";
		top: 27%;
		right: 10%;
		padding: 0;
		letter-spacing: 5px;
	}
}

/*  事業内容　共通
---------------------------------------------------------------------------------------------------- */

.bs_cmn{
	border-bottom: 1px solid #474A4D;
	padding: 18% 3%;
	position: relative;
}
/* ttl */
.ttl_block{
	padding-bottom: 5%;
}

.bs_cmn h2{
	font-size: 1.6em !important;
}
.bs_cmn .small{
	padding: 2%;
	font-size: 0.6em;
	text-align: center;
}
.bs_cmn .small.moved{
	transition-delay: 0.5s;
}
/* txt */
.bs_cmn p.common-content{
	padding: 7% 5% 5%;
	text-align: justify;
}
.bs_cmn .center{
	text-align: center;
	display: block;
}

/* btn */
.gotopage
{
	width: 40%;
	padding: 5% 2%;
	margin: 0 0 0 auto;
	position: relative;
}
.gotopage a.rm-link
{
	display: block;
	width: 100%;
	height: 2vw;
	line-height: 1vw;
	padding: 4vw 2vw;
	text-align: center;
	background: #474A4D;
	color: #fff;
	font-size: 0.6em;
	border-radius: 7px;
	letter-spacing: 2px;
	transition: 0.3s;
	border: solid 1px #474A4D;
}

.gotopage a.rm-link:hover
{
	background: #fff;
	color: #474A4D;
}
.gotopage a.rm-link::before{
	content: '';
	display:block;
	width: 15vw;
	height: 5vw;
	position: absolute;
	top: 35%;left: -37%;
	z-index: 2;
	background: url(../img/check.png) no-repeat center top/70%;
}

/* bnr */
.bs_cmn .bnr-1col{
	height: 19vw;
	position: relative;
}

.bs_cmn .bnr-1col a.bnr-link
{
	display: block;
	width: 100%;
	height: 100%;
	transition: 0.3s;
	position: relative;
	z-index: 3;
}

.bs_cmn .bnr-1col a.bnr-link:hover
{
	opacity: 0.7;
}

.bs_cmn .bnr-1col img{
	position: relative;
	z-index: 2;
}

.bs_cmn .bnr-1col .bnr-bg{
	display: block;
	width: 100%;
	height: 100%;
	background: url(../img/bnr_bg_wine.png) no-repeat center top/100%;
	filter: brightness(0.0);
	transition: 1.8s;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
}

.bs_cmn .bnr-1col .bnr-bg.moved{
	filter: brightness(1.0);
}



@media (min-width:768px){

	.bs_cmn{
		border-bottom: 1px solid #474A4D;
		padding: 6% 10%;
		position: relative;
	}
	/* ttl */
	.ttl_block{
		display: flex;
		padding-bottom: 2%;
	}

	.bs_cmn h2{
		font-size: 5em !important;
	}
	.bs_cmn .small{
		padding: 5% 0 0 4%;
		font-size: 1.5em;
		letter-spacing: 5px;
	}
	.bs_cmn .small.moved{
		transition-delay: 0.5s;
	}
	/* txt */
	.bs_cmn p.common-content{
		padding: 7% 5% 5%;
		font-size: 1.5em;
		line-height: 2;
	}
	.bs_cmn .center{
		text-align: center;
		display: block;
	}

	/* btn */
	.gotopage
	{
		width: 30%;
		padding: 5% 2%;
		margin: 0 0 0 auto;
		position: relative;
	}
	.gotopage a.rm-link
	{
		display: block;
		width: 100%;
		height: 3vw;
		line-height: 0.5vw;
		padding: 3vw 2vw;
		text-align: center;
		background: #474A4D;
		color: #fff;
		font-size: 1em;
		border-radius: 10px;
		letter-spacing: 4px;
		transition: 0.3s;
		border: solid 1px #474A4D;
	}

	.gotopage a.rm-link:hover
	{
		background: #fff;
		color: #474A4D;
	}
	.gotopage a.rm-link::before{
		content: '';
		display:block;
		width: 11vw;
		height: 3vw;
		position: absolute;
		top: 35%;
		left: -40%;
		z-index: 2;
		background: url(../img/check.png) no-repeat center top/70%;
	}

	/* bnr */
	.bs_cmn .bnr-1col{
		height: 14vw;
		max-height: 210px;
		position: relative;
	}

	.bs_cmn .bnr-1col a.bnr-link
	{
		display: block;
		width: 100%;
		height: 100%;
		transition: 0.3s;
		position: relative;
		z-index: 3;
	}

	.bs_cmn .bnr-1col a.bnr-link:hover
	{
		opacity: 0.7;
	}

	.bs_cmn .bnr-1col img{
		position: relative;
		z-index: 2;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
		margin: auto;
		display: block;
	}

	.bs_cmn .bnr-1col .bnr-bg{
		display: block;
		width: 100%;
		height: 100%;
		background: url(../img/bnr_bg_wine.png) no-repeat center top/100%;
		filter: brightness(0.0);
		transition: 1.8s;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
	}



}

/*  A wine
---------------------------------------------------------------------------------------------------- */
#wine{
}
#wine .bnr-1col{
	height: 32.5vw;
}

/*  A realestate
---------------------------------------------------------------------------------------------------- */
#realestate .bnr-1col .bnr-bg{
	background-image: url(../img/bnr_bg_re.png);
}
#realestate .bnr-1col{
	height: 32.5vw;
}


@media (min-width:768px){
	#wine .bnr-1col{
		height: 24vw;
		max-height: 360px;
	}

	#realestate .bnr-1col{
		height: 24vw;
		max-height: 360px;
	}

}


/*  A
luxurygoods
art
counseling
globaletiquette
---------------------------------------------------------------------------------------------------- */

#luxurygoods .bnr-1col .bnr-bg{
	background-image: url(../img/bnr_bg_lg.png);
}


#art .bnr-1col .bnr-bg{
	background-image: url(../img/bnr_bg_art.png);
}

#counseling .bnr-1col .bnr-bg{
	background-image: url(../img/bnr_bg_cs.png);
}


#globaletiquette .bnr-1col .bnr-bg{
	background-image: url(../img/bnr_bg_mn.png);
}


@media (min-width:768px){
	#luxurygoods h2{font-size: 4em !important;}
	#luxurygoods .small{
		padding: 4% 0 0 4%;
	}
	#counseling h2{font-size: 4em !important;}
	#counseling .small{
		padding: 4% 0 0 4%;
		font-size: 1.5em !important;
	}

	#globaletiquette h2{font-size: 4em !important;}
	#globaletiquette .small{
		padding: 4% 0 0 4%;
	}



}

/*  A company
---------------------------------------------------------------------------------------------------- */
#company  .sub-headline-title{
	font-size: 1em;
	text-align: center;
	padding: 4% 2%;
	display: block;
	width: 50%;
	border-bottom: solid 1px #474A4D;
	margin: 0 auto 5%;
}

@media (min-width:768px){

	#company  .sub-headline-title{
		font-size: 1.5em;
		text-align: center;
		padding: 2% 2%;
		display: block;
		width: 30%;
		border-bottom: solid 1px #474A4D;
		margin: 0 auto 5%;
	}

}



/*  A contact
---------------------------------------------------------------------------------------------------- */
#contact{
		background: url(../img/bg_square.png) repeat;
		border-top: solid 1px #474A4D;
		border-bottom: solid 1px #474A4D;

}

#contact .cntct .bnr-1col{
	height: 11vw;
	margin-bottom: 4vw;
}
#contact .cntct .bnr-1col a{
	border-radius: 5px;
	height: 100%;
	display: block;
	width: 100%;
	background: url(../img/bnr_line.png) no-repeat center center/100%,#00B900;
}

#contact > div.bnr-inner.cntct > div:nth-child(2) > a{
	background: url(../img/bnr_mail.png) no-repeat center center/100%,#A1A3A5;
}


#contact > div.bnr-inner.cntct > div:nth-child(3) > a{
	background: url(../img/bnr_tel.png) no-repeat center center/100%,#696F74;
}


#contact .sns{
	height: 13vw;
	padding: 4% 12%;
	margin-bottom: 4vw;
	display: flex;
	justify-content: space-between;
	background: #474A4D;
	border-radius: 5px;
	flex-wrap: unset;
}

#contact h3.sns_tl {
	font-size: 1.5em;
	font-family: "Abril Fatface", serif;
	letter-spacing: 2px;
}
#contact .sns .bnr-1col{
	height: 8vw;
	width: 9vw;
	margin: 0;
}

#contact .sns .bnr-1col a{
	background: url(../img/x.png) no-repeat center center/100%;
}

#contact > div.bnr-inner.cntct > div.bnr-inner.sns > div:nth-child(2) > a{
	background-image: url(../img/insta.png);
}
#contact > div.bnr-inner.cntct > div.bnr-inner.sns > div:nth-child(3) > a{
	background-image: url(../img/tiktok.png);
}
#contact > div.bnr-inner.cntct > div.bnr-inner.sns > div:nth-child(4) > a{
	background-image: url(../img/youtube.png);
}

@media (min-width:768px){
	#contact{
    padding: 10% 25%;
	}
	#contact a{transition: 0.3s;}
	#contact a:hover{opacity: 0.7;}
	#contact .cntct .bnr-1col{
		height: 11vw;
		max-height: 200px;
		margin-bottom: 4vw;
	}
	#contact .cntct .bnr-1col a{
		border-radius: 10px;
		height: 100%;
		display: block;
		width: 100%;
		background: url(../img/bnr_line.png) no-repeat center center/70%,#00B900;
	}

	#contact > div.bnr-inner.cntct > div:nth-child(2) > a{
		background: url(../img/bnr_mail.png) no-repeat center center/70%,#A1A3A5;
	}


	#contact > div.bnr-inner.cntct > div:nth-child(3) > a{
		background: url(../img/bnr_tel.png) no-repeat center center/70%,#696F74;
	}


	#contact .sns{
		height: 11vw;
		max-height: 200px;
		padding: 4% 12%;
		border-radius: 10px;
	}

	#contact h3.sns_tl {
		font-size: 3.5em;
		letter-spacing: 2px;
	}
	#contact .sns .bnr-1col{
		height: 7vw;
		width: 6vw;
		margin: 0;
	}

	#contact .sns .bnr-1col a{
		background: url(../img/x.png) no-repeat center center/100%;
	}



}



/*  A privacy
---------------------------------------------------------------------------------------------------- */

#privacy ul li{
	font-size: 13px;
line-height: 2;
list-style: square outside none;
margin: 0 0 0 20px;
padding: 0;
}
#privacy_page{padding-top: 0%;}
#privacy_page .block-a{padding: 15% 10%;}
#privacy_page p.common-content {
    padding: 2% 0%;
    font-size: 0.8em;
}

#privacy_page h4{
	padding-top: 5%;
}

/*  footer
---------------------------------------------------------------------------------------------------- */

.footer_btn{
	width: 100%;
	max-width: 1500px;
	height: 14vw;
	position: fixed;
	bottom: 0;
	right: 0;
	left: 0;
	margin: 0 auto;
	background: rgba(71, 74, 77,0.5);
	z-index: 999;
}
.footer_btn ul{
	width: 100%;
	height: 100%;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}
.footer_btn ul li{
	position: relative;
	width: calc(100% / 3);

}

.footer_btn ul li::after{
    content: '';
    position: absolute;
    top: 30%;
    right: 0;
    width: 2px;
    height: 20px;
    border-right: 1px solid #fff;
}
.footer_btn ul li:nth-child(3)::after{
	display: none;
}

.footer_btn ul li a
{
	width: 100%;
	 height: 14vw;
	 display: block;
	 text-align: center;
	 color: #fff;
	 position:relative;
	 background: url(../img/tel.png) no-repeat center center/20%;
	 }


.footer_btn ul li:nth-child(2) > a{
	background: url(../img/line.png) no-repeat center center/20%;
}
.footer_btn ul li:nth-child(3) > a{
	background: url(../img/mail.png) no-repeat center center/20%;
}


@media (min-width:768px){
	.footer_btn{
		width: 100%;
		max-width: 1480px;
		height: 5vw;
		position: fixed;
		bottom: 0;
		right: 0;
		left: 0;
		margin: 0 auto;
	}
	.footer_btn ul li{width: 100%;}

	.footer_btn ul li a.footer_btn
	{
		 width: 100%;
		 height: 5vw;
		 display: block;
		 text-align: center;
		position:relative;
		transition: 0.3s;
		background-size: 7%;
		 }
	.footer_btn ul li a:hover{
		opacity: 0.7;
	}

}


.copy{
	font-size: 0.6em;
	padding: 2% 0;
	text-align: center;
	background: #909090;
}

@media (min-width:768px){
	.copy{
		text-align: center;
		background: #909090;
	}
}

.privacy-link{
	font-size: 0.6em;
	padding: 2% 0;
	text-align: center;
	display: block;
	text-decoration: underline;
}
