@charset "UTF-8";


/* m_img_bg
---------------------------------------------------------*/
.contentpage .m_img.m_bg .bg_area {
	background-image: url(../images/m_img@2x.jpg);}



/* message
---------------------------------------------------------*/
#message .com_index4{
	margin-bottom: 80px;
}
#message .fltbox{
	width: 104%;
	margin-right: -4%;
}
#message .fltbox .img_r{
	float: right;
	width: 52%;
}
#message .fltbox .txt_l{
	float: left;
	width: 44%;
	margin-top: -1em;
}
#message .fltbox .txt_l p.ft_no{
	font-size: min(125%,2.2vw);
	letter-spacing: 0.1em;
	line-height: 2.3em;
}
#message .me_index1{
	position: relative;
	text-align: center;
	font-size: min(220%,3.5vw);
	letter-spacing: 0.1em;
	line-height: 1.5em;
	margin-bottom: 50px;
}
#message .me_index1 span{
	position: relative;
	z-index: 2;
	background: #fff;
	padding: 0 1em;
	box-sizing: border-box;
}
#message .me_index1::before{
	position: absolute;
	display: block;
	content: "";
background: linear-gradient(135deg,  rgba(114,94,87,0) 0%,rgba(114,94,87,1) 50%,rgba(114,94,87,0) 100%); 
	background-size: 100% auto;
	width: 100%;
	height: 1px;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
}

/*me_bnr*/
.me_bnr {
	display: flex;
    justify-content: start;
	flex-wrap: wrap;
}
.me_bnr_inbox {
	position: relative;
	width: 31%;
	margin-right: 3.5%;
	margin-top: 3.5%;
	font-size: min(100%,1.5vw);
}
.me_bnr_inbox::before{
	position: absolute;
	display: block;
	content: "";
	background: url(../../../images/common/shadow1@2x.png) no-repeat top left;
	background-size: 100% auto;
	width: 100%;
	height: 200px;
	top:100%;
	left: 0;
	z-index: -1;
}
.me_bnr_inbox:nth-child(3n){
	margin-right: 0;
}
.me_bnr_inbox:nth-child(-n+3) {
	margin-top: 0 !important;
}
.me_bnr .me_bnr_index a {
	position: relative;
	display: block;
	background-color: #f1f0ee;
	height: 9em;
	box-sizing: border-box;
}
.me_bnr .me_bnr_index .cat_thm {
	display: block;
	position: absolute;
	top:0;
	right: 0;
	width: auto;
	height: 100%;
	aspect-ratio: 150 / 150;
}
.me_bnr .me_bnr_index .cat_thm::before{
	position: absolute;
	display: block;
	content: "";
	background: linear-gradient(to right,  rgba(241,240,238,1) 0%,rgba(241,240,238,0) 100%); 
	background-size: 100% auto;
	width: 30%;
	height: 100%;
	top:0;
	left: 0;
}
.me_bnr .me_bnr_index .cat_thm img{
	width: auto;
	height: 100%;
}
.me_bnr .me_bnr_index dl{
	position: absolute;
	z-index: 2;
	left: 0;
	top: 52%;
	transform: translateY(-50%);
	padding: 0 1.8em;
}
.me_bnr .me_bnr_index dl dt{
	font-size:180%;
	line-height: 1em;
}
.me_bnr .me_bnr_index dl dd{
	position: relative;
	display: inline-block;
	padding-right: 1.5em;
	box-sizing: border-box;
	font-size:135%;
	letter-spacing: 0.1em;
	line-height: 1em;
	margin-top: .4em;
}
.me_bnr .me_bnr_index dl dd i{
	position: absolute;
	top: -0.2em;
	transform: rotate(90deg);
	right: 0;
	padding: .75em .55em .75em .65em;
	background: #d5bd8f;
	color: #fff;
}

/*.me_box*/
.me_box{
	position: relative;
	background: #faf5ec;
	padding: 80px 5% 90px;
	box-sizing: border-box;
	overflow: hidden;
}
.me_box::before{
	position: absolute;
	display: block;
	content: "";
	background: url(../images/img02@2x.png)no-repeat top left;
	background-size: 100% auto;
	width: 37%;
	height: 500px;
	top:0;
	left: 0;
}
.me_box .txt{
	padding-left: 30.6%;
	box-sizing: border-box;
	position: relative;
	z-index: 2;
}
.me_box .txt .tit{
	font-size: min(210%,3.2vw);
	letter-spacing: 0.1em;
	line-height: 1.5em;
	margin-bottom: 1em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 
#message .com_index4{
	margin-bottom: 4%;
}
#message .fltbox .img_r{
	margin-left: 4%;
	margin-bottom: .5rem;
}
#message .fltbox .txt_l{
	float: none;
	width: 100%;
	margin-top: 0;
}
#message .fltbox .txt_l p.ft_no{
	letter-spacing: 0.05em;
	line-height: 2em;
}
#message .me_index1{
	margin-bottom: 4%;
}

