@charset "UTF-8";



/*メインイメージ
---------------------------------------------------------*/
/*右側*/
.m_img_area .m_img {
	width: 1452px;
}

/*グラデの丸*/
.m_img_area .m_copy2 {
	position: absolute;
	z-index: 4;
	width: 28%;
	max-width: 420px;
	right: 4%;
	bottom: 4%;
}
.m_img_area .m_copy2 div {
	border-radius: 50%;
	box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.3);
}

/*左側コピー*/
.m_img_area header .m_copy1 {
	position: relative;
}
.m_img_area header .m_copy1 p {
	text-align: left;
	font-size: 135%;
	font-weight: bold;
	letter-spacing: .1em;
	line-height: 1.4em;
	margin: .5em 0 .8em;
}
.m_img_area header .m_copy1 p span {
	font-size: 120%;
	letter-spacing: .05em;
	line-height: 1.3em;
}
.m_img_area header .m_copy1 .abs {
	position: absolute;
	z-index: -1;
	right: 7%;
	top: 0;
	width: 23%;
	max-width: 95px;
}
.m_img_area header .h_txt {
	margin-top: 1.2em;
}

/*飾り*/
.m_img_area .abs_list1 li {
	position: absolute;
	z-index: 1;
}
.m_img_area .abs_list1 li:nth-child(1) {
	width: 10%;
	max-width: 141px;
	left: 442px;
	top: 55%;
}
.m_img_area .abs_list1 li:nth-child(2) {
	width: 11%;
	max-width: 156px;
	left: 580px;
	bottom: 11%;
}
.m_img_area .abs_list1 li:nth-child(3) {
	width: 9%;
	max-width: 128px;
	right: 4%;
	bottom: 3%;
}

/*初期表示アニメーション*/
.m_img_area .m_copy2 div {
	opacity: 0;
	transform: translateY(-10%);
	transition: all 1.0s ease-out 0.5s;
}
.m_img_area.anime_on .m_copy2 div {
	opacity: 1;
	transform: translateY(0%);
}

.m_img_area .abs_list1 li:nth-child(1) div {
	opacity: 0;
	transform: translate(-30%, -50%);
	transition: all 0.6s ease-out 0.1s;
}
.m_img_area .abs_list1 li:nth-child(2) div {
	opacity: 0;
	transform: translate(40%, 20%);
	transition: all 0.6s ease-out;
}
.m_img_area .abs_list1 li:nth-child(3) div {
	opacity: 0;
	transform: translate(50%, -20%);
	transition: all 0.6s ease-out 0.2s;
}

.m_img_area.anime_on .abs_list1 li:nth-child(1) div,
.m_img_area.anime_on .abs_list1 li:nth-child(2) div,
.m_img_area.anime_on .abs_list1 li:nth-child(3) div {
	opacity: 1;
	transform: translate(0%, 0%);
}

.m_img_area .abs_list2 li:nth-child(1) div {
	opacity: 0;
	transform: translate(-40%, -40%);
	transition: all 0.6s ease-out;
}
.m_img_area .abs_list2 li:nth-child(2) div {
	opacity: 0;
	transform: scale(0,0);
	transform-origin: bottom left;
	transition: all 0.6s ease-out 0.2s;
}
.m_img_area.anime_on .abs_list2 li:nth-child(1) div {
	opacity: 1;
	transform: translate(0%, 0%);
}
.m_img_area.anime_on .abs_list2 li:nth-child(2) div {
	opacity: 1;
	transform: scale(1,1);
}

/* 1500px以下
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 1500px) {
.m_img_area .m_img {
	width: 97%;
}
.m_img_area .abs_list1 li:nth-child(1) {
	left: 30%;
}
.m_img_area .abs_list1 li:nth-child(2) {
	left: 38%;
}
}

/* 高さ：1130px以下
------------------------------------------*/
@media only screen and (min-width: 960px) and (max-height: 1130px) {
.m_img_area .m_copy2 {
	width: 36vh;
	min-width: 280px;
}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.m_img_area header {
	padding-top: 7%;
	padding-bottom: 5%;
	z-index: 3;
}
.m_img_area .m_copy2 {
	z-index: 4;		/*グラデの丸*/
	width: 52%;
	right: 0;
	bottom: auto;
	top: 42vw;
	transform: translateX(10%);
}
.m_img_area .abs_list1 li {
	position: absolute;
	z-index: 5;
}

.m_img_area header .m_copy1 p {
	font-size: 77%;
	letter-spacing: .05em;
	margin: .8em 0 1.0em;
}
.m_img_area header .m_copy1 p span {
	letter-spacing: .05em;
}
.m_img_area header .m_copy1 .abs {
	display: none;
}
.m_img_area header .h_txt {
	margin-top: .8em;
}
.m_img_area header .m_img_sp {
	position: relative;
	z-index: 0;
	width: 109%;
	margin-left: -4.5%;
	transform: translateY(-3%);
}
.m_img_area header .site_name dt {
	font-size: 180%;
	padding-top: .5em;
}
.m_img_area header .site_name dd {
	font-size: 100%;
}
	
.m_nav_area .m_nav {
	margin-top: .5em;
}
.m_nav_area .m_nav > li > a {
	padding: .8em 0 .3em;
}

/*飾り*/
.m_img_area .abs_list1 li:nth-child(1) {
	width: 16%;
	left: 3%;
	top: 37%;
	transform: none;
}
.m_img_area .abs_list1 li:nth-child(2) {
	width: 18%;
	left: 2%;
	bottom: 30%;
}
.m_img_area .abs_list1 li:nth-child(3) {
	z-index: 0;
	width: 14%;
	right: 4%;
	bottom: auto;
	top: 10%;
	transform: rotate(90deg);
}
.m_img_area .abs_list2 li:nth-child(2) {
	width: 30%;
	left: 0;
	bottom: 0;
}
}



