@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: 'Noto Serif JP', serif;
	font-weight: 500;
	position: relative;
	max-width: 640px;
	margin: 0 auto;
	line-height: 1.2;
	padding-bottom: 14vw;
	scroll-padding-top: 70px;
	background: #fff;
}
#outer_block{box-sizing: border-box;overflow: hidden;}
@media (min-width:768px){


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

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

/*===========　ロゴ　===========*/
#header_logo{
	width: 100%;
	height: 60px;
	max-width: 640px;

	position: fixed;
	z-index: 999;
	top: 0;
	left: 0;
	right: 0;
	margin: 0 auto;
	display: block;
}
#header_logo:before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background: rgba(51,51,51,0.5);
    backdrop-filter: blur(3px);
}


#header_logo a{
	display: block;
	width: 50vw;
	height: 100%;
	margin: 0 auto;
	position: absolute;
	top: 0;
	left: 0px;
	right: 0;
	background: url(../wimg/w_logo.png) no-repeat center center/100%;
}

@media (min-width:768px){
	#header_logo{
		height: 100px;
		width: 100%;
		max-width: 1500px;
	}
	#header_logo a{
		display: block;
		width: 15vw;
		height: 100%;
		margin: 0 auto;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		background: url(../wimg/w_logo.png) no-repeat center center/100%;
	}
}
/*===========　ヘッダー　===========*/
#html_pc, #html_sp {
    margin: 0 auto;
    z-index: 1;
    display: none;
    width: 100%;
    position: relative;
}

#html_pc{height: 67vw;}
#html_sp{height: 161vw;display: block;}


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

.slider {
  position:relative;
  z-index: 1 !important;
	/*↑z-indexの値をh1のz-indexの値よりも小さくして背景に回す*/
}

/*　PC　*/

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

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

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

#html_pc:before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background: url(../wimg/pc_slide_cover.png) no-repeat center top/100%;
}

/*　SP　*/
#html_sp:before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    content: "";
    display: block;
    width: 100%;
    height: 161vw;
    background: url(../wimg/slide_cover.png) no-repeat center top/100%;
}

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

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

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

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

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

@media (min-width:768px){

}

@media (min-width:768px){
	#html_pc{
		display: block;
		width: 100%;
		max-height: 900px !important;
		min-height: 700px !important;
		height: 67vw !important;	}
	#html_sp{display: none;}

	#html_pc .slider {
		max-height: 900px !important;
		min-height: 700px !important;
		height: 67vw !important;
	}

	#html_pc .slider-item {
		max-height: 900px !important;
		min-height: 700px !important;
		height: 67vw !important;
		}
}






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



#access {
  width: 60vw;
  height: 100vh;
  margin: 0;
  position: fixed;
  top: 0;
  left: -60vw;
  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: 110px auto 0;
	}

#access ul li a{
	color: #fff;
	font-size:1em;
	display: block;
	margin: 0 0 2vw;
	line-height: 1.5;
}

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

.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;
	}
	#access ul li a:before {
		content: '';
		position: absolute;
		bottom: -4%;
		left: 0;
		display: block;
		background: none #fff;
		width: 90%;
		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: 10px;
	left: 20px;
	z-index:9999;
	width: 5vw;
	height: 5vw;
	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: #fff;
  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);
}
.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);
}

