@charset "UTF-8";



/*メインイメージ
---------------------------------------------------------*/
.m_img_area .m_img .m_copy {
	position: absolute;
	z-index: 1;
}
.m_img_area .m_img .cover_img {
	position: relative;
	z-index: 0;
}

.m_img_area .m_img .m_copy {
	margin: auto;
	left: 0;
	right: 0;
	bottom: 10%;
}
.m_img_area .m_img .m_copy .copy1 {
	width: min(70%,110vh);
	max-width: 900px;
	margin: 0 auto 1%;
}
.m_img_area .m_img .m_copy .copy1 img {
	filter: drop-shadow(0 0 12px #000);
}
.m_img_area .m_img .m_copy .copy2 {
	width: min(60%,110vh);
	max-width: 820px;
	margin: 0 auto;
	display: flex;
    justify-content: space-between;
    align-items: center;
}
.m_img_area .m_img .m_copy .copy2 li {
	width: 32%;
	max-width: 260px;
}

.m_img_area .m_img .swiper-slide span {
	width: 100%;
	height: 100vh;
}
.m_img_area .m_img .swiper-slide span.m_landscape {
	display: block;
}
.m_img_area .m_img .swiper-slide span.m_portrait {
	display: none;
}
.m_img_area .m_img .swiper-slide img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.m_img_area .m_img .m_copy .copy1 {
	width: 80%;
}
.m_img_area .m_img .m_copy .copy2 {
	width: 77%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.m_img_area .m_img .m_copy {
	bottom: 4%;
}
.m_img_area .m_img .m_copy .copy1 {
	width: 94%;
	max-width: 100%;
	margin: 0 auto 5%;
}
.m_img_area .m_img .m_copy .copy2 {
	width: 96%;
	max-width: 100%;
}
.m_img_area .m_img .m_copy .copy2 li {
	width: 32.8%;
	max-width: 100%;
}
}

/* 縦向きの場合
------------------------------------------*/
@media only screen and (max-width: 767px) and (orientation: portrait) {
.m_img_area .m_img .swiper-slide span.m_landscape {
	display: none;
}
.m_img_area .m_img .swiper-slide span.m_portrait {
	display: block;
}
}



/*オープン告知
---------------------------------------------------------*/
.open_inf {
	text-align: center;
	background: #f9f5f0;
	padding-bottom: 60px;
}
.open_inf img {
	display: block;
	margin: auto;
}
.open_inf .box1 {
	background: #ad8a53;
	padding: 0 3%;
	position: relative;
}
.open_inf .box1::before,
.open_inf .box1::after {
	content: "";
	position: absolute;
	z-index: 0;
	width: 15%;
	max-width: 200px;
	height: 100%;
	top: 0;
	background: linear-gradient(90deg,rgba(128, 99, 79, 0) 0%, rgba(128, 99, 79, 1) 100%);
	opacity: 0.5;
}
.open_inf .box1::before {
	left: 0;
	transform: rotate(180deg);
}
.open_inf .box1::after {
	right: 0;
}
.open_inf .box1 p {
	position: relative;
	z-index: 1;
	width: 80%;
	margin: 0 auto;
}
.open_inf .box2 {
	margin-top: 50px;
	text-align: center;
	line-height: 1.8em;
}
.open_inf .box2 dt {
	width: 70%;
	margin: 0 auto;
}
.open_inf .box2 dd .txt1 {
	width: 80%;
	margin: 1.5em auto 1.5em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.open_inf {
	padding-bottom: 6%;
}
.open_inf .box2 {
	margin-top: 4%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.open_inf {
	background: none;
	padding-bottom: 0;
}
.open_inf .box1 p {
	width: 100%;
}
.open_inf .box2 {
	margin-top: 6%;
	line-height: 1.6em;
	margin-bottom: 8%;
}
.open_inf .box2 dt {
	width: 100%;
}
.open_inf .box2 dd .txt1 {
	width: 100%;
	margin: 1.0em auto 1.0em;
}
.open_inf .box2 dd .txt2 {
	text-align: left;
	font-size: 90%;
}
}



/*スマホメニュー
---------------------------------------------------------*/
.sp_menu_btn {
	width: 100%;
}
.sp_menu_btn .sp_btn_list {
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
	text-align: left;
}
.sp_menu_btn .sp_btn_list > li {
	width: 50%;
	font-size: 90%;
	letter-spacing: .05em;
	line-height: 1.4em;
	position: relative;
}
.sp_menu_btn .sp_btn_list > li > a {
	display: block;
	position: relative;
	padding: 1.4em 0;
	padding-left: 2.0em;
	background: #f9f5f0;
}
.sp_menu_btn .sp_btn_list > li:nth-child(4n-1) > a,
.sp_menu_btn .sp_btn_list > li:nth-child(4n-2) > a {
	background: #f2f1e9;
}
.sp_menu_btn .sp_btn_list > li > a::before {
	font-family: 'fontello';
	content: '\e802';
	color: #a89b92;
	font-size: 50%;
	position: absolute;
	left: 1.7em;
	top: 50%;
	transform: translateY(-50%);
}
.sp_menu_btn .sp_btn_list .open_box {
	position: absolute;
	width: 100vw;
	top: 100%;
	background: #f9f5f0;
	box-sizing: border-box;
	padding: 8% 6%;
	z-index: 1;
	display: none;	/*初期表示*/
}
.sp_menu_btn .sp_btn_list > li:nth-child(odd) .open_box {
	left: 0;
}
.sp_menu_btn .sp_btn_list > li:nth-child(even) .open_box {
	left: -50vw;
}
.sp_menu_btn .sp_btn_list .sp_in_menu li {
	border-bottom: solid 1px rgba(168,155,146,0.3);
}
.sp_menu_btn .sp_btn_list .sp_in_menu li:last-child {
	border-bottom: none;
}
.sp_menu_btn .sp_btn_list .sp_in_menu a {
	display: block;
	text-align: left;
	padding: 1.0em 1.0em;
	padding-left: 2.0em;
	position: relative;
}
.sp_menu_btn .sp_btn_list .sp_in_menu a::before {
	font-family: 'fontello';
	content: '\e802';
	font-size: 50%;
	position: absolute;
	left: 1.0em;
	top: 50%;
	transform: translateY(-50%);
	opacity: 0.5;
}
.sp_menu_btn .sp_btn_list .menu_open {
	display: inline-block;
	position: relative;
	padding-right: 1.2em;
}
.sp_menu_btn .sp_btn_list .menu_open::before,
.sp_menu_btn .sp_btn_list .menu_open::after {
	content: "";
	position: absolute;
	width: .7em;
	height: 1px;
	background: #80634f;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	transition: all 0.4s;
}
.sp_menu_btn .sp_btn_list .menu_open::before {
	transform: translateY(-50%) rotate(90deg);
}
.sp_menu_btn .sp_btn_list .active .menu_open::before {
	transform: translateY(-50%) rotate(0deg);
}



/*top_info
---------------------------------------------------------*/
.top_info {
	margin-top: 100px;
}
.top_info .box1 .txt1 {
	font-size: 110%;
	letter-spacing: .1em;
	line-height: 1.8em;
	margin-bottom: 50px;
}
.top_info .box1 .flex_box {
	display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.top_info .box1 .flex_box .box_l {
	width: 42%;
	max-width: 450px;
}
.top_info .box1 .flex_box .box_c {
	width: 34%;
	max-width: 370px;
	text-align: center;
}
.top_info .box1 .flex_box .box_r {
	width: 18%;
	max-width: 190px;
	text-align: center;
}

.top_info .box1 .flex_box .box_l .txt2 {
	font-size: 85%;
	letter-spacing: .1em;
	line-height: 2.0em;
	margin-bottom: 1.5em;
}

.top_info .box1 .flex_box .box_c {
	line-height: 1.5em;
}
.top_info .box1 .flex_box .box_c address {
	margin: .5em 0 1.0em;
}
.top_info .box1 .flex_box .box_c .btn a {
	display: inline-block;
	background: #80634f;
	color: #fff;
	font-size: 85%;
	letter-spacing: .1em;
	line-height: 1.2em;
	padding: .5em 2.5em;
	border-radius: 3.0em;
}
.top_info .box1 .flex_box .box_c .btn a:hover {
	background: #ad8a53;
}
.top_info .box1 .flex_box .box_c .btn i {
	font-size: 60%;
	display: inline-block;
	vertical-align: middle;
	transform: translateY(-.1em);
	margin-left: .5em;	
}

.top_info .box1 .flex_box .box_r .icon_link {
	font-size: min(110%,2.0vw);
	letter-spacing: .1em;
	line-height: 1.3em;
}
.top_info .box1 .flex_box .box_r .icon_link li {
	padding-bottom: 1.0em;
	border-bottom: solid 1px rgba(227,207,179,0.3);
	margin-bottom: 1.5em;
}
.top_info .box1 .flex_box .box_r .icon_link li:last-child {
	padding-bottom: 0;
	border-bottom: none;
	margin-bottom: 0;
}
.top_info .box1 .flex_box .box_r .icon_link a {
	display: block;
	padding-top: 3.0em;
	padding-bottom: 1.3em;
	position: relative;
}
.top_info .box1 .flex_box .box_r .icon_link a::before {
	content: "";	/*アイコン*/
	position: absolute;
	width: 2.5em;
	height: 2.5em;
	border-radius: 50%;
	margin: auto;
	left: 0;
	right: 0;
	top: 0;
	background: #80634f url("../images/icon_first_w@2x.png") no-repeat center center;
	background-size: contain;
	transition: background-color 0.5s;
}
.top_info .box1 .flex_box .box_r .icon_link a:hover {
	color: #ad8a53;
}
.top_info .box1 .flex_box .box_r .icon_link a:hover::before {
	transition: background-color 0.2s;
	background-color: #ad8a53;
}
.top_info .box1 .flex_box .box_r .icon_link a::after {
	font-family: 'fontello';
	content: '\e802';
	color: #a89b92;
	font-size: 50%;
	position: absolute;
	margin: auto;
	left: 0;
	right: 0;
	bottom: 0;
}
.top_info .box1 .flex_box .box_r .icon_second a::before {
	background-image: url("../images/icon_second_w@2x.png");
}

.top_info .box1 .contact_box {
	margin: 50px 0 40px;
	border-top: solid 1px rgba(128,99,79,0.3);
	border-bottom: solid 1px rgba(128,99,79,0.3);
	padding: 40px 0 30px;
	display: flex;
    justify-content: center;
    align-items: center;
	column-gap: 2%;
	font-size: min(100%,1.6vw);
}
.top_info .box1 .contact_box .tel dt {
	font-size: 90%;
	letter-spacing: .1em;
	line-height: 1.4em;
	margin-bottom: .5em;
}
.top_info .box1 .contact_box .tel .com_tel {
	font-size: 175%;
}
.top_info .box1 .contact_box .com_reserv_btns {
	width: 67%;
}

.top_info .box1 .medical_list {
	margin-bottom: 60px;
	font-size: 80%;
	letter-spacing: .14em;
	line-height: 1.4em;
}
.top_info .box1 .medical_list dt {
	font-size: 110%;
	letter-spacing: .12em;
	line-height: 1.0em;
	margin-bottom: 1.2em;
}
.top_info .box1 .medical_list ul {
	display: flex;
    flex-wrap: wrap;
	row-gap: 1.0em;
}
.top_info .box1 .medical_list ul li {
	width: 18%;
	margin-right: 2.25%;
}
.top_info .box1 .medical_list ul li:nth-child(5n),
.top_info .box1 .medical_list ul li:last-child {
	margin-right: 0;
}
.top_info .box1 .medical_list ul a {
	display: inline-block;
	vertical-align: middle;
	padding-left: 1.2em;
	position: relative;
}
.top_info .box1 .medical_list ul a:hover {
	color: #a89b92;
}
.top_info .box1 .medical_list ul a::before {
	font-family: 'fontello';
	content: '\e800';
	color: #a89b92;
	position: absolute;
	left: -.2em;
	top: -.1em;
}
.top_info .box1 .medical_list ul .txt_small {
	font-size: 80%;
	letter-spacing: .1em;
	line-height: 1.4em;
}

.top_info .slide_wrap {
	margin-bottom: 50px;
}

.top_info .box2 {
	margin-bottom: 120px;
	display: flex;
    justify-content: space-between;
    align-items: center;
	font-size: min(100%,1.4vw);
}
.top_info .box2 .title_box {
	width: 33%;
	max-width: 370px;
}
.top_info .box2 .bnr_list {
	width: 65%;
	max-width: 730px;
}
.top_info .box2 .title_box {
	text-align: center;
}
.top_info .box2 .title_box h2 {
	font-size: 470%;
	letter-spacing: .08em;
	line-height: 1.2em;
	white-space: nowrap;
	margin: .2em 0 .1em;
}
.top_info .box2 .title_box h2 span {
	display: block;
	font-size: 30%;
	letter-spacing: .55em;
	line-height: 1.2em;
	transform: translateX(.2em);
}
.top_info .box2 .title_box ul {
	color: #ad8a53;
	font-size: 130%;
	letter-spacing: .1em;
	line-height: 1.4em;
}
.top_info .box2 .title_box li {
	margin-bottom: .5em;
}
.top_info .box2 .title_box li:last-child {
	margin-bottom: 0;
}
.top_info .box2 .title_box li:first-child {
	color: #fff;
	font-size: 115%;
	background: #A38F80;
	background: linear-gradient(90deg,rgba(163, 143, 128, 1) 0%, rgba(212, 184, 147, 1) 30%, rgba(163, 143, 128, 1) 100%);
	padding: .2em .5em;
}
.top_info .box2 .bnr_list {
	display: flex;
    justify-content: space-between;
	text-align: center;
}
.top_info .box2 .bnr_list li {
	width: 32%;
	max-width: 230px;
}
.top_info .box2 .bnr_list li a {
	display: block;
	box-sizing: border-box;
	font-size: 190%;
	letter-spacing: .1em;
	line-height: 1.2em;
	border-radius: .5em;
	padding: 0;
	overflow: hidden;
}
.top_info .box2 .bnr_list li:not(.img_bnr) a {
	border: solid 1px #61c9e8;
	background: rgba(97,201,232,0.1);
	padding: .5em 0;
}
.top_info .box2 .bnr_list li:not(.img_bnr) a:hover {
	background: rgba(97,201,232,0.2);
}
.top_info .box2 .bnr_list li:not(.img_bnr) .img_circle {
	width: 62%;
	max-width: 140px;
	margin: 0 auto .5em;
}
.top_info .box2 .bnr_list li:not(.img_bnr) .ft_dm {
	display: inline-block;
	vertical-align: middle;
	font-size: 55%;
	line-height: 1.0em;
	margin-top: -.2em;
	padding-right: 1.5em;
	position: relative;
}
.top_info .box2 .bnr_list li:not(.img_bnr) .arrow {
	display: block;
	width: 1.2em;
	height: 1.2em;
}

.top_info .box2 .bnr_list .bnr_otona .arrow {background: #96cbd1;}
.top_info .box2 .bnr_list .bnr_otona .arrow::before,
.top_info .box2 .bnr_list .bnr_otona .arrow::after {background: #84b5ba;}

.top_info .box2 .bnr_list .bnr_kodomo .arrow {background: #d2b967;}
.top_info .box2 .bnr_list .bnr_kodomo .arrow::before,
.top_info .box2 .bnr_list .bnr_kodomo .arrow::after {background: #c9ac66;}
.top_info .box2 .bnr_list li.bnr_kodomo a {
	border-color: #f7d365;
	background: rgba(247,211,101,0.17);
}
.top_info .box2 .bnr_list li.bnr_kodomo a:hover {
	background: rgba(247,211,101,0.27);
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.top_info {
	margin-top: 8%;
}
.top_info .box1 .txt1 {
	margin-bottom: 5%;
}
.top_info .box1 .flex_box .box_l .txt2 {
	letter-spacing: normal;
}

.top_info .box1 .contact_box {
	margin: 4% 0 4%;
	padding: 4% 0 4%;
}

.top_info .box1 .medical_list {
	margin-bottom: 5%;
	letter-spacing: .05em;
}
.top_info .box1 .medical_list ul {
	row-gap: 1.0em;
}
.top_info .box1 .medical_list ul li {
	width: 23.5%;
	margin-right: 2% !important;
}
.top_info .box1 .medical_list ul li:nth-child(4n),
.top_info .box1 .medical_list ul li:last-child {
	margin-right: 0 !important;
}
.top_info .box1 .medical_list ul a {
	padding-left: 1.0em;
}
.top_info .box1 .medical_list ul .txt_small {
	letter-spacing: .05em;
}

.top_info .slide_wrap {
	margin-bottom: 5%;
}

.top_info .box2 {
	margin-bottom: 8%;
}
.top_info .box2 .bnr_list li:not(.img_bnr) .ft_dm {
	padding-right: 2.0em;
}
.top_info .box2 .bnr_list li:not(.img_bnr) .arrow {
	width: 1.6em;
	height: 1.6em;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.top_info {
	margin-top: 10%;
}
.top_info .box1 .txt1 {
	font-size: 110%;
	letter-spacing: .05em;
	line-height: 1.8em;
	margin-bottom: 8%;
}
.top_info .box1 .flex_box {
	display: block;
}
.top_info .box1 .flex_box .box_l {
	width: 100%;
	max-width: 100%;
	margin-bottom: 6%;
}
.top_info .box1 .flex_box .box_c {
	width: 100%;
	max-width: 100%;
	margin-bottom: 8%;
}
.top_info .box1 .flex_box .box_r {
	width: 100%;
	max-width: 100%;
}

.top_info .box1 .flex_box .box_l .txt2 {
	font-size: 90%;
	letter-spacing: normal;
	line-height: 1.8em;
	margin-bottom: 1.0em;
}

.top_info .box1 .flex_box .box_c {
	line-height: 1.5em;
}
.top_info .box1 .flex_box .box_c address {
	margin: 1.0em 0 1.0em;
}
.top_info .box1 .flex_box .box_c .btn a {
	font-size: 95%;
}

.top_info .box1 .flex_box .box_r .icon_link {
	font-size: 100%;
	letter-spacing: .05em;
	display: flex;
    justify-content: center;
    align-items: center;
	column-gap: 8%;
}
.top_info .box1 .flex_box .box_r .icon_link li {
	padding-bottom: 0;
	border-bottom: none;
	margin-bottom: 0;
}
.top_info .box1 .flex_box .box_r .icon_link a {
	padding-bottom: 0;
	padding-right: .8em;
}
.top_info .box1 .flex_box .box_r .icon_link a::after {
	margin: 0;
	left: auto;
	right: -.1em;
}

.top_info .box1 .contact_box {
	margin: 8% 0 8%;
	padding: 6% 0 8%;
	display: block;
	column-gap: 0;
	font-size: 100%;
}
.top_info .box1 .contact_box .tel {
	display: flex;
    justify-content: center;
    align-items: center;
	margin-bottom: .8em;
}
.top_info .box1 .contact_box .tel dt {
	letter-spacing: normal;
	margin-bottom: 0;
	margin-right: .5em;
}
.top_info .box1 .contact_box .tel .com_tel {
	font-size: 175%;
}
.top_info .box1 .contact_box .com_reserv_btns {
	width: 100%;
}

.top_info .box1 .medical_list {
	margin-bottom: 8%;
	padding: 0 3%;
	font-size: 90%;
	letter-spacing: normal;
}
.top_info .box1 .medical_list dt {
	margin-bottom: 1.2em;
}
.top_info .box1 .medical_list ul {
    justify-content: space-between;
	row-gap: .5em;
}
.top_info .box1 .medical_list ul li {
	width: 48%;
	margin-right: 0;
}
.top_info .box1 .medical_list ul a {
	padding-left: 1.0em;
}
.top_info .box1 .medical_list ul .txt_small {
	letter-spacing: normal;
}

.top_info .slide_wrap {
	margin-bottom: 10%;
}

.top_info .box2 {
	margin-bottom: 14%;
	display: block;
	font-size: 100%;
}
.top_info .box2 .title_box {
	width: 80%;
	max-width: 100%;
	margin: 0 auto 6%;
}
.top_info .box2 .bnr_list {
	width: 100%;
	max-width: 100%;
}
.top_info .box2 .title_box {
	font-size: 80%;
}
.top_info .box2 .title_box h2 span {
	letter-spacing: .4em;
}
.top_info .box2 .bnr_list {
    flex-wrap: wrap;
}
.top_info .box2 .bnr_list li {
	width: 48.5%;
	max-width: 100%;
}
.top_info .box2 .bnr_list li.img_bnr {
	width: 100%;
	margin-top: 3%;
}
.top_info .box2 .bnr_list li a {
	font-size: 150%;
}
.top_info .box2 .bnr_list li:not(.img_bnr) .ft_dm {
	padding-right: 2.5em;
}
.top_info .box2 .bnr_list li:not(.img_bnr) .arrow {
	width: 2.0em;
	height: 2.0em;
}
}



/* お口の健康をサポート：導入
---------------------------------------------------------*/
.support .lead_box {
	background: #E3CFB3;
	background: linear-gradient(45deg,rgba(227, 207, 179, 1) 0%, rgba(128, 99, 79, 1) 100%);
	padding-top: 130px;
	padding-bottom: 120px;
	color: #fff;
	margin-bottom: 120px;
}
.support .lead_box .flex_box {
	display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
	margin-bottom: 50px;
}
.support .lead_box .flex_box .box_l {
	width: 44%;
	max-width: 510px;
	padding-bottom: 60px;
	position: relative;
}
.support .lead_box .flex_box .box_l::before {
	content: "";
	position: absolute;
	width: 60%;
	max-width: 290px;
	height: 1px;
	background: #fff;
	opacity: 0.3;
	left: 0;
	bottom: 0;
}
.support .lead_box .flex_box .box_r {
	width: 53%;
	max-width: 630px;
}
.support .lead_box .flex_box .box_r .movie_box {
	position: relative;
}
.support .lead_box .flex_box .box_r .movie_box .abs {
	width: 26%;
	max-width: 140px;
	position: absolute;
	z-index: 10;
	right: 0;
	top: 0;
	transform: translate(30%,-30%);
}
.support .lead_box .flex_box .box_r .movie_box .abs span {
	display: block;
	animation: rotate 20s infinite linear;
}
/*アニメーション*/
@keyframes rotate {
from {
	transform: rotate(0deg);
}
to {
	transform: rotate(360deg);
}
}

.support .lead_box .txt2 {
	margin-top: 2.0em;
}
.support .lead_box .txt2 .img_l {
	float: left;
	width: 39%;
	max-width: 470px;
}
.support .lead_box .txt2 .txt_r {
	float: right;
	width: 57%;
	max-width: 680px;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.support .lead_box {
	padding-top: 10%;
	padding-bottom: 8%;
	margin-bottom: 8%;
}
.support .lead_box .flex_box {
	margin-bottom: 5%;
}
.support .lead_box .flex_box .box_l {
	padding-bottom: 6%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.support .lead_box {
	padding-top: 14%;
	padding-bottom: 12%;
	margin-bottom: 12%;
}
.support .lead_box .flex_box {
	display: block;
	margin-bottom: 8%;
}
.support .lead_box .flex_box .box_l {
	width: 90%;
	padding-bottom: 8%;
	margin: 0 auto 10%;
}
.support .lead_box .flex_box .box_l::before {
	width: 60%;
	max-width: 100%;
	margin: auto;
	left: 0;
	right: 0;
}
.support .lead_box .flex_box .box_r {
	width: 100%;
	max-width: 100%;
}
.support .lead_box .txt2 {
	margin-top: 2.0em;
}
.support .lead_box .txt2 .img_l {
	float: none;
	width: 70%;
	margin: 0 auto 2.0em;
}
.support .lead_box .txt2 .txt_r {
	float: none;
	width: 100%;
	max-width: 100%;
}
}



/* No.1 〜 No.3
---------------------------------------------------------*/
/*共通*/
.policy .box .title_box,
.medical .mouthpiece .title_box {
	text-align: center;
	margin-bottom: 70px;
}
.support .box .title_box .line_area,
.medical .mouthpiece .title_box .line_area {
	width: 1px;
	height: 70px;
	background: #ad8a53;
	margin: min(70px,5%) auto;
	transform: scale(1,0);
	transform-origin: center top;
	transition: transform 0.6s ease-out;
}
.support .box .title_box .ft_min,
.medical .mouthpiece .title_box .ft_min {
	font-size: 195%;
	letter-spacing: .2em;
	line-height: 1.4em;
	padding-top: 1.0em;
	position: relative;
	opacity: 0;
	transition: opacity 0.6s 0.4s linear;
}
.support .box .title_box .ft_min::before,
.medical .mouthpiece .title_box .ft_min::before {
	content: "01";
	display: block;
	font-family: "dm-sans", sans-serif;
	font-weight: 500;
	font-style: normal;
	color: #bea276;
	font-size: 45%;
	letter-spacing: .12em;
	line-height: 1.2em;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
}
.support .box .title_box.anime_on .line_area,
.medical .mouthpiece .title_box.anime_on .line_area {
	transform: scale(1,1);
}
.support .box .title_box.anime_on .ft_min,
.medical .mouthpiece .title_box.anime_on .ft_min {
	opacity: 1;
}

.policy .box {
	position: relative;
}
.policy .box > div {
	position: relative;
	z-index: 1;
}

.policy .box .first_img {
	width: 100%;
	max-width: 1400px;
	margin: 0 auto 60px;
	position: relative;
	z-index: 1;
}
.policy .box .first_img::before {
	content: "";	/*背景上の白*/
	position: absolute;
	z-index: -1;
	width: 100vw;
	height: 30%;
	max-height: 150px;
	left: 50%;
	top: -1px;
	transform: translateX(-50%);
	background: #fff;
}
.policy .box .first_img .abs {
	position: absolute;
	z-index: 2;
}
.policy .box .first_img div {
	position: relative;
	z-index: 0;
}

.policy .box .lead > dt {
	font-size: min(275%,3.6vw);
	letter-spacing: .15em;
	line-height: 1.6em;
	margin-bottom: .4em;
}

.policy .box .link_list {
	margin-top: 40px;
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.policy .box .link_list > li {
	width: 48.5%;
	max-width: 550px;
}
.policy .box .link_list .img_box {
	position: relative;
	margin-bottom: 30px;
}

/*no.1*/
.policy .no1 .bg {
	background: #f9f5f0;
	padding-bottom: 100px;
}
.policy .no1 .first_img .abs {
	width: 35%;
	max-width: 401px;
	left: 2%;
	top: 0;
	transform: translateY(-10%);
}
.policy .no1 .link_list p.ft_min {
	color: #429972;
	font-size: min(205%,3.0vw);
	letter-spacing: .15em;
	line-height: 1.5em;
	margin-bottom: .5em;
}
.policy .no1 .link_list .btn_list {
	display: flex;
    flex-wrap: wrap;
}
.policy .no1 .link_list .btn_list .com_arrow_link {
	position: relative;
	padding-right: min(40px,3vw);
	margin-right: min(40px,3vw);
}
.policy .no1 .link_list .btn_list .com_arrow_link::after {
	content: "";
	position: absolute;
	width: 1px;
	height: 3.2em;
	background: #ccc5c2;
	right: 0;
	top: 50%;
	transform: translateY(-50%) rotate(35deg);
}
.policy .no1 .link_list .btn_list .com_arrow_link:last-of-type {
	padding-right: 0;
	margin-right: 0;
}
.policy .no1 .link_list .btn_list .com_arrow_link:last-of-type::after {
	display: none;
}
.policy .no1 .device dl {
	margin-top: 70px;
	border-top: solid 1px #ccc5c2;
	padding-top: 50px;
}
.policy .no1 .device dt {
	text-align: center;
	color: #4668c9;
	font-size: 135%;
	letter-spacing: .2em;
	line-height: 1.8em;
	margin-bottom: 1.0em;
}
.policy .no1 .device .width_img {
	text-align: center;
	padding: 60px 0;
	position: relative;
	margin-bottom: 40px;
}
.policy .no1 .device .width_img::before {
	content: "";
	position: absolute;
	z-index: -1;
	width: 100%;
	height: 110%;
	left: 0;
	bottom: 0;
	background: url("../images/top/supo1_img4_bg@2x.jpg") no-repeat center bottom;
	background-size: auto 100%;
}
.policy .no1 .com_arrow_link .arrow {background: #60b490;}
.policy .no1 .com_arrow_link .arrow::before,
.policy .no1 .com_arrow_link .arrow::after {background: #559f7c;}
.policy .no1 .device .com_arrow_link .arrow {background: #6384e3;}
.policy .no1 .device .com_arrow_link .arrow::before,
.policy .no1 .device .com_arrow_link .arrow::after {background: #5971c7;}

/*no.2*/
.support .no2 .title_box .ft_min::before {
	content: "02";
}
.policy .no2 .bg {
	background: #fff3c9;
	padding-bottom: 120px;
}
.policy .no2 .first_img .abs {
	width: 25%;
	max-width: 300px;
	left: 2%;
	top: 0;
	transform: translateY(-10%);
}
.policy .no2 .link_list .img_box .ft_dm {
	color: #fcee21;
	font-size: min(350%,5.0vw);
	letter-spacing: .05em;
	line-height: 1.0em;
	opacity: 0.9;
	position: absolute;
	z-index: 1;
	right: .2em;
	bottom: -.4em;
}
.policy .no2 .link_list dt {
	letter-spacing: .4em;
}
.policy .no2 .link_list .com_arrow_link {
	color: #967900;
	font-size: min(205%,3.0vw);
	line-height: 1.5em;
}
.policy .no2 .link_list .com_arrow_link a {
	letter-spacing: .1em;
}

.policy .no2 .slide_box2 .slide_wrap {
	margin: 120px 0 60px;
	position: relative;
}
.policy .no2 .slide_box2 .slide_wrap .illust li {
	position: absolute;
	z-index: 2;
}
.policy .no2 .slide_box2 .slide_wrap .illust li:nth-child(1) {
	width: 7%;
	max-width: 100px;
	left: 13%;
	bottom: -20px;
}
.policy .no2 .slide_box2 .slide_wrap .illust li:nth-child(2) {
	width: 5%;
	max-width: 75px;
	right: 18%;
	top: -20px;
}
.policy .no2 .slide_box2 .flex_list {
	display: flex;
    justify-content: space-between;
	margin-bottom: 80px;
}
.policy .no2 .slide_box2 .flex_list li {
/*	width: 48%;*/
	max-width: 570px;
	margin-left: auto;
	margin-right: auto;
	display: flex;
    justify-content: space-between;
    align-items: center;
}
.policy .no2 .slide_box2 .flex_list div {
	width: 36%;
	text-align: center;
}
.policy .no2 .slide_box2 .flex_list dl {
	width: 62%;
	box-sizing: border-box;
	padding-left: 5%;
	border-left: solid 1px #b3b3b3;
	padding-bottom: 1.0em;
}
.policy .no2 .slide_box2 .flex_list dt {
	font-size: 125%;
	letter-spacing: .2em;
	line-height: 1.8em;
	margin-bottom: .5em;
}
.policy .no2 .slide_box2 .flex_list dd {
	line-height: 1.6em;
}
.policy .no2 .com_arrow_link .arrow {background: #d2a116;}
.policy .no2 .com_arrow_link .arrow::before,
.policy .no2 .com_arrow_link .arrow::after {background: #c19913;}

/*no.3*/
.support .no3 {
	margin-bottom: 120px;
}
.support .no3 .title_box .ft_min::before {
	content: "03";
}
.policy .no3 .first_img {
	margin-bottom: 80px;
}
.policy .no3 .txt_list {
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.policy .no3 .txt_list li {
	width: 48%;
	max-width: 550px;
	display: flex;
    justify-content: space-between;
    align-items: center;
	margin-top: 70px;
}
.policy .no3 .txt_list li:nth-child(-n+2) {
	margin-top: 0;
}
.policy .no3 .txt_list li div {
	width: 45.5%;
	max-width: 250px;
	border-radius: 50%;
	position: relative;
	overflow: hidden;
}
.policy .no3 .txt_list li div::before {
	content: "";	/*矢印背景*/
	position: absolute;
	z-index: 1;
	width: 25%;
	height: 100%;
	right: 0;
	top: 0;
	background: rgba(128,128,128,0.6);
	transition: all 1.0s;
}
.policy .no3 .txt_list li:hover div::before {
	transition: all 0.4s;
	background: rgba(177,197,83,0.6);
}
.policy .no3 .txt_list li div::after {
	font-family: 'fontello';
	content: '\e800';
	color: #fff;
	font-size: 120%;
	position: absolute;
	z-index: 1;
	right: 5%;
	top: 50%;
	transform: translateY(-50%);
}
.policy .no3 .txt_list li div img {
	position: relative;
	z-index: 0;
}
.policy .no3 .txt_list li dl {
	width: 51%;
	max-width: 270px;
}
.policy .no3 .txt_list li dt {
	font-size: min(175%,2.6vw);
	letter-spacing: .2em;
	line-height: 1.6em;
	margin-bottom: .5em;
}
.policy .no3 .txt_list li dt span {
	color: #b1c553;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
/*共通*/
.policy .box .title_box,
.medical .mouthpiece .title_box {
	margin-bottom: 5%;
}

.policy .box .first_img {
	margin-bottom: 4%;
}

.policy .box .link_list {
	margin-top: 4%;
}
.policy .box .link_list .img_box {
	margin-bottom: 20px;
}

/*no.1*/
.policy .no1 .bg {
	padding-bottom: 8%;
}
.policy .no1 .link_list .btn_list .com_arrow_link {
	padding-right: 2vw;
	margin-right: 2vw;
}
.policy .no1 .link_list .btn_list .com_arrow_link::after {
	height: 2.0em;
}
.policy .no1 .device dl {
	margin-top: 6%;
	padding-top: 4%;
}
.policy .no1 .device dt {
	margin-bottom: .6em;
}
.policy .no1 .device .width_img {
	padding: 3% 0;
	margin-bottom: 3%;
}

/*no.2*/
.policy .no2 .bg {
	padding-bottom: 8%;
}
.policy .no2 .link_list dt {
	letter-spacing: .03em;
}
.policy .no2 .slide_box2 .slide_wrap {
	margin: 8% 0 5%;
}
.policy .no2 .slide_box2 .flex_list {
	margin-bottom: 4%;
}
.policy .no2 .slide_box2 .flex_list dl {
	padding-bottom: 0;
}
.policy .no2 .slide_box2 .flex_list dt {
	font-size: 125%;
	letter-spacing: .2em;
	line-height: 1.8em;
	margin-bottom: .5em;
}
.policy .no2 .slide_box2 .flex_list dd {
	line-height: 1.6em;
}

/*no.3*/
.support .no3 {
	margin-bottom: 8%;
}
.policy .no3 .first_img {
	margin-bottom: 6%;
}
.policy .no3 .txt_list li {
	margin-top: 6%;
}
.policy .no3 .txt_list li dt {
	font-size: 2.8vw;
	letter-spacing: .1em;
	margin-bottom: .2em;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
/*共通*/
.policy .box .title_box,
.medical .mouthpiece .title_box {
	margin-bottom: 8%;
}
.support .box .title_box .line_area,
.medical .mouthpiece .title_box .line_area {
	height: 12vw;
	margin: 6% auto;
}
.support .box .title_box .ft_min,
.medical .mouthpiece .title_box .ft_min {
	font-size: 160%;
	letter-spacing: .15em;
	padding-top: 1.0em;
}
.support .box .title_box .ft_min::before,
.medical .mouthpiece .title_box .ft_min::before {
	font-size: 60%;
}

.policy .box .first_img {
	margin-bottom: 5%;
}
.policy .box .first_img div {
	width: 120%;
	margin-left: -10%;
}

.policy .box .lead > dt {
	font-size: 140%;
	letter-spacing: .05em;
	line-height: 1.6em;
	margin-bottom: .6em;
}

.policy .box .link_list {
	margin-top: 6%;
	display: block;
	border-top: solid 1px #ccc5c2;
}
.policy .box .link_list > li {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	padding: 6% 3%;
	border-bottom: solid 1px #ccc5c2;
	display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}
.policy .box .link_list .img_box {
	width: 37%;
	margin-bottom: 0;
}
.policy .box .link_list dl,
.policy .box .link_list p.ft_min {
	width: 58%;
}

/*no.1*/
.policy .no1 .bg {
	padding-bottom: 12%;
}
.policy .no1 .first_img .abs {
	width: 55%;
	top: 0;
	left: 0;
	transform: translate(-8%,-15%);
}
.policy .no1 .link_list p.ft_min {
	font-size: 125%;
	letter-spacing: .05em;
	line-height: 1.5em;
	margin-bottom: 0;
}
.policy .no1 .link_list .btn_list {
	width: 100%;
	text-align: center;
	font-size: 95%;
	margin-top: 1.0em;
    justify-content: center;
}
.policy .no1 .link_list .btn_list .com_arrow_link {
	padding-right: 5vw;
	margin-right: 5vw;
}
.policy .no1 .link_list .btn_list .com_arrow_link::after {
	height: 2.0em;
}	

.policy .no1 .device dl {
	margin-top: 0;
	border-top: none;
	padding-top: 6%;
}
.policy .no1 .device dt {
	text-align: left;
	font-size: 125%;
	letter-spacing: .1em;
	line-height: 1.6em;
	margin-bottom: .4em;
}
.policy .no1 .device .width_img {
	padding: 6% 0 0;
	margin-bottom: 6%;
}
.policy .no1 .device .width_img::before {
	display: none;
}

/*no.2*/
.policy .no2 .bg {
	padding-bottom: 12%;
}
.policy .no2 .first_img .abs {
	width: 40%;
	top: 0;
	left: 0;
	transform: translate(-8%,-15%);
}
.policy .no2 .link_list .img_box .ft_dm {
	font-size: 120%;
}
.policy .no2 .link_list dt {
	letter-spacing: .2em;
}
.policy .no2 .link_list .com_arrow_link {
	font-size: 125%;
	white-space: nowrap;
}
.policy .no2 .link_list .com_arrow_link a {
	letter-spacing: normal;
	padding-right: 2.0em;
}
.policy .no2 .link_list .com_arrow_link .arrow {
	width: 1.5em;
	height: 1.5em;
}

.policy .no2 .slide_box2 .slide_wrap {
	margin: 12% 0 10%;
}
.policy .no2 .slide_box2 .slide_wrap .illust li:nth-child(1) {
	width: 14%;
}
.policy .no2 .slide_box2 .slide_wrap .illust li:nth-child(2) {
	width: 10%;
}
.policy .no2 .slide_box2 .flex_list {
	display: block;
	margin-bottom: 8%;
}
.policy .no2 .slide_box2 .flex_list li {
	width: 100%;
	max-width: 100%;
	margin-bottom: 6%;
}
.policy .no2 .slide_box2 .flex_list li:last-child {
	margin-bottom: 0;
}
.policy .no2 .slide_box2 .flex_list div {
	width: 26%;
}
.policy .no2 .slide_box2 .flex_list dl {
	width: 70%;
	padding-bottom: 0;
}
.policy .no2 .slide_box2 .flex_list dt {
	font-size: 110%;
	letter-spacing: .05em;
	line-height: 1.6em;
	margin-bottom: .3em;
}

/*no.3*/
.support .no3 {
	margin-bottom: 12%;
}
.policy .no3 .first_img {
	width: 100%;
	margin: 0 auto 10%;
}
.policy .no3 .txt_list li {
	max-width: 100%;
	display: block;
	margin-top: 6%;
}
.policy .no3 .txt_list li div {
	width: 70%;
	margin: 0 auto 6%;
}
.policy .no3 .txt_list li dl {
	width: 100%;
	max-width: 100%;
}
.policy .no3 .txt_list li dt {
	text-align: center;
	font-size: 120%;
	letter-spacing: .1em;
	margin-bottom: .2em;
}
}



/*medical
---------------------------------------------------------*/
.medical {
	background: #f9f5f0;
	padding-top: 130px;
}

.medical .max_1500 {
	padding-bottom: 80px;
	margin-bottom: 80px;
	position: relative;
}
.medical .max_1500::before {
	content: "";	/*罫線*/
	position: absolute;
	width: 94%;
	max-width: 1300px;
	height: 1px;
	background: #ccc5c2;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
}
.medical .max_1500.noborder {
	margin-bottom: 0;
}
.medical .max_1500.noborder::before {
	display: none;
}

.medical .style1 > dt {
	font-size: min(200%,3.2vw);
	letter-spacing: .2em;
	line-height: 1.6em;
	margin-bottom: .5em;
}
.medical .style1 > dt span {
	display: block;
	font-size: 65%;
	letter-spacing: .2em;
	line-height: 1.6em;
}

.medical .style2 > dt {
	font-size: min(235%,3.4vw);
	letter-spacing: .2em;
	line-height: 1.6em;
	margin-bottom: .6em;
}
.medical .style2 dt.ft_dm,
.medical .style2 dt.ft_dm {
	font-size: 120%;
	letter-spacing: .14em;
	line-height: 1.2em;
	margin-bottom: 1.0em;
}
.medical .style2 > dt small {
	display: block;
	font-size: 60%;
	letter-spacing: .2em;
	line-height: 1.6em;
}

.medical .style1 .link_box,
.medical .style2 .link_box {
	margin-top: 40px;
	display: flex;
    flex-wrap: wrap;
}
.medical .style1 .link_box .com_arrow_link,
.medical .style2 .link_box .com_arrow_link {
	margin-right: 10%;
}
.medical .style1 .link_box .com_arrow_link:last-of-type,
.medical .style2 .link_box .com_arrow_link:last-of-type {
	margin-right: 0;
}

/*mouthpiece*/
.medical .mouthpiece {
	position: relative;
	z-index: 1;
}
.medical .mouthpiece .lead {
	font-size: min(375%,5.4vw);
	letter-spacing: .2em;
	line-height: 1.6em;
	margin-bottom: 80px;
}
.medical .mouthpiece .outline {
	position: relative;
	margin-bottom: 60px;
}
.medical .mouthpiece .outline .abs {
	position: absolute;
	z-index: -1;
	width: 45%;
	max-width: 540px;
	right: 0;
	top: 0;
	transform: translate(3%,-50%);
}
.medical .mouthpiece .outline .flt_box .img_box {
	float: left;
	width: 36%;
	max-width: 447px;
}
.medical .mouthpiece .outline .flt_box .style1 {
	float: right;
	width: 60%;
	max-width: 745px;
}

.medical .mouthpiece .piece_type {
	position: relative;
	z-index: 1;
}
.medical .mouthpiece .piece_type ul {
	display: flex;
    justify-content: space-between;
	margin-bottom: 60px;
}
.medical .mouthpiece .piece_type li {
	width: 33%;
	max-width: 410px;
}
.medical .mouthpiece .piece_type li .style2 {
	margin-top: 40px;
}
.medical .mouthpiece .piece_type .memo1 {
	text-align: center;
	font-size: 80%;
	letter-spacing: .24em;
	line-height: 1.4em;
	margin-bottom: 1.5em;
}
.medical .mouthpiece .piece_type .memo2 {
	text-align: center;
	font-size: 90%;
	letter-spacing: .14em;
	line-height: 1.6em;
	background: #fff;
	padding: 1.5em 3%;
	border-radius: 10px;
}
.medical .mouthpiece .case_bnr{
	width: 700px!important;
	margin: 0 auto;
	display: flex!important;
	justify-content: space-between;
	font-size: 200%;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	margin-bottom: 40px;
}
.medical .mouthpiece .case_bnr li{
	width: 46%!important;
	text-align: center;
}
.medical .mouthpiece .case_bnr li a{
	position: relative;
	padding: 15px 1em 15px 0;
	box-sizing: border-box;
	color: #fff;
	display: block;
	z-index: 1;
}
.medical .mouthpiece .case_bnr li:first-child a{
	background-color: #4B99B2;
}
.medical .mouthpiece .case_bnr li:last-child a{
	background-color: #d6b758;
}
.medical .mouthpiece .case_bnr li a::before {
	font-family: 'fontello';
	content: '\e802';
	color: #fff;
	position: absolute;
	line-height: 1.0em;
	right: 0.4em;
	top: 50%;
	transform: translateY(-50%);
	font-size: 40%;
}
.medical .mouthpiece .case_bnr li a::after {
	content: '';
	background: #fff;
	position: absolute;
	width: 1em;
	height: 100%;
	right: 0;
	top: 0;
	opacity: 0.4;
	z-index: -1;
}
.medical .mouthpiece .case_bnr li span{
	font-size: 70%;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	display: block;
}

/*box1、box2*/
.medical .box1 .img_box,
.medical .box2 .img_box {
	width: 40%;
	position: relative
}
.medical .box1 .in_box,
.medical .box2 .in_box {
	width: 57%;
	max-width: 835px;
	box-sizing: border-box;
}
.medical .box1 .img_box {float: right;}
.medical .box2 .img_box {float: left;}
.medical .box1 .in_box {float: left;}
.medical .box2 .in_box {float: right;}
.medical .box1 .img_box p,
.medical .box2 .img_box p {
	position: absolute;
	z-index: 1;
	width: 45%;
	max-width: 222px;
	top: 0;
	transform: translateY(-5%);
}
.medical .box1 .img_box p {
	left: 5%;
}
.medical .box2 .img_box p {
	right: 5%;
}
.medical .box1 .img_box div,
.medical .box2 .img_box div {
	position: relative;
	z-index: 0;
}
.medical .box1 .in_box {
	padding-left: 3%;
}
.medical .box2 .in_box {
	padding-right: 3%;
}
.medical .box1 .style2,
.medical .box2 .style2 {
	width: 100%;
	max-width: 715px;
}
.medical .box1 .style2 {
	margin-left: auto;
	margin-right: 0;
}
.medical .box2 .style2 {
	margin-left: 0;
	margin-right: auto;
}
.medical .box1 .style2 dt.ft_dm,
.medical .box2 .style2 dt.ft_dm {
	margin-bottom: 2.0em;
}

/*box3*/
.medical .box3 ul {
	display: flex;
    justify-content: space-between;
}
.medical .box3 li {
	width: 48.5%;
	max-width: 580px;
}
.medical .box3 li .style1 {
	margin-top: 30px;
}
.medical .box3 li .img_box {
	position: relative;
}
.medical .box3 li .img_box .abs_txt {
	position: absolute;
	width: 38%;
	right: 5%;
	top: -5%;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.medical {
	padding-top: 10%;
}
.medical .max_1500 {
	padding-bottom: 8%;
	margin-bottom: 8%;
}
.medical .style1 > dt {
	font-size: 3.2vw;
	letter-spacing: .15em;
	margin-bottom: .3em;
}
.medical .style1 > dt span {
	font-size: 80%;
	letter-spacing: .15em;
}
.medical .style2 > dt {
	font-size: 3.6vw;
	letter-spacing: .15em;
	margin-bottom: .4em;
}
.medical .style2 dt.ft_dm,
.medical .style2 dt.ft_dm {
	font-size: 100%;
}
.medical .style2 > dt small {
	font-size: 65%;
	letter-spacing: .15em;
}

.medical .style1 .link_box,
.medical .style2 .link_box {
	margin-top: 1.0em;
}
.medical .style1 .link_box .com_arrow_link,
.medical .style2 .link_box .com_arrow_link {
	margin-right: 6%;
}

/*mouthpiece*/
.medical .mouthpiece .lead {
	font-size: 5.8vw;
	letter-spacing: .15em;
	margin-bottom: 6%;
}
.medical .mouthpiece .outline {
	margin-bottom: 6%;
}
.medical .mouthpiece .outline .flt_box .img_box {
	width: 45%;
	margin-right: 4%;
	margin-bottom: 1.5em;
}
.medical .mouthpiece .outline .flt_box .style1 {
	float: none;
	width: 100%;
	max-width: 100%;
}
.medical .mouthpiece .piece_type ul {
	margin-bottom: 6%;
}
.medical .mouthpiece .piece_type li .style2 {
	margin-top: 20px;
}
.medical .mouthpiece .piece_type .memo1 {
	letter-spacing: .1em;
	margin-bottom: 1.0em;
}
.medical .mouthpiece .piece_type .memo2 {
	padding: 1.0em 3%;
	letter-spacing: .1em;
}
.medical .mouthpiece .case_bnr{
	width: 75%!important;
	font-size: 170%;
	margin-bottom: 4%;
}
.medical .mouthpiece .case_bnr li{
	width: 47%!important;
}

/*box1、box2*/
.medical .box1 .img_box,
.medical .box2 .img_box {
	padding-top: 10%;
}
.medical .box1 .style2 dt.ft_dm,
.medical .box2 .style2 dt.ft_dm {
	margin-bottom: 1.0em;
}

/*box3*/
.medical .box3 li .style1 {
	margin-top: 15px;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.medical {
	padding-top: 12%;
}
.medical .max_1500 {
	padding-bottom: 10%;
	margin-bottom: 10%;
}
.medical .style1 > dt {
	font-size: 140%;
	letter-spacing: .1em;
	line-height: 1.5em;
	margin-bottom: .5em;
}
.medical .style1 > dt span {
	font-size: 80%;
	letter-spacing: .1em;
	margin-top: .2em;
}
.medical .style2 > dt {
	font-size: 150%;
	letter-spacing: .1em;
	line-height: 1.5em;
	margin-bottom: .2em;
}
.medical .style2 dt.ft_dm,
.medical .style2 dt.ft_dm {
	font-size: 85%;
	margin-bottom: .5em;
}
.medical .style2 > dt small {
	font-size: 75%;
	letter-spacing: .05em;
	line-height: 1.5em;
}
.medical .style1 .link_box,
.medical .style2 .link_box {
	margin-top: 1.0em;
}
.medical .style1 .link_box .com_arrow_link,
.medical .style2 .link_box .com_arrow_link {
	margin-right: 8%;
}
	
/*mouthpiece*/
.medical .mouthpiece .lead {
	text-align: left;
	font-size: 200%;
	letter-spacing: .15em;
	margin-bottom: 10%;
}
.medical .mouthpiece .outline {
	margin-bottom: 8%;
}
.medical .mouthpiece .outline .abs {
	width: 55%;
	transform: translate(3%,-80%);
}
.medical .mouthpiece .outline .flt_box .img_box {
	float: none;
	width: 100%;
	margin: 0 auto 6%;
}
.medical .mouthpiece .outline .flt_box .style1 {
	float: none;
	width: 100%;
	max-width: 100%;
}
.medical .mouthpiece .piece_type ul {
	display: block;
	margin-bottom: 8%;
}
.medical .mouthpiece .piece_type li {
	width: 100%;
	max-width: 100%;
	display: flex;
    justify-content: space-between;
    align-items: center;
	margin-bottom: 6%;
}
.medical .mouthpiece .piece_type li:last-child {
	margin-bottom: 0;
}
.medical .mouthpiece .piece_type li > div {
	width: 42%;
}
.medical .mouthpiece .piece_type li .style2 {
	width: 54%;
	margin-top: 0;
}
.medical .mouthpiece .piece_type li .style2 .com_arrow_link {
	font-size: 90%;
}
.medical .mouthpiece .piece_type li .style2 .com_arrow_link a {
	letter-spacing: .05em;
}
.medical .mouthpiece .piece_type .memo1 {
	text-align: left;
	letter-spacing: .05em;
	line-height: 1.6em;
	margin-bottom: 1.0em;
}
.medical .mouthpiece .piece_type .memo2 {
	text-align: left;
	letter-spacing: .05em;
	line-height: 1.6em;
	padding: 4%;
}
.medical .mouthpiece .case_bnr{
	width: 100%!important;
	font-size: 140%;
	margin-bottom: 6%;
}
.medical .mouthpiece .case_bnr li{
	width: 48.5%!important;
	display: block;
	margin: 0;
}
.medical .mouthpiece .case_bnr li a{
	padding-top: 3vw;
	padding-bottom: 3vw;
}

/*box1、box2*/
.medical .box1 .img_box,
.medical .box2 .img_box {
	float: none;
	width: 70%;
	margin: 0 auto 6%;
}
.medical .box1 .in_box,
.medical .box2 .in_box {
	float: none;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	padding: 0 3%;
}
.medical .box1 .img_box p {
	left: -15%;
}
.medical .box2 .img_box p {
	right: -15%;
}
.medical .box1 .style2,
.medical .box2 .style2 {
	max-width: 100%;
}
.medical .box1 .style2 dt.ft_dm,
.medical .box2 .style2 dt.ft_dm {
	margin-bottom: 1.0em;
}

/*box3*/
.medical .box3 ul {
	display: block;
}
.medical .box3 li {
	width: 100%;
	max-width: 100%;
	padding-bottom: 10%;
	border-bottom: solid 1px #ccc5c2;
	margin-bottom: 10%;
}
.medical .box3 li:last-child {
	padding-bottom: 0;
	border-bottom: none;
	margin-bottom: 0;
}
.medical .box3 li > div {
	width: 80%;
	margin: 0 auto 4%;
}
.medical .box3 li .style1 {
	margin-top: 0;
}
}



/*.medical .case
---------------------------------------------------------*/
.medical .case {
	padding-bottom: 120px;
}
.medical .case h4 {
	font-size: 235%;
	letter-spacing: .2em;
	line-height: 1.2em;
	margin-bottom: 50px;
}
.medical .case h4 .ft_dm {
	font-size: 50%;
	letter-spacing: .14em;
	line-height: 1.2em;
	display: inline-block;
	transform: translateY(-.5em);
	margin-left: 2%;
}
.medical .case .com_arrow_link {
	text-align: center;
	margin-top: 60px;
}

.medical .case .case_slider {
	width: calc(50% + 630px);	/*スライドショー幅*/
	height: 100%;
	margin-left: auto;
	margin-right: 0;
	overflow: visible;
	z-index: 1;
}
.medical .case .case_slider .swiper-wrapper {
	margin-bottom: 70px;
}
.medical .case .case_slider .swiper-slide {
	width: 50%;
	max-width: 500px;
	margin-right: 3% !important;
}
.medical .case .case_slider .swiper-slide ul {
	display: flex;
    justify-content: space-between;
}
.medical .case .case_slider .swiper-slide li {
	width: 50%;
	position: relative;
	overflow: hidden;
	background: #ccc;
}
.medical .case .case_slider .swiper-slide li::before {
	content: "";	/* 高さ */
	display: block;
	padding-top: 72%;
}
.medical .case .case_slider .swiper-slide li div {
	position: absolute;
	z-index: 0;
	width: 100%;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}
.medical .case .case_slider .swiper-slide li::after {
	content: "BEFORE";	/*テキスト*/
	position: absolute;
	z-index: 1;
	right: 5%;
	bottom: 5%;
	font-family: "dm-sans", sans-serif;
	font-weight: 500;
	font-style: normal;
	color: #fff;
	font-size: 90%;
	letter-spacing: .1em;
	line-height: 1.2em;
}
.medical .case .case_slider .swiper-slide li:last-child::after {
	content: "AFTER";
}
.medical .case .case_slider .swiper-slide p {
	font-family: "dnp-shuei-mincho-pr6n", sans-serif;
	font-weight: 400;
	font-style: normal;
	letter-spacing: .2em;
	line-height: 1.4em;
	margin-top: 1.0em;
}
/*スクロールバー、ボタンの配置*/
.medical .case .case_slider .swiper-scrollbar {
	width: calc(97% - 70px);
}
.medical .case .case_slider .scl_pre_next {
	position: absolute;
	width: 70px;
	right: 0;
	bottom: 0;
	transform: translateY(50%);
	display: flex;
    justify-content: space-between;
    align-items: center;
}
/*swiper：スクロールバー*/
.medical .case .case_slider .swiper-scrollbar {
	position: static !important;
	height: 2px !important;
	background: rgba(204,197,194,0.3);	/*背景色*/
	border-radius: 0;
}
.medical .case .case_slider .swiper-scrollbar .swiper-scrollbar-drag {
	background: #786252;	/*上の色*/
	border-radius: 0;
}
/*swiper：スクロールバー矢印*/
.medical .case .case_slider .scl_pre_next {
	width: 100%;
	max-width: 70px;
	display: flex;
    justify-content: space-between;
    align-items: center;
	font-size: 100%;
	letter-spacing: normal;
	line-height: 1.0em;
}
.medical .case .case_slider .scl_pre_next li {
	position: relative;
	background: none !important;
	width: 1.0em;
	height: 1.0em;
	margin: 0;
	left: auto !important;
	right: auto !important;
}
.medical .case .case_slider .scl_pre_next li::before {
	font-family: 'fontello';
	content: '\e801';
	color: #a69385;
	position: absolute;
	margin: auto;
	left: 0;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
}
.medical .case .case_slider .scl_pre_next li.swiper-button-next::before {
	content: '\e802';
}

/*追加*/
.case_tit{
    margin-bottom: .8em;
}
.case_txt{
    font-size:13px!important;
    line-height: 1.5em!important;
}
.medical .case .case_slider .swiper-slide .case_txt p{
    margin-top: 0!important;
    font-family: "Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
    letter-spacing: normal!important;
}
.case_txt,
.case_txt tr{
    width: 100%;
}
.case_txt th{
    width: 7em;
    background:#a69385;
    color: #fff;
    line-height: 1.4em!important;
    letter-spacing: normal!important;
}
.case_txt td{
    width: calc(100% - 7em);
}
.case_txt th,
.case_txt td{
    vertical-align: top;
    border-bottom: 1px solid #ccc;
    box-sizing: border-box;
    padding: .6em .8em;
}
.case_txt tr:nth-child(1) th,
.case_txt tr:nth-child(1) td{
    border-top:1px solid #ccc;
}


/* 1500px以下
------------------------------------------*/
@media only screen and (max-width: 1500px) {
.medical .case .case_slider {
	width: 98%;	/*スライドショー幅*/
}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.medical .case {
	padding-bottom: 8%;
}
.medical .case h4 {
	letter-spacing: .15em;
	margin-bottom: 4%;
}
.medical .case .com_arrow_link {
	margin-top: 4%;
}

.medical .case .case_slider .swiper-wrapper {
	margin-bottom: 4%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.medical .case {
	padding-bottom: 10%;
}
.medical .case h4 {
	font-size: 180%;
	letter-spacing: .1em;
	margin-bottom: 5%;
}
.medical .case .com_arrow_link {
	margin-top: 6%;
}

.medical .case .case_slider .swiper-wrapper {
	margin-bottom: 6%;
}
.medical .case .case_slider .swiper-slide {
	width: 80%;
	font-size: 90%;
}
.medical .case .case_slider .swiper-slide li::after {
	letter-spacing: .1em;
}
.medical .case .case_slider .swiper-slide p {
	letter-spacing: .1em;
}
/*スクロールバー、ボタンの配置*/
.medical .case .case_slider .swiper-scrollbar {
	width: 78%;
}
.medical .case .case_slider .scl_pre_next {
	width: 15%;
}
    
/*追加*/
.case_txt th,
.case_txt td{
    padding: .6em .7em;
}
}



/*greeting
---------------------------------------------------------*/
.greeting .title_box {
	background-image: url("../images/top/gree_img1@2x.jpg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	position: relative;
	height: 40vw;
	max-height: 580px;
	margin-bottom: 120px;
}
.greeting .title_box h2 {
	color: #e9d9c2;
	font-size: min(1020%,12vw);
	letter-spacing: -.02em;
	line-height: 1.0em;
	position: absolute;
	z-index: 1;
	right: -.1em;
	bottom: 0;
	transform: translateY(40%);
}

.greeting .w1260 {
	margin-bottom: 100px;
}
.greeting .w1260 .box_r {
	float: right;
	width: 32%;
	max-width: 390px;
}
.greeting .w1260 .box_l {
	float: left;
	width: 65%;
	max-width: 780px;
}

.greeting .box_r .img_box {
	position: relative;
}
.greeting .box_r .img_box div {
	position: relative;
	z-index: 0;
}
.greeting .box_r .img_box dl {
	color: #fff;
	position: absolute;
	z-index: 1;
	left: 10%;
	bottom: 10%;
	/*filter: drop-shadow(0 0 5px rgba(0,0,0,0.5));*/
}
.greeting .box_r .img_box dt {
	font-size: 120%;
	letter-spacing: .2em;
	line-height: 1.2em;
	margin-bottom: .2em;
}
.greeting .box_r .img_box dd {
	font-size: 175%;
	letter-spacing: .2em;
	line-height: 1.2em;
}
.greeting .box_r .img_box dd.ft_dm {
	font-size: 100%;
	letter-spacing: .1em;
	line-height: 1.2em;
	margin-top: .2em;
}
.greeting .box_r .com_arrow_link {
	text-align: right;
	margin-top: 2.0em;
}

.greeting .box_l dt {
	font-size: min(295%,4.0vw);
	letter-spacing: .2em;
	line-height: 1.8em;
	margin-bottom: .8em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.greeting .title_box {
	margin-bottom: 10%;
}
.greeting .w1260 {
	margin-bottom: 8%;
}
.greeting .w1260 .box_r {
	margin-left: 4%;
	margin-bottom: 1.0em;
}
.greeting .w1260 .box_l {
	float: none;
	width: 100%;
	max-width: 100%;
}
.greeting .box_r .com_arrow_link {
	margin-top: 1.5em;
}
.greeting .box_l dt {
	letter-spacing: .15em;
	line-height: 1.6em;
	margin-bottom: .4em;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.greeting .title_box {
	margin-bottom: 12%;
}
.greeting .title_box h2 {
	font-size: 300%;
}

.greeting .w1260 {
	margin-bottom: 12%;
}
.greeting .w1260 .box_r {
	float: none;
	width: 60%;
	margin: 0 auto 4%;
}
.greeting .w1260 .box_l {
	float: none;
	width: 100%;
	max-width: 100%;
}

.greeting .box_r .img_box dl {
	left: 6%;
	bottom: 6%;
	font-size: 80%;
}
.greeting .box_r .com_arrow_link {
	margin-top: 4%;
	text-align: center;
}

.greeting .box_l dt {
	font-size: 150%;
	letter-spacing: .1em;
	line-height: 1.5em;
	margin-bottom: .5em;
}
}



/*information
---------------------------------------------------------*/
.information {
	position: relative;
	padding-top: 80px;
}
.information::before {
	content: "";
	position: absolute;
	width: 94%;
	height: 1px;
	background: #ccc5c2;
	margin: auto;
	left: 0;
	right: 0;
	top: 0;
}
.information .w1260 {
	display: flex;
    justify-content: space-between;
	margin-bottom: 80px;
}
.information .w1260 > div {
	width: 47%;
	max-width: 580px;
}
.information h2 {
	font-size: 240%;
	letter-spacing: normal;
	line-height: 1.2em;
	position: relative;
	margin-bottom: .2em;
}
.information .com_arrow_link {
	margin-bottom: 1.0em;
}
.information .com_arrow_link a {
	letter-spacing: .2em;
	padding-right: 2.5em;
}
.information .com_arrow_link .arrow {
	width: 2.0em;
	height: 2.0em;
}
.information .com_arrow_link .arrow {background: #e3cfb4;}
.information .com_arrow_link .arrow::before,
.information .com_arrow_link .arrow::after {background: #cbb69b;}

.information .scl_box {
	height: 11em;
}
.information ul {
	padding-right: 6%;
}
.information ul li {
	margin-bottom: 1.0em;
}
.information ul li:last-child {
	margin-bottom: 0;
}
.information ul dt {
	color: #998372;
	font-size: 90%;
	letter-spacing: .12em;
	line-height: 1.2em;
	margin-bottom: .5em;
}
.information ul dd {
	letter-spacing: .2em;
	line-height: 1.6em;
	padding-left: 1.2em;
	position: relative;
}
.information ul dd::before {
	font-family: 'fontello';
	content: '\e802';
	color: #a89b92;
	font-size: 50%;
	position: absolute;
	left: 0;
	top: 0;
}
.information ul dd a {
	position: relative;
}
.information ul dd a::after {
	position: absolute;
	content: "";
	background-color: #998372;
	width: 0%;
	height: 1px;
	left: 0;
	bottom: 0;
	transition: all 0.4s;
}
.information ul dd a:hover::after {
	width: 100%;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.information {
	padding-top: 6%;
}
.information .w1260 {
	margin-bottom: 6%;
}
.information h2 {
	font-size: 200%;
}
.information ul li {
	margin-bottom: .6em;
}
.information ul dd {
	letter-spacing: .05em;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.information {
	padding-top: 10%;
}
.information .w1260 {
	display: block;
	margin-bottom: 10%;
}
.information .w1260 > div {
	width: 100%;
	max-width: 100%;
	margin-bottom: 8%;
}
.information h2 {
	font-size: 140%;
	margin-bottom: .3em;
}	
.information .com_arrow_link a {
	font-size: 90%;
}
.information .scl_box {
	height: 9em;
}
.information ul li {
	margin-bottom: .8em;
}
.information ul dt {
	letter-spacing: .05em;
	margin-bottom: .3em;
}
.information ul dd {
	font-size: 90%;
	letter-spacing: .1em;
	line-height: 1.4em;
	padding-left: 1.0em;
}
.information .com_arrow_link {
	text-align: center;
}
}



/*clinic
---------------------------------------------------------*/
.clinic {
	background: #E3CFB3;
	background: linear-gradient(45deg,rgba(227, 207, 179, 0.5) 0%, rgba(227, 207, 179, 1) 100%);
	padding: 80px 0;
}
/*ストリートビューあり▼*/
/*
.clinic .w1120 {
	display: flex;
    justify-content: space-between;
}
.clinic .w1120 .box_l {
	width: 37%;
}
.clinic .w1120 .box_r {
	width: 60%;
	max-width: 670px;
}
.clinic .com_sns_bnr .icon_inst {
	margin-top: 40px;
}
*/
/*ストリートビューあり▲*/
/*ストリートビューなし▼*/
.clinic .com_sns_bnr {
	display: flex;
    justify-content: space-between;
	width: 80%;
	max-width: 900px;
	margin: 0 auto;
}
.clinic .com_sns_bnr li {
	width: 49%;
}
/*ストリートビューなし▲*/
.clinic .box_r iframe {
	display: block;
}
.clinic .box_r .com_arrow_link {
	text-align: right;
	margin-top: 40px;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.clinic {
	padding: 6% 0 6%;
}
/*ストリートビューあり▼*/
/*
.clinic .w1120 {
    align-items: center;
}
.clinic .com_sns_bnr.icon_inst {
	margin-top: 10%;
}
*/
/*ストリートビューあり▲*/

.clinic .box_r .com_arrow_link {
	margin-top: 6%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.clinic {
	padding: 10% 0;
}
/*ストリートビューあり▼*/
/*
.clinic .w1120 {
	display: block;
}
.clinic .w1120 .box_l {
	width: 100%;
	margin-bottom: 8%;
}
.clinic .w1120 .box_r {
	width: 100%;
	max-width: 100%;
}
.clinic .box_l ul {
	display: flex;
    justify-content: space-between;
}
.clinic .box_l li {
	width: 49%;
}
.clinic .com_sns_bnr .icon_inst {
	margin-top: 0;
}
*/
/*ストリートビューあり▲*/
/*ストリートビューなし▼*/
.clinic .com_sns_bnr {
	width: 100%;
}
/*ストリートビューなし▲*/

.clinic .box_r iframe {
	height: 350px;
}
.clinic .box_r .com_arrow_link {
	margin-top: 4%;
}
}



/*recruit
---------------------------------------------------------*/
.recruit {
	padding: 2.5%;
	margin-bottom: 50px;
}
.recruit .bg {
	background: url("../images/bg_slash@2x.png") repeat center center;
	background-size: 67px auto;
	padding: 80px 3%;
}
.recruit .bg .in_box {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}
.recruit .bg .box_l {
	width: 35%;
	max-width: 418px;
	text-align: left;
	position: relative;
	z-index: 1;
}
.recruit .bg .box_r {
	position: absolute;
	width: 65%;
	max-width: 780px;
	right: 0;
	top: 0;
	transform: translateY(-5%);
}

.recruit .bg .box_l p.ft_min,
.recruit .bg .box_l .ft_dm {
	position: relative;
	z-index: 1;
}
.recruit .bg .box_l p.ft_min {
	font-size: min(135%,1.8vw);
	letter-spacing: .2em;
	line-height: 1.2em;
}
.recruit .bg .box_l p.ft_dm {
	color: #bea276;
	font-size: min(635%,7.2vw);
	letter-spacing: normal;
	line-height: 1.2em;
}

.recruit .bg .box_r {
	overflow: hidden;
	background: url("../images/top/recr_img@2x.jpg") no-repeat center center;
	background-size: cover;
}
.recruit .bg .box_r .com_rec_list a {
	display: block;
	aspect-ratio: 304 / 360;
	box-sizing: border-box;
	padding-top: 55%;
	padding-left: 8%;
	font-size: min(100%,1.3vw);
}
.recruit .bg .box_r .com_rec_list .ft_min {
	font-size: 240%;
	letter-spacing: .1em;
}
.recruit .bg .box_r .com_rec_list .ft_min span {
	font-size: 60%;
	letter-spacing: .2em;
}
.recruit .bg .box_r .com_rec_list li ul {
	font-size: 90%;
	letter-spacing: .1em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.recruit {
	padding: 2%;
	margin-bottom: 12%;
}
.recruit .bg {
	padding: 6% 3%;
}
.recruit .bg .box_l {
	width: 35%;
}
.recruit .bg .box_r {
	width: 70%;
	right: -6%;
}
.recruit .bg .box_l p.ft_min {
	font-size: 2.1vw;
	letter-spacing: .15em;
}
.recruit .bg .box_r .com_rec_list a {
	padding-top: 48%;
	font-size: 1.4vw;
}
.recruit .bg .box_r .com_rec_list .ft_min {
	letter-spacing: .05em;
}
.recruit .bg .box_r .com_rec_list .ft_min span {
	font-size: 70%;
	letter-spacing: .1em;
}
.recruit .bg .box_r .com_rec_list li ul {
	font-size: 100%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.recruit {
	padding: 4% 4% 0;
	margin-bottom: 10%;
}
.recruit .bg {
	padding: 6% 4% 0;
}
.recruit .bg .box_l {
	width: 100%;
	max-width: 100%;
	text-align: center;
	margin-bottom: 6%;
}
.recruit .bg .box_r {
	position: relative;
	top: auto;
	right: auto;
	width: 120%;
	left: -10%;
}

.recruit .bg .box_l p.ft_min {
	font-size: 110%;
	letter-spacing: .1em;
	margin-bottom: .2em;
}
.recruit .bg .box_l p.ft_dm {
	font-size: 300%;
}
.recruit .bg .box_r .com_rec_list a {
	padding-top: 40%;
	font-size: 105%;
}
.recruit .bg .box_r .com_rec_list .ft_min {
	letter-spacing: .05em;
}
.recruit .bg .box_r .com_rec_list .ft_min span {
	font-size: 75%;
	letter-spacing: .1em;
}
.recruit .bg .box_r .com_rec_list li ul {
	font-size: 80%;
	letter-spacing: normal;
}
}



/*footer
---------------------------------------------------------*/
footer .top_footer {
	display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-direction: row-reverse;
	padding-bottom: 60px;
}
footer .top_footer .box_r {
	width: 64%;
	box-sizing: border-box;
	padding: 5% 3% 0;
	text-align: left;
}
footer .top_footer .box_l {
	width: 36%;
	text-align: center;
}

footer .top_footer .box_r .in_box {
	width: 100%;
	max-width: 690px;
	margin: 0 auto;
}
footer .top_footer .f_clinic dt {
	width: 75%;	/*展開医院ごとに調整想定*/
}
footer .top_footer .com_timetable {
	margin: 40px 0 30px;
}
footer .top_footer .f_contact_box {
	font-size: min(100%,1.5vw);
}
footer .top_footer .f_tel {
	display: flex;
    align-items: center;
	font-size: 125%;
	letter-spacing: .1em;
	line-height: 1.3em;
	margin-bottom: 1.5em;
}
footer .top_footer .f_tel dd {
	font-size: 170%;
	letter-spacing: .02em;
	line-height: 1.2em;
	margin-left: .5em;
}
footer .top_footer .f_map {
	margin-top: 50px;
}

footer .top_footer .box_l .img_area {
	background: url("../images/top/f_img@2x.jpg") no-repeat center center;
	background-size: cover;
}
footer .top_footer .box_l .img_area::before {
	content: "";	/* 高さ */
	display: block;
	padding-top: 830px;
}
footer .top_footer .box_l .f_access {
	background: #c2a87e;
	display: flex;
    justify-content: space-between;
    align-items: center;
	text-align: center;
	font-size: min(90%,1.2vw);
	letter-spacing: .1em;
	line-height: 1.6em;
}
footer .top_footer .box_l .f_access .f_acce_map {
	width: 63%;
	background: #f4ece1;
	padding: 2% 0 4%;
}
footer .top_footer .box_l .f_access .f_acce_bus {
	width: 37%;
	color: #fff;
}
footer .top_footer .box_l .f_access .f_acce_bus p {
	display: inline-block;
	vertical-align: middle;
	padding-top: 6.0em;
	position: relative;
}
footer .top_footer .box_l .f_access .f_acce_bus p::before {
	content: "";
	position: absolute;
	width: 5.0em;
	height: 5.0em;
	margin: auto;
	left: 0;
	right: 0;
	top: 0;
	background: url("../images/icon_bus@2x.png") no-repeat center center;
	background-size: contain;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
footer .top_footer {
	padding-bottom: 4%;
}
footer .top_footer .box_r {
	padding: 5% 3% 0;
}
footer .top_footer .box_l {
	width: 36%;
}
footer .top_footer .f_clinic dt {
	width: 80%;	/*展開医院ごとに調整想定*/
}
footer .top_footer .com_timetable {
	margin: 8% 0 6%;
}
footer .top_footer .f_tel dd {
	font-size: 190%;
}
footer .top_footer .f_map {
	margin-top: 6%;
}

footer .top_footer .box_l .img_area::before {
	padding-top: 80vw;	/* 高さ */
}
footer .top_footer .box_l .f_access {
	display: block;
	font-size: 90%;
	letter-spacing: .05em;
}
footer .top_footer .box_l .f_access .f_acce_map {
	width: 100%;
	padding: 2% 0 4%;
}
footer .top_footer .box_l .f_access .f_acce_bus {
	width: 100%;
	padding: 1.0em 0;
}
footer .top_footer .box_l .f_access .f_acce_bus p {
	padding-top: 0;
	padding-left: 6.0em;
}
footer .top_footer .box_l .f_access .f_acce_bus p::before {
	margin: 0;
	left: 0;
	right: auto;
	top: 50%;
	transform: translateY(-50%);
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
footer .top_footer {
	padding-bottom: 6%;
	display: block;
}
footer .top_footer .box_r {
	width: 100%;
	padding: 0 3%;
}
footer .top_footer .box_l {
	width: 100%;
}

footer .top_footer .box_r .in_box {
	max-width: 100%;
	margin-bottom: 6%;
}
footer .top_footer .f_clinic dt {
	width: 80%;	/*展開医院ごとに調整想定*/
}
footer .top_footer .com_timetable {
	margin: 8% 0 6%;
}
footer .top_footer .f_contact_box {
	font-size: 100%;
}
footer .top_footer .f_tel {
    justify-content: center;
	font-size: 90%;
	letter-spacing: .05em;
	margin-bottom: 1.5em;
}
footer .top_footer .f_tel dd {
	font-size: 170%;
	margin-left: .5em;
}
footer .top_footer .f_map {
	margin-top: 50px;
}

footer .top_footer .box_l {
	display: flex;
}
footer .top_footer .box_l .img_area {
	width: 35%;
}
footer .top_footer .box_l .f_access {
	width: 65%;
}
footer .top_footer .box_l .img_area::before {
	display: none;
}
footer .top_footer .box_l .f_access {
	display: block;
	font-size: 90%;
	letter-spacing: normal;
	line-height: 1.6em;
}
footer .top_footer .box_l .f_access .f_acce_map {
	width: 100%;
	padding: 6% 0 6%;
}
footer .top_footer .box_l .f_access .f_acce_bus {
	width: 100%;
	padding: 6% 0;
}
footer .top_footer .box_l .f_access .f_acce_bus p {
	padding-top: 0;
	padding-left: 6.0em;
}
footer .top_footer .box_l .f_access .f_acce_bus p::before {
	margin: 0;
	left: 0;
	right: auto;
	top: 50%;
	transform: translateY(-50%);
}
}



/*WPプラグイン：カスタム
---------------------------------------------------------*/
/*
.inst_box {
	overflow: hidden !important;
}
.inst_box .bx-viewport{
    overflow: hidden!important;
	height: 280px !important;
}
.inst_box .sbi_item{
	width: 280px!important
}
.inst_box .sbi_photo{        
	height: 280px!important;
}*/
/*WPプラグイン：カスタム*/
.inst_box #sbi_images{
    background: #000;
    padding: 0!important;
    margin: 0!important;
    overflow: hidden!important;
    display: block!important;
}
.inst_box .sbi_item{
    width: 280px!important;
    background: #555;
    overflow: hidden!important;
}
.inst_box .sbi_photo{   
    height: 280px!important;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
    /*
.inst_box .bx-viewport{
	height: 200px !important;
}
.inst_box .sbi_item{
	width: 200px!important
}
.inst_box .sbi_photo{        
	height: 200px!important;
}*/
.inst_box .sbi_item{
	width: 200px !important;
}
.inst_box .sbi_photo{        
	height: 200px !important;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
/*
.inst_box .bx-viewport{
	height: 200px !important;
}
.inst_box .sbi_item{
	width: 200px!important
}
.inst_box .sbi_photo{        
	height: 200px!important;
}*/
.inst_box .sbi_item{
	width: 200px !important;
}
.inst_box .sbi_photo{        
	height: 200px !important;
}
}