/*小児治療メンバー紹介
---------------------------------------------------------*/
#member .w1420 {
	margin-top: 40px;
	margin-bottom: 85px;
	text-align: center;
}
#member .img_box {
	position: relative;
	margin-bottom: 90px;
}
#member .img_box div {
	position: relative;
	z-index: 0;
}
#member .img_box li {
	position: absolute;
	z-index: 1;
}
#member .img_box li:nth-child(1) {
	left: 0;
	bottom: -1px;
	width: 18%;
	max-width: 250px;
	transform: scale(0,0);
	transform-origin: bottom left;
	transition: all 0.4s ease-out;
}
#member .img_box li:nth-child(2) {
	right: 0;
	bottom: -1px;
	width: 22%;
	max-width: 300px;
	transform: scale(0,0);
	transform-origin: bottom right;
	transition: all 0.5s ease-out;
}
#member .img_box .anime_on li:nth-child(1) {
	transform: scale(1,1);
}
#member .img_box .anime_on li:nth-child(2) {
	transform: scale(1,1);
}
#member .img_box li:nth-child(3) {
	z-index: 2;
	right: 9.5%;
	bottom: 10%;
	width: 8%;
	max-width: 95px;
}
#member .img_box h2 {
	position: absolute;
	z-index: 5;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	transform: translateY(33%);
	color: #fff;
	font-size: 260%;
	font-weight: bold;
	letter-spacing: .2em;
	line-height: 1.4em;
}
#member .img_box h2 span {
	display: block;
	width: 50%;
	margin: .5em auto 0;
}
#member .img_box h2 span img {
	margin: auto;
}
#member p {
	font-weight: bold;
}

/* 1200px以下
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 1200px) {
#member .img_box h2 {
	font-size: 3.7vw;
	letter-spacing: .2em;
}
#member p .tb_only {
	display: block !important;
}
#member p .pc_only {
	display: none !important;
}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
#member .w1420 {
	margin-top: 3%;
	margin-bottom: 6%;
}
#member .img_box {
	margin-bottom: 9%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
#member .w1420 {
	margin-top: 0;
	width: 100%;
	padding: 0;
	margin-bottom: 12%;
}
#member .img_box {
	margin-bottom: 28vw;
}
#member .img_box h2 {
	bottom: auto;
	transform: none;
	color: #000;
	font-size: 120%;
	letter-spacing: .15em;
	top: calc(100% + .8em);
}
#member p {
	padding: 0 5%;
}
}



/*TOP共通
---------------------------------------------------------*/
/*スライドショー共通設定*/
.swiper {
    overflow: visible !important;
}
.swip_ticker .swiper-wrapper {
	transition-timing-function: linear !important;	/*滑らかに流れ続ける*/
}

/* 1200px以下
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 1200px) {
.top_index img {
	height: 6vw;
	width: auto;
}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.top_index img {
	height: 7vw;
	width: auto;
}
}



/*診療風景
---------------------------------------------------------*/
#medical .slide_box {
	position: relative;
}
#medical .slide_box .title_box {
	position: absolute;
	z-index: 1;
	width: 100%;
	box-sizing: border-box;
	left: 0;
	top: 0;
	text-align: left;
}
#medical .slide_box .title_box .abs_box {
	position: absolute;
	z-index: 1;
	width: 100%;
	left: 70px;
	top: 60px;
}
#medical .slide_box .title_box h2 {
	color: #fff;
	font-size: 130%;
	font-weight: bold;
	letter-spacing: .2em;
	line-height: 1.2em;
	margin-bottom: .5em;
}
#medical .slide_box .title_box .corner {
	position: relative;
	z-index: 0;
	width: 30%;
	transform: scale(0,0);
	transform-origin: top left;
	transition: all 0.6s ease-out;
}
#medical .slide_box.anime_on .title_box .corner {
	transform: scale(1,1);
}
#medical .slide_box .med_slide {
	z-index: 0;
}
#medical .slide_box .med_slide .swiper-slide {
    width: 800px !important;	/*スライド画像の幅*/
}
#medical .slide_box .slide_arrow {
	position: absolute;
	z-index: 2;
	right: 5%;
	bottom: 0;
	transform: translateY(50%);
	width: 20%;
	max-width: 225px;
	display: flex;
    justify-content: space-between;
    align-items: center;
}
#medical .slide_box .slide_arrow div {
	width: 36%;
	max-width: 80px;
	cursor: pointer;
}

#medical .women {
	margin-top: 40px;
	margin-left: 15%;
	width: 20%;
	position: relative;
	z-index: 0;
	transform: translateY(100%);
	transition: all 0.3s ease-out;
}
#medical .women.anime_on {
	transform: translateY(0%);
}

#medical .inst_box {
	width: 100%;
	background: #FCFC75;
	padding: 60px 0 100px;
	position: relative;
	z-index: 1;
}
#medical .inst_box .corner {
	position: absolute;
	z-index: 0;
	width: 25%;
	max-width: 300px;
	right: 0;
	bottom: 0;
	transform: scale(0,0);
	transform-origin: bottom right;
	transition: all 0.4s ease-out;
}
#medical .inst_box .corner.anime_on {
	transform: scale(1,1);
}
#medical .inst_box .w1200 {
	position: relative;
	z-index: 1;
}
#medical .inst_box h3 {
	font-weight: normal;
	margin: 1.0em 0 2.0em;
}
#medical .inst_box .img_box {
	position: relative;
}
#medical .inst_box .img_box .inst_list {
	width: 95%;
	max-width: 1120px;
}
#medical .inst_box .img_box #sb_instagram #sbi_images .sbi_item {
	width: 22% !important;
	margin-right: 4% !important;
}
#medical .inst_box .img_box #sb_instagram #sbi_images .sbi_item:nth-child(4n) {
	margin-right: 0 !important;
}
#medical .inst_box .link_btn {
	position: absolute;
	z-index: 1;
	right: 0;
	top: 50%;
	transform: translate(100%, -50%) rotate(90deg);
	transform-origin: center center;
}
#medical .inst_box .link_btn a {
	font-size: 95%;
	letter-spacing: .2em;
	line-height: 1.2em;
	display: inline-block;
	padding: 0 1.2em 1.5em;
	border-bottom: solid 1px #000;
}
#medical .inst_box .link_btn a:hover {
	color: #B682CC;
	border-color: #B682CC;
}
#medical .inst_box .link_btn i {
	font-size: 130%;
	font-weight: normal;
	margin-right: .5em;
}

