@charset "utf-8";
/*
Theme Name: res
Version: 1.3.2
Author: T8,Inc.
*/
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:300,400,700&display=swap');
:root {
	--break: 1920;
	--guideline-color: #45a8d5;
	font-size: calc(16 / var(--break) * 100vw);
	--color01: #45a8d5;
	--color02: #40b6b5;
	--color03: #ee93b0;
	--color04: #3f5794;
	--color05: #7cd687;
	--color06: #fff3c9;
	--color07: #9dd3ec;
	--color08: #f284a6;
	--color09: #f6f4fe;
	--color10: #fdf4f7;
	--color11: #ebf6fb;
	--color12: #1bbbbd;
	--color13: #a692f2;
	--color14: #e9619d;
	--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: #45a8d5;
	text-decoration: underline;
}
.minr {
	font-family: "shippori-mincho-b1", sans-serif;
	font-weight: 400;
	font-style: normal;
}
.minb {
	font-family: "shippori-mincho-b1", sans-serif;
	font-weight: 600;
	font-style: normal;
}
.abo {
	font-family: "aboreto", sans-serif;
	font-weight: 400;
	font-style: normal;
}
.made {
	font-family: "madelinette", sans-serif;
	font-weight: 400;
	font-style: normal;
}
.kinu {
	font-family: "kinuta-mincho-stdn", sans-serif;
	font-weight: 400;
	font-style: normal;
}
.txt_grd01 {
	color: #ac8df4;
	background: linear-gradient(90deg, rgba(118, 188, 221, 1) 0%, rgba(172, 141, 244, 1) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	text-shadow: none;
	display: inline-block;
}
.txt_grd02 {
	color: #40b6b5;
	background: linear-gradient(90deg, rgba(69, 168, 213, 1) 0%, rgba(64, 182, 181, 1) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	text-shadow: none;
	display: inline-block;
}
.txt_grd03 {
	color: #ee93b0;
	background: linear-gradient(90deg, rgba(238, 147, 176, 1) 0%, rgba(235, 163, 124, 1) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	text-shadow: none;
	display: inline-block;
}
.txt_grd04 {
	color: #7cd687;
	background: linear-gradient(90deg,rgba(118, 188, 221, 1) 0%, rgba(124, 214, 135, 1) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	text-shadow: none;
	display: inline-block;
}
.bg_grd01 {
	background: #AC8DF4;
	background: linear-gradient(90deg, rgba(118, 188, 221, 1) 0%, rgba(172, 141, 244, 1) 100%);
}
.bg_grd02 {
	background: #7CD687;
	background: linear-gradient(90deg, rgba(118, 188, 221, 1) 0%, rgba(124, 214, 135, 1) 100%);
}
.bg_grd03 {
	background: #EE93B0;
	background: linear-gradient(90deg, rgba(235, 163, 124, 1) 0%, rgba(238, 147, 176, 1) 100%);
}

/*ここまで*/
html, body {
	font-size: 1.125rem;
	font-weight: 300;
	line-height: 2;
	color: #333;
	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;
}
.fsi {
	font-style: italic;
}
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
{
	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;
}
.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 {
		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;
}
.wrap_head01 {
	width: calc(535 / var(--break) * 100vw);
}
header h1 {
	width: calc(335 / var(--break) * 100vw);
}
.address_head {
	left: calc(175 / var(--break) * 100vw);
	bottom: calc(15 / var(--break) * 100vw);
}
.address_head .icn {
	width: calc(14 / var(--break) * 100vw);
}
.row_head01 {
	padding-right: calc(110 / var(--break) * 100vw);
}
.tel_head a {
	outline: none!important;
}
@media(min-width: 768px) and (max-width:1599px) {

}
@media(min-width: 768px) and (max-width:1299px) {
	.wrap_head01 {
		width: calc(435 / var(--break) * 100vw);
	}
	header h1 {
		width: calc(280 / var(--break) * 100vw);
	}
	.address_head {
		position: relative;
		left: auto;
		bottom: auto;
		margin-top: calc(15 / var(--break) * 100vw);
		margin-left: calc(30 / var(--break) * 100vw);
	}
	.address_head .address {
		line-height: 1.3;
		font-size: 1rem;
		letter-spacing: .1em;
	}
	.tel_head {
		width: calc(280 / var(--break) * 100vw)!important;
	}
	.web_head {
		width: calc(210 / var(--break) * 100vw)!important;
	}
}
@media(max-width: 767px) {
	.wrap_head01 {
		width: auto;
	}
	header h1 {
		width: calc(433 / var(--break) * 100vw);
	}
	.address_head, .row_head01 {
		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: 800px;
	height: 100vh;
}
.main_img.tab .slide_main li {
	height: auto;
}
.main01 {
	background: url(images/index/main01.jpg)no-repeat right 30% center / cover;
}
.main02 {
	background: url(images/index/main02.jpg)no-repeat right 30% center / cover;
}
.main03 {
	background: url(images/index/main03.jpg)no-repeat right 30% center / cover;
}
.wrap_main01 {
	left: 4%;
	top: 56%;
	transform: translateY(-50%);
}
.copy_main01 .copy01:after {
	content: "";
	display: block;
	width: calc(160 / var(--break) * 100vw);
	height: 1px;
	background: #333;
	margin-left: calc(20 / var(--break) * 100vw);
}
.copy_main01 .copy02 .fz88 {
	font-size: 5.5rem;
}
.box_main01 {
	width: calc(760 / var(--break) * 100vw);
}
.box_main01 .deco {
	width: calc(298 / var(--break) * 100vw);
	left: calc(-145 / var(--break) * 100vw);
	top: calc(15 / var(--break) * 100vw);
}
.box_main01 .ttl {
	height: calc(65 / var(--break) * 100vw);
}
.box_main01 .txt01 {
	border-bottom: 1px solid #3f5794;
	max-width: 600px;
}
.box_main01 .ccl {
	width: calc(100 / var(--break) * 100vw);
	height: calc(100 / var(--break) * 100vw);
}
.box_main01 .num {
	letter-spacing: -.05em;
}
.row_main01 {
	right: calc(50 / var(--break) * 100vw);
	bottom: 0;
	gap: 0 calc(30 / var(--break) * 100vw);
}
.row_main01:before {
	content: "";
	position: absolute;
	background: url("images/index/img_main02.png")no-repeat center / cover;
	width: calc(251 / var(--break) * 100vw);
	height: calc(188 / var(--break) * 100vw);
	right: calc(-44 / var(--break) * 100vw);
	bottom: calc(-4 / var(--break) * 100vw);
}
.row_main01 .col {
	background: url("images/index/bg_main01.svg")no-repeat center / cover;
	width: calc(193 / var(--break) * 100vw);
	height: calc(209 / var(--break) * 100vw);
}
.row_main01 .col_r {
	background-image: url("images/index/bg_main02.svg");
}
.en_main01 {
	right: calc(80 / var(--break) * 100vw);
	bottom: calc(65 / var(--break) * 100vw);
}
@media(min-width: 768px) and (max-width:1599px) {
	.copy_main01 .copy01 {
		font-size: 2.5rem;
	}
	.copy_main01 .copy01 em {
		font-size: 3.75rem;
	}
	.copy_main01 .copy02 {
		font-size: 3.75rem;
	}
	.copy_main01 .copy02 .fz88 {
		font-size: 5rem;
	}
}
@media(min-width: 768px) and (max-width:1299px) {
	.wrap_main01 {
		left: 2%;
		top: 58%;
	}
	.copy_main01 .copy01 {
		font-size: 2rem;
	}
	.copy_main01 .copy01 em {
		font-size: 3.125rem;
	}
	.copy_main01 .copy02 {
		font-size: 3.5rem;
	}
	.copy_main01 .copy02 .fz88 {
		font-size: 4.5rem;
	}
	.box_main01 {
		width: calc(640 / var(--break) * 100vw);
	}
	.box_main01 .deco {
		width: calc(208 / var(--break) * 100vw);
		left: calc(-55 / var(--break) * 100vw);
	}
	.box_main01 .ttl {
		font-size: 1.25rem;
		height: calc(55 / var(--break) * 100vw);
	}
	.box_main01 .ttl em {
		font-size: 1.875rem;
	}
	.box_main01 .ccl {
		font-size: 1.25rem;
		width: calc(80 / var(--break) * 100vw);
		height: calc(80 / var(--break) * 100vw);
	}
	.box_main01.ja01 {
		font-size: 2rem;
	}
	.box_main01 .num {
		font-size: 6.5rem;
	}
	.box_main01 .ja02 {
		font-size: 1.25rem;
	}
	.box_main01 .ja02 span {
		font-size: 2.5rem;
	}
	.row_main01 {
		right: calc(50 / var(--break) * 100vw);
		font-size: 1.5rem;
	}
	.row_main01:before {
		width: calc(226 / var(--break) * 100vw);
		height: calc(169 / var(--break) * 100vw);
		right: calc(-44 / var(--break) * 100vw);
	}
	.row_main01 .col {
		width: calc(154 / var(--break) * 100vw);
		height: calc(167 / var(--break) * 100vw);
	}
	.en_main01 {
		font-size: 7rem;
	}
}
@media only screen and (max-width: 767px) {
	.main_img .slide_main li {
		min-height: auto;
		height: calc(100svh - calc(120 / var(--break) * 100vw));
	}
	.main01 {
		background: url(images/index/main01_sp.jpg)no-repeat center / cover;
	}
	.main02 {
		background: url(images/index/main02_sp.jpg)no-repeat center / cover;
	}
	.main03 {
		background: url(images/index/main03_sp.jpg)no-repeat center / cover;
	}
	.wrap_main01 {
		left: 4%;
		top: 56%;
		transform: translateY(-50%);
	}
	.copy_main01 .copy01 {
		font-size: 1rem;
		margin-bottom: 3vw;
	}
	.copy_main01 .copy01 em {
		font-size: 1.5rem;
	}
	.copy_main01 .copy01:after {
		width: calc(120 / var(--break) * 100vw);
		margin-left: calc(20 / var(--break) * 100vw);
	}
	.copy_main01 .copy02, .copy_main01 .copy02 span {
		font-size: 1.375rem;
		line-height: 1.5;
	}
	.copy_main01 .copy02 .fz88 {
		font-size: 1.8125rem;
	}
	.box_main01 {
		width: 100%;
		margin-bottom: 2.5vw;
	}
	.box_main01 .box {
		padding: 2vw 3vw 2.5vw;
	}
	.box_main01 .deco {
		width: calc(142 / var(--break) * 100vw);
		left: calc(-10 / var(--break) * 100vw);
		top: calc(30 / var(--break) * 100vw);
	}
	.box_main01 .ttl {
		font-size: .75rem;
		height: calc(60 / var(--break) * 100vw);
	}
	.box_main01 .ttl em {
		font-size: 1rem;
	}
	.box_main01 .txt01 {
		letter-spacing: .1em;
		padding-bottom: 2vw;
		margin-bottom: .5vw;
		font-size: .75rem;
		max-width: calc(554 / var(--break) * 100vw);
	}
	.box_main01 .ccl {
		font-size: .625rem;
		width: calc(94 / var(--break) * 100vw);
		height: calc(94 / var(--break) * 100vw);
	}
	.box_main01 .ja01 {
		font-size: 1.125rem;
	}
	.box_main01 .num {
		font-size: 3.4375rem;
		letter-spacing: -.05em;
	}
	.box_main01 .ja02 {
		font-size: .625rem;
	}
	.box_main01 .ja02 span {
		font-size: 1.375rem;
	}
	.txt_main01 {
		margin-bottom: 5.5vw;
	}
	.row_main01 {
		width: calc(418 / var(--break) * 100vw);
		font-size: .9375rem;
		right: calc(12 / var(--break) * 100vw);
		left: 0;
		margin: auto;
		bottom: 0;
		gap: 0 calc(30 / var(--break) * 100vw);
	}
	.row_main01:before {
		width: calc(280 / var(--break) * 100vw);
		height: calc(210 / var(--break) * 100vw);
		right: calc(-75 / var(--break) * 100vw);
		bottom: calc(-20 / var(--break) * 100vw);
	}
	.en_main01 {
		font-size: 3.8125rem;
		right: 0;
		width: 100%;
		text-align: center;
		bottom: calc(85 / var(--break) * 100vw);
		transform: rotate(-5deg);
	}
	.address_main .icn {
		width: calc(24 / var(--break) * 100vw);
	}
}

/* グローバルナビゲーション gnav
------------------------------------------------------------------*/
.btn_gnav_sp {
	position: fixed;
	top: 0;
	right: 0;
	height: calc(110 / var(--break) * 100vw);
	width: calc(110 / var(--break) * 100vw);
	background: #3f5794;
	z-index: 10000;
	outline: none;
}
.btn_gnav_sp:hover {
	cursor: pointer;
}
.btn_gnav_sp .txt_gnav {
	position: absolute;
	width: calc(55 / var(--break) * 100vw);
	height: calc(12 / var(--break) * 100vw);
	right: 0;
	left: 0;
	bottom: calc(25 / var(--break) * 100vw);
	margin: auto;
	line-height: 1;
}
.btn_gnav_sp .icn_gnav {
	width: calc(40 / var(--break) * 100vw);
	height: 1px;
	position: absolute;
	top: calc(-25 / var(--break) * 100vw);
	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: calc(-10 / var(--break) * 100vw);
}
.btn_gnav_sp .icn_gnav:after {
	bottom: calc(-10 / var(--break) * 100vw);
}
.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: calc(160 / var(--break) * 100vw) 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;
	touch-action: auto !important;
	max-width: calc(600 / var(--break) * 100vw);
}
.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: calc(200 / var(--break) * 100vw);
}
.gnav_sp .nav_main > ul {
	padding: 0 calc(80 / var(--break) * 100vw);
	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 > a {
	padding: calc(12 / var(--break) * 100vw) 0 calc(12 / var(--break) * 100vw) calc(60 / var(--break) * 100vw);
	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;
}
.gnav_sp .nav_main > ul > li > a:after {
	content: "";
	position: absolute;
	left: 0;
	top: 1.1em;
	width: 0;
	height: 0;
	border-top: calc(16 / var(--break) * 100vw) solid #9dd3ec;
	border-right: calc(10 / var(--break) * 100vw) solid transparent;
	border-left: calc(10 / 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;
}
/* パーフェクトスクロールバー */
.ps__thumb-y {
	background: #3f5794 !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 only screen and (max-width: 767px) {
	.btn_gnav_sp {
		top: 3vw;
		right: 3.2vw;
		height: calc(100 / var(--break) * 100vw);
		width: calc(100 / var(--break) * 100vw);
	}
	.btn_gnav_sp .txt_gnav {
		width: calc(62 / var(--break) * 100vw);
		height: auto;
		line-height: 2;
		bottom: 0;
	}
	.btn_gnav_sp .icn_gnav {
		width: calc(40 / var(--break) * 100vw);
		height: 2px;
		top: -3.5vw;
	}
	.btn_gnav_sp .icn_gnav:before, .btn_gnav_sp .icn_gnav:after {
		height: 2px;
	}
	.btn_gnav_sp .icn_gnav:before {
		top: -1.5vw;
	}
	.btn_gnav_sp .icn_gnav:after {
		bottom: -1.5vw;
	}
	.gnav_sp {
		padding: 19vw 0 0;
		max-width: 100%;
	}
	.gnav_sp .nav_main {
		padding-bottom: 20vw;
	}
	.gnav_sp .nav_main > ul {
		padding: 0 3vw;
		font-size: 1rem;
		letter-spacing: 0;
	}
	.gnav_sp .nav_main > ul > li > a {
		padding: 3vw 4vw 3vw 5.5vw;
	}
	.gnav_sp .nav_main > ul > li > a:after {
		top: 1.3em;
		border-top: calc(20 / var(--break) * 100vw) solid #9dd3ec;
		border-right: calc(12 / var(--break) * 100vw) solid transparent;
		border-left: calc(12 / var(--break) * 100vw) solid transparent;
	}
	.ps__thumb-y, .ps--active-x > .ps__rail-x, .ps--active-y > .ps__rail-y {
		width: 2px!important;
	}
}


/* おすすめプラン recommendation
------------------------------------------------------------------*/
.ttl_recommendation01 .ja:before, .ttl_recommendation01 .ja:after {
	content: "";
	display: block;
	flex: 1;
	background: #333;
	height: 1px;
}
.slide_recommendation01 li {
	margin: 0 calc(45 / var(--break) * 100vw);
}
.slide_recommendation01 .slick-prev, .slide_recommendation01 .slick-next {
	width: calc(30 / var(--break) * 100vw);
	height: calc(54 / var(--break) * 100vw);
	background: url("images/index/arw_recommendation.svg")no-repeat center / cover;
	z-index: 9;
	top: 0;
	bottom: 0;
	margin: auto;
	transform: none;
}
.slide_recommendation01 .slick-prev:before, .slide_recommendation01 .slick-next:before {
	display: none;
}
.slide_recommendation01 .slick-prev {
	left: 23.7%;
}
.slide_recommendation01 .slick-next {
	right: 23.7%;
	transform: scaleX(-1);
}
.bnr_recommendation01 {
	width: calc(875 / var(--break) * 100vw);
}
@media(min-width: 768px) and (max-width:1599px) {
	.slide_recommendation01 .slick-prev {
		left: 18.7%;
	}
	.slide_recommendation01 .slick-next {
		right: 18.7%;
	}
}
@media(min-width: 768px) and (max-width:1299px) {
	.slide_recommendation01 .slick-prev {
		left: 11.7%;
	}
	.slide_recommendation01 .slick-next {
		right: 11.7%;
	}
}
@media(max-width: 767px) {
	.recommendation {
		padding: 10.5vw 0 13.5vw;
	}
	.ttl_recommendation01 .en {
		font-size: 1.8125rem;
	}
	.ttl_recommendation01 .ja {
		font-size: 1.5625rem;
	}
	.ttl_recommendation01 .ja span {
		padding: 0 calc(35 / var(--break) * 100vw);
	}
	.slide_recommendation01 {
		width: calc(646 / var(--break) * 100vw);
		margin: 0 auto;
	}
	.slide_recommendation01 li {
		margin: 0;
	}
	.slide_recommendation01 .slick-prev, .slide_recommendation01 .slick-next {
		width: calc(20 / var(--break) * 100vw);
		height: calc(36 / var(--break) * 100vw);
	}
	.slide_recommendation01 .slick-prev {
		left: -6vw;
	}
	.slide_recommendation01 .slick-next {
		right: -6vw;
	}
	.bnr_recommendation01 {
		width: auto;
	}
}


/* counseling
------------------------------------------------------------------*/
.bg_counseling01:before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	background: url("images/page/bg_counseling01.png")no-repeat left 14.5% bottom calc(-117 / var(--break) * 100vw) / calc(195 / var(--break) * 100vw) auto, url("images/page/bg_counseling02.png")no-repeat right 14.5% bottom calc(-117 / var(--break) * 100vw) / calc(241 / var(--break) * 100vw) auto;
	z-index: 1;
}
.bg_counseling01:after {
	content: "";
	position: absolute;
	width: 100%;
	height: calc(30 / var(--break) * 100vw);
	background: url("images/page/ptn02.png")repeat left top / calc(20 / var(--break) * 100vw) auto;
	left: 0;
	bottom: 0;
	z-index: 0;
}
.ttl_counseling01 .en {
	font-size: 9rem;
	letter-spacing: .15em;
}
.bg_counseling02 {
	margin-top: calc(-50 / var(--break) * 100vw);
}
.bg_counseling02:after {
	content: "";
	position: absolute;
	width: 100%;
	height: calc(100% - calc(50 / var(--break) * 100vw));
	left: 0;
	bottom: 0;
	z-index: -1;
	background: url("images/page/bg_counseling03.jpg")no-repeat center / cover;
}
.list_counseling01 li {
	width: 48%;
	position: relative;
	padding-left: calc(40 / var(--break) * 100vw);
	padding-bottom: calc(10 / var(--break) * 100vw);
}
.list_counseling01 li:not(:nth-last-child(-n+2)) {
	border-bottom: 1px solid #333;
	margin-bottom: calc(10 / var(--break) * 100vw);
}
.list_counseling01 li:before {
	content: "";
	position: absolute;
	background: url("images/page/icn_check.svg")no-repeat center / cover;
	width: calc(20 / var(--break) * 100vw);
	height: calc(20 / var(--break) * 100vw);
	left: 0;
	top: .5em;
}
.row_counseling01 {
	max-width: 1000px;
}
.row_counseling01 .col {
	width: 48%;
}
.row_counseling01 .col_l a {
	outline: 1px solid #333;
}
.row_counseling01 .col_l .bg {
	height: calc(120 / var(--break) * 100vw);
}
.row_counseling01 .col_l .icn {
	width: calc(24 / var(--break) * 100vw);
}
.row_counseling01 .col_l .time {
	height: calc(40 / var(--break) * 100vw);
}
.row_counseling01 .col_r {
	animation: pulseEffect 2s ease-in-out infinite;
}
@keyframes pulseEffect {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.05);
  }
}
.row_counseling01 .col_r a {
	height: calc(160 / var(--break) * 100vw);
	background: url("images/page/bg_counseling04.png")no-repeat left calc(5 / var(--break) * 100vw) bottom calc(-5 / var(--break) * 100vw) / calc(120 / var(--break) * 100vw) auto;
}
.row_counseling01 .col_r a:after {
	border-width: calc(20 / var(--break) * 100vw);
	opacity: .5;
}
@media(min-width: 768px) and (max-width:1599px) {
	.bg_counseling01:before {
		background-position: left 5% bottom calc(-117 / var(--break) * 100vw), right 5% bottom calc(-117 / var(--break) * 100vw);
	}
}
@media(min-width: 768px) and (max-width:1299px) {
	.bg_counseling01:before {
		background-size: calc(136 / var(--break) * 100vw) auto, calc(168 / var(--break) * 100vw) auto;
	}
}
@media(max-width: 767px) {
	.bg_counseling01 {
		padding: 9.5vw 0 12vw;
	}
	.bg_counseling01:before {
		background: url("images/page/bg_counseling01.png")no-repeat left 1.6vw bottom / calc(95 / var(--break) * 100vw) auto, url("images/page/bg_counseling02.png")no-repeat right 1vw bottom / calc(118 / var(--break) * 100vw) auto;
	}
	.ttl_counseling01 .en {
		font-size: 2.75rem;
		letter-spacing: .15em;
	}
	.ttl_counseling01 .ja {
		font-size: 1.1875rem;
	}
	.bg_counseling02 {
		margin-top: calc(-65 / var(--break) * 100vw);
		padding-bottom: calc(105 / var(--break) * 100vw);
	}
	.bg_counseling02:after {
		height: calc(100% - calc(65 / var(--break) * 100vw));
		background: url("images/page/bg_counseling03_sp.jpg")no-repeat center / cover;
	}
	.box_counseling01 {
		padding: 6.5vw 3.5vw 7vw;
	}
	.list_counseling01 {
		display: block;
		font-size: 1rem;
		letter-spacing: 0;
		line-height: 1.7;
	}
	.list_counseling01 li {
		width: 100%;
		position: relative;
		padding-left: 6vw;
		padding-bottom: 1.5vw;
		border-bottom: 1px solid #333!important;
	}
	.list_counseling01 li:not(:last-child) {
		margin-bottom: 1vw;
	}
	.list_counseling01 li:before {
		width: calc(25 / var(--break) * 100vw);
		height: calc(25 / var(--break) * 100vw);
		top: .5em;
	}
	.ttl_counseling02 {
		font-size: 1.25rem;
	}
	.row_counseling01 {
		max-width: calc(600 / var(--break) * 100vw);
		gap: calc(30 / var(--break) * 100vw) 0;
	}
	.row_counseling01 .col {
		width: 100%;
	}
	.row_counseling01 .col .ja01 {
		font-size: .75rem;
	}
	.row_counseling01 .col_l .num .abo {
		font-size: 1.5625rem;
	}
	.row_counseling01 .col_l .time {
		height: calc(60 / var(--break) * 100vw);
		font-size: .75rem;
		letter-spacing: .1em;
	}
	.row_counseling01 .col_r a {
		height: calc(175 / var(--break) * 100vw);
		background: url("images/page/bg_counseling04.png")no-repeat left calc(22 / var(--break) * 100vw) bottom  / calc(130 / var(--break) * 100vw) auto;
	}
	.row_counseling01 .col_r a:after {
		border-width: calc(22 / var(--break) * 100vw);
	}
	.row_counseling01 .col_r .ja02 {
		font-size: 1.4375rem;
	}
}


/* touble
------------------------------------------------------------------*/
.bg_trouble01 {
	background: url("images/index/bg_trouble01.jpg")no-repeat center / cover;
}
.bg_trouble01:before {
	content: "";
	position: absolute;
	width: calc(180 / var(--break) * 100vw);
	left: 0;
	top: 0;
	height: 100%;
	background: url("images/page/ptn01.png")repeat left top / calc(20 / var(--break) * 100vw) auto;
	z-index: 0;
}
.copy_trouble01 {
	width: calc(190 / var(--break) * 100vw);
	right: 5%;
	top: calc(-80 / var(--break) * 100vw);
	gap: 0 calc(30 / var(--break) * 100vw);
	height: calc(630 / var(--break) * 100vw);
}
.copy_trouble01 > span > span {
	width: calc(80 / var(--break) * 100vw);
	background: #7CD687;
	background: linear-gradient(0deg, rgba(124, 214, 135, 1) 0%, rgba(118, 188, 221, 1) 100%);
}
.copy_trouble01 > span:after {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background: #fff;
	right: calc(-10 / var(--break) * 100vw);
	bottom: calc(-10 / var(--break) * 100vw);
	z-index: -1;
}
.box_trouble01 {
	width: 50%;
	max-width: 840px;
}
.box_trouble01 .en {
	font-size: 7.75rem;
	letter-spacing: .1em;
}
.list_trouble01 li {
	position: relative;
	padding-bottom: calc(10 / var(--break) * 100vw);
	padding-left: calc(40 / var(--break) * 100vw);
	border-bottom: 1px solid #33333333;
}
.list_trouble01 li:not(:first-child) {
	margin-top: calc(10 / var(--break) * 100vw);
}
.list_trouble01 li:before {
	content: "";
	position: absolute;
	background: url("images/page/icn_check.svg")no-repeat center / cover;
	width: calc(20 / var(--break) * 100vw);
	height: calc(20 / var(--break) * 100vw);
	left: 0;
	top: .45em;
}
.bg_trouble02 {
	background: url("images/index/frame_trouble01.svg")no-repeat center bottom -1px / 100% auto, linear-gradient(90deg, rgba(69, 168, 213, 1) 0%, rgba(63, 87, 148, 1) 100%);
}
.txt_trouble01 .wrap:before {
	content: "";
	position: absolute;
	background: url("images/index/txt_trouble01.svg")no-repeat center / cover;
	width: calc(841 / var(--break) * 100vw);
	height: calc(227 / var(--break) * 100vw);
	left: calc(-55 / var(--break) * 100vw);
	bottom: calc(-10 / var(--break) * 100vw);
	z-index: -1;
}
.txt_trouble01 .wrap:after {
	content: "";
	position: absolute;
	background: url("images/index/deco_trouble01.svg")no-repeat center / cover;
	width: calc(140 / var(--break) * 100vw);
	height: calc(141 / var(--break) * 100vw);
	right: 0;
	top: calc(-15 / var(--break) * 100vw);
	z-index: -1;
}
@media(min-width: 768px) and (max-width:1599px) {
	
}
@media(min-width: 768px) and (max-width:1299px) {
	.bg_trouble01 {
		padding: calc(100 / var(--break) * 100vw) 5% calc(60 / var(--break) * 100vw);
	}
	.copy_trouble01 {
		width: calc(150 / var(--break) * 100vw);
		right: 4%;
		font-size: 2.25rem;
	}
	.copy_trouble01 > span > span {
		width: calc(60 / var(--break) * 100vw);
	}
	.box_trouble01 {
		width: 60%;
		padding-top: calc(65 / var(--break) * 100vw);
	}
	.box_trouble01 .en {
		font-size: 6.5rem;
	}
}
@media(max-width: 767px) {
	.trouble {
		padding-top: calc(200 / var(--break) * 100vw);
	}
	.bg_trouble01 {
		padding: calc(575 / var(--break) * 100vw) 3.2vw calc(80 / var(--break) * 100vw);
		background: url("images/index/bg_trouble01_sp.jpg")no-repeat center top / cover;
	}
	.bg_trouble01:before {
		width: calc(80 / var(--break) * 100vw);
		background-size: calc(10 / var(--break) * 100vw) auto;
	}
	.copy_trouble01 {
		font-size: 1.25rem;
		right: calc(50 / var(--break) * 100vw);
		top: calc(-100 / var(--break) * 100vw);
		height: calc(600 / var(--break) * 100vw);
	}
	.box_trouble01 {
		width: 100%;
		max-width: 100%;
		padding: 9vw 3vw 11vw;
	}
	.box_trouble01 .en {
		font-size: 3.875rem;
		letter-spacing: .15em;
	}
	.list_trouble01 {
		font-size: 1rem;
		letter-spacing: 0;
		line-height: 1.7;
	}
	.list_trouble01 li {
		padding-bottom: 2.6vw;
		padding-left: 6vw;
	}
	.list_trouble01 li:not(:first-child) {
		margin-top: 1vw;
	}
	.list_trouble01 li:before {
		width: calc(25 / var(--break) * 100vw);
		height: calc(25 / var(--break) * 100vw);
	}
	.bg_trouble02 {
		background: url("images/index/frame_trouble01.svg")no-repeat center bottom -1px / auto calc(80 / var(--break) * 100vw), linear-gradient(90deg, rgba(69, 168, 213, 1) 0%, rgba(63, 87, 148, 1) 100%);
	}
	.txt_trouble01 {
		font-size: 1.25rem;
		line-height: 2;
	}
	.txt_trouble01 em {
		line-height: 1.3;
		font-size: 2rem;
	}
	.txt_trouble01 em span {
		font-size: 1.4375rem;
	}
	.txt_trouble01 .wrap:before {
		width: calc(661 / var(--break) * 100vw);
		height: calc(180 / var(--break) * 100vw);
		left: calc(5 / var(--break) * 100vw);
		bottom: calc(55 / var(--break) * 100vw);
	}
	.txt_trouble01 .wrap:after {
		width: calc(83 / var(--break) * 100vw);
		height: calc(85 / var(--break) * 100vw);
		right: calc(-5 / var(--break) * 100vw);
		top: calc(55 / var(--break) * 100vw);
	}
}


/* マウスピース矯正（インビザライン）とは mouthpiece
------------------------------------------------------------------*/
.mouthpiece {
	padding-bottom: calc(250 / var(--break) * 100vw);
	background: url("images/index/bg_mouthpiece02.svg")no-repeat center bottom / 100% auto;
}
.ttl_common01 .en {
	font-size: 8.375rem;
	letter-spacing: .15em;
}
.box_mouthpiece01 {
	background: url("images/index/bg_mouthpiece01.png")no-repeat right calc(40 / var(--break) * 100vw) bottom 32% / calc(1052 / var(--break) * 100vw) auto;
}
.box_mouthpiece01:before {
	content: "";
	position: absolute;
	width: calc(100 / var(--break) * 100vw);
	left: 0;
	top: 0;
	height: 100%;
	background: url("images/page/ptn01.png")repeat left top / calc(20 / var(--break) * 100vw) auto;
	z-index: 0;
}
.img_mouthpiece01 {
	max-width: calc(659 / var(--break) * 100vw);
}
.img_mouthpiece01 .caption {
	right: calc(-185 / var(--break) * 100vw);
	bottom: calc(-20 / var(--break) * 100vw);
}
.txt_mouthpiece02 {
	max-width: 1000px;
}
@media(min-width: 768px) and (max-width:1599px) {

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

}
@media(max-width: 767px) {
	.mouthpiece {
		padding: 5vw 0 32vw;
		background: url("images/index/bg_mouthpiece02.svg")no-repeat center bottom / auto calc(300 / var(--break) * 100vw);
	}
	.ttl_mouthpiece01 {
		margin-bottom: 6vw;
	}
	.ttl_common01 .en {
		font-size: 4.1875rem;
		margin-bottom: 1.5vw;
	}
	.ttl_mouthpiece01 .en {
		font-size: 2.5rem;
		margin-bottom: 2.5vw;
	}
	.ttl_common01 .ja {
		font-size: 1.5625rem;
		line-height: 1.6;
	}
	.box_mouthpiece01 {
		padding: 6vw 4vw 9vw;
		background: url("images/index/bg_mouthpiece01.png")no-repeat right calc(30 / var(--break) * 100vw) bottom 32% / auto calc(234 / var(--break) * 100vw);
		margin-bottom: 5.5vw;
	}
	.box_mouthpiece01:before {
		width: calc(58 / var(--break) * 100vw);
		background: url("images/page/ptn01.png")repeat left top / calc(10 / var(--break) * 100vw) auto;
	}
	.txt_mouthpiece01 {
		font-size: 1.125rem;
		margin-bottom: 6vw;
	}
	.txt_mouthpiece01 em {
		font-size: 1.4375rem;
		line-height: 1.3;
	}
	.img_mouthpiece01 {
		max-width: calc(498 / var(--break) * 100vw);
	}
	.img_mouthpiece01 .caption {
		position: relative;
		right: auto;
		bottom: auto;
		text-align: center;
		font-size: .75rem;
		margin-top: 2vw;
	}
	.txt_mouthpiece02 {
		max-width: calc(646 / var(--break) * 100vw);
	}
}


/* マウスピース矯正（インビザライン）のメリット merit
------------------------------------------------------------------*/
.bg_common01:before {
	content: "";
	position: absolute;
	width: 100%;
	height: calc(40 / var(--break) * 100vw);
	background: url("images/page/ptn01.png")repeat left top / calc(20 / var(--break) * 100vw) auto;
	left: 0;
}
.bg_common01.top:before { top: 0; }
.bg_common01.bottom:before { bottom: 0; }
.ttl_common02 {
	max-width: 1000px;
	margin-right: auto;
	margin-left: auto;
	height: calc(145 / var(--break) * 100vw);
	background: url("images/page/bdr01.svg")repeat-x left bottom 1px / auto;
}
.ttl_common02 .en {
	left: 0;
	top: 0;
	font-size: 8.75rem;
	letter-spacing: .2em;
	width: 100%;
}
.row_merit01 {
	gap: calc(80 / var(--break) * 100vw) 1.55%;
}
.row_merit01 .col {
	width: 32.3%;
	max-width: 400px;
}
.row_merit01 .num {
	filter: drop-shadow(0 0 calc(5 / var(--break) * 100vw) #fff) drop-shadow(0 0 calc(5 / var(--break) * 100vw) #fff) drop-shadow(0 0 calc(10 / var(--break) * 100vw) #fff);
}
.row_merit01 .col .copy {
	height: calc(70 / var(--break) * 100vw);
	border-bottom: calc(3 / var(--break) * 100vw) solid #45a8d5;
}
.row_merit01 .col:nth-child(2n) .copy {
	border-bottom-color: #a692f2;
}
.bg_merit02 {
	padding-top: calc(175 / var(--break) * 100vw);
	background: url("images/index/deco_merit01.png")no-repeat right 10.5% top calc(135 / var(--break) * 100vw) / calc(390 / var(--break) * 100vw) auto, url("images/index/txt_merit01.svg")no-repeat left 31% top calc(110 / var(--break) * 100vw) / calc(803 / var(--break) * 100vw) auto, url("images/index/frame_merit01.svg")no-repeat center top -1px / 100% auto, linear-gradient(90deg, rgba(235, 163, 124, 1) 0%, rgba(238, 147, 176, 1) 100%);
}
.bg_merit02:before {
	background-image: url("images/page/ptn02.png");
}
.txt_merit01 {
	line-height: 2.3;
}
@media(min-width: 768px) and (max-width:1599px) {
	.bg_merit02 {
		background: url("images/index/deco_merit01.png")no-repeat right 5% top calc(110 / var(--break) * 100vw) / calc(390 / var(--break) * 100vw) auto, url("images/index/txt_merit01.svg")no-repeat left 20% top calc(110 / var(--break) * 100vw) / calc(803 / var(--break) * 100vw) auto, url("images/index/frame_merit01.svg")no-repeat center top -1px / 100% auto, linear-gradient(90deg, rgba(235, 163, 124, 1) 0%, rgba(238, 147, 176, 1) 100%);
	}
}
@media(min-width: 768px) and (max-width:1299px) {
	.bg_merit02 {
		background: url("images/index/deco_merit01.png")no-repeat right 5% top calc(100 / var(--break) * 100vw) / calc(310 / var(--break) * 100vw) auto, url("images/index/txt_merit01.svg")no-repeat left 10% top calc(110 / var(--break) * 100vw) / calc(803 / var(--break) * 100vw) auto, url("images/index/frame_merit01.svg")no-repeat center top -1px / 100% auto, linear-gradient(90deg, rgba(235, 163, 124, 1) 0%, rgba(238, 147, 176, 1) 100%);
	}
}
@media(max-width: 767px) {
	.bg_merit01 {
		padding: 14vw 0 13.5vw;
	}
	.ttl_common02 {
		max-width: 100%;
		height: calc(195 / var(--break) * 100vw);
		background-size: 1px auto;
	}
	.ttl_merit01 {
		margin-bottom: calc(108 / var(--break) * 100vw);
	}
	.ttl_common02 .en {
		font-size: 4.375rem;
	}
	.ttl_common02 .ja {
		font-size: 1.25rem;
		line-height: 1.6;
	}
	.row_merit01 {
		gap: calc(105 / var(--break) * 100vw) 0;
		width: calc(646 / var(--break) * 100vw);
		margin: 0 auto;
	}
	.row_merit01 .col {
		width: 100%;
		max-width: 100%;
	}
	.row_merit01 .num {
		font-size: 4.0625rem;
		top: 1vw;
	}
	.row_merit01 .col .copy {
		font-size: 1.125rem;
		height: calc(114 / var(--break) * 100vw);
		border-bottom-width: 2px;
	}
	.row_merit01 .col .box {
		padding: 3vw 6vw 6vw;
	}
	.bg_merit02 {
		padding: 24.5vw 0 12vw;
		background: url("images/index/deco_merit01.png")no-repeat right calc(20 / var(--break) * 100vw) top calc(100 / var(--break) * 100vw) / calc(184 / var(--break) * 100vw) auto, url("images/index/txt_merit01.svg")no-repeat left 3.2vw top calc(130 / var(--break) * 100vw) / calc(533 / var(--break) * 100vw) auto, url("images/index/frame_merit01_sp.svg")no-repeat center top -1px / 100% auto, linear-gradient(90deg, rgba(235, 163, 124, 1) 0%, rgba(238, 147, 176, 1) 100%);
	}
	.txt_merit01 {
		font-size: 1.25rem;
		letter-spacing: .1em;
	}
	.txt_merit01 em {
		line-height: 1.5;
		font-size: 1.6875rem;
		letter-spacing: .1em;
	}
}


/* 当院が選ばれる7つの理由 reason
------------------------------------------------------------------*/
.bg_reason01 {
	background: url("images/index/bg_reason01.jpg")no-repeat center / cover;
}
.bg_reason01 .num_reason01 {
	left: calc(30 / var(--break) * 100vw);
	top: calc(-170 / var(--break) * 100vw);
	letter-spacing: .15em;
}
.en_reason01 {
	width: calc(503 / var(--break) * 100vw);
}
.bg_reason01 .en_reason01 {
	left: calc(-90 / var(--break) * 100vw);
	top: calc(-95 / var(--break) * 100vw);
}
.copy_reason01:after {
	content: "";
	display: block;
	width: calc(100 / var(--break) * 100vw);
	height: 1px;
	background: #333;
	margin: calc(24 / var(--break) * 100vw) auto 0;
}
.copy_reason01.txt_white:after {
	background: #fff;
}
.box_reason01 > .ttl {
	height: calc(80 / var(--break) * 100vw);
}
.box_reason01 > .ttl .icn {
	background: url("images/index/bg_reason02.svg")no-repeat center / cover;
	width: calc(134 / var(--break) * 100vw);
	height: calc(134 / var(--break) * 100vw);
	left: calc(40 / var(--break) * 100vw);
	top: calc(-25 / var(--break) * 100vw);
}
.box_reason01 .box:after {
	content: "";
	position: absolute;
	width: 1px;
	height: calc(100% - calc(60 / var(--break) * 100vw));
	right: 0;
	left: 0;
	margin: auto;
	background: #333;
	top: 0;
	bottom: 0;
}
.box_reason01 .col {
	width: 50%;
}
.box_reason01 .price01 .abo {
	font-size: 5.875rem;
	letter-spacing: -.05em;
}
.box_reason01 .price02 {
	background: #f5f5f5;
	height: calc(60 / var(--break) * 100vw);
	max-width: 400px;
}
.list_reason01 li {
	background: #ebf6fb;
	position: relative;
	padding: calc(4 / var(--break) * 100vw) calc(25 / var(--break) * 100vw) calc(4 / var(--break) * 100vw) calc(60 / var(--break) * 100vw);
}
.list_reason01 li:not(:first-child) {
	margin-top: calc(10 / var(--break) * 100vw);
}
.list_reason01 li:before {
	content: "";
	position: absolute;
	background: url("images/page/icn_check.svg")no-repeat center / cover;
	width: calc(20 / var(--break) * 100vw);
	height: calc(20 / var(--break) * 100vw);
	left: calc(20 / var(--break) * 100vw);
	top: calc(10 / var(--break) * 100vw);
}
.bg_reason02 {
	background: url("images/index/bg_reason03.svg")no-repeat right bottom / 100% auto;
}
.row_reason01.bg03 {
	margin-top: calc(-30 / var(--break) * 100vw);
}
.row_reason01.bg01:before {
	content: "";
	position: absolute;
	width: calc(100 / var(--break) * 100vw);
	left: 0;
	top: 0;
	height: 100%;
	background: url("images/page/ptn01.png")repeat left top / calc(20 / var(--break) * 100vw) auto;
	z-index: 0;
}
.row_reason01.bg02:before, .row_reason01.bg03:before {
	content: "";
	position: absolute;
	width: 100%;
	height: calc(60 / var(--break) * 100vw);
	background: url("images/page/ptn01.png")repeat left top / calc(20 / var(--break) * 100vw) auto;
	left: 0;
	bottom: 0;
	z-index: 0;
}
.row_reason01:after {
	content: "";
	position: absolute;
	width: 100%;
	height: calc(100% - calc(30 / var(--break) * 100vw));
	z-index: -1;
	left: 0;
	bottom: 0;
}
.row_reason01.bg01:after {
	width: 65%;
	background: #fdf4f7;
}
.row_reason01.bg02:after {
	background: #f2fbf3;
}
.row_reason01.bg03:after {
	background: #fff3c9;
	opacity: .4;
}
.row_reason01 .col_img {
	width: 49%;
	max-width: 840px;
}
.row_reason01 .col_img.img01 {
	width: 51%;
	max-width: 871px;
	top: calc(-70 / var(--break) * 100vw);
	right: calc(80 / var(--break) * 100vw);
}
.row_reason01 .col_img:after {
	content: "";
	position: absolute;
	width: 100%;
	height: calc(100% - calc(40 / var(--break) * 100vw));
	background: #fff3c9;
	z-index: -1;
	bottom: 0;
}
.row_reason01 .col_img.left:after {
	left: calc(-40 / var(--break) * 100vw);
}
.row_reason01 .col_img.right:after {
	right: calc(-40 / var(--break) * 100vw);
}
.row_reason01 .col_img.bg02:after {
	background: #9dd3ec;
}
.row_reason01 .col_img.bg03:after {
	background: #7cd687;
}
.row_reason01 .col_img.img01:after {
	display: none;
}
.row_reason01 .col_txt {
	width: 47%;
	max-width: 745px;
}
.row_reason01 .col_txt .wrap {
	max-width: 640px;
}
.row_reason01 .col_txt.deco01:before {
	content: "";
	position: absolute;
	background: url("images/index/deco_reason02.png")no-repeat center / cover;
	width: calc(777 / var(--break) * 100vw);
	height: calc(252 / var(--break) * 100vw);
	left: calc(-80 / var(--break) * 100vw);
	top: calc(-65 / var(--break) * 100vw);
	z-index: -1;
}
.row_reason01 .col_txt.deco02:before {
	content: "";
	position: absolute;
	background: url("images/index/deco_reason01.svg")no-repeat center / cover;
	width: calc(140 / var(--break) * 100vw);
	height: calc(141 / var(--break) * 100vw);
	right: calc(-110 / var(--break) * 100vw);
	top: calc(45 / var(--break) * 100vw);
	z-index: -1;
}
.row_reason01 .num_reason01 {
	top: calc(-30 / var(--break) * 100vw);
	left: 0;
}
.bg_reason03 {
	background: url("images/index/bg_reason04.png")no-repeat left center / auto 100%, url("images/index/bg_reason05.jpg")no-repeat right center / auto 100%;
}
.copy_reason02:before, .copy_reason02:after {
	content: "";
	display: block;
	height: 1px;
	background: #fff;
	flex: 1;
}
.txt_reason03 {
	max-width: 1000px;
}
.bg_reason04 {
	background: url("images/index/bg_reason06.jpg")no-repeat center / cover;
	margin-bottom: calc(215 / var(--break) * 100vw);
}
.bg_reason04 .num_reason01 {
	left: 0;
	top: calc(-70 / var(--break) * 100vw);
}
.row_reason02 {
	gap: 0 2.3%;
}
.row_reason02 .col {
	width: 31.8%;
	max-width: 394px;
}
.row_reason02 .ttl {
	font-weight: 300;
	height: calc(70 / var(--break) * 100vw);
}
.ttl_common03 .ja:before, .ttl_common03 .ja:after {
	content: "";
	display: block;
	background: #333;
	flex: 1;
	height: 1px;
}
.row_reason03 {
	gap: 0 calc(30 / var(--break) * 100vw);
	bottom: calc(-70 / var(--break) * 100vw);
	right: calc(80 / var(--break) * 100vw);
}
.row_reason03 .col {
	width: calc(194 / var(--break) * 100vw);
	height: calc(209 / var(--break) * 100vw);
	background: url("images/index/bg_main01.svg")no-repeat center / cover;
}
.row_reason03 .col.bg02 { background-image: url("images/index/bg_main02.svg"); }
.row_reason03 .col.bg03 { background-image: url("images/index/bg_reason07.svg"); }
.bg_reason05 {
	padding-bottom: calc(200 / var(--break) * 100vw);
	background: url("images/index/bg_reason08.svg")no-repeat center bottom / 100% auto;
}
.bg_reason06 {
	background: url("images/index/bg_reason09.jpg")no-repeat center / cover;
}
.bg_reason06 .num_reason01 {
	left: 0;
	top: calc(-70 / var(--break) * 100vw);
}
.slide_reason01 {
	margin-top: calc(-65 / var(--break) * 100vw);
}
.slide_reason01 li {
	margin: 0 calc(10 / var(--break) * 100vw);
}
.slide_reason01 img {
	width: calc(380 / var(--break) * 100vw);
}
@media(min-width: 768px) and (max-width:1599px) {
	.bg_reason03 {
		background-position: left calc(-50 / var(--break) * 100vw) center, right calc(-50 / var(--break) * 100vw) center;
	}
	.row_reason03 {
		gap: 0 calc(20 / var(--break) * 100vw);
	}
	.row_reason03 .col {
		width: calc(155 / var(--break) * 100vw);
		height: calc(167 / var(--break) * 100vw);
	}
}
@media(min-width: 768px) and (max-width:1299px) {
	.row_reason01 {
		padding-right: 5%;
		padding-bottom: 5%;
	}
	.num_reason01 {
		font-size: 7rem;
	}
	.en_reason01 {
		width: calc(400 / var(--break) * 100vw);
	}
	.copy__reason01 {
		font-size: 1.75rem;
	}
	.row_reason01 .col_img.img01 {
		right: calc(50 / var(--break) * 100vw);
	}
	.bg_reason03 {
		background-position: left calc(-100 / var(--break) * 100vw) center, right calc(-100 / var(--break) * 100vw) center;
	}
	.row_reason03 {
		font-size: 1.25rem;
	}
	.row_reason03 .col {
		width: calc(136 / var(--break) * 100vw);
		height: calc(146 / var(--break) * 100vw);
	}
}
@media(max-width: 767px) {
	.reason {
		padding-top: 11vw;
	}
	.ttl_reason01 {
		margin-bottom: 13vw;
	}
	.bg_reason01 {
		margin-bottom: calc(60 / var(--break) * 100vw);
		padding: 1vw 0 9vw;
		background: url("images/index/bg_reason01_sp.jpg")no-repeat center / cover;
	}
	.num_reason01 {
		font-size: 3.25rem;
	}
	.bg_reason01 .num_reason01 {
		left: 0;
		width: 100%;
		text-align: center;
		top: calc(-55 / var(--break) * 100vw);
	}
	.en_reason01 {
		width: calc(375 / var(--break) * 100vw);
		margin-bottom: 3vw;
	}
	.bg_reason01 .en_reason01 {
		margin: auto;
		position: relative;
		left: auto;
		top: auto;
	}
	.copy_reason01 {
		font-size: 1.25rem;
		line-height: 1.8;
		margin-bottom: 4vw;
	}
	.copy_reason01:after {
		margin: 4vw auto 0;
	}
	.txt_reason01 {
		margin-bottom: 8vw;
	}
	.box_reason01 {
		margin-bottom: calc(75 / var(--break) * 100vw);
	}
	.box_reason01.mb10 {
		margin-bottom: 2vw;
	}
	.box_reason01 > .ttl {
		font-size: 1.125rem;
	}
	.box_reason01 > .ttl .icn {
		width: calc(112 / var(--break) * 100vw);
		height: calc(112 / var(--break) * 100vw);
		left: calc(10 / var(--break) * 100vw);
		top: calc(-15 / var(--break) * 100vw);
	}
	.box_reason01 > .ttl .icn .en {
		font-size: .75rem;
	}
	.box_reason01 > .ttl .icn .num {
		font-size: 1.3125rem;
	}
	.box_reason01 > .ttl .ja {
		font-size: 1.125rem;
	}
	.box_reason01 .box {
		padding: 4vw 4vw 8.5vw;
	}
	.box_reason01 .box:after {
		display: none;
	}
	.box_reason01 .col {
		width: 100%;
		padding: 0;
	}
	.box_reason01 .ttl01 {
		font-size: 1.125rem;
	}
	.box_reason01 .price01 {
		font-size: 1.5625rem;
		margin-bottom: 4vw;
	}
	.box_reason01 .price01 .abo {
		font-size: 3.75rem;
	}
	.box_reason01 .price02 {
		font-size: .9375rem;
		height: calc(80 / var(--break) * 100vw);
		max-width: calc(514 / var(--break) * 100vw);
		border-radius: calc(40 / var(--break) * 100vw);
		padding: 0 0 1vw;
		margin-bottom: 4vw;
	}
	.box_reason01 .price02 span {
		font-size: 1.4375rem;
	}
	.box_reason01 .ttl02 {
		font-size: 1.125rem;
		margin-bottom: 2vw;
	}
	.list_reason01 {
		font-size: 1rem;
		letter-spacing: 0;
	}
	.list_reason01 li {
		padding: 0vw calc(25 / var(--break) * 100vw) 0.5vw 9vw;
	}
	.list_reason01 li:not(:first-child) {
		margin-top: calc(15 / var(--break) * 100vw);
	}
	.list_reason01 li:before {
		width: calc(25 / var(--break) * 100vw);
		height: calc(25 / var(--break) * 100vw);
		top: calc(20 / var(--break) * 100vw);
	}
	.bg_reason02 {
		padding-bottom: calc(80 / var(--break) * 100vw);
		background: url("images/index/bg_reason03_sp.svg")no-repeat right bottom / 100% auto;
	}
	.row_reason01 {
		padding: 0 3.2vw 9vw;
	}
	.row_reason01.bg01.mb150 {
		margin-bottom: 9vw;
	}
	.row_reason01.bg02 {
		margin-bottom: calc(80 / var(--break) * 100vw);
	}
	.row_reason01.bg03 {
		margin-top: calc(-30 / var(--break) * 100vw);
		margin-bottom: calc(115 / var(--break) * 100vw);
	}
	.row_reason01.bg01:before {
		width: calc(80 / var(--break) * 100vw);
		background: url("images/page/ptn01.png")repeat left top / calc(10 / var(--break) * 100vw) auto;
	}
	.row_reason01:after {
		height: calc(100% - calc(30 / var(--break) * 100vw));
	}
	.row_reason01.bg01:after {
		width: 100%;
		left: 0;
	}
	.row_reason01 .col_img {
		width: 100%;
		max-width: calc(646 / var(--break) * 100vw);
		margin: 0 auto calc(100 / var(--break) * 100vw);
		padding-bottom: calc(30 / var(--break) * 100vw);
	}
	.row_reason01 .col_img.img01 {
		width: 100%;
		max-width: calc(660 / var(--break) * 100vw);
		position: relative;
		top: auto;
		right: auto;
		margin-bottom: 13vw;
		padding-bottom: 0;
	}
	.row_reason01 .col_img:after {
		height: calc(100% - calc(30 / var(--break) * 100vw));
	}
	.row_reason01 .col_img.left:after {
		left: calc(-30 / var(--break) * 100vw);
	}
	.row_reason01 .col_img.right:after {
		right: calc(-30 / var(--break) * 100vw);
	}
	.row_reason01 .col_img.img01:after {
		display: none;
	}
	.row_reason01 .col_txt {
		width: 100%;
		max-width: 100%;
	}
	.row_reason01 .col_txt .wrap {
		max-width: calc(646 / var(--break) * 100vw);
		margin: 0 auto;
		padding: 0;
	}
	.row_reason01 .col_txt.deco01:before {
		width: calc(674 / var(--break) * 100vw);
		height: calc(218 / var(--break) * 100vw);
		left: calc(-15 / var(--break) * 100vw);
		top: calc(-100 / var(--break) * 100vw);
	}
	.row_reason01 .col_txt.deco02:before {
		width: calc(118 / var(--break) * 100vw);
		height: calc(119 / var(--break) * 100vw);
		right: calc(15 / var(--break) * 100vw);
		top: calc(-25 / var(--break) * 100vw);
	}
	.row_reason01 .num_reason01 {
		top: calc(-50 / var(--break) * 100vw);
		left: 0;
	}
	.bg_reason03 {
		padding: 51vw 0 52vw;
		background: url("images/index/bg_reason04_sp.png")no-repeat center top / 100% auto, url("images/index/bg_reason05_sp.png")no-repeat center bottom / 100% auto;
		margin-bottom: calc(120 / var(--break) * 100vw);
	}
	.copy_reason02 {
		font-size: 1.25rem;
		margin-bottom: 2vw;
	}
	.copy_reason02 span {
		padding: 0 2vw;
	}
	.txt_reason03 {
		max-width: calc(646 / var(--break) * 100vw);
	}
	.bg_reason04 {
		padding: 1vw 0 calc(80 / var(--break) * 100vw);
		background: url("images/index/bg_reason06_sp.jpg")no-repeat center / cover;
		margin-bottom: calc(80 / var(--break) * 100vw);
	}
	.bg_reason04 .num_reason01 {
		top: calc(-55 / var(--break) * 100vw);
	}
	.txt_reason04 {
		margin-bottom: 6vw;
	}
	.row_reason02 {
		width: calc(646 / var(--break) * 100vw);
		margin-right: auto;
		margin-left: auto;
		gap: calc(60 / var(--break) * 100vw) 0;
	}
	.row_reason02 .col {
		width: 100%;
		max-width: 100%;
	}
	.row_reason02 .ttl {
		font-size: 1.125rem;
		height: calc(115 / var(--break) * 100vw);
	}
	.ttl_common03 .en {
		font-size: 2.5rem;
		margin-bottom: 3vw;
	}
	.ttl_reason02 .en {
		margin-bottom: 2vw;
		font-size: 2.0625rem;
	}
	.ttl_common03 .ja {
		font-size: 1.25rem;
		letter-spacing: .1em;
	}
	.ttl_reason02 .ja {
		line-height: 1.5;
		font-size: 1.5625rem;
	}
	.ttl_common03 .ja > span {
		padding: 0 calc(40 / var(--break) * 100vw);
	}
	.row_reason03 {
		font-size: .75rem;
		gap: 0 calc(30 / var(--break) * 100vw);
		bottom: calc(-60 / var(--break) * 100vw);
		right: 0;
	}
	.bg_reason05 {
		padding-bottom: calc(105 / var(--break) * 100vw);
		background: url("images/index/bg_reason08_sp.svg")no-repeat right bottom / 100% auto;
	}
	.bg_reason06 {
		padding: 1vw 0 19vw;
		background: url("images/index/bg_reason09_sp.jpg")no-repeat center / cover;
	}
	.bg_reason06 .num_reason01 {
		left: 0;
		top: calc(-55 / var(--break) * 100vw);
	}
}


/* マウスピース矯正（インビザライン）治療と他の治療の比較 comparison
------------------------------------------------------------------*/
.comparison {
	padding-bottom: calc(310 / var(--break) * 100vw);
	background: url("images/index/bg_comparison01.svg")no-repeat center bottom / 100% auto;
}
.tbl_comparison01 table {
	width: 100%;
}
.tbl_comparison01 th, .tbl_comparison01 td {
	border: 1px solid #333;
	vertical-align: middle;
}
.tbl_comparison01 th {
	border-right-color: #ebf6fb;
	background: #ebf6fb;
	width: 17.8%;
}
.tbl_comparison01 td {
	width: 27.4%;
}
.tbl_comparison01 tr:not(:first-child) td {
	padding: calc(35 / var(--break) * 100vw) calc(20 / var(--break) * 100vw);
}
.tbl_comparison01 td em {
	line-height: 2;
}
.tbl_comparison01 .ttl {
	height: 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) {
	.comparison {
		padding-bottom: calc(240 / var(--break) * 100vw);
		background: url("images/index/bg_comparison01.svg")no-repeat center bottom / auto calc(300 / var(--break) * 100vw);
	}
	.ttl_comparison01 {
		margin-bottom: 6vw;
	}
	.ttl_comparison01 .en {
		font-size: 2.6875rem;
	}
	.tbl_comparison01 {
		font-size: .875rem;
		letter-spacing: 0;
	}
	.tbl_comparison01 table {
		width: calc(1400 / var(--break) * 100vw);
	}
	.tbl_comparison01 tr:not(:first-child) td {
		padding: 3vw 2vw;
	}
	.tbl_comparison01 td em {
		font-size: 1.25rem;
	}
	.tbl_comparison01 .ttl {
		font-size: 1rem;
		letter-spacing: 0;
		height: calc(120 / var(--break) * 100vw);
	}
}


/* orthodontics
------------------------------------------------------------------*/
.orthodontics {
	background: url("images/index/bg_orthodontics01.jpg")no-repeat center / cover;
}
.orthodontics:before {
	height: calc(60 / var(--break) * 100vw);
	background-image: url("images/page/ptn02.png");
}
.copy_orthodontics01 {
	width: calc(300 / var(--break) * 100vw);
	right: 9%;
	top: calc(-230 / var(--break) * 100vw);
	gap: 0 calc(30 / var(--break) * 100vw);
}
.copy_orthodontics01 > span > span {
	width: calc(80 / var(--break) * 100vw);
	background: #7CD687;
	background: linear-gradient(0deg, rgba(124, 214, 135, 1) 0%, rgba(118, 188, 221, 1) 100%);
}
.copy_orthodontics01 > span:after {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background: #fff;
	right: calc(-10 / var(--break) * 100vw);
	bottom: calc(-10 / var(--break) * 100vw);
	z-index: -1;
}
.ttl_orthodontics01 .ja:before, .ttl_orthodontics01 .ja:after {
	background: #fff3c9;
	margin-top: calc(75 / var(--break) * 100vw);
}
.row_orthodontics01 {
	max-width: 1060px;
	gap: 0 2%;
}
.row_orthodontics01 .col {
	width: 15%;
}
.row_orthodontics01 .ttl {
	height: calc(40 / var(--break) * 100vw);
}
.row_orthodontics01 .icn {
	width: calc(100 / var(--break) * 100vw);
}
@media(min-width: 768px) and (max-width:1599px) {
	.copy_orthodontics01 {
		right: 5%;
	}
}
@media(min-width: 768px) and (max-width:1299px) {
	.copy_orthodontics01 {
		font-size: 2.25rem;
		width: calc(240 / var(--break) * 100vw);
		top: calc(-200 / var(--break) * 100vw);
	}
	.copy_orthodontics01 > span > span {
		width: calc(60 / var(--break) * 100vw);
	}
}
@media(max-width: 767px) {
	.orthodontics {
		padding: 42vw 0 calc(90 / var(--break) * 100vw);
		background: url("images/index/bg_orthodontics01_sp.jpg")no-repeat center / cover;
	}
	.copy_orthodontics01 {
		width: calc(300 / var(--break) * 100vw);
		right: 0;
		left: 0;
		margin: auto;
		top: calc(-135 / var(--break) * 100vw);
		font-size: 1.25rem;
	}
	.ttl_orthodontics01 {
		margin-bottom: 3vw;
	}
	.ttl_orthodontics01 .ja > span {
		padding: 0;
	}
	.ttl_orthodontics01 .en {
		font-size: 2.0625rem;
		margin-bottom: 1vw;
	}
	.ttl_orthodontics01 .ja {
		font-size: 1.4375rem;
	}
	.ttl_orthodontics01 .ja em {
		font-size: 1.25rem;
		display: block;
		line-height: 1.5;
		letter-spacing: .1em;
	}
	.ttl_orthodontics01 .ja:before, .ttl_orthodontics01 .ja:after {
		width: calc(100 / var(--break) * 100vw);
		margin-top: 0;
		position: absolute;
		bottom: 8vw;
	}
	.ttl_orthodontics01 .ja:before {
		left: 0;
	}
	.ttl_orthodontics01 .ja:after {
		right: 0;
	}
	.txt_orthodontics01 {
		margin-bottom: 6.5vw;
	}
	.row_orthodontics01 {
		max-width: 100%;
		margin-bottom: 4vw;
		gap: calc(20 / var(--break) * 100vw) 3.8%;
	}
	.row_orthodontics01 .col {
		width: 30.8%;
	}
	.row_orthodontics01 .ttl {
		font-size: .9375rem;
		height: calc(55 / var(--break) * 100vw);
	}
	.row_orthodontics01 .box {
		padding: 1.5vw 2vw 3vw;
	}
	.row_orthodontics01 .icn {
		width: calc(136 / var(--break) * 100vw);
		margin-bottom: 2.5vw;
	}
	.row_orthodontics01 .txt {
		font-size: .75rem;
		line-height: 1.3;
		letter-spacing: 0;
	}
	.txt_orthodontics02 {
		line-height: 1.6;
	}
}


/* 矯正治療の流れ flow
------------------------------------------------------------------*/
.flow {
	background: url("images/index/bg_flow01.svg")no-repeat center bottom / 100% auto;
}
.box_flow01 {
	border-top: 1px solid #333;
	border-bottom: 1px solid #333;
}
.box_flow01.arw:after {
	content: "";
	position: absolute;
	width: calc(4 / var(--break) * 100vw);
	height: calc(100 / var(--break) * 100vw);
	border-right: calc(4 / var(--break) * 100vw) dotted #8e8d9b;
	right: 0;
	left: 0;
	margin: auto;
	bottom: calc(-100 / var(--break) * 100vw);
}
.box_flow01 > .num {
	width: calc(80 / var(--break) * 100vw);
	height: calc(80 / var(--break) * 100vw);
	right: 0;
	left: 0;
	top: calc(-40 / var(--break) * 100vw);
	margin: auto;
}
.box_flow01 .col_img {
	width: 34%;
	max-width: 380px;
}
.box_flow01 .col_txt {
	width: 62%;
}
.row_flow01 {
	gap: 0 calc(30 / var(--break) * 100vw);
}
@media(min-width: 768px) and (max-width:1599px) {
	
}
@media(min-width: 768px) and (max-width:1299px) {
	
}
@media(max-width: 767px) {
	.flow {
		padding: 11.5vw 0 13.5vw;
		background: url("images/index/bg_flow01.svg")no-repeat center bottom / auto calc(400 / var(--break) * 100vw);
	}
	.ttl_flow01 {
		margin-bottom: 11.5vw;
	}
	.box_flow01 {
		gap: 5.5vw 0;
		padding: calc(90 / var(--break) * 100vw) 4vw calc(70 / var(--break) * 100vw);
	}
	.box_flow01 > .num {
		font-size: 1.125rem;
	}
	.box_flow01 .col_img {
		width: 100%;
		max-width: 100%;
	}
	.box_flow01 .col_txt {
		width: 100%;
	}
	.box_flow01 .ttl {
		font-size: 1.25rem;
		text-align: center;
		margin-bottom: 2vw;
	}
	.box_flow01 .txt.mb35 {
		margin-bottom: 7vw;
	}
	.row_flow01 {
		gap: calc(30 / var(--break) * 100vw) 0;
		width: calc(600 / var(--break) * 100vw);
		margin: 0 auto;
	}
}


/* 費用 fee
------------------------------------------------------------------*/
.bg_fee01 {
	background: url("images/index/bg_fee01.svg")no-repeat center bottom / 100% auto;
}
.tbl_common01 table {
	background: #fff;
	border-color: #45a8d5;
}
.tbl_common01 th {
	background: #45a8d5;
}
.tbl_common01 tr:not(:last-child) td {
	border-bottom-color: #45a8d5;
}
.tbl_common01 .tbl_caption {
	margin-top: calc(10 / var(--break) * 100vw);
}
.bg_fee02:before {
	height: calc(40 / var(--break) * 100vw);
}
.row_fee01 {
	max-width: 920px;
	gap: 0 2%;
}
.row_fee01 .col {
	width: 32%;
}
.row_fee01 .icn {
	width: calc(176 / var(--break) * 100vw);
}
.ttl_fee02 .en.fz120 {
	font-size: 7.5rem;
}
.bg_fee03 {
	background: url("images/index/bg_fee02.jpg")no-repeat center / cover;
}
.box_fee01 {
	background: url("images/index/bg_fee03.png")no-repeat right center / auto 100%;
}
.box_fee01 .ttl {
	width: calc(600 / var(--break) * 100vw);
	height: calc(60 / var(--break) * 100vw);
	border-radius: 0 calc(40 / var(--break) * 100vw) calc(40 / var(--break) * 100vw) 0;
}
.box_fee01 .ccl {
	width: calc(72 / var(--break) * 100vw);
	height: calc(72 / var(--break) * 100vw);
	border: 1px solid #333;
	border-radius: 50%;
}
.box_fee01 .num {
	letter-spacing: -.05em;
}
.bnr_fee01 {
	width: calc(620 / var(--break) * 100vw);
}
.bg_fee04 {
	background: #fff3c980;
}
.btn_fee01 {
	width: calc(300 / var(--break) * 100vw);
}
.btn_fee01 a {
	height: calc(60 / var(--break) * 100vw);
}
.btn_fee01 a:after {
	border-width: calc(12 / var(--break) * 100vw);
	opacity: .3;
}
.box_fee03 .ttl01 {
	font-weight: 300;
	height: calc(60 / var(--break) * 100vw);
}
.box_fee03 .ttl01:hover {
	cursor: pointer;
}
.box_fee03 .ttl01 .icn {
	width: calc(18 / var(--break) * 100vw);
	height: calc(18 / var(--break) * 100vw);
	right: calc(25 / var(--break) * 100vw);
	top: 0;
	bottom: 0;
	margin: auto;
}
.box_fee03 .ttl01 .icn:before {
	content: "";
	position: absolute;
	width: 100%;
	height: 2px;
	background: #fff;
	right: 0;
	left: 0;
	top: 0;
	bottom: 0;
	margin: auto;
}
.box_fee03 .ttl01 .icn:after {
	content: "";
	position: absolute;
	height: 100%;
	width: 2px;
	background: #fff;
	right: 0;
	left: 0;
	top: 0;
	bottom: 0;
	margin: auto;
	opacity: 1;
	transition: .3s;
}
.box_fee03 .ttl01.open .icn:after {
	opacity: 0;
	transition: .3s;
}
.box_fee03 .box {
	display: none;
	border: 1px solid #333;
	border-top: none;
}
.box_fee03 .ttl02 {
	max-width: 960px;
}
.box_fee03 .ttl02:before, .box_fee03 .ttl02:after {
	content: "";
	display: block;
	flex: 1;
	background: #333;
	height: 1px;
}
.row_fee02 {
	gap: 0 1.8%;
}
.row_fee02 .col {
	width: 23.65%;
}
.row_fee02 .box01 {
	height: calc(85 / var(--break) * 100vw);
}
.row_fee02 .box02 {
	height: calc(105 / var(--break) * 100vw);
}
@media(min-width: 768px) and (max-width:1599px) {
	
}
@media(min-width: 768px) and (max-width:1299px) {
	
}
@media(max-width: 767px) {
	.fee {
		padding-bottom: calc(100 / var(--break) * 100vw);
	}
	.bg_fee01 {
		padding: 11vw 0 9vw;
		background: url("images/index/bg_fee01.svg")no-repeat center bottom / auto calc(400 / var(--break) * 100vw);
	}
	.ttl_fee01 {
		margin-bottom: 6vw;
	}
	.tbl_common01 .tbl_caption {
		margin-top: 3vw;
	}
	.bg_fee02 {
		padding: 9vw 0 calc(80 / var(--break) * 100vw);
		margin-bottom: 9vw;
	}
	.bg_fee02 .ttl_fee02 {
		height: calc(140 / var(--break) * 100vw);
	}
	.bg_fee02 .ttl_fee02 .en {
		font-size: 3.75rem;
	}
	.txt_fee01 {
		margin-bottom: 5vw;
	}
	.row_fee01 {
		max-width: 100%;
		gap: calc(20 / var(--break) * 100vw) 3.2%;
	}
	.row_fee01 .col {
		width: 48.4%;
		padding-bottom: 5.5vw;
	}
	.row_fee01 .icn {
		width: calc(204 / var(--break) * 100vw);
	}
	.row_fee01 .ttl {
		font-size: .9375rem;
	}
	.row_fee01 .txt {
		font-size: .75rem;
		letter-spacing: 0;
		line-height: 1.5;
	}
	.ttl_fee02 .en.fz120 {
		font-size: 2.5625rem;
	}
	.txt_fee01 {
		margin-bottom: 8vw;
	}
	.bg_fee03 {
		background: url("images/index/bg_fee02_sp.jpg")no-repeat center / cover;
		margin-bottom: calc(80 / var(--break) * 100vw);
	}
	.box_fee01 {
		padding: calc(380 / var(--break) * 100vw) 0 6vw;
		background: url("images/index/bg_fee03_sp.png")no-repeat center top / 100% auto;
	}
	.box_fee01 .ttl {
		font-size: 1.0625rem;
		width: calc(676 / var(--break) * 100vw);
		height: calc(68 / var(--break) * 100vw);
		padding-left: 3vw;
	}
	.box_fee01 .price {
		-webkit-justify-content: center!important;
		justify-content: center!important;
		padding: 0;
	}
	.box_fee01 .ccl {
		width: calc(90 / var(--break) * 100vw);
		height: calc(90 / var(--break) * 100vw);
		font-size: 1rem;
		margin-bottom: 2.5vw;
	}
	.box_fee01 .num {
		font-size: 4.375rem;
		margin-right: 4vw;
	}
	.box_fee01 .ja01 {
		font-size: .875rem;
		margin-right: 0;
		margin-bottom: 3vw;
	}
	.box_fee01 .ja01 span {
		font-size: 1.6875rem;
	}
	.box_fee01 .ja02 {
		width: 100%;
		text-align: center;
		font-size: 1.4375rem;
		margin-top: 1.5vw;
	}
	.box_fee01 .txt {
		font-size: .75rem;
		line-height: 1.5;
		padding: 0 4vw;
	}
	.bnr_fee01 {
		width: calc(702 / var(--break) * 100vw);
		margin-bottom: calc(80 / var(--break) * 100vw);
	}
	.bg_fee04 {
		padding: calc(85 / var(--break) * 100vw) 0 calc(100 / var(--break) * 100vw);
	}
	.box_fee02 {
		padding: 6.5vw 4vw 8vw;
	}
	.box_fee02 .ttl {
		font-size: 1.0625rem;
		margin-bottom: 3vw;
	}
	.btn_fee01 {
		width: calc(600 / var(--break) * 100vw);
	}
	.btn_fee01 a {
		font-size: 1.0625rem;
		letter-spacing: 0;
		height: calc(100 / var(--break) * 100vw);
	}
	.btn_fee01 a:after {
		border-width: calc(15 / var(--break) * 100vw);
	}
	.box_fee03 .ttl01 {
		font-size: 1.125rem;
		letter-spacing: 0;
		line-height: 1.6;
		height: calc(100 / var(--break) * 100vw);
	}
	.box_fee03 .ttl01 .icn {
		width: calc(25 / var(--break) * 100vw);
		height: calc(25 / var(--break) * 100vw);
		right: calc(30 / var(--break) * 100vw);
	}
	.box_fee03 .ttl01 .icn:before {
		height: 1px;
	}
	.box_fee03 .ttl01 .icn:after {
		width: 1px;
	}
	.box_fee03 .box {
		padding: 5.5vw 4vw 7vw;
	}
	.box_fee03 .ttl02 {
		max-width: 100%;
		font-size: 1.25rem;
		line-height: 1.8;
		margin-bottom: 0;
	}
	.row_fee02 {
		gap: calc(40 / var(--break) * 100vw) 0;
		width: calc(600 / var(--break) * 100vw);
		margin: 0 auto 3vw;
	}
	.row_fee02 .col {
		width: 100%;
	}
	.row_fee02 .box01 {
		font-size: 1.25rem;
		letter-spacing: .2em;
		height: calc(185 / var(--break) * 100vw);
	}
	.row_fee02 .box01 em {
		font-size: 1.5625rem;
	}
	.row_fee02 .box02 {
		font-size: 1.25rem;
		height: calc(235 / var(--break) * 100vw);
	}
	.row_fee02 .box02 em {
		font-size: 1.8125rem;
	}
	.box_fee03 .txt02 {
		line-height: 1.56;
	}
}


/* message
------------------------------------------------------------------*/
.bg_message01 {
	background: url("images/index/deco_message01.png")no-repeat right calc(45 / var(--break) * 100vw) top calc(60 / var(--break) * 100vw) / calc(189 / var(--break) * 100vw) auto, url("images/index/deco_message02.png")no-repeat left 56.5% bottom calc(10 / var(--break) * 100vw) / calc(205 / var(--break) * 100vw) auto, url("images/index/bg_message01.jpg")no-repeat center / cover;
}
.row_message01 {
	max-width: 1680px;
	width: 90%;
}
.row_message01 .col_img {
	width: 45%;
	max-width: 750px;
}
.row_message01 .col_img:after {
	content: "";
	position: absolute;
	width: 100%;
	height: calc(100% - calc(40 / var(--break) * 100vw));
	left: calc(-40 / var(--break) * 100vw);
	bottom: 0;
	z-index: -1;
	background: #7cd687;
}
.row_message01 .name {
	background: url("images/index/bg_main02.svg")no-repeat center / cover;
	width: calc(233 / var(--break) * 100vw);
	height: calc(252 / var(--break) * 100vw);
	right: calc(65 / var(--break) * 100vw);
	bottom: calc(120 / var(--break) * 100vw);
}
.row_message01 .col_txt {
	width: 51%;
	max-width: 810px;
}
.row_message01 .col_txt .wrap {
	max-width: 775px;
}
.row_message01 .col_txt .en {
	width: calc(547 / var(--break) * 100vw);
	margin-right: calc(-85 / var(--break) * 100vw);
	margin-top: calc(-25 / var(--break) * 100vw);
}
.bg_message02 {
	background: url("images/index/bg_message02.svg")no-repeat center bottom / 100% auto, linear-gradient(90deg,rgba(118, 188, 221, 1) 0%, rgba(124, 214, 135, 1) 100%);
}
.box_message01 .ttl {
	font-weight: 400;
	height: calc(50 / var(--break) * 100vw);
}
.list_message01 li:before {
	background: #45a8d5;
}
.bg_message03 {
	padding-top: calc(175 / var(--break) * 100vw);
	background: url("images/index/bg_message03.jpg")no-repeat center / cover;
}
.bg_message03:before {
	height: calc(60 / var(--break) * 100vw);
}
.txt_message01:before {
	content: "";
	position: absolute;
	background: url("images/index/deco_message03.svg")no-repeat center / cover;
	width: calc(200 / var(--break) * 100vw);
	height: calc(203 / var(--break) * 100vw);
	left: calc(-80 / var(--break) * 100vw);
	bottom: 0;
	z-index: -1;
}
.txt_message01:after {
	content: "";
	position: absolute;
	background: url("images/index/deco_message03.svg")no-repeat center / cover;
	width: calc(242 / var(--break) * 100vw);
	height: calc(244 / var(--break) * 100vw);
	right: 13%;
	top: calc(-160 / var(--break) * 100vw);
	z-index: -1;
}
@media(min-width: 768px) and (max-width:1599px) {
	.copy_message01 {
		font-size: 2.25rem;
	}
	.row_message01 .col_txt .en {
		empty-cells: calc(-30 / var(--break) * 100vw);
	}
	.row_message01 .name {
		right: calc(40 / var(--break) * 100vw);
		bottom: calc(80 / var(--break) * 100vw);
	}
}
@media(min-width: 768px) and (max-width:1299px) {
	.copy_message01 {
		font-size: 1.875rem;
	}
	.txt_message01 {
		font-size: 2.25rem;
	}
	.txt_message01 em {
		font-size: 3.75rem;
	}
}
@media(max-width: 767px) {
	.bg_message01 {
		padding: calc(100 / var(--break) * 100vw) 0 13vw;
		background: url("images/index/deco_message01.png")no-repeat right 3.2vw top 37% / calc(85 / var(--break) * 100vw) auto, url("images/index/deco_message02.png")no-repeat left calc(15 / var(--break) * 100vw) bottom calc(35 / var(--break) * 100vw) / calc(148 / var(--break) * 100vw) auto, url("images/index/bg_message01_sp.jpg")no-repeat center / cover;
	}
	.row_message01 {
		max-width: calc(702 / var(--break) * 100vw);
		width: 100%;
		margin: 0 auto;
	}
	.row_message01 .col_img {
		width: 100%;
		max-width: calc(676 / var(--break) * 100vw);
		padding-bottom: calc(35 / var(--break) * 100vw);
		padding-left: calc(35 / var(--break) * 100vw);
		margin: 0 auto 6vw;
	}
	.row_message01 .col_img:after {
		width: calc(100% - calc(35 / var(--break) * 100vw));
		height: calc(100% - calc(35 / var(--break) * 100vw));
		left: 0;
	}
	.row_message01 .name {
		width: calc(290 / var(--break) * 100vw);
		height: calc(314 / var(--break) * 100vw);
		right: calc(15 / var(--break) * 100vw);
		bottom: calc(90 / var(--break) * 100vw);
	}
	.row_message01 .name .ja {
		font-size: .75rem;
	}
	.row_message01 .name .ja em {
		font-size: 1rem;
	}
	.row_message01 .name .en {
		font-size: .6875rem;
	}
	.row_message01 .col_txt {
		width: 100%;
		max-width: 100%;
		padding: 0;
	}
	.row_message01 .col_txt .wrap {
		max-width: calc(646 / var(--break) * 100vw);
		margin: 0 auto;
	}
	.copy_message01 {
		font-size: 1.25rem;
		line-height: 1.7;
		text-align: center;
		margin-bottom: 7vw;
	}
	.row_message01 .col_txt .en {
		width: calc(392 / var(--break) * 100vw);
		margin-right: calc(5 / var(--break) * 100vw);
		margin-top: 0;
	}
	.bg_message02 {
		background: url("images/index/bg_message02.svg")no-repeat center bottom / auto calc(400 / var(--break) * 100vw), linear-gradient(90deg,rgba(118, 188, 221, 1) 0%, rgba(124, 214, 135, 1) 100%);
	}
	.box_message01 {
		padding: calc(60 / var(--break) * 100vw) 5vw 7vw;
		margin-bottom: calc(60 / var(--break) * 100vw);
	}
	.box_message01 .ttl {
		font-size: 1.0625rem;
		letter-spacing: 0;
		height: calc(80 / var(--break) * 100vw);
		margin-bottom: 3.5vw;
	}
	.list_message01 li:not(:first-child) {
		margin-top: 2.3vw;
	}
	.bg_message03 {
		padding-top: 16vw;
		background: url("images/index/bg_message03_sp.jpg")no-repeat center / cover;
	}
	.txt_message01 {
		font-size: 1.25rem;
		line-height: 1.8;
		margin-bottom: 5vw;
	}
	.txt_message01 em {
		display: block;
		margin-top: 1vw;
		font-size: 2.0625rem;
		line-height: 1.4;
	}
	.txt_message01:before {
		width: calc(123 / var(--break) * 100vw);
		height: calc(125 / var(--break) * 100vw);
		left: 0;
		bottom: 16vw;
	}
	.txt_message01:after {
		width: calc(150 / var(--break) * 100vw);
		height: calc(150 / var(--break) * 100vw);
		right: -2vw;
		top: calc(-50 / var(--break) * 100vw);
	}
}


/* 医院紹介 clinic
------------------------------------------------------------------*/
.row_clinic01 .col_img {
	width: 51%;
	max-width: 900px;
}
.row_clinic01 .col_img:after {
	content: "";
	position: absolute;
	width: 100%;
	height: calc(100% - calc(50 / var(--break) * 100vw));
	background: #7cd687;
	right: calc(-60 / var(--break) * 100vw);
	bottom: 0;
	z-index: -1;
}
.row_clinic01 .col_txt {
	width: 45%;
	max-width: 755px;
}
.row_clinic01 .col_txt .wrap {
	max-width: 530px;
}
.row_clinic01 .logo {
	width: calc(300 / var(--break) * 100vw);
}
.row_clinic01 .addresss .icn {
	width: calc(14 / var(--break) * 100vw);
}
.tel_clinic {
	max-width: calc(480 / var(--break) * 100vw);
}
.tel_clinic a {
	outline: 1px solid #333;
}
.tel_clinic .bg {
	height: calc(120 / var(--break) * 100vw);
}
.tel_clinic .num .icn {
	width: calc(24 / var(--break) * 100vw);
}
.tel_clinic .time {
	height: calc(40 / var(--break) * 100vw);
}
.address_clinic .icn {
	width: calc(14 / var(--break) * 100vw);
}
.bg_clinic02 {
	background: url("images/index/bg_clinic01.svg")no-repeat center bottom / 100% auto;
}
.row_clinic02 {
	gap: 0 2.3%;
}
.row_clinic02 .col {
	width: 31.8%;
}
.row_clinic02 .ttl {
	font-weight: 300;
	height: calc(70 / var(--break) * 100vw);
}
.row_clinic02 .icn {
	width: calc(180 / var(--break) * 100vw);
}
.wrap_clinic01 {
	max-width: 1000px;
}
@media(min-width: 768px) and (max-width:1599px) {
	
}
@media(min-width: 768px) and (max-width:1299px) {
	
}
@media(max-width: 767px) {
	.clinic {
		padding-top: 11.5vw;
	}
	.ttl_clinic01 {
		margin-bottom: 6vw;
	}
	.bg_clinic01 {
		padding: calc(80 / var(--break) * 100vw) 0 12vw;
	}
	.row_clinic01 {
		gap: calc(60 / var(--break) * 100vw) 0;
	}
	.row_clinic01 .col_img {
		width: 100%;
		max-width: calc(656 / var(--break) * 100vw);
		margin: 0 auto;
		padding-bottom: calc(25 / var(--break) * 100vw);
	}
	.row_clinic01 .col_img:after {
		height: calc(100% - calc(25 / var(--break) * 100vw));
		right: calc(-25 / var(--break) * 100vw);
	}
	.row_clinic01 .col_txt {
		width: 100%;
		max-width: 100%;
	}
	.row_clinic01 .col_txt .wrap {
		max-width: calc(702 / var(--break) * 100vw);
		margin: 0 auto;
	}
	.row_clinic01 .logo {
		width: calc(490 / var(--break) * 100vw);
		margin-bottom: 5.5vw;
	}
	.row_clinic01 .addresss .icn {
		width: calc(24 / var(--break) * 100vw);
	}
	.address_clinic {
		margin-bottom: 7vw;
	}
	.address_clinic .icn {
		width: calc(24 / var(--break) * 100vw);
	}
	.tel_clinic {
		max-width: calc(600 / var(--break) * 100vw);
		margin-bottom: calc(60 / var(--break) * 100vw);
	}
	.tel_clinic .bg {
		height: calc(120 / var(--break) * 100vw);
	}
	.tel_clinic .ja01 {
		font-size: .75rem;
	}
	.tel_clinic .num .abo {
		font-size: 1.5625rem;
	}
	.tel_clinic .time {
		font-size: .75rem;
		letter-spacing: .1em;
		height: calc(60 / var(--break) * 100vw);
	}
	.bg_clinic02 {
		background: url("images/index/bg_clinic01.svg")no-repeat center bottom / auto calc(400 / var(--break) * 100vw);
	}
	.row_clinic02 {
		gap: calc(20 / var(--break) * 100vw) 3.6%;
		margin-bottom: calc(60 / var(--break) * 100vw);
	}
	.row_clinic02 .col {
		width: 48.2%;
	}
	.row_clinic02 .ttl {
		font-size: .9375rem;
		letter-spacing: 0;
		height: calc(60 / var(--break) * 100vw);
	}
	.row_clinic02 .box {
		padding: 4.5vw 3vw 5vw;
	}
	.row_clinic02 .icn {
		width: calc(155 / var(--break) * 100vw);
	}
	.row_clinic02 .txt {
		font-size: .75rem;
		line-height: 1.5;
		letter-spacing: .1em;
	}
	.wrap_clinic01 {
		max-width: 100%;
	}
}


/* よくあるご質問
------------------------------------------------------------------*/
.box_qa03 {
	border: none;
}
.box_qa03 .box_q .txt {
	background: #AC8DF4;
	background: linear-gradient(90deg, rgba(118, 188, 221, 1) 0%, rgba(172, 141, 244, 1) 100%);
}
.box_qa03 .box_q .txt.bg_grd02 {
	background: #7CD687;
	background: linear-gradient(90deg, rgba(118, 188, 221, 1) 0%, rgba(124, 214, 135, 1) 100%);
}
.box_qa03 .box_q .txt .icn:before, .box_qa03 .box_q .txt .icn:after {
	background: #fff;
}
.box_qa03 .box_q .txt .icn:before {
	height: 1px;
}
.box_qa03 .box_q .txt .icn:after {
	width: 1px;
}
.box_qa03 .box_a {
	border: 1px solid #333;
	border-top: none;
}
@media(min-width: 768px) and (max-width:1599px) {
	
}
@media(min-width: 768px) and (max-width:1299px) {
	
}
@media(max-width: 767px) {
	.qa {
		padding: 12vw 0 13.5vw;
	}
	.ttl_qa01 .en {
		margin-bottom: 4.5vw;
	}
}


/* フッター footer
------------------------------------------------------------------*/
footer {
	position: relative;
}
.row_foot01 > .col_l {
	width: 43%;
	max-width: 365px;
}
.logo_foot {
	width: calc(300 / var(--break) * 100vw);
}
.address_foot .icn {
	width: calc(14 / var(--break) * 100vw);
}
.row_foot01 > .col_r {
	width: 53%;
}
.tbl_time02 .box {
	background: #3f5794;
}
.row_foot02 {
	max-width: 870px;
	gap: 0 2.8%;
}
.tel_common {
	width: calc(320 / var(--break) * 100vw);
}
.tel_foot {
	width: 36.8%;
}
.web_common {
	width: calc(250 / var(--break) * 100vw);
}
.web_foot {
	width: 28.8%;
}
.web_common a {
	height: calc(110 / var(--break) * 100vw);
}
.tel_common a {
	outline: 1px solid #333;
}
.tel_common .bg {
	height: calc(86 / var(--break) * 100vw);
}
.tel_common .num .icn {
	width: calc(20 / var(--break) * 100vw);
}
.tel_common .time {
	height: calc(24 / var(--break) * 100vw);
}
.web_common a:after {
	border-width: calc(13 / var(--break) * 100vw);
	opacity: .5;
}
.web_common .ja01:after {
	content: "";
	position: absolute;
	width: calc(50 / var(--break) * 100vw);
	height: 1px;
	background: #fff;
	opacity: .4;
	right: 0;
	left: 0;
	margin: auto;
	bottom: 0;
}
.bnr_foot01 {
	width: calc(641 / var(--break) * 100vw);
}
.pagetop {
	position: fixed;
	right: calc(30 / var(--break) * 100vw);
	bottom: calc(30 / var(--break) * 100vw);
	z-index: 1000;
	width: calc(80 / 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) {
}
@media(max-width: 767px) {
	.main_foot {
		padding: calc(100 / var(--break) * 100vw) 0 calc(80 / var(--break) * 100vw);
	}
	.row_foot01 {
		gap: 7vw 0;
		margin-bottom: 7vw;
	}
	.row_foot01 > .col_l {
		width: 100%;
		max-width: 100%;
	}
	.logo_foot {
		margin-bottom: 6vw;
		width: calc(490 / var(--break) * 100vw);
	}
	.address_foot .icn {
		width: calc(24 / var(--break) * 100vw);
	}
	.row_foot01 > .col_r {
		width: 100%;
	}
	.row_foot02 {
		max-width: calc(600 / var(--break) * 100vw);
		gap: calc(30 / var(--break) * 100vw) 0;
	}
	.tel_common {
		width: calc(600 / var(--break) * 100vw);
	}
	.tel_foot {
		width: 100%;
	}
	.web_common {
		width: calc(600 / var(--break) * 100vw);
	}
	.web_foot {
		width: 100%;
	}
	.web_common a {
		height: calc(175 / var(--break) * 100vw);
		padding-top: 1.5vw;
	}
	.tel_common .bg {
		height: calc(120 / var(--break) * 100vw);
	}
	.tel_common .ja01 {
		font-size: .75rem;
	}
	.tel_common .num .icn {
		width: calc(24 / var(--break) * 100vw);
	}
	.tel_common .num .abo {
		font-size: 1.5625rem;
	}
	.tel_common .time {
		font-size: .75erm;
		letter-spacing: .1em;
		height: calc(60 / var(--break) * 100vw);
	}
	.web_common a:after {
		border-width: calc(22 / var(--break) * 100vw);
	}
	.web_common .ja01 {
		font-size: .8125rem;
		letter-spacing: .1em;
		padding-bottom: 1.5vw;
		margin-bottom: 0;
	}
	.web_common .ja01:after {
		width: calc(80 / var(--break) * 100vw);
	}
	.web_common .ja02 {
		font-size: 1.4375rem;
	}
	.tbl_time .tbl_caption {
		margin-top: 2vw;
	}
	.bottom_foot {
		margin-bottom: calc(60 / var(--break) * 100vw);
	}
	.bnr_foot01 {
		width: calc(702 / var(--break) * 100vw);
	}
	.copyright {
		font-size: 75%;
		letter-spacing: 0;
		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(340 / var(--break) * 100vw);
	}
	.fix_web {
		width: calc(130 / var(--break) * 100vw);
	}
	.pagetop_sp {
		width: calc(150 / var(--break) * 100vw);
	}
	.fix a {
		display: block;
	}
}

/* グーグルマップ
------------------------------------------------------------------*/
.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(-150 / var(--break) * 100vw);
	height: calc(100% + calc(150 / 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 {
	height: calc(60 / var(--break) * 100vw);
	background: url("images/page/icn_map.svg")no-repeat left calc(30 / var(--break) * 100vw) center / calc(15 / var(--break) * 100vw) auto;
	border: 1px solid #fff;
}
.btn_map a::after {
	content: "";
	width: 0;
	height: 0;
	margin: auto;
	border-left: calc(8 / var(--break) * 100vw) solid #fff;
	border-top: calc(5 / var(--break) * 100vw) solid transparent;
	border-bottom: calc(5 / var(--break) * 100vw) solid transparent;
	position: absolute;
	top: 0;
	bottom: 0;
	right: calc(30 / var(--break) * 100vw)
}
@media(min-width: 768px) and (max-width:1599px) {
}
@media(min-width: 768px) and (max-width:1299px) {
}
@media(max-width: 767px) {
	.map iframe {
		margin-top: calc(-200 / var(--break) * 100vw);
		height: calc(100% + calc(200 / var(--break) * 100vw));
	}
	.btn_map {
		width: calc(600 / var(--break) * 100vw);
		margin: 0 auto calc(60 / var(--break) * 100vw);
		font-size: 1.0625rem;
		letter-spacing: 0;
		position: relative;
		left: auto;
		top: auto;
	}
	.btn_map a {
		height: calc(100 / var(--break) * 100vw);
		background-position: left 3vw center;
		background-size: calc(30 / var(--break) * 100vw) auto;
	}
	.btn_map a::after {
		border-width: calc(10 / var(--break) * 100vw) 0 calc(10 / var(--break) * 100vw) calc(16 / var(--break) * 100vw);
		right: 3vw;
	}
}