@charset "utf-8";
/*
Theme Name: res
Version: 1.5.0
Author: T8,Inc.
*/
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:300,400,700&display=swap');
:root {
	--break: 1920;
	--guideline-color: #db759e;
	font-size: calc(16 / var(--break) * 100vw);
	--color01: #00654d;
	--color02: #db759e;
	--color03: #9a77bd;
	--color04: #59a5c6;
	--color05: #ebc36c;
	--color06: #e47367;
	--color07: #5bd183;
	--color08: #4fb06d;
	--color09: #faf8eb;
	--color10: #fff6e4;
	--color11: #002018;
	--color12: #ffffff;
	--color13: #e3e8e0;
	--color14: #f3f2ea;
	--color15: #06c755;
	--color16: #fafff6;
	--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: #db759e;
	text-decoration: underline;
	text-underline-offset: 0.5em;
}
.maru_m {
	font-family: "vdl-v7marugothic", sans-serif;
	font-weight: 500;
	font-style: normal;
}
.maru_b {
	font-family: "vdl-v7marugothic", sans-serif;
	font-weight: 700;
	font-style: normal;
}
.work_r {
	font-family: "work-sans", sans-serif;
	font-weight: 400;
	font-style: normal;
}
.work_b {
	font-family: "work-sans", sans-serif;
	font-weight: 700;
	font-style: normal;
}
.sichandich_r {
	font-family: "sichandich", sans-serif;
	font-weight: 400;
	font-style: normal;
}
.sictake_r {
	font-family: "sictake-yurari", sans-serif;
	font-weight: 400;
	font-style: normal;
}
/*ここまで*/
html, body {
	font-size: 1.125rem;
	font-weight: 300;
	line-height: 2;
	color: #002018;
	letter-spacing: .1em;
	font-family: "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.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,.inner1600
{
	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;
}
.inner1600 {
	max-width: 1600px;
}
.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); }
.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_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,.inner1600 {
		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;
	padding: calc(30 / var(--break) * 100vw) calc(40 / var(--break) * 100vw);
}
header h1 {
	max-width: calc(772 / var(--break) * 100vw);
	width: 42%;
}
header h1 a,
header h1 a img {
	display: block;
	width: 100%;
}
.row_head {
	width: 58%;
}
.row_head .address_head {
	margin: calc(13 / var(--break) * 100vw) 0 calc(-4 / var(--break) * 100vw);
	padding: calc(9 / var(--break) * 100vw) calc(16 / var(--break) * 100vw) 0;
	border-top: 2px solid var(--color11);
	white-space: nowrap;
}
.row_head .web_head {
	width: calc(310 / var(--break) * 100vw);
	height: calc(80 / var(--break) * 100vw);
	margin: 0 calc(30 / var(--break) * 100vw) 0 calc(25 / var(--break) * 100vw);
}
.row_head .web_head a {
	position: relative;
	width: 100%;
	height: 100%;
	border-radius: 100px;
	border-bottom-left-radius: 0;
	border: 1px solid var(--color11);
}
.row_head .web_head a:after {
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: calc(20 / var(--break) * 100vw);
	width: calc(8 / var(--break) * 100vw);
	height: calc(8 / var(--break) * 100vw);
	margin: auto;
	border-radius: 100%;
	background: var(--color01);
	content: '';
}
.row_head .web_head a .icn {
	width: calc(31 / var(--break) * 100vw);
	margin: 0 calc(19 / var(--break) * 100vw) 0 calc(3 / var(--break) * 100vw);
}
.row_head .line_head {
	width: calc(80 / var(--break) * 100vw);
	height: calc(80 / var(--break) * 100vw);
}
.row_head .line_head a {
	width: 100%;
	height: 100%;
}
.row_head .line_head a .icn {
	width: calc(45 / var(--break) * 100vw);
}
@media(min-width: 768px) and (max-width:1599px) {
	header h1 {
		width: 38%;
	}
	.row_head {
		width: 60%;
	}

}
@media(min-width: 768px) and (max-width:1299px) {
	.row_head .address_head {
		font-size: calc(14 / var(--break) * 100vw);
	}
	.row_head .tel_head a .tel {
		font-size: calc(19 / var(--break) * 100vw);
	}
	.row_head .tel_head a .tel em {
		font-size: calc(29 / var(--break) * 100vw);
	}
	.row_head .web_head {
		width: calc(248 / var(--break) * 100vw);
		height: calc(64 / var(--break) * 100vw);
	}
	.row_head .web_head a .icn {
		width: calc(24 / var(--break) * 100vw);
	}
	.row_head .web_head a .web {
		font-size: calc(22 / var(--break) * 100vw);
	}
	.row_head .line_head {
		width: calc(64 / var(--break) * 100vw);
		height: calc(64 / var(--break) * 100vw);
	}
	.row_head .line_head a .icn {
		width: calc(36 / var(--break) * 100vw);
	}

}
@media(max-width: 767px) {
	header {
		padding: calc(24 / var(--break) * 100vw);
	}
	header h1 {
		max-width: calc(544 / var(--break) * 100vw);
		width: 100%;
	}
	.row_head {
		display: none;
	}

}


/* メインイメージ main_img
------------------------------------------------------------------*/
.main_img {
	position: relative;
}
.main_img .slide_main {
	opacity: 0;
	transition: opacity .3s linear;
	pointer-events: none;
}
.main_img .slide_main.slick-initialized {
	opacity: 1;
}
.main_img .slide_main li {
	min-height: calc(500 / var(--break) * 100vw);
	height: calc(100vh - (200 / var(--break) * 100vw));
}
.main_img.tab .slide_main li {
	height: auto;
}
.main01 {
	background: url(images/index/main01.jpg) no-repeat center / cover;
}
.catch_main {
	top: 50%;
	right: 7.8%;
	transform: translateY(-50%);
	width: calc(745 / var(--break) * 100vw);
	height: calc(495 / var(--break) * 100vw);
	background: url(images/index/shape_main01.svg) no-repeat center / contain;
}
.catch_main .deco01 {
	top: calc(-10 / var(--break) * 100vw);
	left: -4%;
	max-width: 146px;
	width: 20%;
}
.catch_main .deco02 {
	top: calc(56 / var(--break) * 100vw);
	right: -6.7%;
	max-width: 82px;
	width: 12%;
}
.catch_main .catch {
	width: calc(385 / var(--break) * 100vw);
	margin-bottom: calc(22 / var(--break) * 100vw);
}
.catch_main .txt {
	font-size: calc(32.5 / var(--break) * 100vw);
	letter-spacing: 0.1em;
	line-height: 2.48;
}
.catch_main .txt span {
	display: inline-block;
	text-decoration: underline;
	text-underline-offset: 0.7em;
}
.box_main {
	bottom: calc(40 / var(--break) * 100vw);
	left: 3.1%;
}
.box_main .col_box {
	position: relative;
	width: calc(250 / var(--break) * 100vw);
	height: calc(250 / var(--break) * 100vw);
	padding-top: calc(127 / var(--break) * 100vw);
	border-bottom-left-radius: 0;
}
.box_main .col_r {
	margin-top: calc(160 / var(--break) * 100vw);
	margin-left: calc(-30 / var(--break) * 100vw);
}
.box_main .col_box .deco01 {
	top: calc(-33 / var(--break) * 100vw);
	left: 50%;
	transform: translateX(-50%);
	max-width: 190px;
	width: 76%;
}
.box_main .col_box .deco02 {
	top: calc(-41 / var(--break) * 100vw);
	left: 50%;
	transform: translateX(-50%);
	max-width: 122px;
	width: 49%;
}
.box_main .col_box .txt {
	font-size: calc(22 / var(--break) * 100vw);
	letter-spacing: 0;
	line-height: 1.45;
}
@media(min-width: 768px) and (max-width:1599px) {

}
@media(min-width: 768px) and (max-width:1299px) {
	.catch_main {
		transform: translateY(-50%) scale(0.8);
		transform-origin: right center;
	}
	.box_main {
		transform: scale(0.8);
		transform-origin: left bottom;
	}

}
@media only screen and (max-width: 767px) {
	.main_img .slide_main li,
	.main_img.tab .slide_main li {
		max-height: calc(934 / var(--break) * 100vw);
		min-height: calc(900 / var(--break) * 100vw);
		height: calc(100svh - calc(120 / var(--break) * 100vw));
	}
	.main01 {
		background: url(images/index/main01_sp.jpg) no-repeat center / cover;
	}
	.catch_main {
		top: calc(50 / var(--break) * 100vw);
		left: 50%;
		right: auto;
		transform: translate(-50%,0);
		width: calc(671 / var(--break) * 100vw);
		height: calc(446 / var(--break) * 100vw);
	}
	.catch_main .deco01 {
		top: calc(-9 / var(--break) * 100vw);
		left: calc(-16 / var(--break) * 100vw);
		max-width: calc(132 / var(--break) * 100vw);
		width: 100%;
	}
	.catch_main .deco02 {
		top: calc(50 / var(--break) * 100vw);
		right: calc(-15 / var(--break) * 100vw);
		max-width: calc(74 / var(--break) * 100vw);
		width: 100%;
	}
	.catch_main .catch {
		width: calc(346 / var(--break) * 100vw);
	}
	.catch_main .txt {
		font-size: calc(28 / var(--break) * 100vw);
		letter-spacing: 0;
		line-height: 2.59;
	}
	.box_main {
		bottom: calc(22 / var(--break) * 100vw);
		left: calc(23 / var(--break) * 100vw);
	}
	.box_main .col_box {
		width: calc(225 / var(--break) * 100vw);
		height: calc(226 / var(--break) * 100vw);
		padding-top: 16.7vw;
	}
	.box_main .col_l {
		padding-top: 14.6vw;
	}
	.box_main .col_r {
		margin-top: calc(144 / var(--break) * 100vw);
		margin-left: calc(-37 / var(--break) * 100vw);
	}
	.box_main .col_box .deco01 {
		top: -4vw;
		max-width: calc(171 / var(--break) * 100vw);
		width: 100%;
	}
	.box_main .col_box .deco02 {
		top: -4.8vw;
		max-width: calc(109 / var(--break) * 100vw);
		width: 100%;
	}
	.address_main {
		margin: 5.5vw 0;
	}

}

