/*
Theme Name: shiki kensetu
Theme URI:
Author: zeal
Author URI:
Description:
Version: 1.0
License:
License URI:
Tags:

=============================================================================================
*/

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&display=swap');
/*
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');
*/



/*----------------------------------------
	全体
----------------------------------------*/

html{
	font-family:'游ゴシック体', 'Yu Gothic', YuGothic,'メイリオ',Meiryo,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ ゴシック',sans-serif;
	font-size:62.5%;
	color: #333;
	-webkit-text-size-adjust:100%;
	line-height:1.5;
}
.yugo{
	font-family:'游ゴシック体', 'Yu Gothic', YuGothic,'メイリオ',Meiryo,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ ゴシック',sans-serif;
}
.yumin{
    font-family:'游明朝体','Yu Mincho','ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro','ＭＳ Ｐ明朝','ＭＳ 明朝','Sawarabi Mincho',serif;
}
.meiryo{
  font-family:'メイリオ',Meiryo,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ ゴシック',sans-serif;
}

.noto{
	font-family: "Noto Sans JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: normal;
	font-style: normal;
}

.poppins{
	font-family: "Poppins", sans-serif;
}
/*
.montserrat{
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}*/



body{ font-size:1.4rem; font-size: 1.4em; }
#container{
	overflow: hidden;
		color: #000;
			font-weight: 500;
}
img{ vertical-align: bottom; }
a{
	color:#1c1c1c;
	transition: all 0.4s;
	text-decoration: none;
}
a:hover,
.op:hover{
	opacity: 0.7;
	transition: all 0.4s;
}

#faq a{
    color:#1a73e8;
}

.nolink{
	pointer-events: none;
	opacity: 0.3;
}
.opnolink{
	pointer-events: none;
	opacity: 1;
}

.sp_none{
	display: block;
}

@media screen and (max-width: 599px){

	.sp_none{
		display: none;
	}

}
/*END*/