/* 1500px以下
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 1500px) {
#medical .slide_box .title_box .abs_box {
	left: 5%;
	top: 20%;
}
#medical .inst_box .link_btn {
	transform: translate(50%, -50%) rotate(90deg);
}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
#medical .slide_box .title_box .abs_box {
	left: 3%;
}
#medical .slide_box .title_box h2 {
	font-size: 115%;
	margin-bottom: .8em;
}
#medical .slide_box .med_slide .swiper-slide {
    width: 70vw !important;	/*スライド画像の幅*/
}
#medical .women {
	margin-top: 2%;
}
#medical .inst_box {
	padding: 5% 0 8%;
}
#medical .inst_box h3 {
	margin-bottom: 3%;
}
#medical .inst_box .img_box .inst_list {
	width: 90%;
}
#medical .inst_box .link_btn {
	right: 2%;
	transform: translate(50%, -50%) rotate(90deg);
}
#medical .inst_box .link_btn a {
	font-size: 90%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
#medical .slide_box {
	padding-top: 5%;
}
#medical .slide_box .title_box .abs_box {
	left: 4%;
	top: 1.5em;
}
#medical .slide_box .title_box h2 {
	font-size: 85%;
	letter-spacing: .1em;
	margin-bottom: .8em;
}
#medical .slide_box .title_box .top_index img {
	height: 5.2vw;
}
#medical .slide_box .title_box .corner {
	width: 38%;
}
#medical .slide_box .med_slide .swiper-slide {
    width: 100vw !important;	/*スライド画像の幅*/
}
#medical .slide_box .slide_arrow {
	width: 25%;
}

#medical .women {
	margin-top: 2%;
	margin-left: 15%;
	width: 25%;
}

#medical .inst_box {
	padding: 8% 0 10%;
}
#medical .inst_box h3 {
	font-size: 90%;
	letter-spacing: .05em;
	margin: .5em 0 6%;
}
#medical .inst_box .img_box .inst_list {
	width: 85%;
}

#medical .inst_box .img_box #sb_instagram #sbi_images .sbi_item {
	width: 48% !important;
	margin-right: 4% !important;
	margin-top: 4% !important;
}
#medical .inst_box .img_box #sb_instagram #sbi_images .sbi_item:nth-child(2n) {
	margin-right: 0 !important;
}
#medical .inst_box .img_box #sb_instagram #sbi_images .sbi_item:nth-child(-n+2) {
	margin-top: 0 !important;
}
#medical .inst_box .link_btn {
	right: 5%;
	transform: translate(50%, -50%) rotate(90deg);
}
#medical .inst_box .link_btn a {
	font-size: 90%;
	letter-spacing: .15em;
	padding-bottom: 1.0em;
}
}



/*当院の特徴
---------------------------------------------------------*/
#point {
	margin-bottom: 90px;
}
#point .title_box {
	padding-top: 70px;
	width: 85%;
	max-width: 1000px;
	margin: 0 auto 50px;
	position: relative;
}
#point .title_box h2 {
	position: relative;
	z-index: 1;
	width: 90%;
}
#point .title_box div {
	position: absolute;
	z-index: 0;
	width: 12%;
	max-width: 110px;
	right: 0;
	bottom: 0;
}

#point .no {
	position: relative;
}
#point .no p {
	position: relative;
	z-index: 1;
}
#point .no div {
	position: absolute;
	z-index: 0;
	left: 0;
	top: 0;
	transform: scale(0,0);
	transform-origin: top left;
	transition: all 0.3s ease-out;
}
#point .anime_on .no div {
	transform: scale(1,1);
}

/*01・02共通*/
#point .box1 .bg,
#point .box2 .bg {
	width: 96%;
	max-width: 1380px;
	margin-left: auto;
	margin-right: auto;
}
#point .box1 .bg::before,
#point .box2 .bg::before {
	content: "";	/*上下の白*/
	position: absolute;
	z-index: 0;
	width: 100%;
	background: #fff;
}
#point .box1 .bg::after,
#point .box2 .bg::after {
	content: "";	/*背景色*/
	position: absolute;
	z-index: -1;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	transform: scale(1,0);
	transform-origin: left top;
	transition: all 2.0s;
}
#point .box1 .bg.anime_on::after,
#point .box2 .bg.anime_on::after {
	transform: scale(1,1);
}
#point .box1 .bg .w1190,
#point .box2 .bg .w1190 {
	position: relative;
	z-index: 1;
}
#point .box1 .no,
#point .box2 .no {
	width: 22vw;
	max-width: 300px;
}
#point .box1 h3,
#point .box2 h3 {
	font-size: 335%;
	font-weight: bold;
	letter-spacing: .14em;
	line-height: 1.3em;
	padding-top: 40px;
	margin-bottom: .3em;
}

/*01*/
#point .box1 {
	margin-bottom: 100px;
}
#point .box1 .bg {
	position: relative;
}
#point .box1 .bg::before {
	height: 80px;	/*上の白*/
	left: 0;
	top: 0;
}
#point .box1 .bg::after {
	background: rgba(36,169,245,0.1);
}
#point .box1 .bg .w1190 {
	padding-bottom: 60px;
}
#point .box1 .img_box {
	position: relative;
}
#point .box1 .img_box .no {
	position: absolute;
	z-index: 1;
	left: 0;
	top: 0;
}
#point .box1 h3 span {
	color: #2A93DE;
}
#point .box1 .txt {
	width: 82%;
}
#point .box1 .abs {
	position: absolute;
	width: 12%;
	max-width: 140px;
	right: 4%;
	bottom: 0;
	transform: translateY(7%);
}