/* グローバルナビゲーション gnav
------------------------------------------------------------------*/
.wrap_gnav {
	position: relative;
}
.gnav {
	transition: .3s;
	width: 100%;
}
.fix_nav .gnav {
	width: calc(100% - (655 / var(--break) * 100vw));
}
.row_gnav {
	width: calc(655 / var(--break) * 100vw);
	height: auto;
}
.row_gnav .tel_gnav {
	width: 51.3%;
	height: 100%;
}
.row_gnav .tel_gnav a {
	width: 100%;
	height: 100%;
}
.row_gnav .tel_gnav a .tel {
	line-height: 2.05;
}
.row_gnav .web_gnav {
	width: 32.7%;
	height: 100%;
}
.row_gnav .web_gnav a {
	position: relative;
	width: 100%;
	height: 100%;
}
.row_gnav .web_gnav a:after {
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 9.3%;
	width: calc(8 / var(--break) * 100vw);
	height: calc(8 / var(--break) * 100vw);
	border-radius: 100%;
	background: var(--color01);
	margin: auto;
	content: '';
}
.row_gnav .web_gnav a .icn {
	width: calc(31 / var(--break) * 100vw);
	margin-bottom: calc(16 / var(--break) * 100vw);
}
.row_gnav .line_gnav {
	width: 16%;
	height: 100%;
}
.row_gnav .line_gnav a {
	width: 100%;
	height: 100%;
}
.row_gnav .line_gnav a .icn {
	width: calc(53 / var(--break) * 100vw);
}
/* .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: rgba(255,255,255,.9);
}
.fix_nav.is_fixed  {
	transition: .5s;
	transform: translateY(0);
	opacity: 1;
	z-index: 10;
}
.gnav > ul {
	max-width: calc(1570 / var(--break) * 100vw);
	width: 100%;
}
.gnav > ul > li {
	position: relative;
	-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(115 / var(--break) * 100vw);
	position: relative;
}
.fix_nav .gnav > ul > li > a {
	height: calc(143 / var(--break) * 100vw);
	padding-bottom: calc(28 / var(--break) * 100vw);
}
.gnav > ul > li > a:after {
	content: "";
	position: absolute;
	width: calc(40 / var(--break) * 100vw);
	height: calc(2 / var(--break) * 100vw);
	background: var(--color11);
	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 .icn {
	width: calc(42 / var(--break) * 100vw);
	margin-top: calc(11 / var(--break) * 100vw);
	margin-bottom: calc(16 / var(--break) * 100vw);
}
.gnav > ul > li .icn + .ja {
	display: none;
}
.gnav > ul > li .ja {
	margin: calc(26 / var(--break) * 100vw) 0 calc(13 / var(--break) * 100vw);
	font-family: "vdl-v7marugothic", sans-serif;
	font-weight: 500;
	font-style: normal;
}
.gnav > ul > li .en {
	color: var(--color05);
	font-family: "work-sans", sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: calc(12 / var(--break) * 100vw);
	letter-spacing: 0.1em;
	text-transform: uppercase;
}
@media(min-width: 768px) and (max-width:1599px) {
	.fix_nav .gnav {
		width: calc(100% - (524 / var(--break) * 100vw));
		font-size: 80%;
	}
	.row_gnav {
		position: absolute;
		top: 0;
		right: 0;
		height: 125%;
		transform: scale(0.8);
		transform-origin: right top;
	}
	.fix_nav .gnav > ul > li .icn {
		width: calc(33 / var(--break) * 100vw);
	}

}
@media(min-width: 768px) and (max-width:1299px) {
	.fix_nav .gnav {
		width: calc(100% - (393 / var(--break) * 100vw));
		font-size: 60%;
	}
	.row_gnav {
		height: 166.67%;
		transform: scale(0.6);
	}
	.fix_nav .gnav > ul > li > a {
		height: calc(92 / var(--break) * 100vw);
	}
	.fix_nav .gnav > ul > li .icn {
		width: calc(25 / var(--break) * 100vw);
	}
	.fix_nav .gnav > ul > li .en {
		font-size: calc(8 / var(--break) * 100vw);
	}

}
@media only screen and (max-width: 767px) {
	.wrap_gnav, .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);
		border-radius: 100%;
		background: var(--color01);
		z-index: 10000;
		outline: none;
	}
	.btn_gnav_sp .txt_gnav {
		position: absolute;
		width: calc(55 / var(--break) * 100vw);
		right: 0;
		left: 0;
		bottom: 0;
		margin: auto;
	}
	.btn_gnav_sp .icn_gnav {
		width: calc(40 / var(--break) * 100vw);
		height: 2px;
		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: 2px;
		position: absolute;
		left: 0;
		background: #fff;
		transition: transform .3s ease-in-out;
	}
	.btn_gnav_sp .icn_gnav:before {
		top: -1.8vw;
	}
	.btn_gnav_sp .icn_gnav:after {
		bottom: -1.8vw;
	}
	.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: rgba(255,255,255,.9);
		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 var(--color11);
	}
	.gnav_sp .nav_main > ul > li.nav_drawer {
		padding-bottom: 2.5vw;
		border-bottom: 1px dotted var(--color11);
	}
	.gnav_sp .nav_main > ul > li > a {
		padding: 3.1vw 4vw 3.5vw 0;
		border-bottom: 1px dotted var(--color11);
		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;
		right: 0;
		top: 0;
		bottom: 0;
		width: 0;
		height: 0;
		border-left: calc(17 / var(--break) * 100vw) solid var(--color05);
		border-top: calc(12 / var(--break) * 100vw) solid transparent;
		border-bottom: calc(12 / var(--break) * 100vw) solid transparent;
		margin: auto;
	}
	.gnav_sp .nav_main > ul > li.nav_drawer > a:after {
		transform: rotate(90deg);
	}
	.gnav_sp .nav_main > ul > li.nav_drawer > a.open:after {
		transform: rotate(-90deg);
	}
	.gnav_sp .nav_main > ul > li > a .icn {
		display: none;
	}
	.gnav_sp .nav_main > ul > li > a .ja {
		font-family: "vdl-v7marugothic", sans-serif;
		font-weight: 500;
		font-style: normal;
		line-height: 1.56;
	}
	.gnav_sp .nav_main > ul > li > a .en {
		color: var(--color05);
		text-transform: uppercase;
		font-family: "work-sans", sans-serif;
		font-weight: 400;
		font-style: normal;
		font-size: 62.5%;
		letter-spacing: .1em;
		margin-top: 1vw;
	}
	.gnav_sp .nav_sub {
		background: rgba(51,51,51,.9);
		padding: 5.5vw 8vw 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;
	}
	.gnav_sp .nav_sub a {
		padding: 1vw 0 1vw 6vw;
		display: block;
		position: relative;
		color: #fff;
	}
	.gnav_sp .nav_sub a:after {
		content: "";
		position: absolute;
		left: 0;
		top: 1vw;
		bottom: 0;
		width: 0;
		height: 0;
		border-left: calc(16 / var(--break) * 100vw) solid #fff;
		border-top: calc(12 / var(--break) * 100vw) solid transparent;
		border-bottom: calc(12 / var(--break) * 100vw) solid transparent;
		margin: auto;
	}
	.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;
	}
}

/* 新着情報 index_news
------------------------------------------------------------------*/

