@charset "utf-8";
/*
Theme Name: res
Version: 1.4.1
Author: T8,Inc.
*/
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:300,400,700&display=swap');
:root {
	--break: 1920;
	--guideline-color: #333333;
	font-size: calc(16 / var(--break) * 100vw);
	--color01: #C0C0C0;
	--color02: #F2F2F2;
	--color03: #333333;
	--color04: #;
	--color05: #;
	--color06: #;
	--color07: #;
	--color08: #;
	--color09: #;
	--color10: #;
	--color11: #;
	--color12: #;
	--color13: #;
	--color14: #;
	--color15: #;
	--color16: #;
	--color17: #;
	--color18: #;
	--color19: #;

    --size5px:  calc(5 / var(--break) * 100vw);
    --size10px:  calc(10 / var(--break) * 100vw);
    --size15px:  calc(15 / var(--break) * 100vw);
    --size20px:  calc(20 / var(--break) * 100vw); 
    --size25px:  calc(25 / var(--break) * 100vw);
    --size30px:  calc(30 / var(--break) * 100vw);
    --size35px:  calc(35 / var(--break) * 100vw);
    --size40px:  calc(40 / var(--break) * 100vw);
    --size45px:  calc(45 / var(--break) * 100vw);
    --size50px:  calc(50 / var(--break) * 100vw);
    --size55px:  calc(55 / var(--break) * 100vw);
    --size60px:  calc(60/ var(--break) * 100vw);
    --size65px:  calc(65 / var(--break) * 100vw);
    --size70px:  calc(70 / var(--break) * 100vw);
    --size75px:  calc(75 / var(--break) * 100vw);
    --size80px:  calc(80 / var(--break) * 100vw);
    --size85px:  calc(85 / var(--break) * 100vw);
    --size90px:  calc(90 / var(--break) * 100vw);
    --size95px:  calc(95 / var(--break) * 100vw);
    --size100px:  calc(100 / var(--break) * 100vw);
    --size105px:  calc(105 / var(--break) * 100vw);
    --size110px:  calc(110 / var(--break) * 100vw);
    --size115px:  calc(115 / var(--break) * 100vw);
    --size120px:  calc(120 / var(--break) * 100vw);
    --size125px:  calc(125 / var(--break) * 100vw);
    --size130px:  calc(130 / var(--break) * 100vw);
    --size135px:  calc(135 / var(--break) * 100vw);
    --size140px:  calc(140 / var(--break) * 100vw);
    --size145px:  calc(145 / var(--break) * 100vw);
    --size150px:  calc(150 / var(--break) * 100vw);
    --size160px:  calc(160 / var(--break) * 100vw);
    --size170px:  calc(170 / var(--break) * 100vw);
    --size180px:  calc(180 / var(--break) * 100vw);
    --size190px:  calc(190 / var(--break) * 100vw);
    --size200px:  calc(200 / var(--break) * 100vw);
}
@media(min-width: 768px) and (max-width: 1599px) {
    :root {
		--break: 1599;
    }
}
@media(min-width: 768px) and (max-width: 1299px) {
    :root {
		--break: 1299;
    }
}
@media(max-width:767px) {
        :root {
		--break: 750;
    }
}

/*サイト別フォント・カラー設定*/
.txt_link {
	color: #333333;
	text-decoration: underline;
}

/*ここまで*/
html, body {
	font-size: 1.125rem;
	font-weight: 300;
	line-height: 2;
	color: #333333;
	letter-spacing: .1em;
	font-family: "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.vdl {
	font-family: "vdl-v7gothic", sans-serif;
	font-weight: 300;
	font-style: normal;
}
.vdl_b {
	font-family: "vdl-v7gothic", sans-serif;
	font-weight: 700;
	font-style: normal;
}
.dun {
	font-family: "dunbar-low", sans-serif;
	font-weight: 200;
	font-style: normal;
}
.fwn {
	font-weight: normal;
}
.fwb {
	font-weight: bold;
}
img {
	max-width: 100%;
	height: auto;
}
iframe {
	max-width: 100%;
}
video {
	max-width: 100%;
}
* {
	margin: 0;
	padding: 0;
}
li {
	list-style: none;
}
a {
	color: inherit;
	text-decoration: none;
}
#wrap {
	overflow-x: hidden;
}
.oh {
	overflow: hidden;
}
a:hover {
	opacity: .85;
	transition: .3s;
}
a.zoom{
	pointer-events: none;
}
.inner,.inner1000,.inner1140,.inner1200,.inner1340,.inner1500,.inner1720
{
	max-width: 1240px;
	width: 90%;
	margin: 0 auto;
}
.inner1000 {
	max-width: 1000px;
}
.inner1140 {
	max-width: 1140px;
}
.inner1200 {
	max-width: 1200px;
}
.inner1340 {
	max-width: 1340px;
}
.inner1500 {
	max-width: 1500px;
}
.inner1720 {
	max-width: 1720px;
}
.w100 {
	width: 100%!important;
}
table{
	table-layout: fixed;
}
td input{
	max-width: 100%;
}
a[href^="tel:"] {
	cursor: default;
}
a[href^="tel:"]:hover {
	opacity: 1;
}
.slick-slide {
	outline: none;
}
.adjust {
	display: none;
}
.tb_only {
	display: none;
}
.sp_only {
	display: none;
}
.tb_pc {
	display: inherit;
}
.sp_tb {
	display: none;
}
.flex {
	display:-webkit-box;
	display:-ms-flexbox;
	display: -webkit-flex;
	display:flex;
	-webkit-box-pack:justify;
	-ms-flex-pack:justify;
	-webkit-justify-content:space-between;
	justify-content:space-between;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-align-items: flex-start;
	align-items: flex-start;
}
.flex.start     { -webkit-justify-content: flex-start; justify-content: flex-start; }
.flex.end       { -webkit-justify-content: flex-end; justify-content: flex-end; }
.flex.center    { -webkit-justify-content: center; justify-content: center; }
.flex.around    { -webkit-justify-content: space-around; justify-content: space-around; }
.flex.between   { -webkit-justify-content: space-between; justify-content: space-between; }
.flex.stretch   { -webkit-align-items: stretch; align-items: stretch; }
.flex.ai_center { -webkit-align-items: center; align-items: center; }
.flex.ai_start  { -webkit-align-items: flex-start; align-items: flex-start; }
.flex.ai_end    { -webkit-align-items: flex-end; align-items: flex-end; }
.flex.nowrap    { -webkit-flex-wrap: nowrap; flex-wrap: nowrap; }
.flex.column    { -ms-flex-direction:column; -webkit-flex-direction:column; flex-direction:column; }
.flex.row       { -ms-flex-direction:row; -webkit-flex-direction:row; flex-direction:row; }
.flex.c_reverse { -ms-flex-direction:column-reverse; -webkit-flex-direction:column-reverse; flex-direction:column-reverse; }
.flex.r_reverse { -ms-flex-direction:row-reverse; -webkit-flex-direction:row-reverse; flex-direction:row-reverse; }
.flex.cc { -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center; }
.flex.ccc { -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center; text-align: center;}
.flex.cccc { -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center; text-align: center; -webkit-flex-direction:column; flex-direction:column;}
.noshrink       { flex: 0 0 auto; }
.grow           { flex: 1 1 auto; }

.ccl { border-radius: 100%; }
.bdrd5 {border-radius: var(--size5px);}
.bdrd10 {border-radius: var(--size10px);}
.bdrd15 {border-radius: var(--size15px);}
.bdrd20 {border-radius: var(--size20px);}
.bdrd25 {border-radius: var(--size25px);}
.bdrd30 {border-radius: var(--size30px);}
.bdrd35 {border-radius: var(--size35px);}
.bdrd40 {border-radius: var(--size40px);}
.bdrd45 {border-radius: var(--size45px);}
.bdrd50 {border-radius: var(--size50px);}

.txt_center { text-align: center; }
.txt_right { text-align: right; }
.txt_rl {
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-orientation: upright;
}

.mgn_a {
	margin-left: auto;
	margin-right: auto;
}
.mgn_l { margin-left: auto; }
.mgn_r { margin-right: auto; }
.no_mgn { margin-bottom: 0!important;}
.mb5    { margin-bottom: var(--size5px); }
.mb10   { margin-bottom: var(--size10px); }
.mb15   { margin-bottom: var(--size15px); }
.mb20   { margin-bottom: var(--size20px); }
.mb25   { margin-bottom: var(--size25px); }
.mb30   { margin-bottom: var(--size30px); }
.mb35   { margin-bottom: var(--size35px); }
.mb40   { margin-bottom: var(--size40px); }
.mb45   { margin-bottom: var(--size45px); }
.mb50   { margin-bottom: var(--size50px); }
.mb55   { margin-bottom: var(--size55px); }
.mb60   { margin-bottom: var(--size60px); }
.mb65   { margin-bottom: var(--size65px); }
.mb70   { margin-bottom: var(--size70px); }
.mb75   { margin-bottom: var(--size75px); }
.mb80   { margin-bottom: var(--size80px); }
.mb85   { margin-bottom: var(--size85px); }
.mb90   { margin-bottom: var(--size90px); }
.mb95   { margin-bottom: var(--size95px); }
.mb100  { margin-bottom: var(--size100px); }
.mb105  { margin-bottom: var(--size105px); }
.mb110  { margin-bottom: var(--size110px); }
.mb115  { margin-bottom: var(--size115px); }
.mb120  { margin-bottom: var(--size120px); }
.mb125  { margin-bottom: var(--size125px); }
.mb130  { margin-bottom: var(--size130px); }
.mb135  { margin-bottom: var(--size135px); }
.mb140  { margin-bottom: var(--size140px); }
.mb145  { margin-bottom: var(--size145px); }
.mb150  { margin-bottom: var(--size150px); }
.mb160  { margin-bottom: var(--size160px); }
.mb170  { margin-bottom: var(--size170px); }
.mb200  { margin-bottom: var(--size200px); }
.mb05em { margin-bottom:0.5em; }
.mb10em { margin-bottom:1.0em; }
.mb15em { margin-bottom:1.5em; }
.mb20em { margin-bottom:2.0em; }
.mb25em { margin-bottom:2.5em; }
.mb30em { margin-bottom:3.0em; }

.mt5    { margin-top: var(--size5px); }
.mt10   { margin-top: var(--size10px); }
.mt15   { margin-top: var(--size15px); }
.mt20   { margin-top: var(--size20px); }
.mt25   { margin-top: var(--size25px); }
.mt30   { margin-top: var(--size30px); }
.mt35   { margin-top: var(--size35px); }
.mt40   { margin-top: var(--size40px); }
.mt45   { margin-top: var(--size45px); }
.mt50   { margin-top: var(--size50px); }
.mt55   { margin-top: var(--size55px); }
.mt60   { margin-top: var(--size60px); }
.mt65   { margin-top: var(--size65px); }
.mt70   { margin-top: var(--size70px); }
.mt75   { margin-top: var(--size75px); }
.mt80   { margin-top: var(--size80px); }
.mt85   { margin-top: var(--size85px); }
.mt90   { margin-top: var(--size90px); }
.mt95   { margin-top: var(--size95px); }
.mt100  { margin-top: var(--size100px); }
.mt105  { margin-top: var(--size105px); }
.mt110  { margin-top: var(--size110px); }
.mt115  { margin-top: var(--size115px); }
.mt120  { margin-top: var(--size120px); }
.mt125  { margin-top: var(--size125px); }
.mt130  { margin-top: var(--size130px); }
.mt135  { margin-top: var(--size135px); }
.mt140  { margin-top: var(--size140px); }
.mt145  { margin-top: var(--size145px); }
.mt150  { margin-top: var(--size150px); }
.mt05em { margin-top:0.5em; }
.mt10em { margin-top:1.0em; }
.mt15em { margin-top:1.5em; }
.mt20em { margin-top:2.0em; }
.mt25em { margin-top:2.5em; }
.mt30em { margin-top:3.0em; }

.mr5 {margin-right: var(--size5px); }
.mr10 {margin-right: var(--size10px); }
.mr15 {margin-right: var(--size15px); }
.mr20 {margin-right: var(--size20px); }
.mr25 {margin-right: var(--size25px); }
.mr30 {margin-right: var(--size30px); }
.mr35 {margin-right: var(--size35px); }
.mr40 {margin-right: var(--size40px); }
.mr45 {margin-right: var(--size45px); }
.mr50 {margin-right: var(--size50px); }

.ml5 {margin-left: var(--size5px); }
.ml10 {margin-left: var(--size10px); }
.ml15 {margin-left: var(--size15px); }
.ml20 {margin-left: var(--size20px); }
.ml25 {margin-left: var(--size25px); }
.ml30 {margin-left: var(--size30px); }
.ml35 {margin-left: var(--size35px); }
.ml40 {margin-left: var(--size40px); }
.ml45 {margin-left: var(--size45px); }
.ml50 {margin-left: var(--size50px); }

.db { display: block; }
.dib { display: inline-block; }
.por { position: relative; z-index: 1; }
.poa { position: absolute; }
.zi0 { z-index: 0; }
.zi1 { z-index: 1; }
.zi2 { z-index: 2; }

.turn_up {
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
}

.lh1 { line-height: 1; }
.lh11 { line-height: 1.1; }
.lh12 { line-height: 1.2; }
.lh13 { line-height: 1.3; }
.lh14 { line-height: 1.4; }
.lh15 { line-height: 1.5; }
.lh16 { line-height: 1.6; }
.lh17 { line-height: 1.7; }
.lh18 { line-height: 1.8; }
.lh19 { line-height: 1.9; }
.lh2 { line-height: 2; }
.lh22 { line-height: 2.2; }
.lh25 { line-height: 2.5; }

.pt0 { padding-top: 0; }
.pt5 { padding-top: var(--size5px); }
.pt10 { padding-top: var(--size10px); }
.pt15 { padding-top: var(--size15px); }
.pt20 { padding-top: var(--size20px); }
.pt25 { padding-top: var(--size25px); }
.pt30 { padding-top: var(--size30px); }
.pt35 { padding-top: var(--size35px); }
.pt40 { padding-top: var(--size40px); }
.pt45 { padding-top: var(--size45px); }
.pt50 { padding-top: var(--size50px); }
.pt55 { padding-top: var(--size55px); }
.pt60 { padding-top: var(--size60px); }
.pt65 { padding-top: var(--size65px); }
.pt70 { padding-top: var(--size70px); }
.pt75 { padding-top: var(--size75px); }
.pt80 { padding-top: var(--size80px); }
.pt85 { padding-top: var(--size85px); }
.pt90 { padding-top: var(--size90px); }
.pt95 { padding-top: var(--size95px); }
.pt100 { padding-top: var(--size100px); }
.pt105 { padding-top: var(--size105px); }
.pt110 { padding-top: var(--size110px); }
.pt115 { padding-top: var(--size115px); }
.pt120 { padding-top: var(--size120px); }
.pt125 { padding-top: var(--size125px); }
.pt130 { padding-top: var(--size130px); }
.pt135 { padding-top: var(--size135px); }
.pt140 { padding-top: var(--size140px); }
.pt145 { padding-top: var(--size145px); }
.pt150 { padding-top: var(--size150px); }
.pt160 { padding-top: var(--size160px); }
.pt170 { padding-top: var(--size170px); }
.pt180 { padding-top: var(--size180px); }
.pt190 { padding-top: var(--size190px); }
.pt200 { padding-top: var(--size200px); }