/*me_bnr*/
.me_bnr_inbox {
	width: 32%;
	margin-right: 2%;
	margin-top: 2%;
}
.me_bnr .me_bnr_index dl dd i{
	font-size: 50%;
	padding: .65em .4em .65em .5em;
}

/*.me_box*/
.me_box{
	padding: 5% 4%;
}
.me_box .txt .tit{
	margin-bottom:.5em;
}
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) { 
#message .com_index4{
	margin-bottom: 8%;
}
#message .fltbox{
	width: 100%;
	margin-right: 0;
}
#message .fltbox .img_r{
	float: none;
	width: 80%;
	margin: 0 auto 4%;
}
#message .fltbox .txt_l{
	float: none;
	width: 100%;
	margin-top: 0;
}
#message .fltbox .txt_l p.ft_no{
	font-size: 110%;
	letter-spacing: 0.01em;
	line-height: 2em;
}
#message .me_index1{
	font-size: 130%;
	margin-bottom: 5%;
}

/*me_bnr*/
.me_bnr {
	display: block;
}
.me_bnr_inbox {
	width: 100%;
	margin-right: 0;
	margin-top: 0;
	font-size: 90%;
	margin-bottom: 5%;
}
.me_bnr_inbox:last-child {
	margin-bottom: 0;
}
.me_bnr .me_bnr_index dl dd i{
	top: 0.1em;
}

/*.me_box*/
.me_box{
	padding: 18% 5% 6%;
}
.me_box::before{
	width: 70%;
	left: -5%;
	opacity: .3;
	top:-2em;
}
.me_box .txt{
	padding-left: 0;
}
.me_box .txt .tit{
	font-size:130%;
	margin-bottom: .3em;
	text-align: center;
}
}






/* flow
---------------------------------------------------------*/
#flow .flow_list > li{
	border-bottom: 1px solid #ccc;
	padding-bottom: 50px;
	margin-bottom: 50px;
}
#flow .flow_list > li:last-child{
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom:0;
}
#flow .flow_list .index{
	display: flex;
    align-items: center;
	margin-bottom: .5rem;
	font-size: min(100%,1.6vw);
}
#flow .flow_list .index .brown{
	display: inline-block;
	font-size: 330%;
	line-height: 1em;
}
#flow .flow_list .index .brown2{
	display: inline-block;
	font-size: 210%;
	letter-spacing: 0.13em;
	line-height: 1.5em;
	padding-left: .7em;
	box-sizing: border-box;
	margin-bottom: .2em;
}
#flow .flow_list .inbox{
	background: #f1f0ee;
	padding: 50px 4%;
	box-sizing: border-box;
}
#flow .flow_list .inbox li{
	border-bottom: 1px solid #ccc;
	padding-bottom: 40px;
	margin-bottom: 40px;
}
#flow .flow_list .inbox li:last-child{
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom: 0;
}
#flow .flow_list .inbox h5{
	font-size: min(190%,3vw);
	letter-spacing: 0.05em;
	line-height: 1.5em;
	margin-bottom: .4em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 
#flow .flow_list > li{
	padding-bottom: 5%;
	margin-bottom:5%;
}
#flow .flow_list .inbox{
	padding: 4%;
}
#flow .flow_list .inbox li{
	padding-bottom: 5%;
	margin-bottom: 4%;
}
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) { 
#flow .flow_list > li{
	padding-bottom: 8%;
	margin-bottom:8%;
}
#flow .flow_list .index{
	font-size: 65%;
}
#flow .flow_list .inbox{
	padding: 6% 5%;
}
#flow .flow_list .inbox li{
	padding-bottom: 8%;
	margin-bottom:8%;
}
#flow .flow_list .inbox h5{
	font-size: 120%;
}
}





/* 募集
---------------------------------------------------------*/
/*rec_flex*/
.rec_flex {
    justify-content: center;
    align-items: center;
}
.rec_flex .img_l {
	width: 40%;
}
.rec_flex .img_l + .txt_r {
	width: 56%;
	margin-left: 4%;
}
.rec_flex .img_l img {
	width: 100% !important;
	max-width: initial !important;
}
.rec_flex .txt_r {
	font-size: min(130%,2.2vw);
	letter-spacing: 0.1em;
	line-height: 2.2em;
}