/* ※パーフェクトスクロールバー用基本css ここからデザインに合わせて適宜変更してください */
.index_news ul {
	overflow: hidden;
	position: relative;
	padding-right: calc(20 / var(--break) * 100vw);
	max-height: 170px;
	height: auto;
	touch-action: auto !important;
	line-height: 1.75;
}
.index_news li:not(:last-of-type) {
}
.index_news li dt {
}
.index_news li dd {
}
.index_news li dd a {
	color: #db759e; /* コーダーさんへに記載されている★標準テキスト：リンク色に変更*/
	text-decoration: underline;
}
/* パーフェクトスクロールバー */
.ps__thumb-y {
	background: #333333 !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 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;
	}
}


/* index common
------------------------------------------------------------------*/
.ttl_index01 .en {
	margin-bottom: 0.25em;
	letter-spacing: 0.3em;
	line-height: 0.8;
}
@media(min-width: 768px) and (max-width:1599px) {

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

}
@media(max-width: 767px) {
	.ttl_index01 .en {
		margin-bottom: 2.1vw;
		font-size: calc(80 / var(--break) * 100vw);
	}
	.ttl_index01 .ja {
		font-size: calc(40 / var(--break) * 100vw);
		letter-spacing: 0;
	}

}


/* 旧星の森ファミリー歯科の患者さんへ index_information
------------------------------------------------------------------*/
.index_information {
	position: relative;
	margin: calc(170 / var(--break) * 100vw) 0 calc(55 / var(--break) * 100vw);
}
.index_information:before {
	display: block;
	position: absolute;
	bottom: 100%;
	left: 0;
	z-index: 0;
	width: 100%;
	height: calc(69 / var(--break) * 100vw);
	background: url(images/index/shape__information01.svg) no-repeat center bottom / cover;
	content: '';
}
.index_information:after {
	display: block;
	position: absolute;
	top: 100%;
	left: 0;
	z-index: 0;
	width: 100%;
	height: calc(55 / var(--break) * 100vw);
	background: url(images/index/shape__information02.svg) no-repeat center bottom / cover;
	content: '';
}
.index_information .deco01 {
	top: calc(-69 / var(--break) * 100vw);
	left: 5.2%;
	z-index: 2;
	max-width: 180px;
	width: 9.4%;
}
.index_information .deco02 {
	bottom: calc(-56 / var(--break) * 100vw);
	right: 5.2%;
	z-index: 2;
	max-width: 181px;
	width: 9.5%;
}
.index_information .box01 {
	position: relative;
	padding: calc(51 / var(--break) * 100vw) 0;
	border: 1px solid var(--color11);
}
.index_information .box01:before,
.index_information .box01:after {
	display: block;
	position: absolute;
	width: calc(100 / var(--break) * 100vw);
	height: calc(100 / var(--break) * 100vw);
	border-style: solid;
	border-color: var(--color11);
	content: '';
}
.index_information .box01:before {
	top: calc(20 / var(--break) * 100vw);
	left: calc(20 / var(--break) * 100vw);
	border-top-width: 1px;
	border-left-width: 1px;
}
.index_information .box01:after {
	bottom: calc(20 / var(--break) * 100vw);
	right: calc(20 / var(--break) * 100vw);
	border-bottom-width: 1px;
	border-right-width: 1px;
}
.index_information .box01 .ttl {
	margin-bottom: calc(29 / var(--break) * 100vw);
	padding-bottom: calc(45 / var(--break) * 100vw);
	background: url(images/index/shape__information03.svg) no-repeat center bottom / calc(306 / var(--break) * 100vw) auto;
}
.index_information .box01 .ttl span {
	display: inline-block;
}
@media(min-width: 768px) and (max-width:1599px) {

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

}
@media(max-width: 767px) {
	.index_information {
		margin: calc(112 / var(--break) * 100vw) 0 calc(22 / var(--break) * 100vw);
		padding: calc(70 / var(--break) * 100vw) 0;
	}
	.index_information:before {
		height: calc(27 / var(--break) * 100vw);
	}
	.index_information:after {
		height: calc(22 / var(--break) * 100vw);
	}
	.index_information .deco01 {
		top: calc(-48 / var(--break) * 100vw);
		left: 3.2%;
		max-width: calc(180 / var(--break) * 100vw);
		width: 100%;
	}
	.index_information .deco02 {
		bottom: calc(-22 / var(--break) * 100vw);
		right: 3.2%;
		max-width: calc(181 / var(--break) * 100vw);
		width: 100%;
	}
	.index_information .box01 {
		padding: 6.5vw 4% 5.7vw;
	}
	.index_information .box01 .ttl {
		margin-bottom: 2.5vw;
		padding-bottom: 6vw;
		font-size: calc(36 / var(--break) * 100vw);
		letter-spacing: 0;
	}

}