@media (min-width:768px){
	.hanNav	{
		position:fixed;
		top: 30px;
		left: 20px;
		z-index:9999;
		width: 60px;
		height: 40px;
		line-height: 1.2em;
		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: #fff;
	  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;
	background: #D5E9F1;
	padding: 4% 2%;
	margin-bottom: 5%;
	display: block;
	width: 100%;
}

p.common-content
{
	padding: 3% 0%;
	font-size: 0.8em;
	line-height: 1.5;
	text-align: justify;
}

.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: 2% 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: 20% 15%;
}
@media (min-width:768px){
.block-a
{
	padding: 10% 20%;
}
}
/*  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: 10% 0%;
}

.table-inner {
	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 #333;
	padding: 3vw 2vw;
	font-size: 0.7em;
}

.table-inner table th {
	width: 50%;
	color: #333;
}

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

.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: 1em;padding: 2vw;}
}

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

.block-a h2.headline-title
{
	letter-spacing: 4px;
	border: 0;
	padding: 1vw 0;
	margin: 0;
	position: relative;
	z-index: 10;
	!i;!;
	font-size: 1.8em !important;!i;!;
}
.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);
}

/*  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.img_blur {
	font-size: 2.5em;
	line-height: 1.2em;
	font-family: "Abril Fatface", serif;
	font-weight: 400;
}
@media (min-width:768px){
	h2.headline-title.img_blur {
		font-size: 5em;
		line-height: 1.7em;
		padding-bottom: 0;
	}
}
.img_blur{
opacity: 0 !important;
-moz-transition: -moz-transform 0.5s linear;
-webkit-transition: -webkit-transform 0.5s linear;
-o-transition: -o-transform 0.5s linear;
-ms-transition: -ms-transform 0.5s linear;
transition: transform 0.5s linear;
-webkit-animation-duration: 1.5s;
animation-duration: 1.5s;
-webkit-animation-fill-mode: both;
animation-fill-mode: both;
}
.img_blur.moved
{
  -webkit-animation-name: imageBlur;
  animation-name: imageBlur;
  opacity: 1 !important;
  transition: .8s !important;
}


@keyframes imageBlur {
  from {
    opacity: 0;
    -webkit-filter: blur(15px);
    -moz-filter: blur(15px);
    -ms-filter: blur(15px);
    -o-filter: blur(15px);
    filter: blur(15px);
  }

  to {
      opacity: 1;
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }
}

/*  cmn
---------------------------------------------------------------------------------------------------- */
.small{
	text-align: center !important;!i;!;!imoi;!imoi;!imo;!i;!;
	margin-bottom: 5vw;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
}


.blur_frame{
	border: solid 1px #333;
	border-radius: 10px;
	padding: 7%;
	background: rgba(51,51,51,0.1);
	margin-bottom: 10vw;
	backdrop-filter: blur(5px);
}

@media (min-width:768px){
	.small{
		font-size: 1em;
		margin-bottom: 5vw;
	}


	.blur_frame{
		border-radius: 10px;
		padding: 7%;
		margin-bottom: 10vw;
	}
}
/*  A msg
---------------------------------------------------------------------------------------------------- */
#msg{
	position: relative;
	padding: 20% 15% 20%;
	background: url(../wimg/msg_bg_blur.png) no-repeat center top/cover;

}

#msg p.small{
	margin: 0 auto;
	width: 90%;
	text-align: center;
	position: relative;
}

#msg .text_block{
	width: 100%;
	height: 100%;
	padding-top: 11%;
	margin-bottom: 20%;
}


#msg  .sub-headline-title{letter-spacing: 3px;line-height: 1.5;font-size: 1.3em;}



#msg span.bigger{font-size: 2em;padding: 0 2%;}

#msg .blur_frame{
    padding: 10% 15%;
    position: relative;
}

#msg .blur_frame:before {
    position: absolute;
    top: -8vw;
    left: -8vw;
    z-index: 0;
    content: "";
    display: block;
    width: 40vw;
    height: 12vw;
    background: url(../wimg/msg_bg_txt.png) no-repeat center top/100%;
}

@media (min-width:768px){
	#msg{
		position: relative;
		padding: 10% 20% 20%;
		background: url(../wimg/pc_msg_bg_blur.png) no-repeat center top/100%;
	}
	#msg p.small{
	margin: 0 auto;
	width: 90%;
	text-align: center;
	position: relative;
}

#msg .text_block{
	padding-top: 4%;
	margin-bottom: 10%;
}
#msg .blur_frame{
    padding: 5% 10%;
}

#msg .blur_frame:before {
    top: -5vw;
    left: -6vw;
    width: 25vw;
    height: 8vw;
}

	}



/*  A story
---------------------------------------------------------------------------------------------------- */
#story{
	position: relative;
	background: url(../wimg/story_bg_txt.png) no-repeat left center/60%,
 url(../wimg/story_bg_noise.png);
	color: #fff;
}