/*----------------------------------------
	共通
----------------------------------------*/
.bg_black{ background: #000; }
.bg_white{ background: #fff; }
.bg_gray{ background: #eeeeee;}
.bg_em{ background: #52b1ba;}
.bg_beige{ background: #f9f5ec;}


/*----------------------------------------
	text
----------------------------------------*/
p{ line-height: 2; }
.text_bold{ font-weight: bold; }
.text_normal{ font-weight: normal; }

:root {
    --text_g_color: #404040;

}

.bold300{ font-weight: 300; }
.bold400{ font-weight: 400; }
.bold500{ font-weight: 500; }
.bold600{ font-weight: 600; }
.bold800{ font-weight: 800; }

.text_gray{ color: #a0a0a0; }
.text_red{ color: #e60012; }
.text_yellow{ color:#fff100; }
.text_em{ color:#1cabb9; }
.text_white{ color: #fff; }
.text_blue{ color:#1a0dab; }
.text_g_color{ color: var(--text_g_color); }


.palt{
  font-feature-settings: "palt";
}

:root {
	--text12: clamp(1.1rem, 1.1vw, 1.2rem);
    --text13: clamp(1.2rem, 1.25vw, 1.3rem);
    --text14: clamp(1.3rem, 1.34vw, 1.4rem);
    --text15: clamp(1.4rem, 1.4vw, 1.5rem);
    --text16: clamp(1.4rem, 1.5vw, 1.6rem);
    --text18: clamp(1.5rem, 1.7vw, 1.8rem);
    --text20: clamp(1.6rem, 1.9vw, 2rem);
	--text21: clamp(1.7rem, 2vw, 2.1rem);
    --text22: clamp(1.7rem, 2.1vw, 2.2rem);
    --text24: clamp(1.8rem, 2.3vw, 2.4rem);
    --text26: clamp(1.8rem, 2.5vw, 2.6rem);
    --text28: clamp(2rem, 2.6vw, 2.8rem);
    --text30: clamp(2.2rem, 2.8vw, 3rem);
    --text32: clamp(2.2rem, 3vw, 3.2rem);
    --text34: clamp(2.4rem, 3.2vw, 3.4rem);
    --text36: clamp(2.4rem, 3.3vw, 3.6rem);
    --text38: clamp(2.6rem, 3.4vw, 3.8rem);
    --text40: clamp(2.6rem, 3.8vw, 4rem);
    --text42: clamp(2.8rem, 3.9vw, 4.2rem);
    --text44: clamp(2.8rem, 4vw, 4.4rem);
    --text46: clamp(3rem, 4.1vw, 4.6rem);
    --text48: clamp(3rem, 4.2vw, 4.8rem);
    --text50: clamp(3.2rem, 4.3vw, 5rem);

}

.text_12 { font-size: var(--text12); }
.text_13 { font-size: var(--text13); }
.text_14 { font-size: var(--text14); }
.text_15 { font-size: var(--text15); }
.text_16 { font-size: var(--text16); }
.text_18 { font-size: var(--text18); }
.text_20 { font-size: var(--text20); }

.text_21 { font-size: var(--text21); }
.text_22 { font-size: var(--text22); }
.text_24 { font-size: var(--text24); }
.text_26 { font-size: var(--text26); }
.text_28 { font-size: var(--text28); }
.text_30 { font-size: var(--text30); }
.text_32 { font-size: var(--text32); }
.text_34 { font-size: var(--text34); }
.text_36 { font-size: var(--text36); }
.text_38 { font-size: var(--text38); }
.text_40 { font-size: var(--text40); }
.text_42 { font-size: var(--text42); }
.text_44 { font-size: var(--text44); }
.text_46 { font-size: var(--text46); }
.text_48 { font-size: var(--text48); }
.text_50 { font-size: var(--text50); }

.text_56{
	font-size: clamp(3.3rem, 4.4vw, 5.6rem);
}
.text_60 {
    font-size: clamp(3.4rem, 4.5vw, 6rem);
    line-height: 1;
}
.text_68{
	font-size:clamp(3.4rem, 6.8vw, 6.8rem);
	line-height: 1;
}
.text_72{
	font-size:clamp(3.6rem, 7vw, 7.2rem);
	line-height: 1;
}
.text_78{
	font-size:clamp(3.8rem,7.5vw,7.8rem);
	line-height: 1;
}
.text_80{
	font-size:clamp(4.0rem,7.86vw,8.0rem);
	line-height: 1;
}
.text_85{
	font-size:clamp(4.2rem,8.2vw,8.5rem);
	line-height: 1;
}
.text_100{
	font-size:clamp(4.4rem,9.6vw,10rem);
	line-height: 1;
}
.text_150{
	font-size:clamp(7.5rem,11vw,15rem);
	line-height: 1;
}

.vertical50{
    vertical-align: 50%;
}


/*line-height*/
.lh_06{ line-height: 0.6; }
.lh_08{ line-height: 0.8; }
.lh_11{ line-height: 1.1 }
.lh_12{ line-height: 1.2 }
.lh_13{ line-height: 1.3 }
.lh_14{ line-height: 1.4 }
.lh_15{ line-height: 1.5 }
.lh_16{ line-height: 1.6 }
.lh_17{ line-height: 1.7 }
.lh_18{ line-height: 1.8 }

/*letter-spacing*/
.ls_-2{ letter-spacing: -2px; }
.ls_-1{ letter-spacing: -1px; }
.ls_06{ letter-spacing: 0.6px; }
.ls_1{ letter-spacing: 1px; }
.ls_12{ letter-spacing: 1.2px; }
.ls_14{ letter-spacing: 1.4px; }
.ls_18{ letter-spacing: 1.8px; }
.ls_2{ letter-spacing: 2px; }
.ls_3{ letter-spacing: 3px; }
.ls_-01em{ letter-spacing: -0.1em; }
.text_r{text-align:right;}

a.link_tex{ color: #0199cc; }
a.link_tex:hover{ opacity: 0.7; }



@media print, screen and (min-width: 821px){

	/*line-height*/
	.lh_19{ line-height: 1.9; }
	.lh_20{ line-height: 2; }
	.lh_21{ line-height: 2.1; }
	.lh_22{ line-height: 2.2; }
	.lh_23{ line-height: 2.3; }
	.lh_24{ line-height: 2.4; }
	.lh_25{ line-height: 2.5; }
	.lh_26{ line-height: 2.6; }
	.lh_28{ line-height: 2.8; }
	.lh_30{ line-height: 3; }
	.lh_32{ line-height: 3.2; }
	.lh_34{ line-height: 3.4; }
	.lh_36{ line-height: 3.6; }

	/*letter-spacing*/
	.ls_4{ letter-spacing: 4px; }
	.ls_5{ letter-spacing: 5px; }
	.ls_6{ letter-spacing: 6px; }
	.ls_7{ letter-spacing: 7px; }
	.ls_8{ letter-spacing: 8px; }

}/*END*/

@media screen and (max-width: 820px){

	/*letter-spacing*/
	.ls_4{ letter-spacing: 3px; }
	.ls_5{ letter-spacing: 4px; }
	.ls_6{ letter-spacing: 4px; }
	.ls_7{ letter-spacing: 4px; }
	.ls_8{ letter-spacing: 4px; }

	/*line-height*/
	.lh_19,
	.lh_20,
	.lh_21,
	.lh_22,
	.lh_23,
	.lh_24,
	.lh_25{
		line-height: 1.8;
	}

}/*END*/

@media screen and (max-width: 599px){

	/*letter-spacing*/
	.ls_4{ letter-spacing: 2px; }
	.ls_5{ letter-spacing: 2px; }
	.ls_6{ letter-spacing: 2px; }
	.ls_7{ letter-spacing: 2px; }
	.ls_8{ letter-spacing: 2px; }

}/*END*/

li{ list-style:none; }
.center{ text-align:center; }
.text_left{ text-align:left; }
.text_right{ text-align:right; }
.clear{ clear:both; }

.op:hover{
	filter: alpha(opacity=60);
	-moz-opacity:060;
	opacity:0.60;
}

@media screen and (max-width: 599px){
	.sp_text_left{ text-align:left; }
	.sp_center{text-align: center;}

	.sp_palt{
		font-feature-settings: "palt";
	}

}/*END*/


/*----------------------------------------
	layout
----------------------------------------*/

.max_respon{
	max-width:100%;
}
.pc_block{
	display: block;
}
.sp_block{
	display: none;
}
.tb_block{
	display: none;
}
.nm_t5{
	margin-top:-5px;
}
.inner_frame{
	max-width: 1080px;
	width: 100%;
	position: relative;
	box-sizing: border-box;
	margin-inline: auto;
	padding-right: 20px;
	padding-left: 20px;
}
.inner_frame1350{
	max-width: 1350px;
	width: 100%;
	position: relative;
	box-sizing: border-box;
	margin-inline: auto;
}
.rela{
	position: relative;
}
.rela_z1{
	position: relative;
	z-index: 1;
}
.rela_z2{
	position: relative;
	z-index: 2;
}
.rela_z3{
	position: relative;
	z-index: 3;
}

.text_line{
	display: inline-block;
	border-bottom: 1px solid #000;
}

.flex{
	display: flex;
}

.content_fl_box{
	display: flex;
	gap: 3.5%;
}
.content_fl_box.between{
	justify-content: space-between;
}
.content_fl_box.around{
	justify-content: space-around;
}
.content_fl_box.j_center{
	justify-content: center;
}
.content_fl_box.reverse{
	flex-direction: row-reverse;
}
.content_fl_box.end{
	justify-content: flex-end;
}
.j_end{
	justify-content: flex-end;
}

.i_center{
	align-items: center;
}
.i_end{
	align-items: flex-end;
}
.c_end{
	align-content: flex-end;
}
.c_center{
	align-content: center;
}
.content_fl_box.wrap{
	flex-wrap: wrap;
}
.content_fl_box.wrap.row45{
	row-gap: 45px;
}
.content_fl_box.wrap.row40{
	row-gap: 40px;
}
.content_fl_box.wrap.row20{
	row-gap: 20px;
}

.nogap{ gap:0; }
.content_fl_box50{
	display: flex;
}
.box25{width: 25%; }
.box30{width: 30%; }
.box35{width: 35%; }
.box40{width: 40%; }
.box45{width: 45%; }
.box47{width: 48.1%; }
.box50{width: 50%; }
.box55{width: 55%; }
.box60{width: 60%; }
.box65{width: 65%; }
.box70{width: 70%; }
.box75{width: 75%; }


@media screen and (max-width: 768px){

	.inner_frame{
		padding-right: 3.5%;
		padding-left: 3.5%;
	}

}/*END*/

@media screen and (min-width: 600px){
	.order00{ order: 0; }
	.order01{ order: 1; }
	.order02{ order: 2; }
	.order03{ order: 3; }
	.order04{ order: 4; }
	.order05{ order: 5; }



}/*END*/

@media screen and (max-width: 599px){
	.inner_frame{
		padding-right: 4.3%;
		padding-left: 4.3%;
	}

	.content_fl_box{
		flex-wrap: wrap;
	}
	.box,.box70,.box65,.box60,.box40,.box50,.box55,.box25,.box75,.box47,.box45,.box35,.box30{
		width: 100%;
		margin-bottom: 30px;
	}

	.content_fl_box > div:last-child{
		margin-bottom: 0;
	}

	.content_fl_box50{
		flex-wrap: wrap;
	}

	.pc_block{
		display: none;
	}
	.sp_block{
		display: block;
	}

	.content_fl_box.sp_nowrap{
		flex-wrap: nowrap;
	}

	.sp_d_contents{
		display: contents;
	}
	.sp_order_wrap{
		display: flex;
		flex-flow: column;
	}
	.c_order01{ order:1; }
	.c_order02{ order:2; }
	.c_order03{ order:3; }
	.c_order04{ order:4; }
	.c_order05{ order:5; }
	.c_order06{ order:6; }
	.sp_last_btn{
		margin:30px auto 0 auto;
		width: 100%;
	}

	.sp_bg_pb{
		padding-bottom: 0;
	}
	.sp_lastbtn_pt{
		padding-top: 30px;
	}


	.content_fl_box.wrap.row40,.content_fl_box.wrap.row45{
		row-gap:0;
	}
	.content_fl_box.wrap.row20{
		row-gap: 0;
	}

	.sp_mb0{
		margin-bottom: 0;
	}

	.content_fl_box.sp_catalog_gap{
		gap: 1.5%;
	}
	.content_fl_box.sp_catalog_gap > div{
		margin-bottom: 0;
	}


}/*END*/



/*----------------------------------------
	画像中央配置
----------------------------------------*/

.photo_frame{
    position: relative;
    overflow: hidden;
    aspect-ratio: 1 / 1;
}
.photo_frame img{
	width: 100%;
	height: 100%;
	object-fit: cover;
    /*
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate3d(-50%, -50%, 0);
    */
}
.photo_frame img:not(:target){
	left: 0\9;
	top: 0\9;
}
.photo_frame img{
	left: 0\9;
	top: 0\9;
}
@media all and (-ms-high-contrast: none){
.photo_frame img{
		left: 50%\9 !important;
		top: 50%\9 !important;
	}
}
.photo_frame{ z-index: 1; }/*chrome対策*/


/*----------------------------------------
	iframe比率維持
----------------------------------------*/

.map {
    position: relative;
    overflow: hidden;
    text-align: center;
    aspect-ratio: 2 / 1;
}
.map iframe{
	width: 100%;
	height: 100%;
	position: absolute;
	left: 50%;
	top: 50%;
	-webkit-transform: translate3d(-50%, -50%, 0);
	-ms-transform: translate3d(-50%, -50%, 0);
	transform: translate3d(-50%, -50%, 0);
}
.map.ichi{
	aspect-ratio: 1 / 1;
}
.map.nanago{
	aspect-ratio: 2 / 1;
}

.map iframe:not(:target){
	left: 0\9;
	top: 0\9;
}
.map iframe{
	left: 0\9;
	top: 0\9;
}
@media all and (-ms-high-contrast: none){
.map iframe{
		left: 50%\9 !important;
		top: 50%\9 !important;
	}
}
.map{ z-index: 2; }/*chrome対策*/

@media screen and (max-width: 599px){
	.map {
		aspect-ratio: 1 / 1;
	}
	.map.nanago{
		aspect-ratio: 1.2 / 1;
	}

}/*END*/


.movie{
	position: relative;
	overflow: hidden;
	width: 100%;
	height: 100%;
	padding: 56.25% 0 0;
	text-align: center;
}
.movie iframe{
	width: 100%;
	height: 100%;
	position: absolute;
	left: 50%;
	top: 50%;
	-webkit-transform: translate3d(-50%, -50%, 0);
	-ms-transform: translate3d(-50%, -50%, 0);
	transform: translate3d(-50%, -50%, 0);
}
.movie iframe:not(:target){
	left: 0\9;
	top: 0\9;
}
.movie iframe{
	left: 0\9;
	top: 0\9;
}
@media all and (-ms-high-contrast: none) {
.movie iframe{
		left: 50%\9 !important;
		top: 50%\9 !important;
	}
}
.movie iframe{ z-index: 2; }/*chrome対策*/



/*ぱんくず*/

.pan_nav li{
	float: left;
	font-size: 1.4rem;
	letter-spacing: 1px;
	/*white-space: nowrap;*/
	line-height: 1.6;
}
.pan_nav a{
	color: var(--text_g_color);
	text-decoration: none;
}
.pan_nav a:hover{
	opacity: 0.7;
}
.pan_nav a:after{
	content: ">";
	color: var(--text_g_color);
	padding-left: 10px;
	margin-right: 10px;
	display: inline-block;
}
.pan_nav.gray_ver{
	background: #eee;
	color: var(--text_g_color);
}

.pan_nav.text_black li,
.pan_nav.text_black,
.pan_nav.text_black a:after,
.pan_nav.text_black a{
	color: #000;
}
.pan_nav.text_black a:hover{
	color: #000;
	opacity: 0.8;
}

@media screen and (max-width: 960px){
	.pan_nav{
		right: 15%;
	}

}/*END*/

@media screen and (max-width: 599px){

}/*END*/


/*----------------------------------------
	フォーム　テーブル
----------------------------------------*/

.tb_style{
	width: 100%;
}
table.tb_style{
	word-break: break-all;
}
.tb_style th,
.tb_style td{
	line-height: 1.6;
	text-align: left;
	font-weight: normal;
	padding:20px 10px 20px 15px;
	overflow-wrap : break-word;
}
.tb_style th{
	box-sizing: border-box;
	width:30%;
	font-weight: bold;
}
.tb_style td{
	padding-left:15px;
}
.tb_style .tr_add th{
	vertical-align: top;
	padding-top: 4.5%;
}

@media print, screen and (min-width: 900px){

	.tb_style th{
		width: 230px;
	}

}/*END*/

@media screen and (max-width: 899px){

	.tb_style th{
		width: 28%;
	}

}/*END*/

@media screen and (max-width: 599px){

	table.tb_style{
		border-spacing: 0 0;
	}
	.tb_style th{
		width: 100%;
		padding-left: 0;
	}
	.tb_style th, .tb_style td{
		border: none;
		display: block;
		font-size:1.4rem;
	}
	.tb_style th{
		font-weight: bold;
		padding:8px 5px 0 0;
	}
	.tb_style td{
		padding: 8px 0 15px 0;
	}

}/*END*/

/*必須・任意*/
.hissu,
.nini{
	display: inline-block;
	line-height: 1 !important;
	padding: 3px 5px;
	margin-left: 6px;
	vertical-align: middle;
	border-radius: 2px;
	font-size: 1.4rem !important;
	box-sizing: border-box;
	margin-top: -2px;
}
.hissu{
	background: #bb3f49;
	color: #fff;
}
.nini{
	color: #fff;
	background: #7d7d7d;
}
.add span{
	display: inline-block;
	padding-right: 10px;
}
.privacy span{ display: inline-block !important; }
.privacy_error{
	text-align: center;
	padding: 2px 10px;
}
.privacy.check label{
	padding-top:0;
	padding-bottom: 0;
}
.privacy_check .vertical-item{
	display: inline-block !important;
}
.privacy_check{
	background: #ece8dc;
	padding: 25px 10px;
}


/*----------------------------------------
	フォーム
----------------------------------------*/

select,
textarea,
input[type="text"],
input[type="tel"]{
	background:#fff;
	border: none;
	padding: 15px 13px;
	box-sizing: border-box;
	-webkit-appearance: none;
    appearance: none;
	transition: all 0.4s;
	font-size: 1.6rem;
	color: #333;
		font-family:'游ゴシック体', 'Yu Gothic', YuGothic,'メイリオ',Meiryo,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ ゴシック',sans-serif;
}
input:focus{
	outline: none;
}
input[type="button"]{
	-webkit-appearance: none;
    appearance: none;
}
button,
input[type="submit"]{
	-webkit-appearance: none;
    appearance: none;
	transition: all 0.4s;
}
select{
	background-size: auto 100%;
	padding-right: 60px;
}
.tb_style textarea{
	width:100%;
}

.form1{ width: 100px; }
.form2{ width: 120px; }
.form3{ width: 200px; }
.form4{ width: 400px; }
.form_all{ width: 100%; }

input.job_sonota{
	padding: 8px 8px !important;
}

@media screen and (max-width: 768px){

	select,
	textarea,
	input[type="text"]{
		font-size: 1.6rem;
	}
	.form3,
	.form4{
		width: 100%;
	}

}/*END*/


/*----------------------------------------
    datepicker
----------------------------------------*/

#ui-datepicker-div{
    max-width: 100%;
    width: 350px;
}
.ui-state-default,
.ui-widget-content .ui-state-default,
.ui-widget-header .ui-state-default,
.ui-button, html .ui-button.ui-state-disabled:hover,
html .ui-button.ui-state-disabled:active{
    padding: 15px;
}
.ui-datepicker .ui-datepicker-header{
    padding: 8px 0;
}


/*----------------------------------------
	iframe
----------------------------------------*/

.style_k_f{
	width: 100%;
	height: 100%;
	aspect-ratio: 15 / 44;
}
.form_tr{
	width: 100%;
	margin-bottom: 30px;
}
.form_tr label{
	width: 100%;
	position: relative;
	display: inline-block;
	max-width: 100%;
	margin-bottom: 5px;
	font-weight: bold;
}
.form_tr input,.form_tr select,.form_tr textarea{
	display: block;
	width: 100%;
	height: 32px;
	padding: 6px 12px;
	font-size: 13px;
	line-height: 1.42857143;
	color: #555555;
	background-color: #ffffff;
	background-image: none;
	border: 1px solid #cccccc !important;
	border-radius: 4px;
	-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
	box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
	-webkit-transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;
	-o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
	transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
	height:45px;
	font-size:15px;
	border:1px solid #e0e0e0;
	border-radius: 2px;
}
.form_tr textarea{
	height: auto;
}
.form_tr input[type="checkbox"], input[type="radio"]{
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	padding: 0;
	margin-right: 0.4em !important;
	width: 26px;
	height: 26px;
}
.well-form-only{
	min-height: 20px;
	padding: 19px;
	margin-bottom: 5px;
	background-color: #f5f5f5;
	border: 1px solid #e3e3e3;
	border-radius: 4px;
	-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
	box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
}
.form_tr_flex{
	display: flex;
	gap:2.5%;
}
.f_hissu{
	background-color: #df6f5f;
	color: #fff;
	font-size: 1.2rem;
	margin-right: 0.3em;
	font-size: 0.8em;
	padding: 0.05em 0.3em 0.1em 0.3em;
	border-radius: 0.3em;
	white-space: nowrap;
	text-align: center;
	font-weight: normal;
}
.f_nini{
	background-color: #f5b555;
	color: #fff;
	font-size: 1.2rem;
	margin-right: 0.3em;
	font-size: 0.8em;
	padding: 0.05em 0.3em 0.1em 0.3em;
	border-radius: 0.3em;
	white-space: nowrap;
	text-align: center;
	font-weight: normal;
}
input[type="submit"]{
	-webkit-appearance: button;
    appearance: button;
	cursor: pointer;
}
.evform_btn{
	border-radius: 2px;
	padding: 10px 20px;
	font-size: 15px !important;
}
.btn-primary{
	color: #ffffff;
	background-color: #428bca;
	border-color: #357ebd;
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary.focus,
.btn-primary:active,
.btn-primary.active,
.open > .dropdown-toggle.btn-primary{
	color: #ffffff;
	background-color: #3071a9;
	border-color: #285e8e;
}
.btn-primary:active,
.btn-primary.active,
.open > .dropdown-toggle.btn-primary{
	background-image: none;
}

/*----------------------------------------
	ヘッダー
----------------------------------------*/

header {
    width: 100%;
    position: absolute;
    left: 0;
    background: transparent !important;
    z-index: 100;
}

.head_inner {
    box-sizing: border-box;
    width: 100%;
    padding: 0 25px 0 25px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: #000;
    background: transparent;
	transition: all 0.5s;
	height: 92px;
	margin-bottom: 50px;
}
.header_l{
	width: 17.5%;
}
.header_r{
	width:45%;
	display: flex;
	justify-content: flex-end;
	align-items: center;
    gap:20px;
}


.header_r.fixed a{
	color: #fff;
}
.header_r ul{
	display: flex;
	justify-content: flex-end;
    gap:20px;
}

.h_read{
	text-align: right;
	font-size: 1.2rem;
	color:#d2d2d2;
	font-weight: normal;
}


@media screen and (max-width: 1200px){

	.header_l{
		width: 45%;
	}

	.header_r{
		width:50%;
	}




}/*END*/


@media screen and (max-width: 599px){
    .head_inner{
        padding: 15px 15px 0 15px;
        height: auto;
        margin-bottom: 10px;
    }
    .header_r ul{
        display: none;
    }


}/*END*/




/*----------------------------------------
	ドロワー
----------------------------------------*/

.drawer{
	position: relative;
}
.drawer li a{
	position: relative;
	display: block;
	transition: all 0.4s;
}
.drawer li a:hover{
	opacity: 0.7;
}

@media screen and (max-width: 1280px){

	.drawer li a {
		font-size: 1.5rem;
	}

}/*END*/

.menu_btn{
    display: block;
    position: relative;
    width: 60px;
    height: 60px;
    cursor: pointer;
    transition: all 0.6s;
    z-index: 999;
    /*background: #fff;*/
    border-radius: 50%;
    border:1px solid #000;
        margin-left: 10px;
}
.menu_btn span{
    display: inline-block;
    width: 60%;
    height: 1px;
    background: #000;
    position: absolute;
    left: 20%;
    transition: all 0.6s;
}

.menu_btn span:nth-child(1){
    top: 31%;
}
.menu_btn span:nth-child(2){
    top: 50%;
}
.menu_btn span:nth-child(3){
    top: 70%;
}
.open .menu_btn span:nth-child(1){
    transform: rotate(45deg);
    top: 50%;
}
.open .menu_btn span:nth-child(2){
    opacity: 0;
}
.open .menu_btn span:nth-child(3){
    transform: rotate(-45deg);
    top: 50%;
}

.open .menu_btn{
    z-index: 100;
    opacity: 1;
}



.drawer{
	position: fixed;
	background: rgba(255, 255, 255, 1);
	top: 0;
	right: 0;
	width: 100%;
	height: 100vh;
	color: #fff;
	justify-content: center;
	visibility: hidden;
	opacity: 0;
	transform: translateY(-100%);
	transition: 0.5s ease-in-out;
	z-index: 99;
		overflow-y: scroll;
		scrollbar-width: none;
}
.drawer ul{
	float: none;
	text-align: center;
}
.drawer ul li{
	margin-bottom: 25px;
}


.open .drawer{
	visibility: visible;
	opacity: 1;
	transform: translateY(0);
}

.drawer_inner{
	position: relative;
	width: 100%;
	height: 100%;
    background: #dedede;
}

.drawer_contents{
	width: 100%;
	margin-inline: auto;
    display: flex;
    height: 100vh;
}

.drawer_box_l{
    width: 60%;
    overflow: hidden;
}

.drawer_box_r{
    width: 40%;
    display: flex;
    align-items: center;
}

.drawer_box_l img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.drawer_in_content{
    width: 80%;
    max-width: 300px;
    margin-inline:auto;
}

.drawer ul.drawer_menu_list li,.drawer_menu_list li{
    line-height: 1.3;
    text-align: left;
    padding-bottom: 18px;
    border-bottom: 1px solid #a6a6a6;
    margin-bottom: 20px;
}
.drawer_menu_list li:last-child{
    border:none;
}
.drawer_menu_list li a{
    display: block;
}

.sitemap .drawer_menu_list li{
    padding-inline:2.5%;
    padding-bottom: 22px;
    margin-bottom: 24px;
}


@media screen and (max-width: 599px){
	.menu_btn{
		width: 45px;
		height: 45px;
		margin-left: 5px;
	}

    .drawer_contents{
        flex-wrap: wrap;
    }
    .drawer_box_l{
        display: none;
    }
    .drawer_box_r{
        width: 100%;
        align-items: flex-start;
        padding-top: 100px;
    }


}/*END*/





/*----------------------------------------
	footer menu
----------------------------------------*/
.bg_footer{ background: #dedede;}

.footer_flex{
    display: flex;
    justify-content: space-between;
    padding-bottom: 110px;
}
.footer_left{
	width:40%;
    padding-left:4%;
    box-sizing: border-box;
}
.footer_right{
	width: 40%;
	padding-right:4%;
	box-sizing: border-box;
    display: flex;
    justify-content: flex-end;
}

.footer_nav{
	box-sizing: border-box;
	display: flex;
    flex-direction: column;
	gap: 35px;
}
.footer_right li{
	line-height: 1.6;
}
.footer_right a{
	color: var(--text_g_color);
}
.copyright{
	font-size:var(--text12);
    color:#808080;
}





@media (max-width: 599px) {
	.footer_flex{
		padding:0 0 20px 0;
		flex-wrap: wrap;
	}
	.footer_left{
        padding: 0;
		width: 100%;
	}
	.footer_right{
		padding: 0;
		width: 100%;
        justify-content: flex-start;
	}
    .footer_nav{
        flex-direction: row;
        gap: 20px;
        flex-wrap: wrap;
        margin-bottom: 40px;
    }




}/*END*/


/* side_menu */
.side_menu{
	position: fixed;
    top: 50vh;
    right: 0;
    z-index: 6;
    transition: all 0.4s;
}
.side_menu a{
	display: block;
}

.side_menu ul{
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.side_menu ul li{
	width: 52px;
}
@media (max-width: 599px) {
	.side_menu{
		width: 100%;
		display: flex;
		position: fixed;
		top:auto;
		bottom: 0;
		left: 0;
			display: none !important;
	}
	.side_menu ul{
		width: 100%;
	    display: flex;
	    flex-wrap: nowrap;
	    flex-direction: initial;
	    gap: 0;
	}
	.side_menu ul li{
		width:calc(100% / 2);
	}


}/*END*/





/*----------------------------------------
	MV
----------------------------------------*/
.mv{
	position: relative;
    /*background: #dfe2dc;*/
    background: url(./images/top/mvbg_moz.jpg);
    overflow: hidden;

}
/*
.mv:before{
    content:'';
    width: 100%;
    height:100%;
    position: absolute;
    top:0;
    left:0;
    background-image: linear-gradient(rgba(156, 156, 156, 0.4) 1px, transparent 1px), linear-gradient(to right, rgba(156, 156, 156, 0.4) 1px, transparent 1px);
    background-size: 76px 76px;
    background-position: 0;
}
*/
/*
.mv:before {
    content: '';
    width: 120%;
    height: 120%;
    position: absolute;
    top: -10%;
    left: -10%;
    
    background-image: 
        linear-gradient(rgba(156, 156, 156, 0.4) 1px, transparent 1px), 
        linear-gradient(to right, rgba(156, 156, 156, 0.4) 1px, transparent 1px);
    background-size: 76px 76px;
    background-position: 0 0;

    filter: url(#liquid-filter);
    
    pointer-events: none;
}
*/

/*
.mv:before {
    content: '';
    width: 140%;
    height: 140%;
    position: absolute;
    top: -20%;
    left: -20%;
    background-image: 
        linear-gradient(rgba(156, 156, 156, 0.4) 1px, transparent 1px), 
        linear-gradient(to right, rgba(156, 156, 156, 0.4) 1px, transparent 1px);
    background-size: 76px 76px;
    
    filter: url(#liquid-filter);
    animation: wave-grid 10s ease-in-out infinite alternate;
    pointer-events: none;
    
}
@keyframes wave-grid {
    0% {
        transform: translate(0, 0) scale(1) rotate(0deg) skew(0deg);
        background-position: 0 0;
    }
    33% {
        transform: translate(-10px, 15px) scale(1.02) rotate(0.5deg) skew(2deg);
        background-position: 5px 10px;
    }
    66% {
        transform: translate(15px, -10px) scale(0.98) rotate(-0.5deg) skew(-2deg);
        background-position: -10px -5px;
    }
    100% {
        transform: translate(-5px, -5px) scale(1.01) rotate(0.2deg) skew(1deg);
        background-position: 0 0;
    }
}
*/

.mv:before {
    content: '';
    width: 120%;
    height: 120%;
    position: absolute;
    top: 0;
    left: 0;
    
    /* URLエンコードを避けつつ、読みやすく整理したインラインSVG 
       ※線の太さ：stroke-width
       ※波の大きさ：baseFrequency（小さいほど大波）
    */
    /*うねうね
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='100%25'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.005' numOctaves='2' seed='5'%3E%3Canimate attributeName='baseFrequency' dur='20s' values='0.005;0.008;0.005' repeatCount='indefinite'/%3E%3C/feTurbulence%3E%3CfeDisplacementMap in='SourceGraphic' scale='50'/%3E%3C/filter%3E%3Cg filter='url(%23n)'%3E%3Cdefs%3E%3Cpattern id='g' width='86' height='86' patternUnits='userSpaceOnUse'%3E%3Cpath d='M 86 0 L 0 0 0 86' fill='none' stroke='rgba(156, 156, 156, 0.4)' stroke-width='3'/%3E%3C/pattern%3E%3C/defs%3E%3Crect width='100%25' height='100%25' fill='url(%23g)'/%3E%3C/g%3E%3C/svg%3E");
    */


    background-image: url(./images/common/mv_une.jpg);
    background-position: center;



    background-size: cover;
    pointer-events: none;

}















.mv_top_intro_read{
    font-size: clamp(0.9rem, 1.1vw, 1.2rem);;
}

.mv_top_copy{
	max-width: 700px;
	position: absolute;
	transform: translate(-50%,-50%);
	top: 6%;
	left: 38%;
	z-index: 2;
}

.mv_frame{
    display: flex;
    justify-content: space-between;
}
.mv_l{
    width:48%;
    margin-left:-20px;
}
.mv_r{
    width:50%;
}
.mv_texbox{
    padding-left: 40px;
}





:root {
  /* 立方体のサイズをここで一括管理 */
  /* 親要素いっぱいにしたいなら 100% に、画面幅に合わせるなら 20vw などに */
  --cube-size: 300px; 
}

@keyframes roll {
    0% { transform: rotateX(0deg) rotateY(0deg); }
    100% { transform: rotateX(360deg) rotateY(360deg); }
}

.mv_cube_wrap {
  perspective: 2000px;
  /* 親要素の幅に合わせてサイズを可変させたい場合の例 */
  width: 100%; 
  display: flex;
  justify-content: center;
}

.cube { 
  /* 幅と高さを変数に合わせる */
  width: var(--cube-size);
  height: var(--cube-size);
  
  margin: 100px auto;
  position: relative;
  transform-style: preserve-3d;
  animation : roll 14000ms linear infinite;
}

/* 各面共通：サイズを変数に合わせる */
.cube div {
  width: var(--cube-size);
  height: var(--cube-size);
  position: absolute;
  top: 0;
  left: 0;
}

/* 奥行きの計算：サイズの半分（/ 2）を translateZ に入れる */
/* front */
.cube div:nth-child(1) {
  background: rgba(203,203,0,.3);
  transform: translateZ(calc(var(--cube-size) / 2));
}
/* back */
.cube div:nth-child(2) {
  background: rgba(0,255,203,.5);
  transform: translateZ(calc(var(--cube-size) / -2));
}
/* right */
.cube div:nth-child(3) {
  background: rgba(232, 30, 255,.4);
  transform: rotateY(90deg) translateZ(calc(var(--cube-size) / 2));
}
/* left */
.cube div:nth-child(4) {
  background: rgba(127, 255, 255,.4);
  transform: rotateY(90deg) translateZ(calc(var(--cube-size) / -2));
}
/* top */
.cube div:nth-child(5) {
  background: rgba(255,255,203,.3);
  transform: rotateX(90deg) translateZ(calc(var(--cube-size) / 2));
}
/* bottom */
.cube div:nth-child(6) {
  background: rgba(255, 191, 127,.4);
  transform: rotateX(90deg) translateZ(calc(var(--cube-size) / -2));
}







@media screen and (max-width: 980px){
:root {
  --cube-size: 240px; 
}


}/*END*/

@media screen and (max-width: 599px){
    :root {
    --cube-size: 200px; 
    }

    .mv_frame{
        flex-direction: column;
    }
    .mv_l{
        width:100%;
        margin-left:0;
        margin-bottom: 30px;
    }
    .mv_r{
        width:100%;
    }

    .mv_texbox{
        padding-left: 0;
        padding-bottom: 35px;
    }

    .mv_cube_s{
        display: none;
    }



}/*END*/




/*----------------------------------------
	top content
----------------------------------------*/
.blockinline{
	display: inline-block;
}
.title_block{
	position: relative;
}

.ttl_h{
	font-weight: normal;
}
.ttl_h img{
	max-width: 500px;
}

.ttl_h.decoline{
	display: inline-block;
  	padding-right: 20px;
  	background: #fff;
  	position: relative;
}

.ttl_h.decoline:after{
	content:'';
	width: 75vw;
	height: 1px;
	background: #000;
	position: absolute;
	top:40%;
	left: 42%;
	transform: scaleX(0);
}
.ttl_h.decoline.lineup:after{
	left:56%;
}


.ttl_h.decoline.show:after{
	animation-name: line_anime;
	animation-duration: 1.5s;
	animation-timing-function: ease-out;
	animation-fill-mode: forwards;
	transform-origin: left;
	transform: scaleX(0);
	animation-delay: 1.1s;
}
@keyframes line_anime {
    0% {
        transform-origin: left;
        transform: scaleX(0);
    }
    100% {
        transform-origin: left;
        transform: scaleX(1);
    }

}

.intro_img{
    width: 40vw;
    max-width: 478px;
}

.ob_over_block_r{
    background: #000;
    width: 100vw;
}
.ob_over_block_l {
    background: #000;
    width:100vw;

    display: flex;
    justify-content: flex-end;
    margin-left: calc(-100vw + 1040px);
}



.inner_frame_ob{
    width: 100%;
    max-width: 1040px;
}


@media screen and (max-width:1150px){
    .inner_frame_ob {
        width: 90%;
    }
    .ob_over_block_l{
        margin-left: calc(-100vw + 100%);
    }

}/*END*/
@media screen and (max-width:720px){
    .ob_over_block_r,.ob_over_block_l {
        padding: 20px 4.5%;
        box-sizing: border-box;
    }
}/*END*/





.ev_list_three{
	display: flex;
	flex-wrap: wrap;
	gap:40px;
}
.ev_list_three li{
	width: calc((100% - (2 * 40px)) / 3);
	max-width: 320px;
}


.ev_list_two{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap:80px 50px;
}
.ev_list_two li{
	width: calc((100% - (1 * 50px)) / 2);
	max-width: 500px;
}

.new_icon{
    background: #000;
    color:#fff;
    text-align: center;
    width: 18%;
    max-width: 62px;
    padding: 6px 8px;
    position: absolute;
    top:0;
    left: 0;
    z-index: 2;
}







@media screen and (max-width: 960px){
	.ev_list_three {
	  gap: 30px;
	}
	.ev_list_three li{
		width: calc((100% - (2 * 30px)) / 3);
	}

	.wide_main_img{
		aspect-ratio: 1/1;
	}

	.wide_main_img .simpleParallax > img{
		width: 160%;
	}


}/*END*/

@media screen and (min-width: 600px){
    .three_display li:nth-child(4){
        display: none;
    }
}/*END*/
@media screen and (max-width: 599px){
	.ev_list_three {
		gap: 30px 4%;
	}

	.ev_list_three li{
		width: 48%;
	}


	.ev_list_two{
		gap: 40px 4%;
	}
	.ev_list_two li{
		width: 100%;
		max-width: 100%;
	}

	.sp_m_a{
		margin-left: auto;
		margin-right: auto;
	}


    .intro_img{
        width: 100%;
    }




}/*END*/




.btn_style01{
	display: block;
	background: #fff;
	border-radius: 34px;
	text-align: center;
	color: #000;
	transition: all 0.4s;
	width: 85%;
	max-width: 320px;
	padding: 22px 10px 24px 10px;
    border:1px solid #000;
	box-sizing: border-box;
    position: relative;
	font-size: var(--text16);
}
.btn_style01:hover{
	background: #000;
    color:#fff;
	transition: all 0.4s;
}

.btn_style01:before {
  border-right: 2px solid #000;
  border-top: 2px solid #000;
  bottom: 0;
  content: "";
  height: 10px;
  position: absolute;
  right: 28px;
  top: 24px;
  transform: rotate(45deg);
  width: 10px;
}
.btn_style01:hover:before{
  border-right: 2px solid #fff;
  border-top: 2px solid #fff;
  right: 18px;
    transition: all 0.4s;  
}


.m_a{
	margin-left: auto;
	margin-right: auto;
}







/*----------------------------------------
  下層ページ
----------------------------------------*/
.page_ttl{
    position: absolute;
    transform: translate(-50%,-50%);
    top:50%;
    left:50%;
}

.page_ttl img{
	max-width: 600px;
}

.under_line{
	text-decoration: underline;
}

.new_tag{
    background: #000;
    color:#fff;
    text-align: center;
    width: 18%;
    max-width: 62px;
    padding: 6px 8px;
}

.inner_frame860{
    width: 100%;
    max-width: 860px;
    margin-inline:auto;
}


/* テーブル　outline */
ul.archive_list{
	border-top: 1px solid #000;
}
.archive_list li{
	border-bottom: 1px solid #000;
}
.archive_list li a{
	display: block;
	padding: 30px 15px 30px 25px;
}
.list_item{
	width: 100%;
	display: flex;
	gap: 4.2%;
}
.list_item .th{
	min-width: 80px;
	width: 20%;
}
.archive_list.outline li{
  display: block;
  padding: 35px 15px 35px 25px;
  line-height: 1.6;
}
.archive_list span.cate{
	min-width: 100px;
	padding:1px 2px 4px 2px;
	box-sizing: border-box;
	border:1px solid #000;
	border-radius: 10px;
	text-align: center;
	display: inline-block;
	line-height: 1.2;
}








@media screen and (max-width: 960px){



}/*END*/

@media screen and (max-width: 599px){
    .page_ttl{
        top: 65%;
    }

	.list_item{
		gap: 1px 2.6%;
	}
	.list_item_title{
		width: 100%;
	}

    .archive_list.outline li{
        padding: 18px 10px 18px 10px;
        font-feature-settings: "palt";
    }




}/*END*/





/*----------------------------------------
	アコーディオン
----------------------------------------*/
.accordion-title{
	width: 100%;
	margin-inline: auto;
	background: none;
	  color: #fff;
	  cursor: pointer;
	  font-size: 18px;
	  padding: 5px 5px 5px 5px;
	  box-sizing: border-box;
  		line-height: 1.4;
}
.accordion-container {
	/*display: none;*/
	  box-sizing: border-box;
	  color: #000;
	  margin-inline: auto;
	  padding-top:20px;

}
.accordion-list:not(:first-child) {
  margin-top: 20px;
}
.accordion-title {
  cursor: pointer;
  position: relative;
}

.accordion-title:before {
  position: absolute;
  content: '';
  top: 78%;
  right: 20%;
  height: 3px;
  width: 20px;
  background: #e4007f;
  transform: rotate(90deg);
  transition: all .3s ease-in-out;
}
.accordion-title:after {
  position: absolute;
  content: '';
  top: 78%;
  right: 20%;
  height: 3px;
  width: 20px;
  background: #e4007f;
  transition: all .3s ease-in-out;
}

.accordion-title.open:before {
  transform: rotate(180deg);
}
.accordion-title.open:after {
  opacity: 0;
}

.accordion-text {
  display: none;
  padding: 15px 0 20px 0;
}

@media screen and (max-width: 599px){
	.accordion-title:before {
		height: 2px;
		width: 15px;
	}
	.accordion-title:after {
		height: 2px;
		width: 15px;
	}

}/*END*/
















/*----------------------------------------
	Plan tab
----------------------------------------*/
.filter_list li{
    cursor: pointer;
}

.plan_fl_list{
    display: flex;
    gap:40px 2%;
    flex-wrap:wrap;
    justify-content: space-between;
}
.plan_fl_list li{
    width: 48.16%;
    background: #fff;
}

@media screen and (max-width: 599px){
    .plan_fl_list{
        gap:20px 2%;
    }

    .plan_fl_list li{
        width: 100%;
    }
}/*END*/









/*----------------------------------------
	FAQ アコーディオン
----------------------------------------*/
.faq_ac_title{
	width: 100%;
	margin-inline: auto;
	background: #fff;
	cursor: pointer;
	font-size: 18px;
	padding: 20px 2.8%;
	box-sizing: border-box;
	font-size: var(--text18);
	font-weight: 500;
  	line-height: 1.4;
}

.faq_ac_container {
	display: none;
	  box-sizing: border-box;
	  color: #000;
	  margin-inline: auto;
	  padding: 20px 6.74%;
}

.faq_ac_title {
  cursor: pointer;
  position: relative;
  display: flex;
}

.faq_ac_title:before {
  position: absolute;
  content: '';
  top: 50%;
  right: 20px;
  height: 2px;
  width: 24px;
  background: #000;
  transform: rotate(90deg);
  transition: all .3s ease-in-out;
}
.faq_ac_title:after {
  position: absolute;
  content: '';
  top: 50%;
  right: 20px;
  height: 2px;
  width: 24px;
  background: #000;
  transition: all .3s ease-in-out;
}

.faq_ac_title.open:before {
  transform: rotate(180deg);
}
.faq_ac_title.open:after {
  opacity: 0;
}

.faq_ac-text {
  display: none;
  padding: 15px 0 20px 0;
}

.faq_ac_title span{
	width: 94%;
}
.faq_ac_title span:first-child{
	width: 22px;
	padding-right: 1.8%;
}


@media screen and (max-width: 599px){
	.faq_ac_title{
		padding: 15px 2.8%;
	}

	.faq_ac_title span{
		width: 85%;
	}
	.faq_ac_title:before {
		width: 20px;
		right: 10px;
	}
	.faq_ac_title:after {
		width: 20px;
		right: 10px;
	}
	.faq_ac_container{
		padding: 10px 6.74%;
	}


}/*END*/




/*----------------------------------------
	STAFF スタッフ
----------------------------------------*/
.staff_kind_block{
    border-top:1px solid #000;
    border-left:1px solid #000;
    /*border-bottom:1px solid #000;*/
    overflow: hidden;
        margin-top:-1px;
}
.staff_kind_title{
    width: 100%;
    box-sizing: border-box;
    background: #000;
    color:#fff;
    padding:15px 5px 15px 25px;
}
.staff_block_flex{
    display: flex;
    flex-wrap: wrap;
}
.staff_item_content{
    width: 25%;
}
.staff_list_data_tex{
    padding:15px 4%;
    box-sizing: border-box;
    text-align: center;
}

.staff_data_info_item{
    display: flex;
    align-items: center;
    margin-bottom: 10px;
}
.staff_data_info_item .midashi{
    background: #52b1ba;
    color:#fff;
    min-width: 100px;
    padding: 5px 3px;
    box-sizing: border-box;
    text-align: center;
}
/*
.staff_data_info_item .midashi.white{
    background: #fff;
    color:#000;
}
*/
.staff_ac .photo_frame{
    aspect-ratio: 1 / 1;
}

.staff_ac .accordion_area {
  width: 100%;
  box-sizing: border-box;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  position: relative;
}
.staff_ac .accordion_area .accordion_one._flex {
  width: 25%;
  box-sizing: border-box;
    border-right:1px solid #000;
    border-bottom:1px solid #000;
}
.staff_ac .accordion_one .accordion_header {
  padding: 0 0 70px 0;
  text-align: left;
  position: relative;
  z-index: +1;
  cursor: pointer;
  transition-duration: 0.2s;
  box-sizing: border-box;
}
.staff_ac .accordion_one .accordion_header_one {
  border-bottom: 1px solid #000;
  color: #000;
  font-size: 26px;
  font-weight: bold;
  padding: 20px 7%;
  text-align: left;
  position: relative;
  z-index: +1;
  cursor: pointer;
}

.staff_ac .accordion_one .accordion_header:hover {
  opacity: .8;
}
.staff_ac .accordion_one .accordion_header .i_box {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: auto;
  bottom: 5%;
  right: 40%;
  width: 40px;
  height: 40px;
  box-sizing: border-box;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
}
.staff_ac .accordion_one .accordion_header .i_box .one_i {
  display: block;
  width: 18px;
  height: 18px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
  position: relative;
}
.staff_ac .accordion_one .accordion_header.open .i_box {
  -webkit-transform: rotate(-360deg);
  transform: rotate(-360deg);
}
.staff_ac .accordion_one .accordion_header .i_box .one_i:before, .staff_ac .accordion_one .accordion_header .i_box .one_i:after {
  display: flex;
  content: '';
  background-color: #000;
  border-radius: 10px;
  width: 22px;
  height: 1px;
  position: absolute;
  top: 10px;
  left: 0;
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
  transform-origin: center center;
}
.staff_ac .accordion_one .accordion_header .i_box .one_i:before {
  width: 1px;
  height: 22px;
  top: 0;
  left: 10px;
}
.staff_ac .accordion_one .accordion_header.open .i_box .one_i:before {
  content: none;
}
.staff_ac .accordion_one .accordion_header.open .i_box .one_i:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.staff_ac .accordion_one .accordion_inner {
  display: none;
  padding: 0;
  box-sizing: border-box;
  background:#eee;
  padding:50px;
    width: 401%;
    border-top:1px solid #000;
}


.staff_ac .accordion_one .accordion_inner .box_one {
  height: 300px;
}
.staff_ac .accordion_one .accordion_inner p.txt_a_ac {
  margin: 0;
}

/*
.staff_ac .accordion_area .accordion_one._flex:nth-of-type(4n){
    border-right: none;
}
*/

.accordion_one._flex:nth-of-type(4n+1) .accordion_inner {
    transform: translate(0);
}
.accordion_one._flex:nth-of-type(4n+2) .accordion_inner {
    transform: translate(-25%);
}
.accordion_one._flex:nth-of-type(4n+3) .accordion_inner {
    transform: translate(-50%);
}
.accordion_one._flex:nth-of-type(4n) .accordion_inner {
    transform: translate(-75%);
}




@media screen and (max-width: 960px) {

}/*END*/
@media screen and (max-width: 599px) {
    .staff_ac .accordion_area .accordion_one._flex{
        width: 50%;
    }

    .staff_ac .accordion_one .accordion_inner {
        padding: 20px 8%;
        width: 201.5%;
        border-right: 1px solid #000;
    }

    /*
    .staff_ac .accordion_area .accordion_one._flex:nth-of-type(2n+2){
        border-right: none;
    }
    */

    .staff_kind_title{
        padding: 15px 5px 15px 15px;
    }

    .accordion_one._flex:nth-of-type(4n+1) .accordion_inner {
        transform: translate(0);
    }
    .accordion_one._flex:nth-of-type(4n+2) .accordion_inner {
        transform: translate(0);
    }
    .accordion_one._flex:nth-of-type(4n+3) .accordion_inner {
        transform: translate(0);
    }
    .accordion_one._flex:nth-of-type(4n) .accordion_inner {
        transform: translate(0);
    }

    .accordion_one._flex:nth-of-type(2n+1) .accordion_inner {
        transform: translate(0);
    }
    .accordion_one._flex:nth-of-type(2n+2) .accordion_inner {
        transform: translate(-50%);
    }


    

}/*END*/




/*----------------------------------------
  投稿一覧　スタイル
----------------------------------------*/
.cat_flex{
	display: flex;
	justify-content: space-between;
	gap:5px;
	flex-wrap: wrap;
}
.cat_label,.tag_label{
	min-width: 49%;
  background: #4a5f66;
  color: #fff;
  display: inline-block;
  line-height: 1;
  padding: 8px 12px;
  box-sizing: border-box;
  text-decoration: none;
  font-size:clamp(1.2rem, 1.34vw, 1.4rem);
}

.time{
  display: inline-block;
  margin-right: 14px;
}




@media screen and (max-width: 599px){
	.cat_label,.tag_label{
	  padding: 8px 8px;
	}

}/*END*/



/*----------------------------------------
  archive 記事一覧
----------------------------------------*/

.text_waterblue,
.cat_hash.text_waterblue{
	color: #448ab2;
}

.single .gr_list_three li,
.archive .gr_list_three li{
	margin-bottom: 50px;
}

.cat_hash{
	display: inline-block;
	color: #8b8b8b;
	margin:0 12px 12px 0;
	font-feature-settings: "palt";
}

.gr_list_three {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0 4%;
}


.archive_cat_area{
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 10px;
}
.archive_cat_label{
	width: 20%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #000;
    text-align: center;
    background: #fff;
    border:2px solid #000;
    padding: 10px 6px 12px 6px;
    box-sizing: border-box;
    line-height: 1.2;
    font-size:var(--text18);
    font-feature-settings: "palt";
}
.archive_cat_label:hover,
.archive_cat_label.current{
    background: #000;
    color: #fff;
    opacity: 1;
}






.plus_icon{
	position: relative;
	display: inline-block;
	transform: translateX(-50%);
	left: 50%;
}
.plus_icon:before{
	content: '';
	width: 40px;
	height: 40px;
	background: url(./images/plan/plus_icon.jpg) no-repeat;
	position: absolute;
	right: 0;
	bottom: 0;
}








@media screen and (max-width: 599px){
	.gr_list_three {
	    grid-template-columns: repeat(2, 1fr);
	}

	.single .gr_list_three li,
	.archive .gr_list_three li{
		margin-bottom: 20px;
	}

	.archive_cat_area{
		gap: 3px;
	}
	.archive_cat_label{
		width: 24.2%;
		padding: 5px 2px;
	}

    .news_blog .archive_cat_label{
		width: 32%;
		padding: 5px 3px;
	}

	.archive_cat_area.m_b20{
		margin-bottom: 10px !important;
	}

	.cat_hash{
		margin: 0 6px 6px 0;
		font-size: 1.3rem;
	}

	.plan.archive .gr_list_three li{
		margin-bottom: 40px;
	}


	.plan .archive_cat_label{
		width: 24.2%;
		padding: 8px 2px 8px 2px;
		font-feature-settings: "palt";
	}
	.plan .archive_cat_area{
		gap: 10px 3px;
	}


}/*END*/




/*----------------------------------------
  一覧ページャー
----------------------------------------*/
.page-numbers.dots{
	display: inline-block;
	margin-right: 7px;
	margin-top: 13px;
}
.pager{
	position: relative;
	font-family: Arial, sans-serif;
	font-weight: bold;
}
.pager ul{
	position: relative;
	display: flex;
	justify-content: center;
}
.pager.pager_right ul{
	position: relative;
	float: right;
}
.pager li{
	position: relative;
	list-style: none;
	font-size: 1.4rem;
}
.pager li a,
.pager li .current{
	display: inline-block;
	margin-right: 5px;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	aspect-ratio: 1/1;
	width: 40px;
	height: 100%;
	background: #000;
	color: #fff;
	border: 1px solid #000;
	text-decoration: none;
}
.pager li a.prev,
.pager li a.next{
	width: 120px;
	position: relative;
	display: flex;
	gap: 5px;
	justify-content: center;
	align-items: center;
	aspect-ratio: inherit;
}
.pager li a.prev::before,
.pager li a.next::after{
	transition: all 0.7s;
	display: inline-block;
	content: '';
	width: 14px;
	height: 14px;
	background-color: #fff;
}
.pager li a.next::after{
	clip-path: polygon(60% 0, 60% 20%, 25% 50%, 60% 80%, 60% 100%, 0 50%);
	transform: rotate(180deg);
	flex: none;
}
.pager li a.prev::before{
	clip-path: polygon(60% 0, 60% 20%, 25% 50%, 60% 80%, 60% 100%, 0 50%);
	flex: none;
}
.pager li a.prev:hover::before,
.pager li a.next:hover::after{
	background-color: #000;
}
.pager li a.prev{ margin-right: 20px; }
.pager li a.next{ margin-left: 20px; }
.pager li .current{
	background: #737373;
	color: #fff;
	border: #737373 1px solid;
}
.pager li a:hover{
	background: #fff;
	color: #000;
}


@media screen and (max-width: 960px){

	.pager ul{
		position: relative;
	}
	.pager.pager_right ul{
		position: relative;
	}
	.pager li{
		position: relative;
		list-style: none;
		font-size: 1.0rem;
	}
	.pager.pager_right li{
		position: relative;
		list-style: none;
		font-size: 1.0rem;
	}

}/*END*/

@media screen and (max-width: 599px){
	.pager li .current,.pager li a{
		width: 27px;
		box-sizing: border-box;
	}
	.pager li a.prev{ 
		margin-right: 5px;
		text-align: right;
		padding-right: 5px;
	 }
	.pager li a.next{ 
		margin-left: 0px;
		margin-right: 0;
		text-align: left;
		padding-left: 5px;
		padding-right: 5px;
	}

	.pager li a.prev,
	.pager li a.next{
		width: 80px;
	}
	.page-numbers.dots {
    margin-top: 5px;
    margin-right: 5px;
	}
}/*END*/



/*----------------------------------------
  詳細ページャー
----------------------------------------*/
.single_pager{
  display: flex;
}
.single_pager li{
  position: relative;
  float: left;
  list-style: none;
  display: block;
  min-height: 30px;
  text-align: center;
  font-size: 1.2rem;
}
.single_pager li a{
  display: block;
  height: 100%;
  box-sizing: border-box;
  padding: 18px 3px;
  color: #fff;
  background: #000;
  text-decoration: none;
  font-size:clamp(1.3rem, 1.5vw, 1.6rem);
}
.single_pager li a:hover{
  opacity: 0.7;
}
.single_prev{
  width: 23.5%;
  margin-right: 1.5%;
}
.single_list{ width: 50%; }
.single_next{
  width: 23.5%;
  margin-left: 1.5%;
}


.single_pager li.single_prev a:before{
  content: "〈";
  position: absolute;
  left: 5%;
  top: 36%;
  width: 20px;
  height: auto;
  z-index: 2;
}

.single_pager li.single_next a:before{
  content: "〉";
  position: absolute;
  right: 5%;
  top: 36%;
  width: 20px;
  height: auto;
  z-index: 2;
}


@media screen and (max-width: 768px){

  .single_prev{ width: 28.5%; }
  .single_list{ width: 40%; }
  .single_next{ width: 28.5%; }

}/*END*/

@media screen and (max-width: 599px){
  .single_pager li a{
    font-size: 1.2rem;
    padding: 15px 3px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .single_pager li.single_prev a:before,
  .single_pager li.single_next a:before{
    top: 38%;
  }
  .single_pager li.single_prev a:before{
    left:1.4%;
  }
  .single_pager li.single_next a:before{
    right:1.4%;
  }



}/*END*/



/*----------------------------------------
  記事詳細
----------------------------------------*/
.inner_frame_post{
    width: 100%;
    max-width: 750px;
    margin-inline:auto;
}

.photo_main img{
    width: 100%;
    height: auto;
}

.entry_text{
  font-size: 1.2rem;
  color: #434343;
  line-height: 1.5;
}
.entry_date{
  color: #666;
}

.entry_data p{
  word-break: break-all;
  word-wrap: break-word;
}


/* 管理画面との余白差を無くす */
.entry_content p img {
    margin-bottom: 10px;
}

.entry_content p{
    font-size: clamp(1.4rem, 1.5vw, 1.6rem);
    font-weight: 400;
}
.entry_content table td{
    font-weight: 400;
}


/* ギャラリー＆ライトボックス　プラグイン関連 */
.pp_content_container .pp_gallery{
  display: none !important;
}

a.wp-block-button__link{
  color:#fff !important;
}

@media screen and (max-width: 599px){


}/*END*/



/*----------------------------------------
	Gallery ギャラリー カラム
----------------------------------------*/
.entry_content .gallery{
	display: flex;
	flex-wrap: wrap;
	gap: 2.5%;
}
.entry_content .gallery-item:hover{
	opacity: 0.7;
}
.gallery-item{
	margin-bottom: 30px;
}
.gallery-columns-1 .gallery-item{
	width: 100%;
}
.gallery-columns-2 .gallery-item{
	width: calc((100% - (1 * 2.5%)) / 2);
}
.gallery-columns-3 .gallery-item{
	width: calc((100% - (2 * 2.5%)) / 3);
}
.gallery-columns-4 .gallery-item{
	width: calc((100% - (3 * 2.5%)) / 4);
}
.gallery-columns-5 .gallery-item{
	width: calc((100% - (4 * 2.5%)) / 5);
}
.gallery-columns-6 .gallery-item{
	width: calc((100% - (5 * 2.5%)) / 6);
}
.gallery-columns-7 .gallery-item{
	width: calc((100% - (6 * 2.5%)) / 7);
}
.gallery-columns-8 .gallery-item{
	width: calc((100% - (7 * 2.5%)) / 8);
}
.gallery-columns-9 .gallery-item{
	width: calc((100% - (8 * 2.5%)) / 9);
}
.gallery-icon{
	position: relative;
	overflow: hidden;
	background: #eee;
	width: 100%;
	padding: 100% 0 0;
}
.gallery-item img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate3d(-50%, -50%, 0);
}
.entry_content figcaption{
	font-size: var(--text16);
	font-family: "Noto Sans JP", sans-serif;
	line-height: 1.6;
	color: #868686;
	padding-top: 5px;
}

.model_midokoro figcaption{
	color: #000;
}
.model_midokoro .gallery-icon{
	padding: 72.8% 0 0;
}



@media screen and (max-width:599px){

	.gallery-item{
		margin-bottom: 15px;
	}

	/*
	.entry_content .gallery{
		justify-content: space-between;
	}

    .gallery-columns-4 .gallery-item,
    .gallery-columns-5 .gallery-item,
    .gallery-columns-6 .gallery-item,
    .gallery-columns-7 .gallery-item,
    .gallery-columns-8 .gallery-item,
    .gallery-columns-9 .gallery-item{
    	width: 31.2%;
    }
	*/


	.model_midokoro figcaption{
		font-size: 1.2rem;
		line-height: 1.4;
	}

	.entry_content figcaption{
		font-size: 1.2rem;
	}

}/*END*/



.news_column .entry_content .gallery,
.works .entry_content .gallery{
	margin-bottom: 30px;
}

.news_column .gallery-item,
.works .gallery-item{
	margin-bottom: 0;
}

.news_column .entry_content .gallery,
.works .entry_content .gallery{
	gap: 5px;
}

.news_column .gallery-columns-1 .gallery-item,
.works .gallery-columns-1 .gallery-item{
	width: 100%;
}

.news_column .gallery-columns-2 .gallery-item,
.works .gallery-columns-2 .gallery-item{
	width: calc((100% - (1 * 5px)) / 2);
}

.news_column .gallery-columns-3 .gallery-item,
.works .gallery-columns-3 .gallery-item{
	width: calc((100% - (2 * 5px)) / 3);
}

.news_column .gallery-columns-4 .gallery-item,
.works .gallery-columns-4 .gallery-item{
	width: calc((100% - (3 * 5px)) / 4);
}

.news_column .gallery-columns-5 .gallery-item,
.works .gallery-columns-5 .gallery-item{
	width: calc((100% - (4 * 5px)) / 5);
}

.news_column .gallery-columns-6 .gallery-item,
.works .gallery-columns-6 .gallery-item{
	width: calc((100% - (5 * 5px)) / 6);
}

.news_column .gallery-columns-7 .gallery-item,
.works .gallery-columns-7 .gallery-item{
	width: calc((100% - (6 * 5px)) / 7);
}

.news_column .gallery-columns-8 .gallery-item,
.works .gallery-columns-8 .gallery-item{
	width: calc((100% - (7 * 5px)) / 8);
}

.news_column .gallery-columns-9 .gallery-item,
.works .gallery-columns-9 .gallery-item{
	width: calc((100% - (8 * 5px)) / 9);
}

.news_column .gallery-item img,
.works .gallery-item img{
	height: 100% !important;
	object-fit: cover;
}

.news_column .gallery-icon,
.works .gallery-icon{
	padding: 0;
	aspect-ratio: 5/7;
}


.designer .entry_content .gallery{
	gap: 10px;
}

.designer .gallery-columns-1 .gallery-item{
	width: 100%;
}

.designer .gallery-columns-2 .gallery-item{
	width: calc((100% - (1 * 10px)) / 2);
}

.designer .gallery-columns-3 .gallery-item{
	width: calc((100% - (2 * 10px)) / 3);
}

.designer .gallery-columns-4 .gallery-item{
	width: calc((100% - (3 * 10px)) / 4);
}

.designer .gallery-columns-5 .gallery-item{
	width: calc((100% - (4 * 10px)) / 5);
}

.designer .gallery-columns-6 .gallery-item{
	width: calc((100% - (5 * 10px)) / 6);
}

.designer .gallery-columns-7 .gallery-item{
	width: calc((100% - (6 * 10px)) / 7);
}

.designer .gallery-columns-8 .gallery-item{
	width: calc((100% - (7 * 10px)) / 8);
}

.designer .gallery-columns-9 .gallery-item{
	width: calc((100% - (8 * 10px)) / 9);
}

.designer .gallery-item img{
	height: 100% !important;
	object-fit: cover;
}

.designer .gallery-icon{
	padding: 0;
	aspect-ratio: 5/7;
}

.designer .gallery-item img{
	position: static;
	transform: translate3d(0, 0, 0);
}