/*02*/
#point .box2 .slide_box {
	position: relative;
}
#point .box2 .slide_box .no {
	position: absolute;
	z-index: 1;
	left: 0;
	top: 0;
}
#point .box2 .slide_box .swiper {
	z-index: 0;
}
#point .box2 .slide_box .abs_list li {
	position: absolute;
	z-index: 1;
	width: 8%;
	max-width: 95px;
}
#point .box2 .slide_box .abs_list li:nth-child(1) {
	left: 22%;
	top: 0;
	transform: translateY(-18%);
}
#point .box2 .slide_box .abs_list li:nth-child(2) {
	right: 13%;
	bottom: 0;
	transform: translateY(80%);
}
#point .slide_box .poi_slide .swiper-slide {
    width: 800px !important;	/*スライド画像の幅*/
}
#point .box2 .bg {
	position: relative;
	margin-bottom: 80px;
}
#point .box2 .bg::before {
	height: 110px;	/*下の白*/
	left: 0;
	bottom: 0;
}
#point .box2 .bg::after {
	background: rgba(249,152,181,0.1);
}
#point .box2 h3,
#point .box2 .txt {
	width: 100%;
	max-width: 990px;
	margin-left: auto;
	margin-right: auto;
}
#point .box2 h3 span {
	color: #E37293;
}
#point .box2 .img_box {
	width: 100%;
	max-width: 1110px;
	margin: 30px auto 0;
	display: flex;
    justify-content: space-between;
}
#point .box2 .img_box li {
	width: 33%;
	max-width: 348px;
	position: relative;
}
#point .box2 .img_box li p {
	position: absolute;
	z-index: 1;
	width: 40%;
	max-width: 122px;
	right: 0;
	top: 0;
}
#point .box2 .img_box li p span {
	display: block;
	transform: scale(0,0);
	transform-origin: center center;
	transition: all 0.6s ease-out;
}
#point .box2 .img_box li:nth-child(2) p span {transition-delay: 0.1s;}
#point .box2 .img_box li:nth-child(3) p span {transition-delay: 0.2s;}
#point .box2 .img_box.anime_on li p span {
	transform: scale(1,1);
}

/*03-09共通*/
#point .box3_9 .box_list {
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
#point .box3_9 .box_list > li {
	width: 48.5%;
	max-width: 660px;
	position: relative;
	padding-top: 100px;
	margin-bottom: 60px;
}
#point .box3_9 .box_list > li::before {
	content: "";	/*背景色*/
	position: absolute;
	z-index: -1;
	width: 85%;
	max-width: 550px;
	height: 65%;
	left: 0;
	top: 0;
	transform: scale(1,0);
	transform-origin: left top;
	transition: all 2.0s;
}
#point .box3_9 .box_list > li.anime_on::before {
	transform: scale(1,1);
}
#point .box3_9 .box_list .no {
	position: absolute;
	z-index: 0;
	left: 0;
	top: 0;
	width: 15vw;
	max-width: 200px;
}
#point .box3_9 .box_list .in_box {
	width: 90%;
	max-width: 590px;
	margin-left: auto;
	margin-right: 0;
	position: relative;
	z-index: 1;
}
#point .box3_9 .box_list h3 {
	font-size: 190%;
	font-weight: bold;
	letter-spacing: .14em;
	line-height: 1.5em;
	margin-bottom: .5em;
}
#point .box3_9 .box_list .fs15 {
	margin-top: 1.5em;
}
#point .box3_9 .box_list .fs15 small {
	font-size: 90%;
	color: #666;
}

/*横長*/
#point .box3_9 .box_list > li.width_box {
	width: 100%;
	max-width: 100%;
	padding-top: 70px;
	padding-bottom: 40px;
	margin-bottom: 0;
}
#point .box3_9 .box_list > li.width_box::before {
	width: 100%;	/*背景色*/
	max-width: 100%;
	height: 100%;
}
#point .box3_9 .box_list> li.width_box .no {
	z-index: 1;
}
#point .box3_9 .box_list > li.width_box .in_box {
	width: 91%;
	max-width: 100%;
	margin: 0 auto;
	z-index: 0;
}
#point .box3_9 .box_list > li.width_box .in_box .img_item {
	position: absolute;
	left: 0;
	top: .5em;
	width: 48%;
	max-width: 590px;
}
#point .box3_9 .box_list > li.width_box .in_box h3,
#point .box3_9 .box_list > li.width_box .in_box .fs15 {
	width: 49%;
	margin-left: auto;
	margin-right: 0;
}

/*色*/
#point .box3_9 .box_list .color3::before {background: rgba(33,214,191,0.1);}
#point .box3_9 .box_list .color3 h3 span {color: #1BB09C;}
#point .box3_9 .box_list .color4::before {background: rgba(230,183,57,0.1);}
#point .box3_9 .box_list .color4 h3 span {color: #D3A834;}
#point .box3_9 .box_list .color5::before {background: rgba(182,130,204,0.1);}
#point .box3_9 .box_list .color5 h3 span {color: #AD64CC;}
#point .box3_9 .box_list .color6::before {background: rgba(83,157,245,0.1);}
#point .box3_9 .box_list .color6 h3 span {color: #3986E3;}
#point .box3_9 .box_list .color7::before {background: rgba(83,207,111,0.1);}
#point .box3_9 .box_list .color7 h3 span {color: #3DB357;}
#point .box3_9 .box_list .color8::before {background: rgba(255,119,139,0.1);}
#point .box3_9 .box_list .color8 h3 span {color: #DE5D70;}
#point .box3_9 .box_list .color9::before {background: rgba(53,193,212,0.1);}
#point .box3_9 .box_list .color9 h3 span {color: #28ADBF;}