.pb0 { padding-bottom: 0; }
.pb5 { padding-bottom: var(--size5px); }
.pb10 { padding-bottom: var(--size10px); }
.pb15 { padding-bottom: var(--size15px); }
.pb20 { padding-bottom: var(--size20px); }
.pb25 { padding-bottom: var(--size25px); }
.pb30 { padding-bottom: var(--size30px); }
.pb35 { padding-bottom: var(--size35px); }
.pb40 { padding-bottom: var(--size40px); }
.pb45 { padding-bottom: var(--size45px); }
.pb50 { padding-bottom: var(--size50px); }
.pb55 { padding-bottom: var(--size55px); }
.pb60 { padding-bottom: var(--size60px); }
.pb65 { padding-bottom: var(--size65px); }
.pb70 { padding-bottom: var(--size70px); }
.pb75 { padding-bottom: var(--size75px); }
.pb80 { padding-bottom: var(--size80px); }
.pb85 { padding-bottom: var(--size85px); }
.pb90 { padding-bottom: var(--size90px); }
.pb95 { padding-bottom: var(--size95px); }
.pb100 { padding-bottom: var(--size100px); }
.pb105 { padding-bottom: var(--size105px); }
.pb110 { padding-bottom: var(--size110px); }
.pb115 { padding-bottom: var(--size115px); }
.pb120 { padding-bottom: var(--size120px); }
.pb125 { padding-bottom: var(--size125px); }
.pb130 { padding-bottom: var(--size130px); }
.pb135 { padding-bottom: var(--size135px); }
.pb140 { padding-bottom: var(--size140px); }
.pb145 { padding-bottom: var(--size145px); }
.pb150 { padding-bottom: var(--size150px); }
.pb160 { padding-bottom: var(--size160px); }
.pb170 { padding-bottom: var(--size170px); }
.pb180 { padding-bottom: var(--size180px); }
.pb190 { padding-bottom: var(--size190px); }
.pb200 { padding-bottom: var(--size200px); }

.pr5 {padding-right: var(--size5px); }
.pr10 {padding-right: var(--size10px); }
.pr15 {padding-right: var(--size15px); }
.pr20 {padding-right: var(--size20px); }
.pr25 {padding-right: var(--size25px); }
.pr30 {padding-right: var(--size30px); }
.pr35 {padding-right: var(--size35px); }
.pr40 {padding-right: var(--size40px); }
.pr45 {padding-right: var(--size45px); }
.pr50 {padding-right: var(--size50px); }
.pr55 {padding-right: var(--size55px); }
.pr60 {padding-right: var(--size60px); }
.pr65 {padding-right: var(--size65px); }
.pr70 {padding-right: var(--size70px); }
.pr75 {padding-right: var(--size75px); }
.pr80 {padding-right: var(--size80px); }
.pr85 {padding-right: var(--size85px); }
.pr90 {padding-right: var(--size90px); }
.pr95 {padding-right: var(--size95px); }
.pr100 { padding-right: var(--size100px); }

.pl5 {padding-left: var(--size5px); }
.pl10 {padding-left: var(--size10px); }
.pl15 {padding-left: var(--size15px); }
.pl20 {padding-left: var(--size20px); }
.pl25 {padding-left: var(--size25px); }
.pl30 {padding-left: var(--size30px); }
.pl35 {padding-left: var(--size35px); }
.pl40 {padding-left: var(--size40px); }
.pl45 {padding-left: var(--size45px); }
.pl50 {padding-left: var(--size50px); }
.pl55 {padding-left: var(--size55px); }
.pl60 {padding-left: var(--size60px); }
.pl65 {padding-left: var(--size65px); }
.pl70 {padding-left: var(--size70px); }
.pl75 {padding-left: var(--size75px); }
.pl80 {padding-left: var(--size80px); }
.pl85 {padding-left: var(--size85px); }
.pl90 {padding-left: var(--size90px); }
.pl95 {padding-left: var(--size95px); }
.pl100 { padding-left: var(--size100px); }

.prl5 { padding-right: var(--size5px); padding-left: var(--size5px); }
.prl10 { padding-right: var(--size10px); padding-left: var(--size10px); }
.prl15 { padding-right: var(--size15px); padding-left: var(--size15px); }
.prl20 { padding-right: var(--size20px); padding-left: var(--size20px); }
.prl25 { padding-right: var(--size25px); padding-left: var(--size25px); }
.prl30 { padding-right: var(--size30px); padding-left: var(--size30px); }
.prl35 { padding-right: var(--size35px); padding-left: var(--size35px); }
.prl40 { padding-right: var(--size40px); padding-left: var(--size40px); }
.prl45 { padding-right: var(--size45px); padding-left: var(--size45px); }
.prl50 { padding-right: var(--size50px); padding-left: var(--size50px); }
.prl55 { padding-right: var(--size55px); padding-left: var(--size55px); }
.prl60 { padding-right: var(--size60px); padding-left: var(--size60px); }
.prl65 { padding-right: var(--size65px); padding-left: var(--size65px); }
.prl70 { padding-right: var(--size70px); padding-left: var(--size70px); }
.prl75 { padding-right: var(--size75px); padding-left: var(--size75px); }
.prl80 { padding-right: var(--size80px); padding-left: var(--size80px); }
.prl85 { padding-right: var(--size85px); padding-left: var(--size85px); }
.prl90 { padding-right: var(--size90px); padding-left: var(--size90px); }
.prl95 { padding-right: var(--size95px); padding-left: var(--size95px); }
.prl100 { padding-right: var(--size100px); padding-left: var(--size100px); }

.fz10{font-size: .625rem; letter-spacing: .1em;}
.fz12{font-size: .75rem; letter-spacing: .1em;}
.fz13{font-size: .8125rem; letter-spacing: .1em;}
.fz14{font-size: .875rem; letter-spacing: .1em;}
.fz15{font-size: .9375rem; letter-spacing: .1em;}
.fz16{font-size: 1rem; letter-spacing: .1em;}
.fz18{font-size: 1.125rem; letter-spacing: .1em;}
.fz20{font-size: 1.25rem; letter-spacing: .1em;}
.fz22{font-size: 1.375rem; letter-spacing: .1em;}
.fz24{font-size: 1.5rem; letter-spacing: .1em;}
.fz25{font-size: 1.5625rem; letter-spacing: .1em;}
.fz26{font-size: 1.625rem; letter-spacing: .1em;}
.fz28{font-size: 1.75rem; letter-spacing: .1em;}
.fz30{font-size: 1.875rem; letter-spacing: .1em;}
.fz32{font-size: 2rem; letter-spacing: .1em;}
.fz34{font-size: 2.125rem; letter-spacing: .1em;}
.fz36{font-size: 2.25rem; letter-spacing: .1em;}
.fz38{font-size: 2.375rem; letter-spacing: .1em;}
.fz40{font-size: 2.5rem; letter-spacing: .1em;}
.fz42{font-size: 2.625rem; letter-spacing: .1em;}
.fz44{font-size: 2.75rem; letter-spacing: .1em;}
.fz46{font-size: 2.875rem; letter-spacing: .1em;}
.fz48{font-size: 3rem; letter-spacing: .1em;}
.fz50{font-size: 3.125rem; letter-spacing: .1em;}
.fz52{font-size: 3.25rem; letter-spacing: .1em;}
.fz54{font-size: 3.375rem; letter-spacing: .1em;}
.fz56{font-size: 3.5rem; letter-spacing: .1em;}
.fz58{font-size: 3.625rem; letter-spacing: .1em;}
.fz60{font-size: 3.75rem; letter-spacing: .1em;}
.fz62{font-size: 3.875rem; letter-spacing: .1em;}
.fz64{font-size: 4rem; letter-spacing: .1em;}
.fz66{font-size: 4.125rem; letter-spacing: .1em;}
.fz68{font-size: 4.25rem; letter-spacing: .1em;}
.fz70{font-size: 4.375rem; letter-spacing: .1em;}
.fz80{font-size: 5rem; letter-spacing: .1em;}
.fz84{font-size: 5.25rem; letter-spacing: .1em;}
.fz90{font-size: 5.625rem; letter-spacing: .1em;}
.fz96{font-size: 6rem; letter-spacing: .1em;}
.fz100{font-size: 6.25rem; letter-spacing: .1em;}
.fz110{font-size: 6.875rem; letter-spacing: .1em;}
.fz120{font-size: 7.5rem; letter-spacing: .1em;}
.fz130{font-size: 8.125rem; letter-spacing: .1em;}
.fz140{font-size: 8.75rem; letter-spacing: .1em;}
.fz150{font-size: 9.375rem; letter-spacing: .1em;}

.ls0 { letter-spacing: 0; }
.ls05 { letter-spacing: .05em; }
.ls1 { letter-spacing: .1em; }
.ls15 { letter-spacing: .15em; }
.ls2 { letter-spacing: .2em; }