/* 大治西條ファミリー歯科が選ばれる理由 index_feature
------------------------------------------------------------------*/
.index_feature {
	margin-bottom: calc(158 / var(--break) * 100vw);
}
.ttl__feature {
	background: url(images/index/shape__feature01.svg) no-repeat center bottom / calc(85 / var(--break) * 100vw) auto;
}
.ttl__feature .deco01 {
	top: 0;
	left: 0;
	max-width: 121px;
	width: 9.8%;
}
.ttl__feature .deco02 {
	top: 0;
	right: 0;
	max-width: 120px;
	width: 9.7%;
}
.ttl__feature .ttl_index .ja span {
	display: inline-block;
	line-height: 1;
}
.txt__feature01 dt {
	margin-bottom: calc(26 / var(--break) * 100vw);
}
.txt__feature01 dt .ttl {
	margin-bottom: calc(12 / var(--break) * 100vw);
}
.txt__feature01 dt .ttl .en span {
	display: inline-block;
	position: relative;
}
.txt__feature01 dt .ttl .en span:before,
.txt__feature01 dt .ttl .en span:after {
	display: block;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: calc(8 / var(--break) * 100vw);
	height: calc(8 / var(--break) * 100vw);
	border-radius: 100%;
	content: '';
}
.txt__feature01 dt .ttl_col01 .en span:before,
.txt__feature01 dt .ttl_col01 .en span:after {
	background: var(--color06);
}
.txt__feature01 dt .ttl_col02 .en span:before,
.txt__feature01 dt .ttl_col02 .en span:after {
	background: var(--color04);
}
.txt__feature01 dt .ttl_col03 .en span:before,
.txt__feature01 dt .ttl_col03 .en span:after {
	background: var(--color02);
}
.txt__feature01 dt .ttl_col04 .en span:before,
.txt__feature01 dt .ttl_col04 .en span:after {
	background: var(--color08);
}
.txt__feature01 dt .ttl_col05 .en span:before,
.txt__feature01 dt .ttl_col05 .en span:after {
	background: var(--color03);
}
.txt__feature01 dt .ttl .en span:before {
	left: -1em;
}
.txt__feature01 dt .ttl .en span:after {
	right: -0.7em;
}
.txt__feature01 dt .ttl_col01 .num {
	color: var(--color06);
}
.txt__feature01 dt .ttl_col02 .num {
	color: var(--color04);
}
.txt__feature01 dt .ttl_col03 .num {
	color: var(--color02);
}
.txt__feature01 dt .ttl_col04 .num {
	color: var(--color08);
}
.txt__feature01 dt .ttl_col05 .num {
	color: var(--color03);
}
.txt__feature01 dt .copy span {
	display: inline-block;
	margin: 0 -1em;
}
.area__feature01 {
	position: relative;
}
.area__feature01:after {
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 0;
	width: 100%;
	height: calc(100% - (490 / var(--break) * 100vw));
	background-image: url(images/index/bg__feature01.png);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: auto 100%;
	content: '';
}
.row__feature01 {
	position: relative;
}
.row__feature01 .col_img {
	width: 50%;
}
.row__feature01 .col_img .img {
	max-width: 871px;
}
.row__feature01 .col_txt {
	width: 50%;
}
.row__feature01 .col_txt .unit {
	max-width: 800px;
	width: 94%;
}
.row__feature01 .col_txt .deco01 {
	top: 0;
	right: 0;
	max-width: 727px;
	width: 38%;
}
.row__feature02 .col {
	position: relative;
	width: 50%;
	padding: 0 calc(45 / var(--break) * 100vw);
}
.row__feature02 .col_r {
	padding-top: calc(80 / var(--break) * 100vw);
}
.row__feature02 .col .unit {
	max-width: 821px;
	width: 95%;
}
.row__feature02 .col .deco01 {
	top: calc(80 / var(--break) * 100vw);
	left: 0;
	max-width: 830px;
	width: 87%;
}
.row__feature02 .col .deco02 {
	top: 0;
	right: 0;
	max-width: 827px;
	width: 87%;
}
.row__feature02 .col .img {
	margin-bottom: calc(56 / var(--break) * 100vw);
}
.wrap__feature01 .shape01 {
	top: calc(200 / var(--break) * 100vw);
	left: 0;
	right: 0;
	max-width: 575px;
	width: 30%;
	margin: auto;
}
.wrap__feature01 .img01 {
	bottom: calc(106 / var(--break) * 100vw);
	right: 14%;
	max-width: 523px;
	width: 28%;
}
.wrap__feature01 .row_box01 {
	gap: calc(40 / var(--break) * 100vw) 0;
	max-width: 1720px;
	width: 98%;
}
.wrap__feature01 .row_box01 .col_box {
	position: relative;
	max-width: 860px;
	width: 50%;
	aspect-ratio: 1.6796875 / 1;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
}
.wrap__feature01 .row_box01 .col_box01 {
	background-image: url(images/index/box__feature01.svg);
}
.wrap__feature01 .row_box01 .col_box02 {
	margin-bottom: calc(-110 / var(--break) * 100vw);
	background-image: url(images/index/box__feature02.svg);
}
.wrap__feature01 .row_box01 .col_box03 {
	margin-top: calc(105 / var(--break) * 100vw);
	padding: calc(40 / var(--break) * 100vw) calc(48 / var(--break) * 100vw) 0;
	aspect-ratio: 1.6667 / 1;
	background-image: url(images/index/box__feature03.svg);
}
.wrap__feature01 .row_box01 .col_box .row_ttl {
	width: 100%;
	padding-left: calc(50 / var(--break) * 100vw);
}
.wrap__feature01 .row_box01 .col_box .row_ttl .col_img {
	width: 50%;
}
.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl {
	width: 50%;
}
.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .deco01 {
	max-width: 345px;
	width: 100%;
}
.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .deco02 {
	max-width: calc(94 / var(--break) * 100vw);
	width: 28%;
}
.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .wrap_ttl {
	min-height: calc(143 / var(--break) * 100vw);
}
.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .wrap_ttl:has(.ja02) {
	min-height: calc(153 / var(--break) * 100vw);
}
.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .ttl .ja {
	margin-bottom: 0.5em;
	line-height: 1.44;
}
.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .ttl .ja02 {
	margin-bottom: 0.6em;
	line-height: 1.46;
}
.wrap__feature01 .row_box01 .col_box .txt {
	width: 100%;
	padding-left: calc(50 / var(--break) * 100vw);
	padding-right: calc(50 / var(--break) * 100vw);
}
.wrap__feature01 .row_box01 .col_box03 .box01 {
	top: calc(-120 / var(--break) * 100vw);
	right: 29%;
	width: calc(250 / var(--break) * 100vw);
	height: calc(159 / var(--break) * 100vw);
	padding-top: calc(75 / var(--break) * 100vw);
	background: url(images/index/deco__feature08.png) no-repeat center bottom / contain;
}
.wrap__feature01 .row_box01 .col_box03 .row_img {
	width: 100%;
	padding-left: calc(60 / var(--break) * 100vw);
}
.wrap__feature01 .row_box01 .col_box03 .row_img .col {
	max-width: 337px;
	width: 48%;
}
.wrap__feature01 .row_box01 .col_box03 .row_img .col .img {
	margin-bottom: calc(23 / var(--break) * 100vw);
}
.wrap__feature01 .row_box01 .col_box03 .row_img .col p {
	line-height: 1.46;
}
@media(min-width: 768px) and (max-width:1599px) {
	.area__feature01:after {
		height: calc(100% - (390 / var(--break) * 100vw));
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .ttl .ja02 {
		letter-spacing: 0;
	}
	.wrap__feature01 .row_box01 .col_box .txt {
		padding-right: 0;
	}

}
@media(min-width: 768px) and (max-width:1299px) {
	.txt__feature01 dt .ttl .num {
		font-size: calc(80 / var(--break) * 100vw);
	}
	.txt__feature01 dt .copy {
		font-size: calc(32 / var(--break) * 100vw);
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl {
		margin-top: calc(-30 / var(--break) * 100vw);
		margin-bottom: calc(20 / var(--break) * 100vw);
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .wrap_ttl {
		min-height: calc(114 / var(--break) * 100vw);
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .wrap_ttl:has(.ja02) {
		min-height: calc(122 / var(--break) * 100vw);
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .wrap_ttl {
		min-height: calc(114 / var(--break) * 100vw);
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .ttl .ja {
		font-size: calc(24 / var(--break) * 100vw);
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .ttl .ja02 {
		font-size: calc(20 / var(--break) * 100vw);
	}
	.wrap__feature01 .row_box01 .col_box03 .box01 {
		transform: scaleX(0.8);
		transform-origin: right bottom;
	}
	.wrap__feature01 .row_box01 .col_box03 .row_img .col p {
		font-size: calc(20 / var(--break) * 100vw);
	}

}
@media(max-width: 767px) {
	.index_feature {
		margin-bottom: 15.5vw;
	}
	.ttl__feature {
		margin-bottom: 8vw;
		padding: 12.9vw 0 6.4vw;
	}
	.ttl__feature .deco01 {
		top: 11vw;
		left: -2vw;
		max-width: calc(96 / var(--break) * 100vw);
		width: 100%;
	}
	.ttl__feature .deco02 {
		top: 11.2vw;
		right: -3vw;
		max-width: calc(96 / var(--break) * 100vw);
		width: 100%;
	}
	.ttl__feature .ttl_index .ja span {
		display: inline-block;
		line-height: 1;
	}
	.txt__feature01 dt {
		margin-bottom: 2.3vw;
	}
	.txt__feature01 dt .ttl {
		margin-bottom: 1.7vw;
	}
	.txt__feature01 dt .ttl .en {
		font-size: calc(30 / var(--break) * 100vw);
	}
	.txt__feature01 dt .ttl .en span:before {
		left: -3.6vw;
	}
	.txt__feature01 dt .ttl .en span:after {
		right: -3vw;
	}
	.txt__feature01 dt .ttl .num {
		font-size: calc(100 / var(--break) * 100vw);
	}
	.txt__feature01 dt .copy {
		font-size: calc(40 / var(--break) * 100vw);
		letter-spacing: 0;
	}
	.area__feature01 {
		margin-bottom: calc(80 / var(--break) * 100vw);
		padding-bottom: calc(46 / var(--break) * 100vw);
	}
	.area__feature01:after {
		height: calc(5532 / var(--break) * 100vw);
		background-image: url(images/index/bg__feature01_sp.png);
		background-size: cover;
	}
	.row__feature01 {
		margin-bottom: 8.4vw;
		padding: 0 3.2vw;
	}
	.row__feature01 .col_img {
		width: 100%;
		margin-bottom: 7.4vw;
	}
	.row__feature01 .col_img .img {
		max-width: 100%;
	}
	.row__feature01 .col_txt {
		position: relative;
		width: 100%;
	}
	.row__feature01 .col_txt .unit {
		max-width: calc(646 / var(--break) * 100vw);
		width: 100%;
	}
	.row__feature01 .col_txt .deco01 {
		top: -4.4vw;
		right: -3.2vw;
		max-width: calc(557 / var(--break) * 100vw);
		width: 100%;
	}
	.row__feature02 .col {
		width: 100%;
		padding: 0 0;
	}
	.row__feature02 .col_l {
		margin-bottom: 16.5vw;
	}
	.row__feature02 .col_r {
		padding-top: 0;
	}
	.row__feature02 .col .unit {
		max-width: calc(702 / var(--break) * 100vw);
		width: 100%;
		margin: 0 auto;
	}
	.row__feature02 .col .deco01 {
		max-width: 100%;
		width: 100%;
	}
	.row__feature02 .col .deco02 {
		top: calc(-80 / var(--break) * 100vw);
		max-width: 100%;
		width: 100%;
	}
	.row__feature02 .col .img {
		margin-bottom: 7.5vw;
	}
	.wrap__feature01 .shape01 {
		top: calc(548 / var(--break) * 100vw);
		left: 2.6vw;
		right: auto;
		max-width: calc(651 / var(--break) * 100vw);
		width: 100%;
	}
	.wrap__feature01 .img01 {
		position: relative;
		bottom: 0;
		left: 0;
		right: 0;
		max-width: calc(523 / var(--break) * 100vw);
		width: 100%;
		margin: calc(40 / var(--break) * 100vw) auto 0;
	}
	.wrap__feature01 .row_box01 {
		gap: calc(100 / var(--break) * 100vw) 0;
		max-width: 100%;
		width: 100%;
	}
	.wrap__feature01 .row_box01 .col_box {
		max-width: 100%;
		width: 100%;
		padding: calc(68 / var(--break) * 100vw) 0 0;
		aspect-ratio: auto;
	}
	.wrap__feature01 .row_box01 .col_box01 {
		height: calc(947 / var(--break) * 100vw);
		background-image: url(images/index/box__feature01_sp.svg);
	}
	.wrap__feature01 .row_box01 .col_box02 {
		height: calc(853 / var(--break) * 100vw);
		margin-bottom: 0;
		background-image: url(images/index/box__feature02_sp.svg);
	}
	.wrap__feature01 .row_box01 .col_box03 {
		height: calc(1044 / var(--break) * 100vw);
		margin-top: calc(24 / var(--break) * 100vw);
		padding: 0vw;
		aspect-ratio: auto;
		background-image: url(images/index/box__feature03_sp.svg);
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl {
		margin-bottom: 2.5vw;
		padding-left: 0;
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_img {
		position: relative;
		z-index: 1;
		width: calc(345 / var(--break) * 100vw);
		margin: 0 auto 0vw;
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl {
		width: 100%;
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .deco01 {
		position: absolute;
		top: calc(-20 / var(--break) * 100vw);
		right: calc(182 / var(--break) * 100vw);
		z-index: 0;
		max-width: calc(345 / var(--break) * 100vw);
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .deco02 {
		width: 100%;
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .wrap_ttl {
		min-height: auto !important;
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .ttl {
		margin-bottom: 3.3vw;
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .ttl .ja {
		margin-top: 3.5vw;
		margin-bottom: 1.9vw;
		font-size: calc(36 / var(--break) * 100vw);
		letter-spacing: 0;
		line-height: 1.28 !important;
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .ttl .ja02 {
		margin-bottom: 2.9vw;
	}
	.wrap__feature01 .row_box01 .col_box .row_ttl .col_ttl .ttl .en {
		font-size: calc(22 / var(--break) * 100vw);
	}
	.wrap__feature01 .row_box01 .col_box .txt {
		width: calc(550 / var(--break) * 100vw);
		margin: 0 auto;
		padding: 0;
	}
	.wrap__feature01 .row_box01 .col_box03 {
		padding-top: calc(155 / var(--break) * 100vw);
	}
	.wrap__feature01 .row_box01 .col_box03 .box01 {
		top: calc(-43 / var(--break) * 100vw);
		left: 0;
		right: 0;
		margin: auto;
		padding-top: 9.6vw;
		font-size: 1rem;
		letter-spacing: 0;
	}
	.wrap__feature01 .row_box01 .col_box03 .row_img {
		gap: 5.6vw 0;
		padding: 0;
	}
	.wrap__feature01 .row_box01 .col_box03 .row_img .col {
		max-width: 100%;
		width: 100%;
	}
	.wrap__feature01 .row_box01 .col_box03 .row_img .col .img {
		width: calc(336 / var(--break) * 100vw);
		margin: 0 auto 2.7vw;
	}
	.wrap__feature01 .row_box01 .col_box03 .row_img .col p {
		font-size: 1rem;
		letter-spacing: 0;
	}

}


/* 診療内容 index_medical
------------------------------------------------------------------*/
.index_medical {
	position: relative;
	padding-bottom: calc(138 / var(--break) * 100vw);
}
.index_medical:before,
.index_medical:after {
	display: block;
	position: absolute;
	left: 0;
	width: 100%;
	background-repeat: no-repeat;
	background-size: cover;
	content: '';
}
.index_medical:before {
	top: calc(-69 / var(--break) * 100vw);
	height: calc(69 / var(--break) * 100vw);
	background-image: url(images/index/shape__medical01.svg);
	background-position: center top;
}
.index_medical:after {
	bottom: 0;
	height: calc(69 / var(--break) * 100vw);
	background-image: url(images/index/shape__medical02.svg);
	background-position: center bottom;
}
.index_medical .deco01 {
	top: calc(-70 / var(--break) * 100vw);
	left: 5.2%;
	max-width: 361px;
	width: 19%;
}
.index_medical .deco02 {
	top: calc(-70 / var(--break) * 100vw);
	right: 5.2%;
	max-width: 361px;
	width: 19%;
}
.index_medical .deco03 {
	top: 0;
	left: 0;
	max-width: 210px;
	width: 11%;
}
.index_medical .deco04 {
	bottom: calc(98 / var(--break) * 100vw);
	right: 0;
	max-width: 210px;
	width: 11%;
}
.row__medical01 {
	gap: calc(50 / var(--break) * 100vw) 0;
}
.row__medical01 .col_btn {
	position: relative;
	max-width: 725px;
	width: 49%;
}
.row__medical01 .col_btn .img {
	position: relative;
}
.row__medical01 .col_btn .ttl {
	bottom: calc(45 / var(--break) * 100vw);
	padding-right: calc(110 / var(--break) * 100vw);
	right: 0;
}
.row__medical01 .col_btn .ttl .ja {
	position: relative;
	margin-bottom: 0.4em;
	line-height: 1.25;
}
.row__medical01 .col_btn .ttl .ja:after {
	display: block;
	position: absolute;
	top: 0;
	right: calc(-60 / var(--break) * 100vw);
	width: calc(48 / var(--break) * 100vw);
	height: 100%;
	background: url(images/index/arw__medical01.svg) no-repeat right center / contain;
	content: '';
}
@media(min-width: 768px) and (max-width:1799px) {
	.index_medical .deco03 {
		left: -3%;
	}
	.index_medical .deco04 {
		right: -3%;
	}

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

}
@media(min-width: 768px) and (max-width:1299px) {
	.row__medical01 .col_btn .ttl .ja {
		font-size: calc(32 / var(--break) * 100vw);
	}

}
@media(max-width: 767px) {
	.ttl__medical .en {
		padding-left: 3vw;
	}
	.index_medical {
		padding-top: 9vw;
		padding-bottom: 12.1vw;
	}
	.index_medical:before {
		top: calc(-27 / var(--break) * 100vw);
		height: calc(27 / var(--break) * 100vw);
	}
	.index_medical:after {
		bottom: 0;
		height: calc(27 / var(--break) * 100vw);
	}
	.index_medical .deco01 {
		top: calc(-32 / var(--break) * 100vw);
		left: auto;
		right: 3.2vw;
		max-width: calc(243 / var(--break) * 100vw);
		width: 100%;
	}
	.index_medical .deco02 {
		top: calc(-32 / var(--break) * 100vw);
		left: 3.2vw;
		right: auto;
		max-width: calc(243 / var(--break) * 100vw);
		width: 100%;
	}
	.index_medical .deco03 {
		z-index: 2;
		max-width: calc(126 / var(--break) * 100vw);
		width: 100%;
	}
	.index_medical .deco04 {
		z-index: 2;
		bottom: calc(547 / var(--break) * 100vw);
		max-width: calc(126 / var(--break) * 100vw);
		width: 100%;
	}
	.row__medical01 {
		gap: 5.8vw 0;
	}
	.row__medical01 .col_btn {
		max-width: 100%;
		width: 100%;
	}
	.row__medical01 .col_btn .img {
		margin-bottom: 4vw;
	}
	.row__medical01 .col_btn .ttl {
		bottom: 3.4vw;
		padding-right: 11.7vw;
	}
	.row__medical01 .col_btn .ttl .ja {
		font-size: calc(40 / var(--break) * 100vw);
		line-height: 1.15;
	}
	.row__medical01 .col_btn .ttl .en {
		font-size: calc(22 / var(--break) * 100vw);
	}

}


/* 年齢・年代別のお口のケア index_age
------------------------------------------------------------------*/
.ttl__age {
	top: calc(295 / var(--break) * 100vw);
	left: 50%;
	transform: translate(-50%, 0);
}
.ttl__age .en {
	padding-left: 0.2em;
}
.area__age01 {
	padding-bottom: calc(38 / var(--break) * 100vw);
}
.area__age02:before,
.area__age02:after {
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	height: 100%;
	content: '';
}
.area__age02:before {
	z-index: 0;
	max-width: 1770px;
	width: 98%;
	background: #fff;
}
.area__age02:after {
	z-index: 1;
	width: 46.875%;
	background: var(--color10);
}
.box__age01 {
	width: calc(661 / var(--break) * 100vw);
	height: calc(440 / var(--break) * 100vw);
	padding-top: calc(155 / var(--break) * 100vw);
	background: url(images/index/box__age01.png) no-repeat center top / contain;
	line-height: 1.62;
}
.wrap__age01 {
	top: 0;
	left: 0;
	width: calc(961 / var(--break) * 100vw);
	height: calc(973 / var(--break) * 100vw);
}
.wrap__age01 .img {
	animation: 60s linear infinite spin;
}
.wrap__age01 .img img {
	display: block;
	width: 100%;
}
.row__age01 .col_btn {
	position: relative;
	width: 24%;
}
.row__age01 .col_btn .unit {
	padding: calc(31 / var(--break) * 100vw) 5% calc(83 / var(--break) * 100vw);
	background: rgb(227 232 224 / 0.2);
}
.row__age01 .col_btn .unit:before {
	display: block;
	position: absolute;
	top: -1px;
	left: -1px;
	width: calc(81 / var(--break) * 100vw);
	height: calc(81 / var(--break) * 100vw);
	border-top-left-radius: calc(25 / var(--break) * 100vw);
	content: '';
	clip-path: polygon(0 0, 100% 0, 0 100%);
}
.row__age01 .col_btn.bg_col02 .unit:before {
	background: var(--color02);
}
.row__age01 .col_btn.bg_col03 .unit:before {
	background: var(--color03);
}
.row__age01 .col_btn.bg_col04 .unit:before {
	background: var(--color04);
}
.row__age01 .col_btn.bg_col06 .unit:before {
	background: var(--color06);
}
.row__age01 .col_btn .unit dt {
	margin-bottom: calc(22 / var(--break) * 100vw);
}
.row__age01 .col_btn .num {
	bottom: calc(-6 / var(--break) * 100vw);
	left: 0;
	line-height: 1;
}
.row__age01 .col_btn.bg_col02 .num {
	color: var(--color02);
}
.row__age01 .col_btn.bg_col03 .num {
	color: var(--color03);
}
.row__age01 .col_btn.bg_col04 .num {
	color: var(--color04);
}
.row__age01 .col_btn.bg_col06 .num {
	color: var(--color06);
}
.row__age01 .col_btn .txt {
	bottom: 0;
	right: 0;
	width: calc(127 / var(--break) * 100vw);
	height: calc(40 / var(--break) * 100vw);
	border-top-left-radius: calc(20 / var(--break) * 100vw);
	border-bottom-right-radius: calc(19 / var(--break) * 100vw);
}
.row__age01 .col_btn .txt:before,
.row__age01 .col_btn .txt:after {
	display: block;
	position: absolute;
	width: calc(10 / var(--break) * 100vw);
	height: calc(10 / var(--break) * 100vw);
	background: url(images/index/shape__ager01.svg) no-repeat right bottom / contain;
	content: '';
}
.row__age01 .col_btn .txt:before {
	right: 100%;
	bottom: 0;
}
.row__age01 .col_btn .txt:after {
	bottom: 100%;
	right: 0;
}
.row__age01 .col_btn .txt span {
	display: inline-block;
	position: relative;
	margin-top: 0.2em;
	padding-right: 0.8em;
}
.row__age01 .col_btn .txt span:after {
	display: block;
	position: absolute;
	top: 0;
	bottom: 0.2em;
	right: 0;
	width: calc(10 / var(--break) * 100vw);
	height: calc(12 / var(--break) * 100vw);
	margin: auto;
	content: '';
	clip-path: polygon(100% 50%, 0% 100%, 0 0);
}
.row__age01 .col_btn.bg_col02 .txt span:after {
	background: var(--color02);
}
.row__age01 .col_btn.bg_col03 .txt span:after {
	background: var(--color03);
}
.row__age01 .col_btn.bg_col04 .txt span:after {
	background: var(--color04);
}
.row__age01 .col_btn.bg_col06 .txt span:after {
	background: var(--color06);
}
@keyframes spin {
	0% {
		transform: rotate(360deg)
	}

	100% {
		transform: rotate(0)
	}

	from {
		transform: rotate(0)
	}

	to {
		transform: rotate(360deg)
	}
}
@media(min-width: 768px) and (max-width:1599px) {
	.wrap__age01 {
		transform: scale(0.9);
		transform-origin: left top;
	}

}
@media(min-width: 768px) and (max-width:1299px) {
	.box__age01 {
		width: calc(520 / var(--break) * 100vw);
		height: calc(350 / var(--break) * 100vw);
		padding-top: calc(120 / var(--break) * 100vw);
		font-size: calc(20 / var(--break) * 100vw);
	}
	.wrap__age01 {
		transform: scale(0.75);
	}
	.row__age01 .col_btn .num {
		left: 0.2em;
		font-size: calc(28 / var(--break) * 100vw);
	}
	.row__age01 .col_btn .num em {
		font-size: calc(45 / var(--break) * 100vw);
	}

}
@media(max-width: 767px) {
	.area__age01 {
		margin-top: calc(100 / var(--break) * 100vw);
		padding-top: calc(547 / var(--break) * 100vw);
		padding-bottom: calc(40 / var(--break) * 100vw);
	}
	.area__age01:after {
		display: block;
		position: absolute;
		bottom: 0;
		left: 0;
		z-index: 0;
		width: 100%;
		height: calc(100% - (487 / var(--break) * 100vw));
		background: #fff;
		content: '';
	}
	.area__age02 {
		padding: 0 0 calc(100 / var(--break) * 100vw);
	}
	.area__age02:before,
	.area__age02:after {
		top: auto;
		bottom: 0;
		width: 100% !important;
	}
	.area__age02:before {
		max-width: 100%;
		height: 100%;
	}
	.area__age02:after {
		height: calc(823 / var(--break) * 100vw);
	}
	.box__age01 {
		width: calc(702 / var(--break) * 100vw);
		height: calc(468 / var(--break) * 100vw);
		font-size: 1rem;
		letter-spacing: 0;
		line-height: 1.56;
	}
	.wrap__age01 {
		left: 50%;
		transform: translateX(-50%);
	}
	.row__age01 {
		gap: calc(40 / var(--break) * 100vw) 0;
	}
	.row__age01 .col_btn {
		width: 100%;
	}
	.row__age01 .col_btn .unit {
		padding: 3.5vw 6% 12.3vw;
	}
	.row__age01 .col_btn .unit dt {
		margin-bottom: 1.2vw;
		font-size: calc(40 / var(--break) * 100vw);
		letter-spacing: 0;
	}
	.row__age01 .col_btn .num {
		bottom: -0.5vw;
		font-size: calc(44 / var(--break) * 100vw);
	}
	.row__age01 .col_btn .num em {
		font-size: calc(70 / var(--break) * 100vw);
	}
	.row__age01 .col_btn .txt {
		width: calc(153 / var(--break) * 100vw);
		height: calc(50 / var(--break) * 100vw);
		border-top-left-radius: calc(30 / var(--break) * 100vw);
		border-bottom-right-radius: calc(28 / var(--break) * 100vw);
		font-size: calc(21.5 / var(--break) * 100vw);
	}
	.row__age01 .col_btn .txt span:after {
		width: calc(12 / var(--break) * 100vw);
		height: calc(14 / var(--break) * 100vw);
	}

}


/* よくあるご質問 index_faq
------------------------------------------------------------------*/
.ttl__faq .en {
	background: var(--color07) url(images/page/bg_ptn01.png) repeat center / calc(7 / var(--break) * 100vw) auto;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	letter-spacing: 0.25em;
}
.ttl__faq .ja {
	margin-left: calc(10 / var(--break) * 100vw);
}
.index_faq {
	margin: calc(117 / var(--break) * 100vw) 0 calc(60 / var(--break) * 100vw);
}
.btn__faq {
	position: relative;
	max-width: calc(1240 / var(--break) * 100vw);
	width: 100%;
}
.btn__faq a {
	max-width: 1000px;
	width: 81%;
	border-radius: 200px;
}
.btn__faq a .img {
	bottom: 0;
	left: 0;
	width: calc(602 / var(--break) * 100vw);
}
.btn__faq a .img .txt {
	line-height: 1.56;
}
.btn__faq a .img .txt01 {
	top: 3.1em;
	left: 1.7em;
}
.btn__faq a .img .txt02 {
	top: 1.3em;
	left: 12.2em;
}
.btn__faq a .img .txt03 {
	top: 9.9em;
	left: 9.8em;
}
.btn__faq a .area {
	position: relative;
	width: 100%;
	height: 100%;
	padding: calc(42 / var(--break) * 100vw) 0;
}
.btn__faq a .area:before {
	display: block;
	position: absolute;
	inset: 0;
	z-index: 0;
	width: calc(100% - (20 / var(--break) * 100vw));
	height: calc(100% - (20 / var(--break) * 100vw));
	margin: auto;
	border-radius: 200px;
	background: rgb(0 101 77 / 0.2);
	z-index: 0;
	content: '';
}
.btn__faq a .unit {
	width: 61%;
}
.btn__faq a .arw {
	top: 50%;
	right: calc(30 / var(--break) * 100vw);
	transform: translateY(-50%);
	width: calc(90 / var(--break) * 100vw);
}
@media(min-width: 768px) and (max-width:1599px) {

}
@media(min-width: 768px) and (max-width:1299px) {
	.btn__faq a .unit {
		width: 58%;
	}

}
@media(max-width: 767px) {
	.ttl__faq {
		-webkit-justify-content: center !important;
		justify-content: center !important;
		margin-bottom: 3.4vw;
	}
	.ttl__faq .en {
		font-size: calc(80 / var(--break) * 100vw);
	}
	.ttl__faq .ja {
		font-size: calc(40 / var(--break) * 100vw);
		letter-spacing: 0;
	}
	.index_faq {
		margin: calc(226 / var(--break) * 100vw) 0 calc(100 / var(--break) * 100vw);
	}
	.btn__faq {
		max-width: 100%;
	}
	.btn__faq a {
		max-width: 100%;
		width: 100%;
		border-radius: calc(200 / var(--break) * 100vw);
	}
	.btn__faq a .img {
		top: calc(-126 / var(--break) * 100vw);
		bottom: auto;
		width: 100%;
	}
	.btn__faq a .img .txt {
		font-size: calc(22 / var(--break) * 100vw);
		letter-spacing: 0;
		line-height: 1.64;
	}
	.btn__faq a .img .txt01 {
		top: 8.4vw;
		left: 4.6vw;
	}
	.btn__faq a .img .txt02 {
		top: 3.4vw;
		left: 34vw;
	}
	.btn__faq a .img .txt03 {
		top: 27.6vw;
		left: 27.4vw;
	}
	.btn__faq a .area {
		padding: 41.4vw 8% 20.6vw;
	}
	.btn__faq a .area:before {
		border-radius: calc(200 / var(--break) * 100vw);
	}
	.btn__faq a .unit {
		width: 100%;
	}
	.btn__faq a .unit p {}
	.btn__faq a .arw {
		top: auto;
		bottom: calc(20 / var(--break) * 100vw);
		left: 0;
		right: 0;
		transform: translateY(0);
		margin: auto;
	}

}


/* MESSAGE index_message
------------------------------------------------------------------*/
.ttl__message {
	width: calc(527 / var(--break) * 100vw);
}
.index_message {
	margin-bottom: calc(112 / var(--break) * 100vw);
	padding-top: calc(322 / var(--break) * 100vw);
	background-image: url(images/index/img__message01.png);
	background-repeat: no-repeat;
	background-position: center top;
	background-size: 100% auto;
}
.row__message01 {
	max-width: 1720px;
	width: 90%;
}
.row__message01 .col_name {
	position: relative;
	max-width: 598px;
	width: 35%;
	margin-top: calc(241 / var(--break) * 100vw);
	padding-top: calc(131 / var(--break) * 100vw);
}
.row__message01 .col_name .deco01 {
	top: 0;
	left: 0;
	max-width: 360px;
	width: 61%;
}
.row__message01 .col_name .name {
	position: relative;
	width: calc(399 / var(--break) * 100vw);
	height: calc(258 / var(--break) * 100vw);
	padding-left: 11.7%;
	background: url(images/index/box__message01.svg) no-repeat center / contain;
}
.row__message01 .col_name .name .box {
	top: calc(51 / var(--break) * 100vw);
	left: calc(8 / var(--break) * 100vw);
	width: calc(100 / var(--break) * 100vw);
	height: calc(100 / var(--break) * 100vw);
}
.row__message01 .col_name .name .ja {
	position: relative;
	margin: 0.2em 0 0.55em;
	padding-bottom: 0.6em;
}
.row__message01 .col_name .name .ja:after {
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	width: calc(195 / var(--break) * 100vw);
	height: calc(5 / var(--break) * 100vw);
	margin: auto;
	background: url(images/index/shape__message01.svg) no-repeat center bottom / contain;
	content: '';
}
.row__message01 .col_name .name .en {
	letter-spacing: 0.3em;
}
.row__message01 .col_txt {
	max-width: 910px;
	width: 60%;
	border-left: 1px solid var(--color11);
}
.row__message01 .col_txt .copy {
	margin: calc(37 / var(--break) * 100vw) 0 calc(30 / var(--break) * 100vw);
}
.row__message01 .col_txt .copy span {
	display: inline-block;
	margin-right: -1em;
}
@media(min-width: 768px) and (max-width:1599px) {
	.row__message01 .col_name {
		margin-top: calc(120 / var(--break) * 100vw);
	}

}
@media(min-width: 768px) and (max-width:1299px) {
	.row__message01 .col_name {
		margin-top: 0;
	}

}
@media(max-width: 767px) {
	.ttl__message {
		margin: auto;
	}
	.index_message {
		margin-bottom: 11.7vw;
		padding-top: calc(391 / var(--break) * 100vw);
		background-image: url(images/index/img__message01_sp.png);
	}
	.row__message01 {
		max-width: calc(702 / var(--break) * 100vw);
		width: 100%;
	}
	.row__message01 .col_name {
		max-width: 100%;
		width: 100%;
		margin: 0 0 calc(40 / var(--break) * 100vw);
		padding-top: calc(92 / var(--break) * 100vw);
	}
	.row__message01 .col_name .deco01 {
		left: calc(150 / var(--break) * 100vw);
		max-width: calc(288 / var(--break) * 100vw);
		width: 100%;
	}
	.row__message01 .col_name .name {
		padding-left: 9vw;
	}
	.row__message01 .col_name .name .box {
		font-size: calc(26 / var(--break) * 100vw);
	}
	.row__message01 .col_name .name .ja {
		font-size: calc(40 / var(--break) * 100vw);
	}
	.row__message01 .col_name .name .en {
		font-size: calc(18 / var(--break) * 100vw);
	}
	.row__message01 .col_txt {
		max-width: 100%;
		width: 100%;
		padding: 0 4vw 0 3.5vw;
		border-left-width: calc(2 / var(--break) * 100vw);
	}
	.row__message01 .col_txt .copy {
		margin: 3.9vw 0 3.1vw;
		font-size: calc(36 / var(--break) * 100vw);
		letter-spacing: 0;
		line-height: 1.39;
		text-align: center;
	}
	.row__message01 .col_txt .copy span {
		margin-left: -1em;
	}

}


/* Instagram index_instagram
------------------------------------------------------------------*/
.index_instagram {
	position: relative;
	max-width: 1720px;
	width: 96%;
	margin-bottom: calc(200 / var(--break) * 100vw);
	border-radius: 200px;
	border: calc(2 / var(--break) * 100vw) solid var(--color11);
}
.index_instagram:before,
.index_instagram:after {
	display: block;
	position: absolute;
	width: calc(50 / var(--break) * 100vw);
	height: 5px;
	background: #fff;
	content: '';
}
.index_instagram:before {
	top: -3px;
	right: 14%;
}
.index_instagram:after {
	bottom: -3px;
	left: 14%;
}
.wrap__instagram01 {
	position: relative;
}
.wrap__instagram01 .btn01 {
	position: absolute;
	right: 0;
	left: 0;
	top: 0;
	bottom: 0;
	width: calc(100 / var(--break) * 100vw);
	height: calc(100 / var(--break) * 100vw);
	margin: auto;
}
.wrap__instagram01 .btn01 a,
.wrap__instagram01 .btn01 a img {
	display: block;
	width: 100%;
}
.wrap__instagram01 #sb_instagram {
	padding: 0 !important;
}
.wrap__instagram01 #sb_instagram #sbi_images {
	gap: calc(20 / var(--break) * 100vw) !important;
	padding: 0 !important;
}
@media(min-width: 768px) and (max-width:1599px) {

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

}
@media(max-width: 767px) {
	.index_instagram {
		max-width: 100%;
		width: 100%;
		border-radius: 0;
		border-left: none;
		border-right: none;
	}
	.index_instagram:before,
	.index_instagram:after {
		width: calc(60 / var(--break) * 100vw);
	}
	.index_instagram:before {
		right: calc(90 / var(--break) * 100vw);
	}
	.index_instagram:after {
		left: calc(90 / var(--break) * 100vw);
	}
	.wrap__instagram01 #sb_instagram.sbi_mob_col_3 #sbi_images {
		grid-template-columns: repeat(3, 1fr);
	}
	.wrap__instagram01 #sb_instagram #sbi_images {
		gap: calc(10 / var(--break) * 100vw) !important;
	}

}


/* フッター footer
------------------------------------------------------------------*/
footer {
	padding-top: calc(83 / var(--break) * 100vw);
}
.main_foot .inner {
	max-width: 1094px;
}
.logo_foot {
	max-width: calc(772 / var(--break) * 100vw);
	width: 100%;
}
.tbl_time03 thead th {
	font-family: "vdl-v7marugothic", sans-serif;
	font-weight: 500;
	font-style: normal;
	font-size: calc(16 / var(--break) * 100vw);
	letter-spacing: 0.1em;
}
.tbl_time03 .tbl_caption {
	margin-top: calc(22 / var(--break) * 100vw);
	line-height: 1.56;
}
.row_foot01 > .col_l {
	max-width: 504px;
	width: 47%;
}
.row_foot01 > .col_l dl {
	gap: calc(20 / var(--break) * 100vw) 0;
}
.row_foot01 > .col_l dl > div {
	border-radius: 100px;
}
.row_foot01 > .col_l dt {
	width: calc(80 / var(--break) * 100vw);
}
.row_foot01 > .col_l dd {
	width: calc(100% - (100 / var(--break) * 100vw));
}
.row_foot01 > .col_l dd p {
	line-height: 1.45;
}
.row_foot01 > .col_r {
	max-width: 530px;
	width: 49%;
}
.area_foot01 {
	position: relative;
}
.area_foot01:before {
	display: block;
	position: absolute;
	top: calc(-83 / var(--break) * 100vw);
	left: 0;
	z-index: 0;
	width: 100%;
	height: calc(83 / var(--break) * 100vw);
	background: url(images/page/shape_foot01.svg) no-repeat center top / cover;
	content: '';
}
.area_foot01:after {
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 0;
	width: 100%;
	max-height: 100%;
	height: calc(367 / var(--break) * 100vw);
	background: url(images/page/bg_foot01.jpg) no-repeat center bottom / cover;
	content: '';
}
.area_foot01 .copy {
	margin-bottom: calc(36 / var(--break) * 100vw);
	line-height: 1.88;
}
.area_foot01 .copy em {
	display: inline-block;
	line-height: 1;
}
.area_foot01 .row01 {
	gap: 0 4.3%;
	line-height: 1.45;
}
.area_foot01 .row01 .col {
	max-width: 270px;
	width: 21.742%;
	background: url(images/page/box_foot01.png) no-repeat center top / contain;
}
.area_foot01 .row01 .col:before {
	display: block;
	padding-top: 82.3%;
	content: '';
}
.area_foot01 .row02 .tel_foot {
	width: 32%;
}
.area_foot01 .row02 .web_foot {
	width: 32%;
}
.area_foot01 .row02 .line_foot {
	width: 32%;
}
.bg_foot01 .inner {
	width: 95%;
}
.link_foot dt {
	line-height: 1;
}
.link_foot dt span {
	display: inline-block;
	position: relative;
}
.link_foot dt span:before,
.link_foot dt span:after {
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	width: calc(8 / var(--break) * 100vw);
	height: calc(8 / var(--break) * 100vw);
	margin: auto;
	border-radius: 100%;
	background: var(--color05);
	content: '';
}
.link_foot dt span:before {
	left: -0.75em;
}
.link_foot dt span:after {
	right: -0.55em;
}
.link_foot dd ul li {
	position: relative;
}
.link_foot dd ul li:not(:last-child) {
	margin-right: 0.1em;
	padding-right: 1em;
}
.link_foot dd ul li:not(:last-child):after {
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	width: 1em;
	height: 1em;
	content: '｜';
}
.bnr_foot01 {
	max-width: 605px;
	width: 100%;
}
.pagetop {
	position: fixed;
	right: calc(22 / var(--break) * 100vw);
	bottom: calc(17 / var(--break) * 100vw);
	z-index: 1000;
	width: calc(79 / var(--break) * 100vw);
}
.copyright {
	height: calc(80 / var(--break) * 100vw);
	letter-spacing: 0.3em;
}
@media(min-width: 768px) and (max-width:1599px) {
}
@media(min-width: 768px) and (max-width:1299px) {
}
@media(max-width: 767px) {
	footer {
		padding-top: calc(32 / var(--break) * 100vw);
	}
	.main_foot {
		padding-bottom: 7.5vw;
	}
	.main_foot .inner {
		max-width: calc(702 / var(--break) * 100vw);
	}
	.logo_foot {
		max-width: calc(626 / var(--break) * 100vw);
		margin-bottom: 7.4vw;
	}
	.address_foot {
		margin-bottom: 8vw;
	}
	.tbl_time03 {
		max-width: 100% !important;
	}
	.tbl_time03 thead th {
		padding: 3.7vw 0 4.5vw;
		font-size: 1rem;
	}
	.tbl_time03 tbody tr th,
	.tbl_time03 tbody tr td {
		padding: 3.6vw 0 0.9vw;
	}
	.tbl_time03 tbody tr:last-child th,
	.tbl_time03 tbody tr:last-child td {
		padding-bottom: 4vw;
	}
	.tbl_time03 .tbl_caption {
		margin-top: 3.3vw;
		line-height: 1.29;
	}
	.row_foot01 > .col_l {
		max-width: 100%;
		width: 100%;
		margin-bottom: 8vw;
	}
	.row_foot01 > .col_l dl {
		gap: calc(30 / var(--break) * 100vw) 0;
		width: calc(600 / var(--break) * 100vw);
		margin: 0 auto;
	}
	.row_foot01 > .col_l dt {
		width: calc(96 / var(--break) * 100vw);
	}
	.row_foot01 > .col_l dd {
		width: calc(100% - (116 / var(--break) * 100vw));
	}
	.row_foot01 > .col_l dd p {
		font-size: calc(26 / var(--break) * 100vw);
		letter-spacing: 0;
		line-height: 1.23;
	}
	.row_foot01 > .col_r {
		max-width: 100%;
		width: 100%;
	}
	.area_foot01 {
		padding: 2.6vw 0 8vw;
	}
	.area_foot01:before {
		top: calc(-32 / var(--break) * 100vw);
		height: calc(32 / var(--break) * 100vw);
	}
	.area_foot01:after {
		height: calc(646 / var(--break) * 100vw);
		background-image: url(images/page/bg_foot01_sp.jpg);
	}
	.area_foot01 .copy {
		margin-bottom: 6vw;
		font-size: calc(30 / var(--break) * 100vw);
		letter-spacing: 0;
		line-height: 2;
	}
	.area_foot01 .copy em {
		font-size: calc(40 / var(--break) * 100vw);
		letter-spacing: 0;
	}
	.area_foot01 .row01 {
		gap: calc(30 / var(--break) * 100vw) calc(30 / var(--break) * 100vw);
		font-size: calc(26 / var(--break) * 100vw);
		letter-spacing: 0.05em;
		line-height: 1.54;
	}
	.area_foot01 .row01 .col {
		max-width: none;
		width: calc(270 / var(--break) * 100vw);
		height: calc(222 / var(--break) * 100vw);
		padding-top: 2vw;
	}
	.area_foot01 .row01 .col:before {
		padding-top: 0;
	}
	.area_foot01 .row02 {
		gap: 4vw 0;
		width: calc(600 / var(--break) * 100vw);
		margin: 0 auto;
	}
	.area_foot01 .row02 .tel_foot {
		width: 100%;
	}
	.area_foot01 .row02 .web_foot {
		width: 100%;
	}
	.area_foot01 .row02 .line_foot {
		width: 100%;
	}
	.bg_foot01 .inner {
		width: calc(702 / var(--break) * 100vw);
	}
	.link_foot {
		margin-bottom: 6.6vw;
	}
	.link_foot dt {
		font-size: calc(36 / var(--break) * 100vw);
		line-height: 0.8;
	}
	.link_foot dd {
		margin: 0 4vw;
	}
	.link_foot dd ul {
		font-size: calc(28 / var(--break) * 100vw);
		letter-spacing: 0;
		line-height: 1.64;
	}
	.bnr_foot01 {
		max-width: 100%;
		width: calc(605 / var(--break) * 100vw);
	}
	.copyright {
		font-size: 75%;
		letter-spacing: 0.1em;
		padding: 3vw 0 20vw;
		height: auto;
	}
	.pagetop {
		display: none!important;
	}
	.fix {
		position: fixed;
		width: 100%;
		left: 0;
		bottom: 0;
		z-index: 9;
	}
	.fix_tel {
		width: calc(280 / var(--break) * 100dvw);
	}
	.fix_web {
		width: calc(160 / var(--break) * 100dvw);
	}
	.fix_line {
		width: calc(160 / var(--break) * 100dvw);
	}
	.pagetop_sp {
		width: calc(150 / var(--break) * 100dvw);
	}
	.fix a,
	.fix a img {
		display: block;
		width: 100%;
	}
}

/* グーグルマップ
------------------------------------------------------------------*/
.map {
	position: relative;
	width: 100%;
	padding: calc(500 / var(--break) * 100vw) 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-family: "work-sans", sans-serif;
	font-weight: 700;
	font-style: normal;
	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 {
	height: calc(60 / var(--break) * 100vw);
	background: #fff url("images/page/icn_map.svg") no-repeat left calc(28 / var(--break) * 100vw) center / calc(18 / var(--break) * 100vw) auto;
	border-radius: 100px;
	border-bottom-left-radius: 0;
	border: 1px solid var(--color11);
}
.btn_map a::after {
	content: "";
	position: absolute;
	top: 0;
	right: calc(30 / var(--break) * 100vw);
	width: calc(19 / var(--break) * 100vw);
	height: 100%;
	background: url(images/page/arw_btn01.svg) no-repeat right center / contain;
}
@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));
	}
}
@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);
		font-size: 1rem;
		letter-spacing: 0.1em;
		position: relative;
		left: auto;
		top: auto;
	}
	.btn_map a {
		height: calc(100 / var(--break) * 100vw);
		background-position: left 4vw center;
		background-size: calc(26 / var(--break) * 100vw) auto;
	}
	.btn_map a::after {
		right: 4vw;
		width: calc(29 / var(--break) * 100vw);
	}
}