/* 1350px以下
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 1350px) {
#point {
	margin-bottom: 4%;
}
#point .box3_9 .box_list h3 {
	font-size: 2.6vw;
}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
#point {
	margin-bottom: 2%;
}
#point .title_box {
	padding-top: 6%;
	margin-bottom: 5%;
}

/*01・02共通*/
#point .box1 h3,
#point .box2 h3 {
	font-size: 5.0vw;
	padding-top: .8em;
	margin-bottom: .2em;
}

/*01*/
#point .box1 {
	margin-bottom: 8%;
}
#point .box1 .bg::before {
	height: 10vw;	/*上の白*/
}
#point .box1 .bg .w1190 {
	padding-bottom: 6%;
}

/*02*/
#point .slide_box .poi_slide .swiper-slide {
    width: 60vw !important;	/*スライド画像の幅*/
}
#point .box2 .bg {
	margin-bottom: 8%;
}
#point .box2 .bg::before {
	height: 10vw;	/*下の白*/
}
#point .box2 .img_box {
	margin-top: 3%;
}

/*03-09共通*/
#point .box3_9 .box_list > li {
	padding-top: 8vw;
	margin-bottom: 6%;
}
#point .box3_9 .box_list > li::before {
	height: 40vw;	/*背景色*/
}
#point .box3_9 .box_list h3 {
	font-size: 3.2vw;
	letter-spacing: .1em;
}
#point .box3_9 .box_list .fs15 {
	margin-top: 1.0em;
}

/*横長*/
#point .box3_9 .box_list > li.width_box {
	padding-top: 6%;
	padding-bottom: 4%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
#point {
	margin-bottom: 2%;
}
#point .title_box {
	padding-top: 10%;
	width: 94%;
	margin-bottom: 6%;
}

/*01・02共通*/
#point .box1 .no,
#point .box2 .no {
	width: 25vw;
}
#point .box1 h3,
#point .box2 h3 {
	font-size: 140%;
	letter-spacing: .05em;
	line-height: 1.4em;
	padding-top: .8em;
	margin-bottom: .2em;
}

/*01*/
#point .box1 {
	margin-bottom: 10%;
}
#point .box1 .bg::before {
	height: 10vw;	/*上の白*/
}
#point .box1 .bg .w1190 {
	padding-bottom: 6%;
}
#point .box1 .txt {
	width: 100%;
}
#point .box1 .abs {
	width: 10%;
	right: 4%;
	bottom: auto;
	transform: none;
	top: 38vw;
}

/*02*/
#point .box2 .slide_box .abs_list li {
	width: 10%;
}
#point .box2 .slide_box .abs_list li:nth-child(1) {
	left: 25%;
}
#point .box2 .slide_box .abs_list li:nth-child(2) {
	right: 5%;
}
#point .slide_box .poi_slide .swiper-slide {
    width: 80vw !important;	/*スライド画像の幅*/
}
#point .box2 .bg {
	margin-bottom: 10%;
}
#point .box2 .bg::before {
	height: 110px;	/*下の白*/
}
#point .box2 .img_box {
	margin-top: 22%;
}
#point .box2 .img_box li p {
	width: 70%;
	right: 50%;
	top: 0;
	transform: translate(50%, -80%);
}

/*03-09共通*/
#point .box3_9 .box_list {
	display: block;
}
#point .box3_9 .box_list > li {
	width: 100%;
	max-width: 100%;
	padding-top: 10% !important;
	margin-bottom: 8%;
}
#point .box3_9 .box_list > li::before {
	width: 85% !important;	/*背景色*/
	max-width: 100% !important;
	height: 70vw !important;
}
#point .box3_9 .box_list .no {
	width: 20vw;
}
#point .box3_9 .box_list .in_box {
	width: 94% !important;
	max-width: 100%;
	margin-left: auto !important;
	margin-right: 0 !important;
}
#point .box3_9 .box_list h3 {
	font-size: 130%;
	letter-spacing: .05em;
	line-height: 1.5em;
	margin-bottom: .5em;
}
#point .box3_9 .box_list .fs15 {
	margin-top: .8em;
}

/*横長*/
#point .box3_9 .box_list > li.width_box {
	padding-bottom: 0;
}
#point .box3_9 .box_list > li.width_box .in_box .img_item {
	position: static;
	width: 100%;
}
#point .box3_9 .box_list > li.width_box .in_box h3,
#point .box3_9 .box_list > li.width_box .in_box .fs15 {
	width: 100%;
}
}



/*小児矯正歯科専門SITE
---------------------------------------------------------*/
#orth {
	margin-bottom: 100px;
}

#orth .link_box {
	width: 80%;
	max-width: 780px;
	margin: 0 auto;
	padding: 0 0 40px;
	margin-bottom: 20px;
	text-align: center;
}

/*#orth .link_box {
	width: 80%;
	max-width: 1100px;
	margin: 0 auto;
	border-top: solid 1px #000;
	padding: 15px 0 30px;
	margin-bottom: 20px;
	text-align: center;
	position: relative;
}
#orth .link_box::before {
	content: "";
	position: absolute;
	width: 0;
	height: 100%;
	left: 0;
	top: 0;
	background: rgba(53,193,212,0.1);
	transition: all 0.4s ease-out;
}
#orth .link_box:hover::before {
	width: 100%;
}
#orth .link_box:hover a {
	color: #28ADBF;
}
#orth .link_box a {
	display: inline-block;
	text-align: left;
	font-size: 280%;
	letter-spacing: .2em;
	line-height: 1.2em;
	padding: .1em 0;
	padding-right: 2.0em;
	background: url("../images/top/arw_next@2x.png") no-repeat right bottom;
	background-size: 1.5em auto;
}
#orth .link_box span {
	display: inline-block;
	font-size: 50%;
	letter-spacing: .2em;
	line-height: 1.2em;
	transform: translateY(-.3em);
}
#orth .link_box small {
	display: block;
	margin-top: .2em;
}*/
#orth .slide_box {
	position: relative;
}
#orth .slide_box .ort_slide .swiper-slide {
    width: 350px !important;	/*スライド画像の幅*/
}
#orth .slide_box .ort_slide .swiper-slide:nth-child(even) {
	padding-top: 50px;
}
#orth .slide_box .abs_list li {
	position: absolute;
	z-index: -1;
}
#orth .slide_box .abs_list li:nth-child(1) {
	width: 10%;
	max-width: 128px;
	right: 7%;
	top: 0;
	transform: translateY(-30%);
}
#orth .slide_box .abs_list li:nth-child(2) {
	width: 12%;
	max-width: 156px;
	right: 52%;
	bottom: 0;
	transform: translateY(40%);
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 1020px) {
#orth .link_box a {
	font-size: 4.5vw;
	letter-spacing: .2em;
}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
#orth {
	margin-bottom: 8%;
}
#orth .link_box {
	padding: 2% 0 4%;
	margin-bottom: 2%;
}
#orth .slide_box .ort_slide .swiper-slide {
    width: 25vw !important;	/*スライド画像の幅*/
}
#orth .slide_box .ort_slide .swiper-slide:nth-child(even) {
	padding-top: 50px;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