#story .blur_frame{
    border-color: #fff;
}

@media (min-width:768px){

	#story{
		background: url(../wimg/story_bg_txt.png) no-repeat left center/40%,
	 url(../wimg/story_bg_noise.png);
	}

}

/*  A special
---------------------------------------------------------------------------------------------------- */
#special{
	position: relative;
	background: url(../wimg/sp_bg.png) no-repeat center top/cover;
	color: #fff;
}
#special .blur_frame{
    border-color: #fff;
}

#special  .sub-headline-title{
	font-size: 1.2em;
	padding-top: 7vw;
	background: url(../wimg/sp_ttl.png) no-repeat center top/11%;
}

@media (min-width:768px){

	#special{
		position: relative;
		background: url(../wimg/sp_bg.png) no-repeat center center/cover;
		color: #fff;
	}
#special  .sub-headline-title{
	font-size: 1.2em;
	padding-top: 4vw;
	background: url(../wimg/sp_ttl.png) no-repeat center top/6%;
}
}

/*  A select
---------------------------------------------------------------------------------------------------- */
#select{
	position: relative;
	background: url(../wimg/sl_bg_txt1.png) no-repeat left top 10vw/40%, url(../wimg/sl_bg_txt2.png) no-repeat right bottom 10vw/40%, url(../wimg/noise.png), #FDF0D5;
	padding-bottom: 40%;
}

#select .blur_frame{
	background: rgba(255,255,255,0.1);
	backdrop-filter: blur(5px);
}
#select h3{font-size: 1.2em;position: relative;line-height: 2;padding-top: 30px;}
#select h3:before{
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right:0;
	display: block;
	width: 30px;
	height: 30px;
	background: url(../wimg/sl_ttl.png) no-repeat center top/60%;
	margin: 0 auto;
}


#select .select_slide_img{
	display: block;
	width: 100%;
	height: 25vw;
	background: url(../wimg/w_slide_img.png) repeat-x center center/170%;
	animation: toleft 60s linear 0s infinite;
	position: absolute;
	left: 0;
}
@keyframes toleft {
  0% { background-position-x: 0; }
  100% { background-position-x: -200vw; }
}

@media (min-width:768px){
	#select{
		position: relative;
		background: url(../wimg/sl_bg_txt1.png) no-repeat left top 8vw/22%,
		url(../wimg/sl_bg_txt2.png) no-repeat right bottom 10vw/30%,
		url(../wimg/noise.png), #FDF0D5;
		padding-bottom: 40%;
	}

}
/*  A episode
---------------------------------------------------------------------------------------------------- */
#episode{
	position: relative;
	background: url(../wimg/ep_bg.png) no-repeat center top/cover;
	color: #fff;
}

/*タブを並べる設定*/
.tab-postit {
    display: flex;
    flex-wrap: wrap;
    max-width: 650px;
}
/*タブ見出しの設定*/
.tab-postit > label {
    flex: 1 1;
    order: -1;
    min-width: 70px;
    padding: .7em 1em .5em;
    border-bottom: 1px solid #333;
    border-radius: 0;
    background: rgba(51,51,51,0.2);
    color: #ccc;
    font-size: .9em;
    text-align: center;
    cursor: pointer;
    backdrop-filter: blur(5px);
}
.tab-postit h3{
    font-size: 0.8em !important;
    letter-spacing: 1px;
}
/*ホバーされた時*/
.tab-postit > label:hover {
    opacity: 0.8;
}
/*表示しない*/
.tab-postit input {
    display: none;
}
/*デフォルトでは表示しない*/
.tab-postit > div {
    display: none;
    width: 100%;
    padding: 1.5em 1em;
}
/*クリックされた時*/
.tab-postit label:has(:checked) {
    background: rgba(255,255,255,0.4);
    border-color: #333 #333 #333 #333;
    border-style: solid;
    border-width: 1px 1px 0px 1px;
    border-radius: 5px 5px 0 0px;
    color: #000;
}
/*クリックされたら表示*/
.tab-postit label:has(:checked) + div {
    display: block;
}