.txt_white { color: #fff!important; }
.bg_white { background-color: #fff!important; }
.shadow_w {
	text-shadow: 0px 0px 5px #fff, 0px 0px 5px #fff, 0px 0px 10px #fff, 0px 0px 10px #fff, 0px 0px 15px #fff, 0px 0px 15px #fff;
}
em { font-style: normal; }


.txt_col01{color: var(--color01) !important;}
.txt_col02{color: var(--color02) !important;}
.txt_col03{color: var(--color03) !important;}
.txt_col04{color: var(--color04) !important;}
.txt_col05{color: var(--color05) !important;}
.txt_col06{color: var(--color06) !important;}
.txt_col07{color: var(--color07) !important;}
.txt_col08{color: var(--color08) !important;}
.txt_col09{color: var(--color09) !important;}
.txt_col10{color: var(--color10) !important;}
.txt_col11{color: var(--color11) !important;}
.txt_col12{color: var(--color12) !important;}
.txt_col13{color: var(--color13) !important;}
.txt_col14{color: var(--color14) !important;}
.txt_col15{color: var(--color15) !important;}
.txt_col16{color: var(--color16) !important;}
.txt_col17{color: var(--color17) !important;}
.txt_col18{color: var(--color18) !important;}
.txt_col19{color: var(--color19) !important;}
.txt_col20{color: var(--color20) !important;}

.txt_col_fl01::first-letter{color: var(--color01) !important;}
.txt_col_fl02::first-letter{color: var(--color02) !important;}
.txt_col_fl03::first-letter{color: var(--color03) !important;}
.txt_col_fl04::first-letter{color: var(--color04) !important;}
.txt_col_fl05::first-letter{color: var(--color05) !important;}
.txt_col_fl06::first-letter{color: var(--color06) !important;}
.txt_col_fl07::first-letter{color: var(--color07) !important;}
.txt_col_fl08::first-letter{color: var(--color08) !important;}
.txt_col_fl09::first-letter{color: var(--color09) !important;}
.txt_col_fl10::first-letter{color: var(--color10) !important;}
.txt_col_fl11::first-letter{color: var(--color11) !important;}
.txt_col_fl12::first-letter{color: var(--color12) !important;}
.txt_col_fl13::first-letter{color: var(--color13) !important;}
.txt_col_fl14::first-letter{color: var(--color14) !important;}
.txt_col_fl15::first-letter{color: var(--color15) !important;}
.txt_col_fl16::first-letter{color: var(--color16) !important;}
.txt_col_fl17::first-letter{color: var(--color17) !important;}
.txt_col_fl18::first-letter{color: var(--color18) !important;}
.txt_col_fl19::first-letter{color: var(--color19) !important;}
.txt_col_fl20::first-letter{color: var(--color20) !important;}

.bg_col01{background-color: var(--color01) !important;}
.bg_col02{background-color: var(--color02) !important;}
.bg_col03{background-color: var(--color03) !important;}
.bg_col04{background-color: var(--color04) !important;}
.bg_col05{background-color: var(--color05) !important;}
.bg_col06{background-color: var(--color06) !important;}
.bg_col07{background-color: var(--color07) !important;}
.bg_col08{background-color: var(--color08) !important;}
.bg_col09{background-color: var(--color09) !important;}
.bg_col10{background-color: var(--color10) !important;}
.bg_col11{background-color: var(--color11) !important;}
.bg_col12{background-color: var(--color12) !important;}
.bg_col13{background-color: var(--color13) !important;}
.bg_col14{background-color: var(--color14) !important;}
.bg_col15{background-color: var(--color15) !important;}
.bg_col16{background-color: var(--color16) !important;}
.bg_col17{background-color: var(--color17) !important;}
.bg_col18{background-color: var(--color18) !important;}
.bg_col19{background-color: var(--color19) !important;}
.bg_col20{background-color: var(--color20) !important;}

.bdr {border: solid 1px #fff;}
.bdr_col01{border-color: var(--color01) !important;}
.bdr_col02{border-color: var(--color02) !important;}
.bdr_col03{border-color: var(--color03) !important;}
.bdr_col04{border-color: var(--color04) !important;}
.bdr_col05{border-color: var(--color05) !important;}
.bdr_col06{border-color: var(--color06) !important;}
.bdr_col07{border-color: var(--color07) !important;}
.bdr_col08{border-color: var(--color08) !important;}
.bdr_col09{border-color: var(--color09) !important;}
.bdr_col10{border-color: var(--color10) !important;}
.bdr_col11{border-color: var(--color11) !important;}
.bdr_col12{border-color: var(--color12) !important;}
.bdr_col13{border-color: var(--color13) !important;}
.bdr_col14{border-color: var(--color14) !important;}
.bdr_col15{border-color: var(--color15) !important;}
.bdr_col16{border-color: var(--color16) !important;}
.bdr_col17{border-color: var(--color17) !important;}
.bdr_col18{border-color: var(--color18) !important;}
.bdr_col19{border-color: var(--color19) !important;}
.bdr_col20{border-color: var(--color20) !important;}

.bbw {
	border-bottom: 1px solid #fff;
}

.parallax { 
	width: 100%; 
	background-attachment: fixed!important; 
} 
.parallax.is_ios, .tab.parallax { 
	background-attachment: inherit!important; 
} 
.ready {
	position: relative;
}
.ready a {
	pointer-events: none;
}
.ready a:hover {
	opacity: 1;
	cursor: default;
}
.ready:before {
	content: "準備中";
    color: #fff;
    text-align: center;
    width: calc(100 / var(--break) * 100vw);
    height: calc(40 / var(--break) * 100vw);
    line-height: calc(40 / var(--break) * 100vw);
    background: rgba(51,51,51,.7);
    font-size: 1.125rem;
    letter-spacing: .1em;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    z-index: 2;
    position: absolute;
}
@media(max-width: 767px){ 
.parallax, .parallax.is_ios, .tab.parallax {  
		width: 100%;  
		background-attachment: inherit!important;  
	}
}
@media(min-width: 768px) {
	a[href^="tel:"] {
		pointer-events: none;
	}
	.slick-slide img,
	#sb_instagram .sbi_photo_wrap
	{
		backface-visibility: hidden;
		-webkit-backface-visibility: hidden;
	}
}
@media(min-width: 768px) and (max-width:1599px) {
}
@media(min-width: 768px) and (max-width:1299px) {
	.pc_only {
		display: none;
	}
	.tb_only {
		display: inherit;
	}
	.sp_only {
		display: none;
	}
	.tb_pc {
		display: inherit;
	}
	.sp_tb {
		display: inherit;
	}
}
@media(max-width: 767px) {
	:root {
		font-size: 4.27vw;
	}
	html, body {
		font-size: 1rem;
		letter-spacing: 0;
	}
	.lum-lightbox {
		background-color: rgba(255,255,255,.9);
	}
	.lum-close-button:after, .lum-close-button:before {
		background-color: rgb(000,000,000);
	}
	.lum-gallery-button {
		display: none !important;
	}
	a.zoom{
		position: relative;
		display: block;
		pointer-events: auto;
	}
	a.zoom:before {
		content: "タップで拡大します";
		position: absolute;
		width: 100%;
		height: 4.27vw;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
		margin: auto;
		letter-spacing: .1em;
		line-height: 4.27vw;
		text-shadow: 0 0 calc(5 / var(--break) * 100vw) #fff, 0 0 calc(5 / var(--break) * 100vw) #fff, 0 0 calc(10 / var(--break) * 100vw) #fff, 0 0 calc(10 / var(--break) * 100vw) #fff, 0 0 calc(15 / var(--break) * 100vw) #fff, 0 0 calc(15 / var(--break) * 100vw) #fff;
		text-align: center;
	}
	a.zoom:after{
		content: '';
		position: absolute;
		top: 0;
		right: 0;
		display: block;
		width: 1.5em;
		height: 1.5em;
		background-color: rgba(0,0,0,0.5);
		background-image: url("images/page/icn_zoom.svg");
		background-size: 1em 1em;
		background-position: center center;
		background-repeat: no-repeat;
	}
	.lum-lightbox.lum-open {
		z-index: 10;
	}
	.lum-lightbox-image-wrapper {
		overflow-x: scroll;
	}
	.lum-lightbox-inner img {
		max-width: calc(1000 / var(--break) * 100vw);
	}
	.inner,.inner1000,.inner1140,.inner1200,.inner1340,.inner1500,.inner1720 {
		width: 100%;
		max-width: calc(702 / var(--break) * 100vw);
	}
	.pc_only {
		display: none;
	}
	.tb_only {
		display: none;
	}
	.sp_only {
		display: inherit;
	}
	.tb_pc {
		display: none;
	}
	.sp_tb {
		display: inherit;
	}

	.pt_1vw { padding-top: 1vw;}
	.pt_2vw { padding-top: 2vw;}
	.pt_3vw { padding-top: 3vw;}
	.pt_4vw { padding-top: 3vw;}
	.pt_5vw { padding-top: 5vw;}
	.pt_6vw { padding-top: 6vw;}
	.pt_7vw { padding-top: 7vw;}
	.pt_8vw { padding-top: 8vw;}
	.pt_9vw { padding-top: 9vw;}
	.pt_10vw { padding-top: 10vw;}
	.pt_11vw { padding-top: 11vw;}
	.pt_12vw { padding-top: 12vw;}
	.pt_13vw { padding-top: 13vw;}
	.pt_14vw { padding-top: 14vw;}
	.pt_15vw { padding-top: 15vw;}

	.pb_1vw { padding-bottom: 1vw; }
	.pb_2vw { padding-bottom: 2vw; }
	.pb_3vw { padding-bottom: 4vw; }
	.pb_5vw { padding-bottom: 5vw; }
	.pb_6vw { padding-bottom: 6vw; }
	.pb_7vw { padding-bottom: 7vw; }
	.pb_8vw { padding-bottom: 8vw; }
	.pb_9vw { padding-bottom: 9vw; }
	.pb_10vw { padding-bottom: 10vw; }
	.pb_11vw { padding-bottom: 11vw; }
	.pb_12vw { padding-bottom: 12vw; }
	.pb_13vw { padding-bottom: 13vw; }
	.pb_14vw { padding-bottom: 14vw; }
	.pb_15vw { padding-bottom: 15vw; }
	
	.ls0_sp { letter-spacing: 0!important; }
	.ls05_sp { letter-spacing: .05em!important; }
	.ls15_sp { letter-spacing: .15em!important; }
	.ls2_sp { letter-spacing: .2em!important; }

	.txt_width {
		max-width: calc(646 / var(--break) * 100vw)!important;
		margin-left: auto;
		margin-right: auto;
	}
	.sp_left {
		text-align: left!important;
	}
	.shadow_w {
		text-shadow: 0 0 calc(5 / var(--break) * 100vw) #fff, 0 0 calc(5 / var(--break) * 100vw) #fff, 0 0 calc(10 / var(--break) * 100vw) #fff, 0 0 calc(10 / var(--break) * 100vw) #fff, 0 0 calc(15 / var(--break) * 100vw) #fff, 0 0 calc(15 / var(--break) * 100vw) #fff;
	}
	.txt_tb {
		writing-mode: horizontal-tb;
	}
	.ready:before {
		font-size: .75rem;
	}
}


/* ヘッダー header
------------------------------------------------------------------*/
header {
	z-index: 10;
}
header h1 {
	width: calc(340 / var(--break) * 100vw);
}
.wrap_head01 {
	width: calc(531 / var(--break) * 100vw);
}
.tel_common {
	width: calc(290 / var(--break) * 100vw);
}
.tel_common a {
	height: calc(80 / var(--break) * 100vw);
	background-color: #33333380;
}
.web_common {
	width: calc(230 / var(--break) * 100vw);
}
.web_common a {
	height: calc(80 / var(--break) * 100vw);
	background-color: #33333380;
}
.web_common .icn {
	width: calc(24 / var(--break) * 100vw);
}
.web_common .arw {
	width: calc(21 / var(--break) * 100vw);
}
.add_head .icn {
	width: calc(20 / var(--break) * 100vw);
}
@media(min-width: 768px) and (max-width:1599px) {

}
@media(min-width: 768px) and (max-width:1299px) {

}
@media(max-width: 767px) {
	header {
		padding: 3vw!important;
	}
	.wrap_head01 {
		display: none;
	}
	.add_head .icn {
		width: calc(30 / var(--break) * 100vw);
	}
}


/* メインイメージ main_img
------------------------------------------------------------------*/
.main_img { position: relative; }
.main_img .slide_main { opacity: 0; }
.main_img .slide_main li{
  position: relative;
  overflow: hidden;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  height: 100vh;
  min-height: 600px;
}
/* 背景 */
.main_img .slide_main li::before{
  content:'';
  display:block;
  background-repeat:no-repeat;
  background-position:center;
  background-size:cover;
  width:calc(100% + 100px);
  height:100%;
  transform: translate(0px,0); /* 待機位置 */
}
/* 画像 */
.main_img ul .main01::before{ background-image:url(images/index/main01.jpg); }
.main_img ul .main02::before{ background-image:url(images/index/main02.jpg); }
.main_img ul .main03::before{ background-image:url(images/index/main03.jpg); }
/* アニメ */
@keyframes mainSlideMove{
  0%   { transform: translate(-60px,0); }
  100% { transform: translate(0,0); }
}
/* JSが付けるクラスだけを見る */
.main_img .slide_main li.anim::before{
  animation: mainSlideMove 8.8s linear both;
}
.wrap_main01 {
	width: 90%;
	max-width: 1500px;
	left: 0;
	right: 0;
	margin: auto;
	position: absolute;
    top: 56%;
    transform: translateY(-50%);
}

.scrollDown {
	max-width: 9px;
	width: calc(2px + var(--size10px));
	height: calc(130 / var(--break) * 100vw);
	position: absolute;
	bottom: 0;
	left: calc(40 / var(--break) * 100vw);
}
.scrollDown .txt {
	width: calc(9 / var(--break) * 100vw);
    display: block;
    position: relative;
    top: calc(-60 / var(--break) * 100vw);
}
.scrollDown::before {
	content: "";
	width: 1px;
	height: 100%;
	margin: auto;
	background: #fff;
	position: absolute;
	inset: 0;
}
.scrollDown::after {
	content: "";
	width: calc(var(--size10px) - 1px);
	height: calc(var(--size10px) - 1px);
	margin: auto;
	background: #fff;
	border-radius: 100%;
	position: absolute;
	bottom: 0;
	animation: circlemove 3s ease-in-out infinite, cirlemovehide 3s ease-out infinite;
}

.row_main01 {
	width: calc(420 / var(--break) * 100vw);
	right: 11%;
    margin: auto;
    position: absolute;
    top: 80%;
    transform: translateY(-50%);
}
.row_main01 .col {
	width: calc(200 / var(--break) * 100vw);
	height: calc(200 / var(--break) * 100vw);
	background: url("images/index/ccl_main01.svg") no-repeat center / cover;
}
@keyframes circlemove {
	0% {
		bottom: 100%;
	}

	100% {
		bottom: -5px;
	}
}

@keyframes cirlemovehide {
	0% {
		opacity: 0
	}

	50% {
		opacity: 1;
	}

	80% {
		opacity: 0.9;
	}

	100% {
		opacity: 0;
	}
}
@media(min-width: 768px) and (max-width:1599px) {

}
@media(min-width: 768px) and (max-width:1299px) {
	.main_img .slide_main li{
	  height: calc(750 / var(--break) * 100vw);
	  min-height: auto;
	}
	.copy_main01 {
		margin-bottom: calc(40 / var(--break) * 100vw);
	}
}
@media only screen and (max-width: 767px) {
	.main_img .slide_main li {
		min-height: auto;
		height: calc(100svh - calc(120 / var(--break) * 100vw));
	}
	.main_img ul .main01::before{
		background-image: url("images/index/main01_sp.jpg");
	}
	.main_img ul .main02::before{
		background-image: url(images/index/main02_sp.jpg);
	}
	.main_img ul .main03::before{
		background-image: url(images/index/main03_sp.jpg);
	}
	.wrap_main01 {
        width: 100%;
        max-width: 100%;
        top: 50%;
        position: static;
        transform: none;
    }
	.copy_main01 {
        font-size: calc(50 / var(--break) * 100vw);
        text-align: center;
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        width: 100%;
        letter-spacing: 0;
    }
	.row_main01 {
        width: calc(480 / var(--break) * 100vw);
        right: 0;
        left: 0;
        margin: auto;
        bottom: calc(60 / var(--break) * 100vw);
        position: absolute;
        top: auto;
    }
	.row_main01 .col {
		width: calc(240 / var(--break) * 100vw);
		height: calc(240 / var(--break) * 100vw);
	}
	.row_main01 .col .txt {
		font-size: calc(28 / var(--break) * 100vw);
	}
}

/* グローバルナビゲーション gnav
------------------------------------------------------------------*/
.gnav {
	transition: .3s;
	width: 100%;
	background-color: #f2f2f2;
	position: relative;
}
/* .gnav.is_fixed {
	position: fixed;
	left: 0;
	z-index: 10;
	transition: .3s;
} */
.fix_nav {
	position: fixed;
	top: 0;
	left: 0;
	z-index: -1;
	transition: .5s;
	width: 100%;
	transform: translateY(-100%);
	opacity: 0;
	background: #ffffff;
}
.fix_nav.is_fixed  {
	transition: .5s;
	transform: translateY(0);
	opacity: 1;
	z-index: 10;
}
.fix_nav .gnav {
    width: calc(100% - calc(560 / var(--break) * 100vw));
	background-color: #fff;
	position: static;
}
.fix_nav .gnav > ul > li > a {
	height: calc(100 / var(--break) * 100vw);
	padding-bottom: calc(5 / var(--break) * 100vw);
}
.fix_nav .gnav > ul > li .ja {
	margin-bottom: calc(5 / var(--break) * 100vw);
}
.gnav > ul {
	max-width: 1410px;
}
.gnav > ul > li {
	-ms-flex-grow: 1;
	flex-grow: 1;
}
.gnav > ul > li > a {
	display:flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-flex-direction: column;
	flex-direction: column;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-ms-align-items: center;
	align-items: center;
	height: calc(160 / var(--break) * 100vw);
	position: relative;
}
.gnav > ul > li > a:after {
	content: "";
	position: absolute;
	width: calc(1 / var(--break) * 100vw);
	height: calc(20 / var(--break) * 100vw);
	background: #c0c0c0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	opacity: 0;
	transition: .3s;
}
.gnav > ul > li > a:hover:after, .gnav > ul > li > a.active:after, .gnav > ul > li > a.open:after {
	opacity: 1;
	transition: .3s;
}
.gnav > ul > li .en {
	/*text-transform: uppercase;*/
}
.gnav .nav_sub {
	display: none;
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	z-index: 3;
	width: 100%;
	background-color: #f2f2f2;
	padding: calc(65 / var(--break) * 100vw) 0 calc(80 / var(--break) * 100vw);
}
.row_nav_sub01 ul {
	width: 31.5%;
}
.row_nav_sub01 ul li {
    position: relative;
}
.row_nav_sub01 ul li a {
    padding-left: calc(27 / var(--break) * 100vw);
	padding-bottom: calc(7 / var(--break) * 100vw);
	border-bottom: solid 1px #fff;
	display: block;
}
.row_nav_sub01 ul li::before {
    content: "";
    position: absolute;
    width: calc(5 / var(--break) * 100vw);
    height: calc(5 / var(--break) * 100vw);
    border-bottom: 1px solid #434343;
    border-right: 1px solid #434343;
    transform: rotate(-45deg);
    left: calc(10 / var(--break) * 100vw);
    top: calc(16 / var(--break) * 100vw);
    bottom: auto;
    margin: auto;
}
.row_nav_sub01 ul li:nth-child(n+2) {
	margin-top: calc(7 / var(--break) * 100vw);
}
.bnr_nav01 {
	width: calc(480 / var(--break) * 100vw);
}
@media(min-width: 768px) and (max-width:1599px) {

}
@media(min-width: 768px) and (max-width:1299px) {
	.fix_nav .gnav > ul > li .ja {
		font-size: 1rem;
	}
	.fix_nav .gnav {
		width: calc(100% - calc(370 / var(--break) * 100vw));
		padding: 0 calc(10 / var(--break) * 100vw);
	}
	.row_fix_nav01 {
		margin-right: 0;
	}
	.row_fix_nav01 .tel_common {
		width: calc(195 / var(--break) * 100vw);
		margin-right: calc(5 / var(--break) * 100vw);
	}
	.row_fix_nav01 .tel_common .en {
		font-size: .9375rem;
	}
	.row_fix_nav01 .tel_common .en .num {
		font-size: 1.5rem;
	}
	.row_fix_nav01 .web_common {
		width: calc(170 / var(--break) * 100vw);
	}
	.row_fix_nav01 .web_common .ja {
		font-size: 1.125rem;
	}
}
@media only screen and (max-width: 767px) {
	.gnav, .fix_nav {
		display: none;
	}
	.btn_gnav_sp {
		position: fixed;
		top: 3vw;
		right: 3.2vw;
		height: calc(100 / var(--break) * 100vw);
		width: calc(100 / var(--break) * 100vw);
		background: #333;
		z-index: 10000;
		outline: none;
	}
	.btn_gnav_sp .txt_gnav {
		position: absolute;
		width: calc(52 / var(--break) * 100vw);
		right: 0;
		left: 0;
		bottom: 0;
		margin: auto;
	}
	.btn_gnav_sp .icn_gnav {
		width: calc(40 / var(--break) * 100vw);
		height: 1px;
		position: absolute;
		top: -3.5vw;
		bottom: 0;
		left: 0;
		right: 0;
		margin: auto;
		background: #fff;
		transition: transform .3s ease-in-out;
	}
	.btn_gnav_sp .icn_gnav:before, .btn_gnav_sp .icn_gnav:after {
		content: "";
		width: 100%;
		height: 1px;
		position: absolute;
		left: 0;
		background: #fff;
		transition: transform .3s ease-in-out;
	}
	.btn_gnav_sp .icn_gnav:before {
		top: -1.5vw;
	}
	.btn_gnav_sp .icn_gnav:after {
		bottom: -1.5vw;
	}
	.open .btn_gnav_sp .icn_gnav {
		background: none;
	}
	.open .btn_gnav_sp .icn_gnav:before, .open .btn_gnav_sp .icn_gnav:after {
		background: #fff;
		transition: transform .3s ease-in-out;
	}
	.open .btn_gnav_sp .icn_gnav:before {
		transform: rotate(45deg);
		top: 0;
	}
	.open .btn_gnav_sp .icn_gnav:after {
		transform: rotate(-45deg);
		bottom: 0;
	}
	.gnav_sp {
		padding: 19vw 0 0;
		overflow-y: auto;
		overflow-x: hidden;
		background: #fff;
		position: fixed;
		top: 0;
		right: 0;
		z-index: 9999;
		height: 100%;
		visibility: hidden;
		opacity: 0;
		width: 80%;
		transition: opacity .6s ease, visibility .6s ease;
		line-height: 1.45;
	}
	.bg_gnav {
		visibility: hidden;
		transition: .3s;
		opacity: 0;
	}
	.open .bg_gnav {
		width: 100%;
		height: 100%;
		position: fixed;
		z-index: 9998;
		background: rgba(0,0,0,0);
		visibility: visible;
		opacity: 1;
		transition: .3s;
		left: 0;
		top: 0;
	}
	.gnav_sp .nav_main {
		padding-bottom: 20vw;
	}
	.gnav_sp .nav_main > ul {
		padding: 0 3vw;
		display: block;
	}
	.gnav_sp .nav_main > ul > li {
		opacity: 0;
		transform: translateX(50%);
		transition: transform .6s ease, opacity .2s ease;
	}
	.gnav_sp .nav_main > ul > li:first-child {
		border-top: 1px dotted #c1c1c1;
	}
	.gnav_sp .nav_main > ul > li.nav_drawer {
		padding-bottom: 2.5vw;
		border-bottom: 1px dotted #c1c1c1;
	}
	.gnav_sp .nav_main > ul > li > a {
		padding: 3.5vw 6.5vw 3.5vw 0;
		border-bottom: 1px dotted #c1c1c1;
		display:-webkit-box;/*--- Androidブラウザ用 ---*/
		display:-ms-flexbox;/*--- IE10 ---*/
		display: -webkit-flex;/*--- safari（PC）用 ---*/
		display:flex;
		-webkit-box-pack:justify;/*--- Androidブラウザ用 ---*/
		-ms-flex-pack:justify;/*--- IE10 ---*/
		-webkit-justify-content:space-between;/*--- safari（PC）用 ---*/
		justify-content:space-between;
		-webkit-flex-wrap: wrap; /* Safari */
		flex-wrap: wrap;
		-ms-align-items: center;
		align-items: center;
		position: relative;
		letter-spacing: 0;
	}
	.gnav_sp .nav_main > ul > li.nav_drawer > a {
		border-bottom: none;
	}
	.gnav_sp .nav_main > ul > li > a:after {
		content: "";
        position: absolute;
        width: calc(15 / var(--break) * 100vw);
        height: calc(15 / var(--break) * 100vw);
        border-bottom: calc(2 / var(--break) * 100vw) solid #333333;
        border-right: calc(2 / var(--break) * 100vw) solid #333333;
        transform: rotate(-45deg);
        right: calc(7 / var(--break) * 100vw);
        top: 0;
        bottom: 0;
        margin: auto;
	}
	.gnav_sp .nav_main > ul > li.nav_drawer > a:after {
		transform: rotate(45deg);
	}
	.gnav_sp .nav_main > ul > li.nav_drawer > a.open:after {
		transform: rotate(-90deg);
	}
	.gnav_sp .nav_main > ul > li > a .ja {
		margin-bottom: 0;
	}
	.gnav_sp .nav_main > ul > li > a .en {
		/*text-transform: uppercase;*/
		font-size: 62.5%;
		letter-spacing: .1em;
	}
	.gnav_sp .nav_sub {
		background: #f2f2f2;
		padding: 6.5vw 6vw 7.5vw;
		/*display: none;*/ /* クリックで開閉させる場合はコメント解除 */
	}
	.gnav_sp .nav_sub li {
		opacity: 0;
		transform: translateX(50%);
		transition: transform .6s ease, opacity .2s ease;
	}
	.gnav_sp .nav_sub li:not(:last-child) {
		margin-bottom: 2.5vw;
	}
	.row_nav_sub01 ul li a {
		padding: 1vw 0 1vw 6vw;
		display: block;
		position: relative;
		border-bottom: none;
	}
	.row_nav_sub01 ul li a:after {
		content: "";
        position: absolute;
        width: calc(15 / var(--break) * 100vw);
        height: calc(15 / var(--break) * 100vw);
        border-bottom: calc(2 / var(--break) * 100vw) solid #333333;
        border-right: calc(2 / var(--break) * 100vw) solid #333333;
        transform: rotate(-45deg);
        left: calc(7 / var(--break) * 100vw);
        top: 0;
        bottom: 0;
        margin: auto;
	}
	.row_nav_sub01 ul li::before {
		display: none;
	}
	.open .gnav_sp {
		visibility: visible;
		opacity: 1;
	}
	.open .gnav_sp .nav_main > ul > li, .open .gnav_sp .nav_sub li {
		opacity: 1;
		transform: translateX(0);
		transition: transform 1s ease, opacity .9s ease;
	}
	.row_nav_sub01 ul {
		width: 100%;
	}
	.row_nav_sub01 ul li:nth-child(n+2) {
		margin-top: calc(0 / var(--break) * 100vw);
	}
	.row_nav_sub01 ul:not(:last-child) {
		margin-bottom: 2.5vw;
	}
	.bnr_nav01 {
		width: 100%;
	}
}

/* 新着情報 index_news
------------------------------------------------------------------*/
.row__news01 {
	border-top: solid 1px #c0c0c0;
}
.row__news01 .col_l {
	width: 19%;
}
.row__news01 .col_r {
	width: 81%;
}
/* ※パーフェクトスクロールバー用基本css ここからデザインに合わせて適宜変更してください */
.index_news ul {
	overflow: hidden;
	position: relative;
	padding-right: calc(20 / var(--break) * 100vw);
	max-height: calc(205 / var(--break) * 100vw);
	height: auto;
	touch-action: auto !important;
	line-height: 1.75;
}
.index_news li:not(:last-of-type) {
	margin-bottom: calc(22 / var(--break) * 100vw);
}
.index_news li {
	border-bottom: dotted calc(2 / var(--break) * 100vw) #c3c3c3;
	padding-bottom: calc(22 / var(--break) * 100vw);
}
.index_news li dt {
	width: 9%;
}
.index_news li dd {
	width: 91%;
}
.index_news li dd a {
	color: #333333; /* コーダーさんへに記載されている★標準テキスト：リンク色に変更*/
	text-decoration: underline;
}
/* パーフェクトスクロールバー */
.ps__thumb-y {
	background: #c0c0c0 !important;
	right: 0px !important;
	width: 4px !important;
}
.ps--active-x > .ps__rail-x,
.ps--active-y > .ps__rail-y {
	background: none !important;
	right: 0px !important;
	width: 4px !important;
	opacity: 1!important;
}
.ps .ps__rail-x.ps--clicking, .ps .ps__rail-x:focus, .ps .ps__rail-x:hover, .ps .ps__rail-y.ps--clicking, .ps .ps__rail-y:focus, .ps .ps__rail-y:hover {
	opacity: 1!important;
}
@media(min-width: 768px) and (max-width:1599px) {
}
@media(min-width: 768px) and (max-width:1299px) {
}
@media(max-width: 767px) {
	.index_news {
		margin-bottom: 14vw;
	}
	.row__news01 .col_l {
		width: 100%;
		margin-bottom: 4vw;
	}
	.ttl__news01 {
		text-align: center;
	}
	.ttl__news01 .en {
		font-size: calc(80 / var(--break) * 100vw);
	}
	.ttl__news01 .ja {
		font-size: calc(32 / var(--break) * 100vw);
		letter-spacing: 0;
	}
	.row__news01 .col_r {
        width: 100%;
        max-width: calc(646 / var(--break) * 100vw);
        margin-left: auto;
        margin-right: auto;
    }
	.index_news ul {
		padding-right: 5vw;
		max-height: calc(500 / var(--break) * 100vw);
	}
	.index_news li:not(:last-of-type) {
	}
	.index_news li dl {
		display: block;
	}
	.index_news li dt {
		width: 100%;
	}
	.index_news li dd {
		width: 100%;
		line-height: 1.5625;
	}
	.ps__thumb-y, .ps--active-x > .ps__rail-x, .ps--active-y > .ps__rail-y {
		width: 2px!important;
	}
}


/* concept
------------------------------------------------------------------*/
.index_concept {
	margin-top: calc(200 / var(--break) * 100vw);
}
.bg__concept01 > .en {
    letter-spacing: .1em;
    font-size: calc(160 / var(--break) * 100vw);
    top: calc(-26 / var(--break) * 100vw);
    right: 9.5%;
    color: #c0c0c099;
}
.row__concept01 {
	width: 93%;
	max-width: 1410px;
}
.row__concept01 .col_move {
	width: 58%;
	max-width: 800px;
	overflow: hidden;
	background: transparent;
}
.row__concept01 .col_txt {
	width: 36%;
}
.row__concept01 .col_txt .en {
	padding-bottom: calc(40 / var(--break) * 100vw);
	margin-bottom: calc(28 / var(--break) * 100vw);
}
.row__concept01 .col_txt .en::before {
	content: "";
	position: absolute;
	background: #333333;
	width: calc(1 / var(--break) * 100vw);
	height: calc(20 / var(--break) * 100vw);
	transform: rotate(30deg);
	right: 0;
	left: 0;
	bottom: 0;
	margin: auto;
}
.btn__concept01 a {
	border: solid #000 1px;
}
.btn_common01 {
	width: calc(400 / var(--break) * 100vw);
}
.btn_common01 a {
	transition: .3s;
	overflow: hidden;
}
.btn_common01 a::before {
	content: "";
    position: absolute;
	background: url("images/page/arw02.svg") no-repeat center / cover;
    width: calc(30 / var(--break) * 100vw);
    height: calc(6 / var(--break) * 100vw);
	top: 0;
	bottom: 0;
	margin: auto;
	right: calc(30 / var(--break) * 100vw);
	transition: .3s;
	z-index: 2;
}
.btn_common01 a::after{
  content: "";
  position: absolute;
  inset: 0;
  background: #333;
  transform: scaleX(0);
  transform-origin: bottom right;
  transition: transform .35s ease;
  z-index: 1;
}
.btn_common01 a span{
  position: relative;
  z-index: 2;
}
.deco__concept01 {
	position:absolute;
	top:0;
	left:0;
	width: calc(210 / var(--break) * 100vw);
	z-index: -1;
}
.deco__concept02 {
	position:absolute;
	bottom:0;
	right:0;
	width: calc(700 / var(--break) * 100vw);
	z-index: -1;
}
.deco__concept03 {
	position:absolute;
	top:0;
	left:0;
	width: calc(700 / var(--break) * 100vw);
	z-index: -1;
}
.deco__concept04 {
	position:absolute;
	bottom:0;
	right:0;
	width: calc(210 / var(--break) * 100vw);
	z-index: -1;
}
/*動き*/
.l-topAbout_imageArea2{
  overflow:hidden;
}
.l-topAbout_imageArea2 .c-dummybox{
  position:absolute;
  inset:0;
  background:#f2f2f2;
  z-index:1;
  transform-origin:left center;
  transform:scaleX(0);
  will-change: transform;
}
.l-topAbout_imageArea2.white .c-dummybox{
  background:#fff;
}
.l-topAbout_imageArea2 .c-revealImg{
  position:relative;
  z-index:2;
  display:block;
}
.l-topAbout_imageArea2 .c-revealImg img{
  display:block;
  width:100%;
  height:auto;
  opacity:0;
  transform: scale(1.12);
  filter: blur(8px) brightness(1.12);
  will-change: opacity, transform, filter;
}
.l-topAbout_imageArea2[data-is-active="true"] .c-dummybox{
  animation: dummy-grow 1.3s cubic-bezier(0,0.55,0.45,1) forwards;
}
.l-topAbout_imageArea2[data-is-active="true"] .c-revealImg img{ /* 画像遅延 */
  animation:
    img-fade 2s ease-out 1.05s forwards, /* フェード */
    img-scale 2s cubic-bezier(0.61,1,0.88,1) .8s forwards; /* スケール */
}
@keyframes dummy-grow{
  0%   { transform: scaleX(0); }
  100% { transform: scaleX(1); }
}
@keyframes img-fade{
  0%   { opacity: 0; }
  100% { opacity: 1; }
}
@keyframes img-scale{
  0%{
    transform: scale(1.12);
    filter: blur(8px) brightness(1.12);
  }
  20%{
    filter: blur(0) brightness(1);
  }
  100%{
    transform: scale(1);
    filter: blur(0) brightness(1);
  }
}

@media(min-width: 767px) {
	.btn_common01 a:hover::before {
		background: url("images/page/arw03.svg") no-repeat center / cover;
	}
	.btn_common01 a:hover::after{
		transform: scaleX(1);
		transform-origin: bottom left;
	}
	.btn_common01 a:hover span{
		color: #fff;
	}
	.btn_common01 a:hover {
		opacity: 1;
	}
}
@media(min-width: 768px) and (max-width:1599px) {
	.bg__concept01 > .en {
		font-size: calc(140 / var(--break) * 100vw);
		right: 3.5%;
	}
	.row__concept01 .col_txt .copy {
		font-size: calc(38 / var(--break) * 100vw);
	}
	.row__concept01 .col_txt > .txt {
		text-shadow: 0px 0px 5px #fff, 0px 0px 5px #fff, 0px 0px 10px #fff, 0px 0px 10px #fff, 0px 0px 15px #fff, 0px 0px 15px #fff;
	}
	.bg__concept01.ptn02 {
		margin-bottom: calc(100 / var(--break) * 100vw);
	}
}
@media(min-width: 768px) and (max-width:1299px) {
	.index_concept {
		margin-top: calc(100 / var(--break) * 100vw);
	}
	.bg__concept01 {
		padding: calc(0 / var(--break) * 100vw) 0 calc(0 / var(--break) * 100vw);
	}
	.bg__concept01.ptn02 {
		padding: calc(0 / var(--break) * 100vw) 0 calc(0 / var(--break) * 100vw);
	}
	.bg__concept01 > .en {
        font-size: calc(120 / var(--break) * 100vw);
        right: 0%;
    }
	.deco__concept02,.deco__concept03 {
		width: calc(550 / var(--break) * 100vw);
	}
	.row__concept01 {
		width: 95%;
	}
	.row__concept01 .col_txt {
		width: 38%;
	}
	.btn__concept01 {
		width: 100%;
	}
	.row__concept01 .col_txt .copy {
        font-size: calc(33 / var(--break) * 100vw);
    }
}
@media(max-width: 767px) {
	.index_concept {
		margin-top: calc(16 / var(--break) * 100vw);
	}
	.bg__concept01 {
		padding-bottom: 14vw;
    	margin-bottom: 7vw;
	}
	.bg__concept01 > .en {
		letter-spacing: .1em;
        font-size: calc(120 / var(--break) * 100vw);
        top: 0;
        right: 0;
        left: 0;
        color: #c0c0c0;
        margin: auto;
        text-align: center;
        position: relative;
        width: 100%;
        margin-bottom: 16vw;
	}
	.row__concept01 {
		width: 100%;
		max-width: calc(700 / var(--break) * 100vw);
	}
	.row__concept01 .col_move {
		width: 100%;
        max-width: 100%;
        margin-bottom: 14vw;
	}
	.row__concept01 .col_txt {
		width: 100%;
        max-width: calc(646 / var(--break) * 100vw) !important;
        margin-left: auto;
        margin-right: auto;
	}
	.row__concept01 .col_txt .en {
		font-size: calc(40 / var(--break) * 100vw);
		padding-bottom: calc(53 / var(--break) * 100vw);
		margin-bottom: calc(10 / var(--break) * 100vw);
	}
	.row__concept01 .col_txt .en::before {
		width: calc(1 / var(--break) * 100vw);
		height: calc(40 / var(--break) * 100vw);
	}
	.row__concept01 .col_txt .copy {
        font-size: calc(50 / var(--break) * 100vw);
		letter-spacing: 0;
		margin-bottom: 2vw;
    }
	.btn_common01 {
		width: calc(600 / var(--break) * 100vw);
	}
	.btn_common01 a {
		padding: 3.2vw 0 3.5vw;
	}
	.btn_common01 a span {
		font-size: calc(32 / var(--break) * 100vw);
	}
	.btn_common01 a::before {
		width: calc(50 / var(--break) * 100vw);
        height: calc(10 / var(--break) * 100vw);
        right: calc(40 / var(--break) * 100vw);
		background: url("images/page/arw03.svg") no-repeat center / cover;
	}
	.btn_common01 a {
		background-color: #333!important;
	}
	.btn_common01 a span{
		color: #fff;
	}
	.deco__concept02 {
		top: 30vw;
		bottom: auto;
		left: 0;
		right: auto;
		width: calc(560 / var(--break) * 100vw);
		z-index: -1;
	}
	.deco__concept01 {
		top: auto;
		left: auto;
		width: calc(210 / var(--break) * 100vw);
		right: 0;
		bottom: 0;
	}
	.bg__concept01.ptn02 {
		padding: 13vw 0 12vw;
	}
	.deco__concept03 {
		width: calc(560 / var(--break) * 100vw);
	}
}

/* feature
------------------------------------------------------------------*/
.bg__feature01 {
	background: url("images/index/bg_feature01.png") no-repeat center / cover;
	height: calc(600 / var(--break) * 100vw);
	position: relative;
}
.ttl__feature01 {
	width: calc(750 / var(--break) * 100vw);
	right: 0;
	top: 24%;
	position: absolute;
}
.ttl__feature01 .en {
	font-size: calc(160 / var(--break) * 100vw);
	letter-spacing: .12em;
	padding-bottom: calc(28 / var(--break) * 100vw);
	margin-bottom: calc(25 / var(--break) * 100vw);
}
.wrap__feature01 {
	z-index: 2;
    width: 42%;
    max-width: calc(620 / var(--break) * 100vw);
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    margin: auto;
    right: 0;
}
.en__feature01 {
	line-height: .8;
	background: linear-gradient(
    to left,
    #333333 0%,
    #333333 28%,
    #c4b48a 28%,
    #c4b48a 100%
  );
  background-repeat: no-repeat;
  background-size: 100% 1px;
  background-position: left bottom;
}
.en__feature01.left {
	background: linear-gradient(
    to right,
    #333333 0%,
    #333333 28%,
    #c4b48a 28%,
    #c4b48a 100%
  );
	background-repeat: no-repeat;
  background-size: 100% 1px;
  background-position: left bottom;
}
.img__feature01 {
	width: 90%;
	max-width: 1240px;
	position: relative;
}
.bg__feature03 {
	width: 93%;
	max-width: 1720px;
}
.row__feature01 {
	width: 90%;
	max-width: 1345px;
}
.row__feature01 .col_move {
	width: 53%;
	max-width: 700px;
}
.row__feature01 .col_txt {
	width: 40%;
}
.deco__feature01 {
	width: calc(270 / var(--break) * 100vw);
	bottom: calc(-17 / var(--break) * 100vw);
	left: 0;
	z-index: -1;
}
/*03*/
.bg__feature04 {
	width: 97%;
	max-width: 1820px;
	padding: calc(158 / var(--break) * 100vw) 5.5% calc(155 / var(--break) * 100vw) 0;
}
.img__feature03 {
    width: 26%;
    max-width: calc(470 / var(--break) * 100vw);
    top: calc(150 / var(--break) * 100vw);
    left: 0;
}
.img__feature04 {
    width: 19%;
    max-width: calc(340 / var(--break) * 100vw);
    top: calc(375 / var(--break) * 100vw);
    left: 7%;
}
.img__feature05 {
    width: 28%;
    max-width: calc(500 / var(--break) * 100vw);
    top: calc(50 / var(--break) * 100vw);
    left: 27%;
}
.bg__feature04 .wrap__feature01 {
    position: relative;
    top: 0%;
    transform: none;
    margin-left: auto;
    margin-right: 0;
}

/*04*/
.bg__feature05 {
	padding: calc(90 / var(--break) * 100vw) 0 calc(134 / var(--break) * 100vw);
}
.img__feature06 {
    width: 41%;
    max-width: calc(700 / var(--break) * 100vw);
    top: calc(102 / var(--break) * 100vw);
    right: 17%;
}
.img__feature07 {
    width: 16%;
    max-width: calc(270 / var(--break) * 100vw);
    top: 0;
    right: 0;
}
.img__feature08 {
    width: 16%;
    max-width: calc(270 / var(--break) * 100vw);
    bottom: 0;
    right: 0;
}
.bg__feature05 .wrap__feature01 {
    position: relative;
    top: 0%;
    transform: none;
    margin-left: 0;
    margin-right: auto;
}
/*05*/
.row__feature02 .col_img {
	width: 51%;
}
.row__feature02 .col_txt {
	width: 46%;
}
.row__feature02 .wrap__feature01 {
    position: relative;
    top: 0%;
    transform: none;
    width: 78%;
    max-width: 100%;
}
/* 親 */
.col_img.collage__feature01{
  display: grid;
  grid-template-columns: 38% 62%;
  grid-template-rows: 1fr 1fr 0.55fr;
  gap: calc(24 / var(--break) * 100vw);
  align-items: stretch;
  height: min(720px, calc(720 / var(--break) * 100vw));
}
/* 配置*/
.col_img.collage__feature01 .item1{ grid-column:2; grid-row:1 / 3; } /* 1：右上大 */
.col_img.collage__feature01 .item2{ grid-column:1; grid-row:1; }     /* 2：左上 */
.col_img.collage__feature01 .item3{ grid-column:1; grid-row:2 / 4; } /* 3：左下縦 */
.col_img.collage__feature01 .item4{ grid-column:2; grid-row:3; }     /* 4：右下横 */

/* revealの基準 */
.col_img.collage__feature01 .l-topAbout_imageArea2{
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
/* 画像フィット */
.col_img.collage__feature01 .c-revealImg,
.col_img.collage__feature01 picture,
.col_img.collage__feature01 img{
  display:block;
  width:100%;
  height:100%;
}
.col_img.collage__feature01 img{
  object-fit: cover;
}
/*06*/
.bg__feature02.ptn02 .wrap__feature01 {
    right: auto;
    left: 0;
}
/*07 08*/
.row__feature03 .col {
	width: 47%;
	position: relative;
	padding-bottom: calc(95 / var(--break) * 100vw);
}
.row__feature03 .en__feature01 {
	writing-mode: vertical-rl;
    text-orientation: sideways;
    height: 51.5%;
    right: 4.5%;
    top: 0;
    background: linear-gradient(to bottom, #333333 0%, #333333 28%, #c4b48a 28%, #c4b48a 100%);
    background-repeat: no-repeat;
    background-size: 1px 100%;
    background-position: left top;
	line-height: .85;
}
.row__feature03 .col::before {
	content: "";
    position: absolute;
	background: #f2f2f2;
    width: 88%;
    height: 81%;
	right: 0;
	bottom: 0;
	z-index: -1;
}
.img__feature09 {
	width: 87%;
	max-width: 700px;
	margin-bottom: calc(40 / var(--break) * 100vw);
}
.row__feature03 .col .wrap {
	width: 63%;
    margin-right: 12.5%;
    margin-left: auto;
}
.slide_feature01 .slide img { 
	width: calc(900 / var(--break) * 100vw); 
} 
.slide_feature01 .slide li { 
	z-index: 1; 
}
@media(min-width: 768px) and (max-width:1599px) {
	.deco__feature01 {
		left: -4%;
	}
	.img__feature05 {
		width: 25%;
	}
	.img__feature03 {
		top: calc(185 / var(--break) * 100vw);
	}
	.bg__feature05 {
		padding: calc(35 / var(--break) * 100vw) 0 calc(67 / var(--break) * 100vw);
	}
	.img__feature06 {
		width: 37%;
	}
	.row__feature02 .col_img {
		width: 56%;
		gap: calc(18 / var(--break) * 100vw);
	}
	.row__feature02 .col_txt {
		width: 41%;
	}
	.row__feature03 .col .copy {
		font-size: calc(42 / var(--break) * 100vw);
	}
}
@media(min-width: 768px) and (max-width:1299px) {
	.ttl__feature01 {
		width: calc(650 / var(--break) * 100vw);
	}
	.ttl__feature01 .en {
		font-size: calc(100 / var(--break) * 100vw);
	}
	.ttl__feature01 .ja {
		font-size: calc(30 / var(--break) * 100vw);
	}
	.wrap__feature01 .copy,.row__feature01 .copy {
		font-size: calc(36 / var(--break) * 100vw);
		margin-bottom: calc(25 / var(--break) * 100vw);
	}
	.bg__feature04 {
		padding: calc(85 / var(--break) * 100vw) 5.5% calc(98 / var(--break) * 100vw) 0;
	}
	.img__feature04 {
		top: calc(340 / var(--break) * 100vw);
	}
	.bg__feature05 {
        padding: 0;
    }
	.img__feature08 {
		bottom: auto;
		top: calc(270 / var(--break) * 100vw);
	}
	.col_img.collage__feature01 .item2 img{
	  object-position: left center;
	}
	.row__feature03 .col .copy {
        font-size: calc(35 / var(--break) * 100vw);
    }
	
}
@media(max-width: 767px) {
	.index_feature {
		margin-bottom: 10vw;
	}
	.bg__feature01 {
		background: url(images/index/bg_feature01_sp.png) no-repeat center / cover;
		height: calc(700 / var(--break) * 100vw);
		position: relative;
		margin-bottom: 10.5vw;
	}
	.ttl__feature01 {
		width: calc(646 / var(--break) * 100vw);
		right: 0;
		left: 0;
		margin: auto;
		top: calc(100 / var(--break) * 100vw);
	}
	.ttl__feature01 .en {
		text-align: center;
		font-size: calc(120 / var(--break) * 100vw);
		letter-spacing: .1em;
		padding-bottom: calc(28 / var(--break) * 100vw);
		margin-bottom: calc(25 / var(--break) * 100vw);
	}
	.ttl__feature01 .ja {
		font-size: calc(40 / var(--break) * 100vw);
		letter-spacing: 0em;
		text-align: center;
	}
	.img__feature01 {
		width: 100%;
		max-width: 100%;
	}
	.wrap__feature01 {
		width: 100%;
		max-width: calc(646 / var(--break) * 100vw);
		position: relative;
		top: -6vw;
		transform: none;
		margin: auto;
		right: 0;
	}
	.bg__feature05 .wrap__feature01 {
        margin-left: auto;
    	margin-right: auto;
    }
	.en__feature01 {
		font-size: calc(40 / var(--break) * 100vw);
	}
	.wrap__feature01 .copy,.row__feature01 .copy {
		font-size: calc(50 / var(--break) * 100vw);
		margin-bottom: calc(25 / var(--break) * 100vw);
		letter-spacing: 0;
	}
	.bg__feature02 {
		background-color: #f2f2f2;
		padding-bottom: 5vw;
		margin-bottom: 13vw;
	}
	.inner__feature01 {
		max-width: 100%;
	}
	.bg__feature03 {
		width: 100%;
		max-width: 100%;
		padding-bottom: 55.5vw;
		margin-bottom: 13vw;
	}
	.row__feature01 {
		width: 100%;
        max-width: calc(700 / var(--break) * 100vw);
		margin-left: auto;
		margin-right: auto;
	}
	.row__feature01 .col_move {
		width: 100%;
        max-width: 100%;
        margin-bottom: 9vw;
	}
	.row__feature01 .col_move .move{
		margin-bottom: 0;
	}
	.row__feature01 .col_txt {
		width: 100%;
        max-width: calc(646 / var(--break) * 100vw) !important;
        margin-left: auto;
        margin-right: auto;
	}
	.img__feature02 {
		position: absolute;
		bottom: 24vw;
		right: 3.5vw;
		width: calc(400 / var(--break) * 100vw);
	}
	.deco__feature01 {
		width: calc(270 / var(--break) * 100vw);
		bottom: calc(0 / var(--break) * 100vw);
		left: 3vw;
	}
	.bg__feature04 {
		width: 100%;
		max-width: 100%;
		padding: calc(613 / var(--break) * 100vw) 0 calc(92 / var(--break) * 100vw) 0;
		margin-bottom: 13vw;
	}
	.bg__feature04 .wrap__feature01 {
		position: relative;
		top: 0%;
		transform: none;
		margin-left: auto;
		margin-right: auto;
		width: 100%;
		max-width: calc(646 / var(--break) * 100vw);
	}
	.img__feature03 {
		width: 55%;
		max-width: calc(329 / var(--break) * 100vw);
		top: calc(127 / var(--break) * 100vw);
		left: 1vw;
	}
	.img__feature04 {
		width: 32%;
		max-width: calc(238 / var(--break) * 100vw);
		top: calc(296 / var(--break) * 100vw);
		left: 15vw;
	}
	.img__feature05 {
		width: 47%;
		max-width: calc(350 / var(--break) * 100vw);
		top: calc(64 / var(--break) * 100vw);
		left: auto;
		right: 3vw;
	}
	.bg__feature05 {
        padding: calc(550 / var(--break) * 100vw) 0 calc(90 / var(--break) * 100vw);
        margin-bottom: 0;
    }
	.img__feature06 {
		width: 73%;
		max-width: calc(490 / var(--break) * 100vw);
		top: calc(73 / var(--break) * 100vw);
		right: auto;
		left: -2vw;
	}
	.img__feature07 {
		width: 29%;
		max-width: calc(189 / var(--break) * 100vw);
		top: 0;
		right: -1.5vw;
	}
	.img__feature08 {
		width: 28%;
		max-width: calc(189 / var(--break) * 100vw);
		bottom: auto;
		right: -1.5vw;
		top: calc(287 / var(--break) * 100vw);
	}
	.row__feature02 {
		margin-bottom: 13vw;
	}
	.row__feature02 .col_img {
		width: 100%;
		margin: 0 auto calc(20 / var(--break) * 100vw);
	}
	.row__feature02 .col_txt {
        width: 100%;
        max-width: calc(700 / var(--break) * 100vw);
        padding: 8vw 0vw 13vw;
        margin-left: auto;
        margin-right: auto;
    }
	.row__feature02 .col_img.collage__feature01{
		display: grid !important;
		grid-template-columns: 38% 62%;
		grid-template-rows: 1fr 1fr 0.85fr;
		gap: calc(20 / var(--break) * 100vw);
		width: 100%;
		max-width: calc(700 / var(--break) * 100vw);
		height: calc(490 / var(--break) * 100vw);
		box-sizing: border-box;
		overflow: hidden;
	}
	.row__feature02 .col_img.collage__feature01 .collage__item{
		min-width: 0;
		overflow: hidden;
	}
	.row__feature02 .col_img.collage__feature01 .item1{ grid-column:2; grid-row:1 / 3; } /* 右上大 */
	.row__feature02 .col_img.collage__feature01 .item2{ grid-column:1; grid-row:1; }     /* 左上 */
	.row__feature02 .col_img.collage__feature01 .item3{ grid-column:1; grid-row:2 / 4; } /* 左下 */
	.row__feature02 .col_img.collage__feature01 .item4{ grid-column:2; grid-row:3; }     /* 右下 */
	.row__feature02 .col_img.collage__feature01 .l-topAbout_imageArea2{
		position: relative;
		width: 100%;
		height: 100%;
	}
	.row__feature02 .col_img.collage__feature01 .c-revealImg,
	.row__feature02 .col_img.collage__feature01 picture,
	.row__feature02 .col_img.collage__feature01 img{
		display:block;
		width:100%;
		height:100%;
	}
	.row__feature02 .col_img.collage__feature01 img{
		object-fit: cover;
	}
	.row__feature02 .wrap__feature01 {
		position: relative;
		top: 0%;
		transform: none;
		width: 89%;
	}
	.row__feature03 {
		margin-bottom: calc(93 / var(--break) * 100vw);
	}
	.row__feature03 .col {
		width: 100%;
		position: relative;
		padding-bottom: calc(95 / var(--break) * 100vw);
	}
	.img__feature09 {
		width: 100%;
		max-width: 100%;
		margin-bottom: calc(130 / var(--break) * 100vw);
	}
	.row__feature03 .col .wrap {
		width: 88%;
		margin-right: auto;
		margin-left: auto;
	}
	.row__feature03 .col .copy {
        font-size: calc(50 / var(--break) * 100vw);
		margin-bottom: 3vw;
		letter-spacing: 0;
    }
	.row__feature03 .en__feature01 {
        writing-mode: horizontal-tb;
        height: auto;
        top: 81vw;
        right: 0;
        left: 0;
        background: linear-gradient(to left, #333333 0%, #333333 28%, #c4b48a 28%, #c4b48a 100%);
        background-repeat: no-repeat;
        background-size: 100% 1px;
        background-position: left bottom;
        width: 90%;
        margin: auto;
        text-align: right;
    }
	.row__feature03 .col_r .en__feature01 {
		text-align: left;
		background: linear-gradient(to right, #333333 0%, #333333 28%, #c4b48a 28%, #c4b48a 100%);
		background-repeat: no-repeat;
		background-size: 100% 1px;
		background-position: left bottom;
	}
	.row__feature03 .col::before {
		width: 100%;
		height: 100%;
	}
}

/* medical
------------------------------------------------------------------*/
.index_medical {
	margin-bottom: calc(240 / var(--break) * 100vw);
}
.index_medical::before {
	content: "";
    position: absolute;
	background: url("images/index/bg_medical01.png") no-repeat center / cover;
    width: 100%;
    height: calc(100% - calc(223 / var(--break) * 100vw));
	right: 0;
	left: 0;
	bottom: 0;
	margin: auto;
	z-index: -1;
}
.ttl__medical01 .en {
	font-size: calc(160 / var(--break) * 100vw);
	letter-spacing: .1em;
}
.btn__medical01 a {
	background: url("images/index/bg_medical03.png") no-repeat center / cover;
}
.btn__medical01 a::before {
    background: url(images/page/arw03.svg) no-repeat center / cover;
}
.btn__medical01 a .deco {
	position: relative;
	width: 100%;
	height: 100%;
	display: block;
}
.btn__medical01 a .deco::before {
	content: "";
    position: absolute;
	border: solid calc(1 / var(--break) * 100vw) #fff;
    width: calc(100% - calc(20 / var(--break) * 100vw));
    height: calc(100% - calc(20 / var(--break) * 100vw));
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	margin: auto;
}
.box__medical02 {
	padding: calc(40 / var(--break) * 100vw) 0 calc(40 / var(--break) * 100vw);
}
.row__medical01 .col {
	width: calc(100% / 4);
	position: relative;
}
.row__medical01 .col:not(:last-child)::before {
	content: "";
    position: absolute;
	background: #c0c0c0;
    width: calc(1 / var(--break) * 100vw);
    height: 100%;
	top: 0;
	bottom: 0;
	right: 0;
	margin: auto;
}
.row__medical01 .col a {
	padding: calc(20 / var(--break) * 100vw) 0 calc(15 / var(--break) * 100vw);
}
.row__medical01 .col .icn {
	width: calc(140 / var(--break) * 100vw);
}
.row__medical01 .col .arw {
	width: calc(30 / var(--break) * 100vw);
	transition: .3s;
}
.row__medical02 .col {
	width: 32%;
}
.row__medical02 .col:nth-child(n+4) {
	margin-top: calc(20 / var(--break) * 100vw);
}
.row__medical02 .col a {
	height: calc(180 / var(--break) * 100vw);
	position: relative;
	padding: 0 calc(10 / var(--break) * 100vw) 0 calc(40 / var(--break) * 100vw);
}
.row__medical02 .col .icn {
	width: calc(100 / var(--break) * 100vw);
	margin-right: calc(25 / var(--break) * 100vw);
}
.row__medical02 .col .arw {
	width: calc(30 / var(--break) * 100vw);
	right: calc(20 / var(--break) * 100vw);
	bottom: calc(20 / var(--break) * 100vw);
	transition: .3s;
}
.btn__medical02 a {
	background: url("images/index/bg_medical02.png") no-repeat center / cover;
	outline-offset: calc(-10 / var(--break) * 100vw);
    outline: #fff solid 1px;
	padding: calc(30 / var(--break) * 100vw) 0 calc(37 / var(--break) * 100vw);
}
.btn__medical02 a::before {
	content: "";
    position: absolute;
    background: url(images/page/arw03.svg) no-repeat center / cover;
    width: calc(30 / var(--break) * 100vw);
    height: calc(6 / var(--break) * 100vw);
    top: 0;
    bottom: 0;
    margin: auto;
    right: calc(40 / var(--break) * 100vw);
    z-index: 2;
	transition: .3s;
}
.row__medical01 .col a:hover .arw {
	margin-right: calc(-20 / var(--break) * 100vw);
	transition: .3s;
}
.row__medical02 .col a:hover .arw {
	right: calc(10 / var(--break) * 100vw);
	transition: .3s;
}
.btn__medical02 a:hover::before {
	right: calc(30 / var(--break) * 100vw);
	transition: .3s;
}
@media(min-width: 768px) and (max-width:1599px) {

}
@media(min-width: 768px) and (max-width:1299px) {
	.row__medical02 .col .icn {
        width: calc(80 / var(--break) * 100vw);
        margin-right: calc(10 / var(--break) * 100vw);
    }
	.row__medical02 .col a {
		height: calc(150 / var(--break) * 100vw);
		padding: 0 calc(10 / var(--break) * 100vw) 0 calc(20 / var(--break) * 100vw);
	}
	.ttl__medical02 .ja {
        font-size: calc(19 / var(--break) * 100vw);
    }
}
@media(max-width: 767px) {
	.index_medical {
		margin-bottom: calc(135 / var(--break) * 100vw);
    	padding-bottom: 13vw;
	}
	.ttl__medical01 .en {
		font-size: calc(120 / var(--break) * 100vw);
		letter-spacing: .1em;
		margin-bottom: 4.5vw;
	}
	.ttl__medical01 .ja {
		font-size: calc(40 / var(--break) * 100vw);
	}
	.index_medical::before {
		background: url(images/index/bg_medical01_sp.png) no-repeat center / cover;
		height: calc(100% - calc(194 / var(--break) * 100vw));
	}
	.box__medical01 {
		padding: 3vw 3vw;
	}
	.btn__medical01 a {
		padding: 0;
	}
	.btn__medical01 a .deco {
		position: relative;
		width: 100%;
		height: 100%;
		display: block;
		padding: 4vw 0 5vw;
	}
	.btn__medical01 .txt {
		font-size: calc(32 / var(--break) * 100vw);
		margin-bottom: 1vw;
	}
	.btn__medical01 .en {
		font-size: calc(24 / var(--break) * 100vw);
		letter-spacing: .1em;
	}
	.row__medical01 .col {
		width: 50%;
	}
	.row__medical01 .col a {
		padding: calc(0 / var(--break) * 100vw) 0 calc(32 / var(--break) * 100vw);
	}
	.row__medical01 .col .icn {
		width: calc(140 / var(--break) * 100vw);
		margin-bottom: 2vw;
	}
	.ttl__medical02 {
		margin-bottom: 1.5vw;
	}
	.ttl__medical02 .ja {
		font-size: calc(28 / var(--break) * 100vw);
		letter-spacing: 0;
	}
	.ttl__medical02 .en {
		font-size: calc(20 / var(--break) * 100vw);
	}
	.row__medical01 .col .arw {
		width: calc(50 / var(--break) * 100vw);
 	}
	.row__medical01 .col:nth-child(odd)::before {
		content: "";
		position: absolute;
		background: #c0c0c0;
		width: 1px;
		height: calc(100% - calc(20 / var(--break) * 100vw));
		top: 0;
		bottom: 0;
		right: 0;
		margin: auto;
	}
	.row__medical01 .col:nth-child(2)::before {
		display: none;
	}
	.row__medical01 .col:nth-child(-n+2)::after {
		content: "";
		position: absolute;
		background: #c0c0c0;
		width: calc(100% - calc(20 / var(--break) * 100vw));
		height: 1px;
		bottom: 0;
		left: 0;
		right: 0;
		margin: auto;
	}
	.row__medical01 .col:nth-child(-n+2) {
		margin-bottom: 6vw;
	}
	.box__medical02 {
		padding: calc(40 / var(--break) * 100vw) 0 calc(0 / var(--break) * 100vw);
	}
	.row__medical02 .col {
		width: 100%;
		max-width: calc(646 / var(--break) * 100vw);
		margin-left: auto;
		margin-right: auto;
	}
	.row__medical02 .col:nth-child(n+2) {
		margin-top: calc(20 / var(--break) * 100vw);
	}
	.row__medical02 .col .icn {
		width: calc(100 / var(--break) * 100vw);
		margin-right: calc(25 / var(--break) * 100vw);
	}
	.row__medical02 .ttl__medical02 {
        margin-bottom: 0;
    }
	.row__medical02 .ttl__medical02 .ja {
        font-size: calc(28 / var(--break) * 100vw);
        letter-spacing: 0;
		margin-bottom: 2vw;
    }
	.row__medical02 .col .arw {
		width: calc(50 / var(--break) * 100vw);
		right: calc(24 / var(--break) * 100vw);
		bottom: calc(12 / var(--break) * 100vw);
	}
	.btn__medical02 .txt {
		font-size: calc(40 / var(--break) * 100vw);
	}
	.btn__medical02 .en {
		font-size: calc(24 / var(--break) * 100vw);
		letter-spacing: .1em;
	}
	.btn__medical02 .ja {
		font-size: calc(26 / var(--break) * 100vw);
	}
	.btn__medical02 a {
		background: url(images/index/bg_medical02_sp.png) no-repeat center / cover;
		outline-offset: calc(-10 / var(--break) * 100vw);
		outline: #fff solid 1px;
		padding: calc(41 / var(--break) * 100vw) 0 calc(92 / var(--break) * 100vw);
	}
	.btn__medical02 a::before {
		width: calc(50 / var(--break) * 100vw);
		height: calc(6 / var(--break) * 100vw);
		top: auto;
		bottom: 5vw;
		margin: auto;
		left: 0;
		right: 0;
	}
	.btn__medical02 a::before {
        width: calc(50 / var(--break) * 100vw);
        height: calc(10 / var(--break) * 100vw);
        top: auto;
        bottom: 8vw;
        margin: auto;
        left: 0;
        right: 0;
    }
}

/* message
------------------------------------------------------------------*/
.box__message01 {
	padding: calc(80 / var(--break) * 100vw) 0 calc(0 / var(--break) * 100vw);
}
.box__message01::before {
	content: "";
    position: absolute;
	background: #f2f2f2;
    width: 100%;
    height: 71%;
	right: 0;
	left: 0;
	top: 0;
	margin: auto;
	z-index: -1;
}
.box__message01 .wrap {
	width: 90%;
	max-width: 1500px;
}
.row__message01 .col_img {
	width: 23%;
	max-width: 350px;
}
.row__message01 .col_txt {
	width: 70%;
}
.row__message01 .col_txt > .txt {
	padding-bottom: calc(58 / var(--break) * 100vw);
    margin-bottom: calc(22 / var(--break) * 100vw);
}
.row__message02 .ccl {
	width: calc(50 / var(--break) * 100vw);
	height: calc(50 / var(--break) * 100vw);
}
.move__message01 {
	width: 90%;
	max-width: 1240px;
}
@media(min-width: 768px) and (max-width:1599px) {

}
@media(min-width: 768px) and (max-width:1299px) {

}
@media(max-width: 767px) {
	.index_message {
		margin-bottom: 12.5vw;
	}
	.box__message01 .en {
		font-size: calc(100 / var(--break) * 100vw);
	}
	.box__message01::before {
		width: 100%;
		height: 100%;
	}
	.box__message01 .wrap {
		width: 100%;
		max-width: calc(700 / var(--break) * 100vw);
	}
	.row__message01 .col_img {
		width: 100%;
		max-width: calc(350 / var(--break) * 100vw);
		margin: 0 auto 7vw;
	}
	.row__message01 .col_txt {
		width: 89%;
		margin-left: auto;
		margin-right: auto;
	}
	.row__message01 .col_txt .copy {
		font-size: calc(40 / var(--break) * 100vw);
		letter-spacing: 0;
		margin-bottom: 4vw;
	}
	.row__message01 .col_txt > .txt {
		padding-bottom: calc(43 / var(--break) * 100vw);
		margin-bottom: calc(18 / var(--break) * 100vw);
	}
	.row__message02 .ccl {
		width: calc(50 / var(--break) * 100vw);
		height: calc(50 / var(--break) * 100vw);
	}
	.row__message02 .ccl .txt_white {
		font-size: calc(20 / var(--break) * 100vw);
	}
	.row__message02 .ja {
		font-size: calc(40 / var(--break) * 100vw);
	}
	.row__message02 .en {
		font-size: calc(20 / var(--break) * 100vw);
	}
	.move__message01 {
        width: 100%;
        max-width: calc(702 / var(--break) * 100vw);
    }
	.box__message01 {
		padding: calc(110 / var(--break) * 100vw) 0 calc(0 / var(--break) * 100vw);
	}
}

/* youtube
------------------------------------------------------------------*/
.index_youtube {
	
}
.box__youtube01 {
	width: 95%;
	max-width: 1770px;
}
.box__youtube01 .en {
	font-size: calc(160 / var(--break) * 100vw);
    top: calc(-10 / var(--break) * 100vw);
    left: 6%;
    line-height: .8;
    letter-spacing: .1em;
}
.slide__youtube01 {
	width: 90%;
	max-width: calc(1360 / var(--break) * 100vw);
}
.slide__youtube01 .slick-prev {
	background: url("images/page/arw05.svg")no-repeat center / cover;
	width: calc(61 / var(--break) * 100vw);
	height: calc(61 / var(--break) * 100vw);
	transform: translate(0);
	top: 0;
	bottom: 0;
	margin: auto;
	left: -5.8%;
	z-index: 1;
}
.slide__youtube01 .slick-next {
	background: url("images/page/arw05.svg")no-repeat center / cover;
	width: calc(61 / var(--break) * 100vw);
	height: calc(61 / var(--break) * 100vw);
	right: -5.8%;
	transform: translate(0) scaleX(-1);
	top: 0;
	bottom: 0;
	margin: auto;
	z-index: 1;
}
.slide__youtube01 .slick-prev:before, .slide__youtube01 .slick-next:before {
	display: none;
}
.slide__youtube01 .slick-list {
	padding: 0!important;
}
.slide__youtube01 li {
	padding: 0 calc(15 / var(--break) * 100vw);
}

.slide__youtube01 li iframe,
.slide__youtube01 li .yt-thumb{
  width: calc(432 / var(--break) * 100vw) !important;
  height: calc(243 / var(--break) * 100vw);
  display: block;
margin-left: auto;
margin-right: auto;
}

.yt-frame{
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
}
.yt-frame iframe{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
@media(min-width: 768px) and (max-width:1599px) {

}
@media(min-width: 768px) and (max-width:1299px) {
	.slide__youtube01 li iframe, .slide__youtube01 li .yt-thumb {
		width: calc(330 / var(--break) * 100vw) !important;
		height: calc(185 / var(--break) * 100vw);
	}
}
@media(max-width: 767px) {
	.index_youtube {
		margin-bottom: 5.5vw;
	}
	.box__youtube01 {
		width: 100%;
		max-width: calc(702 / var(--break) * 100vw);
		padding: 17vw 0 13vw;
	}
	.box__youtube01 .en {
    	font-size: calc(120 / var(--break) * 100vw);
		top: calc(-10 / var(--break) * 100vw);
		left: 0;
		right: 0;
		margin: auto;
		text-align: center;
	}
	.slide__youtube01 {
        width: 100%;
        max-width: calc(646 / 750 * 100vw);
    }
	.slide__youtube01 .slick-prev {
		left: -2.8%;
	}
	.slide__youtube01 .slick-next {
		right: -2.8%;
	}
	.slide__youtube01 li iframe, .slide__youtube01 li .yt-thumb {
		width: calc(646 / var(--break) * 100vw) !important;
		height: calc(363 / var(--break) * 100vw);
	}
	.slide__youtube01 li {
		padding: 0 calc(0 / var(--break) * 100vw);
	}
}

/* Topics index_topics
------------------------------------------------------------------*/
.box__topics .unit h2 .en {
	line-height: 0.8;
}
.box__topics .unit h2 .link {
	width: calc(100 / var(--break) * 100vw);
	height: calc(40 / var(--break) * 100vw);
	font-weight: 300;
}
.box__topics .unit h2 .link::before {
	content: "";
	position: absolute;
	width: calc(6 / var(--break) * 100vw);
	height: calc(6 / var(--break) * 100vw);
	border-bottom: 1px solid #fff;
	border-right: 1px solid #fff;
	transform: rotate(-45deg);
	right: calc(10 / var(--break) * 100vw);
	top: 0;
	bottom: 0;
	margin: auto;
}
.box__topics .unit h2 .link span {
	margin-bottom: 0.1em;
}
.box__topics .unit ul li {
	width: 32%;
	box-shadow: 0 0 20px rgba(150, 110, 70, 0.1),0 0 20px rgba(150, 110, 70, 0.1);
}
.box__topics .unit ul li a {
	padding: calc(40 / var(--break) * 100vw) calc(38 / var(--break) * 100vw) calc(40 / var(--break) * 100vw);
}
.box__topics .unit ul li dl {
	width: calc(100% - (140 / var(--break) * 100vw));
}
.box__topics .unit ul li dl dt h4 {
	margin: 0.6em 0 0.4em;
	font-weight: 300;
	text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}
.box__topics .unit ul li dl dd {
	line-height: 1.67;
}
.row__bnr01 .col {
	width: 32%;
}
.row__bnr01 .col a {
	height: calc(140 / var(--break) * 100vw);
	padding: 0 calc(30 / var(--break) * 100vw) 0 calc(40 / var(--break) * 100vw);
}
.row__bnr01 .col01 a {
	background: url("images/index/bg_bnr01.png") no-repeat center / cover;
}
.row__bnr01 .col02 a {
	background: url("images/index/bg_bnr02.png") no-repeat center / cover;
}
.row__bnr01 .col03 a {
	background: url("images/index/bg_bnr03.png") no-repeat center / cover;
}
.row__bnr01 .col a::before {
	content: "";
    position: absolute;
    background: url(images/page/arw03.svg) no-repeat center / cover;
    width: calc(30 / var(--break) * 100vw);
    height: calc(6 / var(--break) * 100vw);
    top: 0;
    bottom: 0;
    margin: auto;
    right: calc(40 / var(--break) * 100vw);
    transition: .3s;
    z-index: 2;
}
.row__bnr01 .col .icn {
	width: calc(50 / var(--break) * 100vw);
	margin-right: calc(30 / var(--break) * 100vw);
}
@media(min-width: 767px) {
	.row__bnr01 .col a:hover::before {
		right: calc(30 / var(--break) * 100vw);
		transition: .3s;
	}
}
@media(min-width: 768px) and (max-width:1599px) {

}
@media(min-width: 768px) and (max-width:1299px) {

}
@media(max-width: 767px) {
	.index_topics {
		padding: calc(0 / var(--break) * 100vw) 0;
	}
	.box__topics {
		padding-top: 8vw;
	}
	.box__topics .unit {
		max-width: calc(702 / var(--break) * 100vw);
		width: 100%;
	}
	.box__topics .unit h2 {
		margin-bottom: 8vw;
		flex-direction: column;
	}
	.box__topics .unit h2 .en {
		font-size: calc(80 / var(--break) * 100vw);
        margin-right: 0;
        margin-bottom: 4vw;
	}
	.box__topics .unit h2 .ja {
		font-size: calc(32 / var(--break) * 100vw);
        margin-right: 0;
        letter-spacing: 0;
        margin-bottom: 3.5vw;
	}
	.box__topics .unit h2 .link {
		top: 0vw;
		width: calc(200 / var(--break) * 100vw);
		height: calc(80 / var(--break) * 100vw);
		font-size: calc(32 / var(--break) * 100vw);
	}
	.box__topics .unit h2 .link::before {
		width: calc(10 / var(--break) * 100vw);
		height: calc(10 / var(--break) * 100vw);
		right: calc(22 / var(--break) * 100vw);
	}
	.box__topics .unit ul {
		gap: calc(20 / var(--break) * 100vw) 0;
	}
	.box__topics .unit ul li {
		width: 100%;
	}
	.box__topics .unit ul li a {
		padding: calc(35 / var(--break) * 100vw) calc(32 / var(--break) * 100vw) calc(35 / var(--break) * 100vw);
		align-items: center;
	}
	.box__topics .unit ul li .thmb {
		width: calc(180 / var(--break) * 100vw);
	}
	.box__topics .unit ul li .thmb img {
		height: calc(180 / var(--break) * 100vw);
	}
	.box__topics .unit ul li dl {
		width: calc(100% - (210 / var(--break) * 100vw));
	}
	.box__topics .unit ul li dl dt .date {
		font-size: calc(28 / var(--break) * 100vw);
	}
	.box__topics .unit ul li dl dt h4 {
		margin: 2.4vw 0 1.2vw;
		font-size: calc(34 / var(--break) * 100vw);
		letter-spacing: 0;
	}
	.box__topics .unit ul li dl dd {
		line-height: 1.56;
	}
	.box__topics .unit ul li dl dd .txt_link {
		font-size: 1rem;
		letter-spacing: 0;
	}
	.row__bnr01 .col {
		width: 100%;
	}
	.row__bnr01 .col:nth-child(n+2) {
		margin-top: calc(20 / var(--break) * 100vw);
	}
	.row__bnr01 .col .icn {
		width: calc(80 / var(--break) * 100vw);
		margin-right: calc(30 / var(--break) * 100vw);
	}
	.row__bnr01 .col .txt {
		width: calc(40 / var(--break) * 100vw);
	}
	.row__bnr01 .col a {
		height: calc(175 / var(--break) * 100vw);
		padding: 0 calc(30 / var(--break) * 100vw) 0 calc(50 / var(--break) * 100vw);
	}
	.row__bnr01 .col a::before {
		width: calc(50 / var(--break) * 100vw);
		height: calc(10 / var(--break) * 100vw);
	}
	.row__bnr01 {
		width: 100%;
		max-width: calc(600 / var(--break) * 100vw);
		margin-left: auto;
		margin-right: auto;
	}
}

/* index_instagram
------------------------------------------------------------------*/
.index_instagram {
	margin-bottom: calc(300 / var(--break) * 100vw);
}
.wrap_instagram #sb_instagram {
	padding: 0!important;
}
.wrap_instagram #sb_instagram #sbi_images {
	padding: 0!important;
	gap: calc(20 / var(--break) * 100vw)!important;
}
.btn_instagram {
	right: 0;
	left: 0;
	top: 0;
	bottom: 0;
	width: calc(100 / var(--break) * 100vw);
	height: calc(100 / var(--break) * 100vw);
	margin: auto;
}
@media(min-width: 768px) and (max-width:1599px) {
	
}
@media(min-width: 768px) and (max-width:1299px) {
	
}
@media(max-width: 767px) {
	.index_instagram {
		margin-bottom: calc(100 / var(--break) * 100vw);
	}
	.ttl_instagram01 {
		font-size: 1rem;
		letter-spacing: .1em;
		margin-bottom: 6vw;
	}
	.wrap_instagram #sb_instagram #sbi_images {
		gap: calc(10 / var(--break) * 100vw)!important;
	}
}

/* rectuit
------------------------------------------------------------------*/
.index_rectuit::before {
    content: "";
    position: absolute;
    background: #f2f2f2;
    width: 90%;
    max-width: calc(1580 / var(--break) * 100vw);
    height: 100%;
    top: 0;
    bottom: 0;
    margin: auto;
    left: 0;
}
.img__rectuit01 {
	width: 53%;
	max-width: 1000px;
	right: 0;
	top: calc(-100 / var(--break) * 100vw);
}
.box__rectuit01 {
	padding: calc(83 / var(--break) * 100vw) 0 calc(100 / var(--break) * 100vw);
}
@media(min-width: 768px) and (max-width:1599px) {

}
@media(min-width: 768px) and (max-width:1299px) {

}
@media(max-width: 767px) {
	.index_rectuit {
		margin-bottom: 14vw;
	}
	.index_rectuit::before {
		background: #f2f2f2;
		width: 100%;
		max-width: 100%;
		height: 69%;
		top: 0;
		bottom: 0;
		margin: auto;
		left: 0;
	}
	.box__rectuit01 {
		padding: calc(42 / var(--break) * 100vw) 0 calc(100 / var(--break) * 100vw);
	}
	.box__rectuit01 .en {
		font-size: calc(100 / var(--break) * 100vw);
        position: relative;
        transform: none;
        -webkit-transform: none;
        text-align: center;
        margin-bottom: 4vw;
	}
	.box__rectuit01 .txt {
		font-size: calc(32 / var(--break) * 100vw);
        text-align: center;
        letter-spacing: 0;
	}
	.img__rectuit01 {
        width: 100%;
        max-width: calc(700 / var(--break) * 100vw);
        right: 0;
        left: 0;
        margin: auto;
        top: 0;
        position: relative;
    }
	.btn__rectuit01 {
		margin-left: auto;
    	margin-right: auto;
	}
}


/* フッター footer
------------------------------------------------------------------*/
.bg_foot01 {
	padding-top: calc(300 / var(--break) * 100vw);
	margin-bottom: calc(95 / var(--break) * 100vw);
}
.bg_foot01::before {
	content: "";
    position: absolute;
	background: url("images/page/bg_foot01.png") no-repeat center / cover;
    width: 100%;
    height: calc(500 / var(--break) * 100vw);
	right: 0;
	left: 0;
	top: 0;
	margin: auto;
	z-index: -1;
}
.box_foot01 {
	padding: calc(100 / var(--break) * 100vw) 0 calc(0 / var(--break) * 100vw);
}
.row_foot01 {
	width: 90%;
	max-width: 1150px;
}
.row_foot01 > .col_l {
	width: 46%;
}
.logo_foot {
	width: calc(340 / var(--break) * 100vw);
}
.add_foot .icn {
	width: calc(20 / var(--break) * 100vw);
}
.row_foot01 > .col_r {
	width: 47%;
	max-width: 530px;
}
.tbl_time02 .box {
    background: #f2f2f2;
}
.tbl_time02 table {
    color: #333333;
}
.tbl_time02 thead th {
    border-bottom: 1px solid #333333;
}
.tbl_time02 tbody th, .tbl_time02 tbody td {
    vertical-align: top;
}
.tbl_time02 tbody td .deco {
    font-size: calc(10 / var(--break) * 100vw);
}
.tbl_time02 tbody tr:first-child th {
    padding-left: 0;
}
.tbl_time02 tbody th, .tbl_time02 tbody td {
    padding: calc(20 / var(--break) * 100vw) 0 calc(11 / var(--break) * 100vw);
    line-height: 1;
}
.tbl_time02 tbody tr:last-child th, .tbl_time02 tbody tr:last-child td {
    padding: calc(3 / var(--break) * 100vw) 0 calc(19 / var(--break) * 100vw);
}
.tbl_time02 tbody tr:first-child th {
    padding-left: .6em;
}
.tbl_caption {
	margin-top: calc(10 / var(--break) * 100vw);
    line-height: 1.6;
}
.row_foot03 {
	width: 95%;
	max-width: 1820px;
}
.row_foot03 .col_l {
	width: 59%;
}
.row_foot03 .col_r {
	width: 38%;
}
.fc .fc-button-primary:disabled {
    background-color: #c0c0c0!important;
    border-color: #c0c0c0!important;
}
.fc .fc-button-primary {
    background-color: #c0c0c0 !important;
    border-color: #c0c0c0 !important;
}
.fc-col-header-cell .fc-scrollgrid-sync-inner {
	background-color: #666666;
	color: #fff;
}
.fc-theme-standard td, .fc-theme-standard th {
    border: 1px solid #d8d8d8;
    border: 1px solid var(--fc-border-color, #d8d8d8);
}
.fc .fc-scrollgrid-section > td {
    border-right: 1px solid #ddd;
}
.fc-toolbar-chunk {
	display: flex;
    align-items: center;
}
.fc .fc-toolbar-title {
    font-size: 1em!important;
}
.fullcalendar {
	width: 86%;
    margin-left: auto;
    margin-right: auto;
}
.main_foot02 {
	position: relative;
    z-index: 0;
	padding-top: calc(90 / var(--break) * 100vw);
	padding-bottom: calc(70 / var(--break) * 100vw);
}
.row_footer_sitemap>.col_l {
	max-width: 380px;
	width: 31%;
}
.row_footer_sitemap>.col_r {
	max-width: 789px;
    width: 64%;
}
.ttl_foot01 {
	position: relative;
}
.ttl_foot01::before {
	content: "";
    position: absolute;
	background: #c0c0c0;
    width: 100%;
    height: calc(1 / var(--break) * 100vw);
	top: 0;
	bottom: 0;
	margin: auto;
	right: 0;
	left: 0;
	z-index: -1;
}
.list_sitemap.list_default li {
	padding-left: calc(18 / var(--break) * 100vw);
}
.list_sitemap.list_default li::before {
    content: "";
    position: absolute;
	background: #ababab;
    width: calc(10 / var(--break) * 100vw);
    height: calc(1 / var(--break) * 100vw);
	top: calc(13 / var(--break) * 100vw);
    left: calc(0 / var(--break) * 100vw);
}
.list_sitemap li:nth-of-type(n + 2) {
	margin-top: calc(13 / var(--break) * 100vw) !important;
}
.list_sitemap.list_default.ptn02 li {
	width: 50%;
}
.list_sitemap.list_default.ptn02 li:nth-child(2) {
	margin-top: 0 !important;
}
.row_foot04 .col {
	width: 48%;
}
.pagetop {
	position: fixed;
	right: calc(30 / var(--break) * 100vw);
	bottom: calc(30 / var(--break) * 100vw);
	z-index: 1000;
	width: calc(34 / var(--break) * 100vw);
}
.copyright {
	height: calc(80 / var(--break) * 100vw);
}
@media(min-width: 768px) and (max-width:1599px) {
}
@media(min-width: 768px) and (max-width:1299px) {
	.tel_foot {
		width: calc(255 / var(--break) * 100vw);
	}
	.web_foot {
		width: calc(205 / var(--break) * 100vw);
	}
	.tbl_caption {
		font-size: 1rem;
	}
}
@media(max-width: 767px) {
	.bg_foot01 {
		padding-top: calc(300 / var(--break) * 100vw);
		margin-bottom: calc(75 / var(--break) * 100vw);
	}
	.bg_foot01::before {
		background: url(images/page/bg_foot01_sp.png) no-repeat center / cover;
		height: calc(400 / var(--break) * 100vw);
	}
	.box_foot01 {
		padding: calc(100 / var(--break) * 100vw) 0 calc(0 / var(--break) * 100vw);
		width: 100%;
		max-width: calc(702 / var(--break) * 100vw);
		margin-left: auto;
		margin-right: auto;
	}
	.logo_foot {
		width: calc(340 / var(--break) * 100vw);
		margin-bottom: 6vw;
	}
	.add_foot .icn {
		width: calc(30 / var(--break) * 100vw);
	}
	.row_foot02  {
		width: 100%;
		max-width: calc(500 / var(--break) * 100vw);
		margin-left: auto;
		margin-right: auto;
	}
	.tel_foot {
		width: 100%;
		margin-bottom: calc(20 / var(--break) * 100vw);
	}
	.tel_foot a {
		height: calc(120 / var(--break) * 100vw);
	}
	.tel_foot .en {
		font-size: calc(28 / var(--break) * 100vw);
	}
	.tel_foot .en .num {
		font-size: calc(46 / var(--break) * 100vw);
	}
	.web_foot {
		width: 100%;
	}
	.web_foot a {
		height: calc(120 / var(--break) * 100vw);
	}
	.web_foot .icn {
		width: calc(40 / var(--break) * 100vw);
		margin-right: 4vw;
	}
	.web_foot .ja {
		font-size: calc(32 / var(--break) * 100vw);
		margin-right: 4vw;
	}
	.web_foot .arw {
		width: calc(40 / var(--break) * 100vw);
	}
	.row_foot01 {
		display: block;
	}
	.row_foot01 {
		width: 100%;
		max-width: 100%;
	}
	.row_foot01 > .col_l {
		width: 100%;
		max-width: 100%;
		text-align: center;
		margin-bottom: 8vw;
	}
	.row_foot01 > .col_r {
		width: 100%;
		max-width: 100%;
		margin: 0 auto;
	}
	.tbl_time02 tbody th, .tbl_time02 tbody td {
		padding: calc(24 / var(--break) * 100vw) 0 calc(20 / var(--break) * 100vw);
	}
	.tbl_time02 tbody td .deco {
		font-size: calc(20 / var(--break) * 100vw);
		margin-top: calc(8 / var(--break) * 100vw);
		margin-left: calc(2 / var(--break) * 100vw);
		display: block;
	}
	.tbl_time02 tbody tr:first-child th {
		padding-left: 0;
	}
	.tbl_time .tbl_caption {
        font-size: calc(27 / var(--break) * 100vw);
        letter-spacing: 0;
        margin-top: 3vw;
        line-height: 1.6;
    }
	.row_foot03 {
        margin-bottom: 8vw;
    }
	.row_foot03 {
		width: 100%;
		max-width: calc(702 / var(--break) * 100vw);
	}
	.row_foot03 .col_l {
		width: 100%;
		order: 2;
	}
	.row_foot03 .col_r {
		width: 100%;
		order: 1;
		margin-bottom: calc(100 / var(--break) * 100vw);
	}
	.row_footer_sitemap>.col_l {
		max-width: 100%;
		width: 100%;
		margin-bottom: 6vw;
	}
	.row_footer_sitemap>.col_r {
		max-width: 100%;
		width: 100%;
	}
	.ttl_foot01 {
		text-align: center;
		font-size: calc(40 / var(--break) * 100vw);
		border-bottom: solid 1px #c0c0c0;
		padding-bottom: 1vw;
        margin-bottom: 4vw;
	}
	.ttl_foot01 .bg_col02 {
		padding-right: 0;
	}
	.ttl_foot01::before {
		display: none;
	}
	.main_foot02 {
		padding-top: calc(44 / var(--break) * 100vw);
		padding-bottom: calc(70 / var(--break) * 100vw);
	}
	.list_sitemap {
		font-size: calc(26 / var(--break) * 100vw);
	}
	.list_sitemap.list_default li {
		padding-left: calc(70 / var(--break) * 100vw);
	}
	.list_sitemap li:nth-of-type(n + 2) {
		margin-top: calc(21 / var(--break) * 100vw) !important;
	}
	.list_sitemap.list_default li::before {
		width: calc(20 / var(--break) * 100vw);
		height: calc(1 / var(--break) * 100vw);
		top: calc(16 / var(--break) * 100vw);
		left: calc(31 / var(--break) * 100vw);
	}
	.list_sitemap.list_default.w50 li {
		width: 100%;
	}
	.list_sitemap.list_default.w50 li:nth-child(2) {
		margin-top: calc(21 / var(--break) * 100vw) !important;
	}
	.list_sitemap.w50 li:nth-child(1) { order: 1; }
	.list_sitemap.w50 li:nth-child(2) { order: 6; }
	.list_sitemap.w50 li:nth-child(3) { order: 2; }
	.list_sitemap.w50 li:nth-child(4) { order: 7; }
	.list_sitemap.w50 li:nth-child(5) { order: 3; }
	.list_sitemap.w50 li:nth-child(6) { order: 8; }
	.list_sitemap.w50 li:nth-child(7) { order: 4; }
	.list_sitemap.w50 li:nth-child(8) { order: 9; }
	.list_sitemap.w50 li:nth-child(9) { order: 5; }
	.list_sitemap.w50 li:nth-child(10){ order: 10; }
	.row_foot04 .col {
		width: 100%;
		max-width: calc(600 / var(--break) * 100vw);
		margin-left: auto;
		margin-right: auto;
	}
	.row_foot04 .col:nth-child(n+2) {
		margin-top: calc(20 / var(--break) * 100vw);
	}
	.copyright {
		font-size: 75%;
		padding: 4vw 0 20vw;
		height: auto;
	}
	.pagetop {
		display: none!important;
	}
	.fix {
		position: fixed;
		width: 100%;
		left: 0;
		bottom: 0;
		z-index: 9;
	}
	.fix_tel {
		width: calc(330 / var(--break) * 100dvw);
	}
	.fix_web {
		width: calc(300 / var(--break) * 100dvw);
	}
	.pagetop_sp {
		width: calc(120 / var(--break) * 100dvw);
	}
	.fix a {
		display: block;
	}
}

/* グーグルマップ
------------------------------------------------------------------*/
.map {
	position: relative;
	width: 100%;
	padding: 500px 0 0 0;
	overflow: hidden;
}
.map iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	margin-top: calc(-170 / var(--break) * 100vw);
	height: calc(100% + calc(340 / var(--break) * 100vw));
}
.btn_map {
	width: calc(300 / var(--break) * 100vw);
	font-size: 1.25rem;
	letter-spacing: .1em;
	left: calc(30 / var(--break) * 100vw);
	top: calc(30 / var(--break) * 100vw);
	z-index: 1;
}
.btn_map a {
	display: block;
    text-align: center;
}
.btn_map a .bg {
	width: 100%;
    height: 100%;
    display: block;
    padding: calc(10 / var(--break) * 100vw) 0 calc(10 / var(--break) * 100vw);
}
.btn_map a .bg::before {
    content: "";
    position: absolute;
    background: url(images/page/icn_map.svg) no-repeat center / cover;
    width: calc(20 / var(--break) * 100vw);
    height: calc(20 / var(--break) * 100vw);
    top: 0;
    bottom: 0;
    margin: auto;
    left: calc(28 / var(--break) * 100vw);
    transition: .3s;
    z-index: 2;
}
.btn_map a:hover .bg::before {
	background: url(images/page/icn_map02.svg) no-repeat center / cover;
	transition: .3s;
}
@media(min-width: 768px) and (max-width:1599px) {
}
@media(min-width: 768px) and (max-width:1299px) {
	.map iframe {
		margin-top: calc(-280 / var(--break) * 100vw);
		height: calc(100% + calc(560 / var(--break) * 100vw));
	}
	.map {
		padding: 300px 0 0 0;
	}
	.row_foot03 .col_r iframe {
		height: 300px;
	}
	.row_foot03 .col_l {
		width: 50%;
	}
	.row_foot03 .col_r {
		width: 48%;
	}
}
@media(max-width: 767px) {
	.map iframe {
		margin-top: calc(-200 / var(--break) * 100vw);
		height: calc(100% + calc(400 / var(--break) * 100vw));
	}
	.btn_map {
		width: calc(600 / var(--break) * 100vw);
		margin: 0 auto calc(60 / var(--break) * 100vw);
		letter-spacing: 0;
		position: relative;
		left: auto;
		top: auto;
	}
	.btn_map a {
		padding: 0;
		background-position: left 3vw center;
		background-size: calc(40 / var(--break) * 100vw) auto;
	}
	.btn_map a .bg {
		padding: calc(12 / var(--break) * 100vw) 0 calc(13 / var(--break) * 100vw);
	}
	.btn_map a .bg::before {
		width: calc(40 / var(--break) * 100vw);
		height: calc(40 / var(--break) * 100vw);
		background: url(images/page/icn_map02.svg) no-repeat center / cover;
	}
	.btn_map a span {
		font-size: calc(34 / var(--break) * 100vw);
	}
}