#orth {
	margin-bottom: 12%;
}
#orth .link_box {
	width: 94%;
	padding: 4% 0;
	margin-bottom: 4%;
}
#orth .link_box a {
	font-size: 130%;
	letter-spacing: .15em;
}
#orth .link_box span {
	font-size: 70%;
	letter-spacing: .15em;
	transform: translateY(-.1em);
}
#orth .link_box small {
	margin-top: .4em;
}
#orth .slide_box .ort_slide .swiper-slide {
    width: 30vw !important;	/*スライド画像の幅*/
}
#orth .slide_box .ort_slide .swiper-slide:nth-child(even) {
	padding-top: 6vw;
}
#orth .slide_box .abs_list li:nth-child(1) {
	width: 15%;
}
#orth .slide_box .abs_list li:nth-child(2) {
	width: 18%;
}
}



/*歯科医師からメッセージ
---------------------------------------------------------*/
#message .bg {
	position: relative;
	padding-top: 180px;
	margin-bottom: 100px;
}
#message .bg::before {
	content: "";	/*下の白*/
	position: absolute;
	z-index: 0;
	width: 100%;
	height: 200px;
	background: #fff;
	left: 0;
	bottom: 0;
}
#message .bg::after {
	content: "";	/*背景*/
	position: absolute;
	z-index: -1;
	width: 100%;
	height: calc(100% - 30px);
	left: 0;
	bottom: 0;
	background: #F5F2E4 url("../images/top/bg1@2x.jpg") no-repeat right top;
	background-size: 880px auto;
}
#message h2 {
	position: absolute;
	left: 5%;
	top: 0;
}
#message .w1260 {
	position: relative;
	z-index: 1;
}
#message .txt1 dt {
	font-size: 195%;
	font-weight: bold;
	letter-spacing: .32em;
	line-height: 1.6em;
	margin-bottom: 1.4em;
}
#message .txt1 dt span {
	display: block;
	padding-top: .4em;
	width: 65%;
	opacity: 0;
	transform: translateX(-10%);
	transition: all 1.0s ease-out;
}
#message .txt1 dt span.anime_on {
	opacity: 1;
	transform: translateX(0%);
}
#message .flt_box {
	margin: 40px 0 70px;
}
#message .flt_box .flt_l {
	width: 32%;
	max-width: 380px;
}
#message .flt_box .flt_r {
	width: 65%;
}
#message .txt2 dt {
	color: #16ACBF;
	font-size: 120%;
	font-weight: bold;
	letter-spacing: .2em;
	line-height: 1.8em;
	margin-bottom: .8em;
}
#message .dr {
	margin-top: 40px;
}
#message .dr dd {
	margin-top: .5em;
	letter-spacing: .2em;
	line-height: 1.2em;
}
#message .dr dd span {
	font-size: 170%;
	letter-spacing: .2em;
	line-height: 1.2em;
	margin-left: .4em;
}
#message .prof_box {
	border-top: solid 1px rgba(102,102,102,0.7);
	border-bottom: solid 1px rgba(102,102,102,0.7);
	padding: 40px 2%;
	display: flex;
    justify-content: space-between;
	margin-bottom: 120px;
}
#message .prof_box .box_l {
	width: 33%;
}
#message .prof_box .box_r {
	width: 65%;
}
#message .prof_box dl {
	margin-bottom: 1.5em;
}
#message .prof_box dl:last-of-type {
	margin-bottom: 0;
}
#message .prof_box dt {
	color: #666;
	font-size: 110%;
	font-weight: bold;
	letter-spacing: .18em;
	line-height: 1.2em;
	margin-bottom: .8em;
}
#message .prof_box dd {
	color: #4D4D4D;
	font-size: 90%;
	letter-spacing: .04em;
	line-height: 1.6em;
}
#message .prof_box dd li {
	padding-left: 1.5em;
	position: relative;
	margin-bottom: .3em;
}
#message .prof_box dd li::before {
	content: "";
	position: absolute;
	letter-spacing: normal;
	line-height: 1.0em;
	width: .8em;
	height: .8em;
	border-radius: 50%;
	background: #B3B3B3;
	opacity: 0.7;
	left: 0;
	top: .4em;
}
#message .prof_box dd li:last-child {
	margin-bottom: 0;
}
#message .prof_box .box_r dd {
	display: flex;
    justify-content: space-between;
}
#message .prof_box .box_r dd ul {
	width: 50%;
}
#message .prof_box .box_r dd ul:last-of-type {
	width: 48%;
}

#message .img_box {
	width: 100%;
	max-width: 1140px;
	margin: 0 auto;
	position: relative;
}
#message .img_box img {
	margin: auto;
}
#message .img_box .abs {
	position: absolute;
	z-index: 1;
	width: 37%;
	max-width: 420px;
	right: 0;
	top: 0;
	opacity: 0;
	transform: translate(20%, -5%);
	transition: all 1.0s ease-out;
}
#message .img_box.anime_on .abs {
	opacity: 1;
	transform: translate(20%, -15%);
}