.can-scroll {
    width: max-content;
    height: 100vw;
    background: rgba(255,255,255,0.4);
    backdrop-filter: blur(5px);
    overflow: auto;
    border: 1px solid #333;
    border-top: none;
    border-radius: 0 0 5px 5px;
}

.talk{
    border: 1px solid #333;
    border-radius: 5px;
    padding: 3%;
    margin-bottom: 4% !important;
    min-width: 50%;
    max-width: 80%;
    display: inline-block;
    color: #333;
    font-size: 0.6em;
    backdrop-filter: blur(5px);
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
}

.customer{margin: 0 auto 0 0;position: relative;padding-top: 20px;}

.staff{display: flex;justify-content: right;position: relative;padding-top: 20px;}

.customer:before{
	content: 'Customer';
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 40px;
	height: 20px;
	background: url(../wimg/ep_cs.png) no-repeat top left/15px;
	font-size: 13px;
	color: #333;
	text-indent: 20px;
}

.staff:before{
	content: 'Staff';
	position: absolute;
	top: 0;
	right: 5px;
	display: block;
	width: 55px;
	height: 20px;
	background: url(../wimg/ep_staff.png) no-repeat top right/15px;
	font-size: 13px;
	color: #333;
	text-indent: 5px;
}

@media (min-width:768px){

	#episode{
		position: relative;
		background: url(../wimg/pc_ep_bg.png) no-repeat center top/cover;
		color: #fff;
	}
	.tab-postit {
	    max-width: max-content;
	}
	.can-scroll {
	    height: 55vw;
	    min-width: 860px;
	}
	.talk{
	    border-radius: 5px;
	    padding: 3%;
	    margin-bottom: 4% !important;
	    min-width: 25%;
	    max-width: 50%;
	    font-size: 1em;
	    backdrop-filter: blur(5px);
	    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	}
	.customer{padding-top: 24px;}

	.staff{padding-top: 25px;}

	.customer:before{
		content: 'Customer';
		position: absolute;
		top: 0;
		left: 0;
		display: block;
		width: 45px;
		height: 25px;
		background: url(../wimg/ep_cs.png) no-repeat top left 8px/18px;
		font-size: 15px;
		color: #333;
		text-indent: 30px;
	}

	.staff:before{
		content: 'Staff';
		position: absolute;
		top: 0;
		right: 10px;
		display: block;
		width: 55px;
		height: 20px;
		background: url(../wimg/ep_staff.png) no-repeat top right/18px;
		font-size: 15px;
		color: #333;
		text-indent: -4px;
	}

}


/*  A consulting
---------------------------------------------------------------------------------------------------- */
#consulting{
	position: relative;
	background: url(../wimg/cslt_bg.png) no-repeat center top/cover;
}
#consulting h3{position: relative;font-size: 0.9em;letter-spacing: 1px;border-bottom: 1px solid #333;}





tr.ttl_tr{
	background: rgba(255,255,255,0.4);
}

#consulting .blur_frame h3{width: 47vw;margin: 0 auto 5vw;}
#consulting .bnr-1col
{
	width: 100%;
	height: 20vw;
}
#consulting a.line{
	border-radius: 5px;
	height: 15vw;
	display: block;
	width: 100%;
	background: url(../img/bnr_line.png) no-repeat center center/100%,#00B900;
}
#consulting a.base{
	height: 100%;
	display: block;
	width: 100%;
	background: url(../wimg/bnr_base.png) no-repeat center center/100%;
	border: 2px solid #333;
}

#consulting .blur_frame img{
    display: block;
    margin: 5vw auto;
}

@media (min-width:768px){
	#consulting h3{position: relative;font-size: 1em;letter-spacing: 1px;}
	#consulting h3:before{
		content: '';
		position: absolute;
		top: 49%;
		bottom: 0;
		left: 24%;
		display: block;
		width: 30px;
		height: 1px;
		background: #333;
	}


	#consulting h3:after{
		content: '';
		position: absolute;
		top: 49%;
		bottom: 0;
		right: 24%;
		display: block;
		width: 30px;
		height: 1px;
		background: #333;
	}
	#consulting .blur_frame h3{width: 100%;margin: 0 auto 5vw;font-size: 1.3em;box-sizing: border-box;}
	#consulting .bnr-1col
	{
		width: 100%;
		height: 20vw;
	}
	#consulting a{transition: 0.3s;}
	#consulting a:hover{opacity: 0.7;}
	#consulting  .blur_frame{
    padding: 10% 15%;
}

}