/*rec_table*/
.rec_table  {
	width: 100%;
	border-top: solid 1px #ccc;
	font-size:100%;
	table-layout: fixed;/*列幅を均等*/
}
.rec_table tr{
	width: 100%;
}
.rec_table th,
.rec_table td {
	box-sizing: border-box;
	padding: 2rem 2.5rem;
	text-align: left;
	font-weight: normal;
	border-bottom: solid 1px #ccc;
	vertical-align: middle;
}
.rec_table th{
	width: 24%;
	background: #f1f0ee;
	font-family: "Noto Serif JP", serif;
	font-optical-sizing: auto;
	font-weight: 400!important;
	font-style: normal;
	color: #756159;
	text-align: center;
	font-size:110%;
	line-height: 1.5em;
	letter-spacing: 0.2em;
}
.rec_table td{
	width: 76%;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 
.rec_flex {
    align-items: flex-start;
}
.rec_flex .txt_r {
	letter-spacing: .05em;
	line-height: 1.8em;
}
.rec_table th,
.rec_table td {
	padding: 1.5rem 1.5rem;
}
.rec_table th{
	letter-spacing: 0.1em;
}
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) { 
/*rec_flex*/
.rec_flex {
	display: block;
}
.rec_flex .img_l {
	width: 100%;
	margin: 0 auto 4%;
}
.rec_flex .img_l + .txt_r {
	width: 100%;
	margin-left: 0;
}
.rec_flex .txt_r {
	font-size: 110%;
	letter-spacing: .05em;
	line-height: 1.8em;
}
	
/*rec_table*/
.rec_table tr{
	display: block;
	width: 100%;
}
.rec_table th,
.rec_table td {
	display: block!important;
	width: 100%!important;
}
.rec_table td{
	padding: 3vw 0 6vw;
}
.rec_table th{
	padding: 3vw 0;
	border-bottom: none;
	letter-spacing: 0.1em;
}
}





/* スタッフへインタビュー
---------------------------------------------------------*/
#interview .com_index4{
	margin-bottom: 90px;
}
#interview .int_list li{
	background: #fff;
	margin-bottom: 60px;
	padding: 60px 5%;
	box-sizing: border-box;
}
#interview .int_list li:last-child{
	margin-bottom: 0;
}
#interview .int_list li .img_l{
	width: 27.5%;
	float: left;
}
#interview .int_list li .txt_r{
	width: 67%;
	float: right;
	text-align: center;
}
#interview .int_list li .txt_r dl{
	margin-bottom: 3em;
}
#interview .int_list li .txt_r dt{
	position: relative;
	margin-bottom: .5em;
}
#interview .int_list li .txt_r dt::before{
	position: absolute;
	display: block;
	content: "";
	background: #c1472d;
	background-size: 100% auto;
	width: 1px;
	height: 1.3em;
	top: .1em;
	left: .2em;
	transform: rotate(35deg);
}
#interview .int_list li .txt_r dt,
#interview .int_list li .txt_r dd{
	font-size: min(130%,2.5vw);
	letter-spacing: 0.15em;
	line-height: 1.5em;
	padding-left: 1.2em;
	box-sizing: border-box;
}
#interview .int_list li .txt_r dd span{
	font-size:160%;
}

/*開閉*/
.int_text{
	text-align: left;
	max-height: 2000px;
	transition: max-height 0.6s cubic-bezier(.4,0,.2,1);
}
.int_text.is-close{
	max-height:min(350px,22vw);
	overflow: hidden;
	position: relative;
}
.int_text.is-close::after{
	content:"";
	position:absolute;
	left:0;
	bottom:0;
	width:100%;
	height:60px;
	background: linear-gradient(to bottom, rgba(255,255,255,0), #fff);
}
.more_btn{
	position: relative;
	display:none;
	background: #756159;
	color:#fff;
	cursor:pointer;
	text-align: center;
	letter-spacing: 0.1em;
	line-height: 1em;
	border:none;
	border-radius: 50px;
	margin: 0 auto;
	padding: 1em 6.5em .9em 5.5em;
}
.more_btn::before{
	position: absolute;
	font-family: 'fontello';
	content: '\e800';	
	font-size: 75%;
	top: 1.3em;
	transform: rotate(-90deg);
	right: 7em;
}
.has-more .more_btn{
	display:inline-block;
}
.int_text.is-close + .more_btn::before{
	transform: rotate(90deg);
	top: 1.4em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 
#interview .com_index4{
	margin-bottom: 5%;
}
#interview .int_list li{
	margin-bottom: 6%;
	padding: 5%;
}
#interview .int_list li .txt_r{
	width: 68%;
}
#interview .int_list li .txt_r dl{
	margin-bottom: 1em;
}
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) { 
#interview .com_index4{
	margin-bottom: 6%;
}
#interview .com_index4_txt2{
	letter-spacing: normal;
}
#interview .int_list li{
	margin-bottom: 8%;
	padding:5%;
}
#interview .int_list li .img_l{
	float: none;
	width: 60%;
	margin: 0 auto 5%;
}
#interview .int_list li .txt_r{
	float: none;
	width:100%;
}
#interview .int_list li .txt_r dl{
	margin-bottom: 1em;
}
#interview .int_list li .txt_r dt,
#interview .int_list li .txt_r dd{
	font-size: 110%;
}
.int_text.is-close{
	max-height:40vw;
}
}