#message .img_box .abs p {
	position: relative;
	z-index: 0;
	border-radius: 50%;
	box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.3);
}
#message .img_box .abs > div {
	position: absolute;
	z-index: 1;
	width: 20%;
	max-width: 95px;
	right: 20%;
	bottom: 6%;
}

/* 1500px以下
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 1500px) {
#message .bg::after {
	background-size: 59% auto;
}
}

/* 1300px以下
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 1300px) {
#message .img_box .abs {
	width: 32%;
	transform: translate(10%, -15%);
}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
#message .bg {
	padding-top: 14%;
	margin-bottom: 8%;
}
#message .bg::before {
	height: 20vw;	/*下の白*/
}
#message .bg::after {
	height: calc(100% - 2vw);	/*背景*/
}
#message .txt1 dt {
	font-size: 3.3vw;
	letter-spacing: .2em;
	margin-bottom: 1.0em;
}
#message .flt_box {
	margin: 4% 0 5%;
}
#message .txt2 dt {
	font-size: 120%;
	letter-spacing: .15em;
	margin-bottom: .5em;
}
#message .dr {
	margin-top: 4%;
}
#message .dr dd {
	margin-top: .3em;
}
#message .prof_box {
	padding: 4% 0;
	margin-bottom: 10%;
	font-size: 90%;
}
#message .prof_box dd {
	letter-spacing: normal;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
#message .bg {
	background-size: 50% auto;
	padding-top: 18%;
	margin-bottom: 14%;
}
#message .bg::before {
	height: 20vw;	/*下の白*/
}
#message .bg::after {
	height: calc(100% - 3vw);	/*背景*/
	background-size: 50% auto;
}
#message .txt1 dt {
	font-size: 120%;
	letter-spacing: .15em;
	margin-bottom: 1.0em;
}
#message .txt1 dt span {
	width: 75%;
}
#message .flt_box {
	margin: 6% 0 8%;
}	
	
#message .flt_box .flt_l {
	float: none;
	width: 60%;
	margin: 0 auto 1.0em;
}
#message .flt_box .flt_r {
	float: none;
	width: 100%;
}
#message .txt2 dt {
	letter-spacing: .05em;
	margin-bottom: .3em;
}
#message .dr {
	font-size: 90%;
	margin-top: 1.5em;
}
#message .dr dd {
	margin-top: .2em;
}
#message .prof_box {
	font-size: 90%;
	padding: 4% 0;
	display: block;
	margin-bottom: 10%;
}
#message .prof_box .box_l {
	width: 100%;
	display: flex;
    justify-content: space-between;
}
#message .prof_box .box_r {
	width: 100%;
}
#message .prof_box .box_l dl {
	width: 49%;
	margin-bottom: 1.0em;
}
#message .prof_box dt {
	margin-bottom: .5em;
}
#message .prof_box dd {
	letter-spacing: normal;
	line-height: 1.4em;
}
#message .prof_box dd li {
	padding-left: 1.2em;
	margin-bottom: .3em !important;
}
#message .prof_box .box_r dd {
	display: block;
}
#message .prof_box .box_r dd ul,
#message .prof_box .box_r dd ul:last-of-type {
	width: 100%;
}

#message .img_box .abs {
	width: 40%;
	transform: translate(14%, -40%);
}
}



/*アクセス
---------------------------------------------------------*/
#access .bg {
	background: #F2F2F2;
	padding-bottom: 80px;
	position: relative;
}
#access .bg::before {
	content: "";
	position: absolute;
	z-index: 0;
	width: 100%;
	height: 30px;
	left: 0;
	top: 0;
	background: #fff;
}
#access .bg .w1340 {
	position: relative;
	z-index: 1;
}
#access .bg .w1340 img {
	margin: auto;
}

#access .title_box {
	text-align: center;
	margin-bottom: 50px;
}
#access .title_box .ft_agenda {
	font-size: 180%;
	letter-spacing: .12em;
	line-height: 1.2em;
	margin: .5em 0 .8em;
}
#access .title_box .ft_udkakugo {
	line-height: 1.6em;
}

#access .box {
	background: #fff;
	margin-bottom: 20px;
}
#access .box h3 {
	background: #67C1E0;
	color: #fff;
	font-size: 130%;
	letter-spacing: .4em;
	line-height: 1.2em;
	padding: .6em 1.0em;
}
#access .box h3 .yellow{
	letter-spacing: 0.1em;
	color: #FCFC75;
}
#access .box .inbox {
	color: #333;
	font-size: 90%;
	letter-spacing: .04em;
	line-height: 1.6em;
	display: flex;
    justify-content: space-between;
}
#access .box .inbox .box_l {
	width: 61%;
	box-sizing: border-box;
	padding: 20px 3% 40px;
}
#access .box .inbox .box_r {
	width: 39%;
	box-sizing: border-box;
	padding: 20px 1.5%;
	background: #FAFAFA;
}

#access .box .cli_name {
	display: flex;
    justify-content: space-between;
    align-items: center;
}
#access .box .cli_name dt {
	width: 100px;
}
#access .box .cli_name dd {
	width: calc(97% - 100px);
	font-size: 200%;
	font-weight: bold;
	letter-spacing: .04em;
	line-height: 1.4em;
}
#access .box .cli_name.no_logo dd{
	margin: 0.4em 0;
}
#access .box .txt_flex {
	display: flex;
    justify-content: space-between;
    align-items: center;
	margin: .2em 0 1.0em;
}
#access .box .txt_flex .parking {
	text-align: right;
	width: 12em;
	box-sizing: border-box;
}
#access .box .txt_flex .parking i {
	display: inline-block;
	font-weight: normal;
	color: #67C1E0;
	font-size: 160%;
	margin-right: .2em;
	transform: translateY(.1em);
}