/*  A contact
---------------------------------------------------------------------------------------------------- */
#contact{
	position: relative;
	background: url(../wimg/cnt_bg_txt.png) no-repeat left top 20vw/60%,
 url(../wimg/cnt_bg_blur.png)no-repeat center center/cover;
}

#contact p.common-content{margin-bottom: 10vw;}
#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  .cntct .bnr-1col a.mail{
	background: url(../wimg/wine_bnr_mail.png) no-repeat center center/100%,#E7C8B4;
}


#contact  .cntct .bnr-1col a.tel{
	background: url(../img/bnr_tel.png) no-repeat center center/100%,#BE8B77;
}


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

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

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

#contact .sns .bnr-1col  a.insta{
	background-image: url(../img/insta.png);
}
#contact .sns .bnr-1col  a.tiktok{
	background-image: url(../img/tiktok.png);
}
#contact .sns .bnr-1col  a.youtube{
	background-image: url(../img/youtube.png);
}
#contact .base_info h3{
    margin-bottom: 3vw;
    font-size: 1.2em;
}
#contact .base_info .bnr-1col{height: 20vw;}
#contact .base_info a.base{
	height: 21vw;
	display: block;
	width: 100%;
	background: url(../wimg/bnr_base.png) no-repeat center center/100%;
	border: 2px solid #333;
}

#contact .blur_frame img{
    display: block;
    margin: 5vw auto;
}

#contact a.law{
	padding: 3vw;
	color: #fff;
	display: block;
	margin: 0 auto;
	width: 36vw;
	text-align: center;
	border: 1px solid #FFF;
	border-radius: 5px;
}

@media (min-width:768px){

	#contact{
		position: relative;
		background: url(../wimg/cnt_bg_txt.png) no-repeat left top 20vw/39%,
  url(../wimg/pc_cnt_bg_blur.jpg)no-repeat center center/cover;
		padding: 10% 25%;
	}
	#contact p.common-content{margin-bottom: 5vw;}

	#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  .cntct .bnr-1col a.mail{
		background: url(../wimg/wine_bnr_mail.png) no-repeat center center/70%,#E7C8B4;
	}


	#contact  .cntct .bnr-1col a.tel{
		background: url(../img/bnr_tel.png) no-repeat center center/70%,#D3A394;
	}


	#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%;
	}


	#contact .base_info .bnr-1col{height: 14vw;margin: 5vw auto;}
	#contact .base_info a.base{
		height: 13vw;
		display: block;
		width: 100%;
		background: url(../wimg/bnr_base.png) no-repeat center center/100%;
		border: 2px solid #333;
	}

	#contact .blur_frame img{
	    display: block;
	    margin: 3vw auto;
	}

	#contact a.law{
		padding: 1vw;
		color: #fff;
		display: block;
		margin: 0 auto 6vw;
		width: 15vw;
		text-align: center;
		border: 1px solid #FFF;
		border-radius: 5px;
		letter-spacing: 1px;
	}


}

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

#privacy ul li{
	font-size: 13px;
line-height: 2;
list-style: square outside none;
margin: 0 0 0 20px;
padding: 0;
}

#privacy h3{
	margin-top: 3vw;
	margin-bottom: 2vw;
}

#privacy  p.common-content{margin-bottom: 2vw;}

#privacy  .table-inner table th{width: 35%;}

span._bold{
	font-weight: bold;
}

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

.footer_btn{
	width: 100%;
	max-width: 1500px;
	height: 14vw;
	position: fixed;
	bottom: 0;
	right: 0;
	left: 0;
	margin: 0 auto;
	background: rgba(51,51,51,0.8);
	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: 1500px;
    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;
		max-width: 1500px;
		width: 100%;
		margin: 0 auto;
	}
	}


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