#access .box .cli_img {
	float: right;
	width: 43%;
	max-width: 310px;
}
#access .box .cli_info {
	float: left;
	width: 55%;
}

#access .box .cli_tel {
	color: #67C1E0;
	margin-bottom: .7em;
}
#access .box .cli_tel a {
	color: #67C1E0;
}
#access .box .cli_tel p {
	font-weight: bold;
	letter-spacing: .2em;
	line-height: 1.2em;
	width: 7em;
	padding: .7em 0;
	box-sizing: border-box;
	text-align: center;
	border: solid 2px #67C1E0;
	border-radius: .6em;
}
#access .box .cli_tel dt {
	font-weight: bold;
	letter-spacing: .12em;
	line-height: 1.4em;
}
#access .box .cli_tel dd {
	font-size: 260%;
	letter-spacing: .04em;
	line-height: 1.2em;
	white-space: nowrap;	/*改行禁止*/
}
#access .box .cli_tel dd i {
	font-size: 80%;
	font-weight: normal;
}
#access .box .cli_tel:not(.no_txt) {
	display: flex;
    align-items: center;
}
#access .box .cli_tel p {
	margin-right: .7em;
}
#access .box .red_txt{
  font-size: 90%;
  letter-spacing: 0.05em;
  line-height: 1.5em;
  color: #FF0000;
  font-weight: bold;
  padding-left: 1em;
  text-indent: -1em;
  margin-bottom: 1.5em;
  margin-top: -0.5em;
}

#access .box .cli_time img {
	margin-left: 0;
}
#access .box .cli_time p {
	margin-top: .5em;
}

#access .box .box_r iframe {
	display: block;
	width: 100%;
	height: 340px;
}
#access .box .box_r ul {
	width: 100%;
	max-width: 470px;
	margin: 20px auto 0;
	display: flex;
    justify-content: space-between;
	text-align: center;
}
#access .box .box_r li {
	width: 49%;
	max-width: 230px;
}
#access .box .box_r li a {
	display: block;
	background: #67C1E0;
	color: #fff;
	font-weight: bold;
	letter-spacing: .14em;
	line-height: 1.2em;
	padding: .8em 0;
	border-radius: .5em;
}
#access .box .box_r li span {
	padding-right: 2.0em;
	position: relative;
}
#access .box .box_r li span::before {
	font-family: 'fontello';
	content: '\e802';
	font-weight: normal;
	font-size: 110%;
	position: absolute;
	right: 0;
	top: .1em;
}

/* 1400px以下
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 1400px) {
#access .box .cli_tel {
	font-size: 1.1vw;
}
#access .box .cli_tel p {
	margin-right: .5em;
}
#access .box .red_txt{
  font-size: 0.95vw;
}
}

/* 1200px以下
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 1200px) {	
#access .box {
	width: 100%;
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}
#access .box .inbox {
	display: block;
}
#access .box .inbox .box_l {
	width: 100%;
	padding: 3%;
}
#access .box .inbox .box_r {
	width: 100%;
	padding: 3%;
}
#access .box .cli_tel {
	font-size: 100%;
}
#access .box .red_txt{
  font-size: 90%;
}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
#access .bg {
	padding-bottom: 6%;
}
#access .bg::before {
	height: 3vw;
}

#access .title_box {
	margin-bottom: 4%;
}
#access .title_box .ft_agenda {
	font-size: 160%;
	letter-spacing: .1em;
}

#access .box .cli_name dt {
	width: 10%;
}
#access .box .cli_name dd {
	width: 88%;
}

#access .box .txt_flex {
	margin: 1.0em 0;
}

#access .box .cli_tel {
	font-size: 95%;
}
#access .box .cli_tel p {
	letter-spacing: .1em;
	width: 6.5em;
}
#access .box .red_txt{
  font-size: 85%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
#access .bg {
	padding-bottom: 6%;
}
#access .bg::before {
	height: 3vw;
}

#access .title_box {
	margin-bottom: 6%;
}
#access .title_box .ft_agenda {
	font-size: 130%;
}
#access .title_box .ft_udkakugo {
	font-size: 90%;
	letter-spacing: .1em;
}

#access .box h3 {
	text-align: center;
	font-size: 105%;
	padding: .4em 0;
}
#access .box h3 .red{
	display: block;
	margin-top: 0.25em;
}
#access .box .inbox {
	letter-spacing: normal;
	display: block;
}
#access .box .inbox .box_l {
	width: 100%;
	padding: 4%;
	text-align: center;
}
#access .box .inbox .box_r {
	width: 100%;
	padding: 4%;
}

#access .box .cli_name {
	display: block;
}
#access .box .cli_name dt {
	width: 25%;
	margin: 0 auto .2em;
}
#access .box .cli_name dd {
	width: 100%;
	font-size: 130%;
	margin-bottom: .2em;
}
#access .box .txt_flex {
	display: block;
	margin-bottom: 1.0em;
}
#access .box .txt_flex .parking {
	width: 100%;
	text-align: center;
}

#access .box .cli_img {
	float: none;
	width: 100%;
	margin: 0 auto 1.0em;
}
#access .box .cli_info {
	float: none;
	width: 100%;
}

#access .box .cli_tel {
	font-size: 90%;
	margin-bottom: .5em;
}
#access .box .cli_tel p {
	letter-spacing: .1em;
	width: 6em;
}
#access .box .red_txt{
  font-size: 80%;
  text-align: left;
}
#access .box .cli_tel dt {
	letter-spacing: .05em;
}
#access .box .cli_tel dd {
	letter-spacing: normal;
}
#access .box .cli_time img {
	margin-left: auto;
}

#access .box .box_r iframe {
	height: 250px;
}
#access .box .box_r ul {
	max-width: 100%;
	margin-top: .5em;
}
#access .box .box_r li {
	max-width: 100%;
}
#access .box .box_r li a {
	font-size: 90%;
}
}



/*
---------------------------------------------------------*/

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
}