@charset "utf-8";

/*---------------- メインビジュアル ----------------*/
#main{
	background-image: url(../img/index/mainvisual-bg.png);
	background-position: top center;
	background-repeat: no-repeat;
	background-size: 100% auto;
}
#main #main-inner{
	width: 1240px;
	margin: 0 auto;
	padding: 40px 30px 0;
	position: relative;
}
#main:after {
	content: "";
	display: block;
	width: 1290px;
	margin: -65px auto 0;
	height: 154px;
	background-image: url(../img/index/main-inner-bg.png);
	background-position: bottom center;
	background-repeat: no-repeat;
	background-size: 100% auto;
	z-index: -1;
	position: relative;
}
#mainvisual{padding-bottom: 84px;}
#mainvisual h2,#mainvisual .lead{
	position: absolute;
	z-index: 52;
}
#mainvisual .copy{
	position: absolute;
	z-index: 52;
}
#mainvisual h2{
	bottom: -32px;
	left: 340px;
	width: 560px;
}
#mainvisual .lead{
	width: 315px;
	top: 123px;
	right: 225px;
}
#mainvisual .copy{
	width: 139px;
	top: 114px;
	left: 95px;
}
/* イラスト配置 */
.mainvisual-deco{
	width: 100%;
	position: absolute;
	height: 914px;
	top: 0;
	left: 0;
	overflow: hidden;
	pointer-events: none;
}
.mainvisual-deco img:not(#mainvisual-deco-bg){ position: absolute;}
#mainvisual-deco-wood{
	width: 196px;
	bottom: 30px;
	left: 230px;
	z-index: 53;
}
#mainvisual-deco-leaf{ display: none;}
#mainvisual-deco-giraffe{
	width: 418px;
	bottom:20px;
	right: 104px;
	z-index: 53;
}
#mainvisual-deco-airplane{
	width: 70px;
	top: 119px;
	right: 118px;
}
#mainvisual-deco-butterfly-left{
	width: 42px;
	bottom:227px;
	left: 0;
}
#mainvisual-deco-butterfly-right{
	width: 42px;
	bottom: 127px;
	right: 20px;
	margin-bottom: 60px;
}
#mainvisual-deco-green{
	width: 152px;
	top: 235px;
	right: 179px;
}
#mainvisual-deco-rain-left{
	width: 153px;
	top:260px;
	left: 0;
}
#mainvisual-deco-rain-right{
	width: 163px;
	bottom: 279px;
	right: -30px;
}
#mainvisual-deco-snail{
	width: 98px;
	bottom: 39px;
	left: 351px;
	z-index: 53;
}
#mainvisual-deco-backwood{
	width: 323px;
	bottom: 70px;
	right: 98px;
	z-index: 0;
}

/* アニメーション */
#mainvisual-deco-butterfly-left, #mainvisual-deco-wood, #mainvisual-deco-giraffe{animation:FloatRightUp 2s ease-in-out infinite alternate;}
#main:after{animation:FloatRightDown 2s ease-in-out infinite alternate;}
#mainvisual-deco-butterfly-right, #mainvisual-deco-airplane{animation:FloatLeftUp 2s ease-in-out infinite alternate;}
#mainvisual-deco-rain-left, #mainvisual-deco-backwood, #mainvisual-deco-green, #mainvisual-deco-rain-right{animation:FloatLeftDown 2s ease-in-out infinite alternate;}
#mainvisual-deco-snail{animation:FloatRight 2s ease-in-out infinite alternate;}

@keyframes FloatRightUp{
	0%{transform:translate3d(0,0,0);}
	100%{transform:translate3d(15px,-15px,0)}
}
@keyframes FloatRightDown{
	0%{transform:translate3d(0,0,0);}
	100%{transform:translate3d(15px,12px,0)}
}
@keyframes FloatRight{
	0%{transform:translate3d(0,0,0);}
	100%{transform:translate3d(15px,0,0)}
}
@keyframes FloatLeftUp{
	0%{transform:translate3d(0,0,0);}
	100%{transform:translate3d(-15px,-15px,0)}
}
@keyframes FloatLeftDown{
	0%{transform:translate3d(0,0,0);}
	100%{transform:translate3d(-15px,15px,0)}
}

/*	スライダー */
.svgmasks{
	height: 0;
	width: 0;
}

#mainvisual-slide .bx-wrapper svg{
	width: 705px;
	height: 705px;
}
.bx-wrapper {
	width: 705px;
	height: 705px;
	margin: 0 auto;
	position: relative;
	background: none;
	border: 0;
	box-shadow: none;
	overflow: hidden;
}
#mainvisual,#mainvisual-slide{ position: relative;}
#mainvisual-slide:before{
	position: absolute;
	top: -7px;
	left: 257px;
	width: 720px;
	height: 720px;
	background-image: url(../img/index/mainvisual-frame.png);
	background-repeat: no-repeat;
	z-index: 51;
	content: "";
	pointer-events: none;
}

/*	IE対策 */
.bx-loading{ display: none; }
.bx-viewport{ overflow: visible !important; }

/*	スライダーページャーカスタム */
.custom-pager{
	position: absolute;
	bottom: 162px;
	width: 100%;
	z-index: 99;
}
.custom-pager .bx-pager {
	text-align: center;
	font-size: .85em;
	font-family: Arial;
	font-weight: bold;
	color: #fff;
}
.custom-pager .bx-default-pager a {
	width: 11px;
	height: 11px;
	margin: 0 8px;
	text-indent: -9999px;
	display: inline-block;
	outline: 0;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-radius: 5px;
}
.custom-pager .bx-default-pager a.active {
	width: 8px;
	height: 8px;
	background: #fff;
	vertical-align: -1.6px;
}
.custom-pager .bx-default-pager a:link, .custom-pager .bx-default-pager a:visited {background: #fff;}
.custom-pager .bx-default-pager a:hover,.custom-pager .custom-pager .bx-default-pager a:active, .bx-default-pager a:focus {background: #ae8249;}

.custom-pager .bx-pager .bx-pager-item, .custom-pager .bx-controls-auto .bx-controls-auto-item {
	display: inline-block;
	*zoom: 1;
	*display: inline;
}

/*---------------- 2つの支援サービス ----------------*/
#top-service{
	position: relative;
	margin-top: -15px;
}
#top-service #top-service-inner {
	width: 1300px;
	margin: 50px auto 0;
	text-align: center;
}
#top-service:before {
	content: "";
	display: block;
	width: 100%;
	margin: 0 auto;
	height: 50px;
	background-image: url(../img/index/top-service-bg.png);
	background-position: top center;
	background-repeat: no-repeat;
	background-size: 100% auto;
	z-index: 53;
	position: relative;
}
#top-service:after{
	content: "";
	display: block;
	width: 179px;
	height: 323px;
	background-image: url(../img/index/top-service-bg-dot.png);
	position: absolute;
	background-repeat: no-repeat;
	top: 24px;
	right: 150px;
	z-index: 100;
}
#top-service h3,#top-ryouiku h3{
	width: 515px;
	margin: 0 auto 20px;
}
#top-service ul{
	display: flex;
	width: 968px;
	margin: 0 auto 60px;
}
#top-service ul li{
	width: 451px;
	margin: 0 33px;
}
#top-service h4{
	font-size: 1.63em;
	background-position: bottom center;
	background-repeat: no-repeat;
	background-size: auto 16px;
	padding-bottom: 18px;
	margin: 10px 0 30px;
}
#top-service #top-service-jidou h4{	background-image: url(../img/index/top-service-jidou-deco.png);}
#top-service #top-service-houkago h4{	background-image: url(../img/index/top-service-houkago-deco.png);}
#top-service .btn-detail{
	display: block;
	width: 294px;
	margin: 0 auto 95px;
	background-image: url("../img/index/top-service-btn.png");
	background-position: center;
	background-repeat: no-repeat;
}
#top-service a.btn-detail:hover{transform: translate(3px,3px);}

/*---------------- 充実した療育 ----------------*/
#top-ryouiku{ position: relative;}
#top-ryouiku:before{
	content: "";
	display: block;
	width: 221px;
	height: 350px;
	position: absolute;
	bottom: -120px;
	left: 0;
	background-image: url(../img/index/top-ryouiku-bg-dot.png);
	background-size: 100%;
	background-repeat: no-repeat;
}
#top-ryouiku-inner{
	width: 1300px;
	margin: 0 auto;
	padding: 77px 0 57px;
	background-color: #fff;
	text-align: center;
}
#top-ryouiku p{ margin-bottom: 60px;}
#top-ryouiku p span{
	font-size: 1.375em;
	background:linear-gradient(transparent 60%, #fff3a6 60%);
}
#top-ryouiku ul{
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	position: relative;
	height: 920px;
}
#top-ryouiku ul li{
	width: 322px;
	position: absolute;
}
#top-ryouiku02{
	right: 113px;
	top: 243px;
}
#top-ryouiku04{
	left: 113px;
	top: 243px;
}
#top-ryouiku03{
	top: 480px;
}
#top-ryouiku2 ul li:nth-child(3), #top-ryouiku ul li:last-child{margin-right: 0;}

/**セクション3　療育環境へのこだわり**/
#top-section3{
	background-image: url("../img/index/section3_bg.gif");
	height: 1120px;
}
#top-section3-inner{
	width: 1300px;
	margin: auto;
	text-align: center;
	padding-top: 64px;
	padding-bottom: 90px;
	position: relative;
}
#top-section3-inner img{
	width: auto;
}
.top-section3-box{
	width: 390px;
	text-align: center;
	position: absolute;
}
#top-section3-inner .top-section3-box:nth-last-of-type(3){
	top: 250px;	
	left:50px;
}
#top-section3-inner .top-section3-box:nth-last-of-type(2){
	left: 470px;
	top: 380px;
}
#top-section3-inner .top-section3-box:nth-last-of-type(1){
	right: 30px;
	top: 500px;	
}
.top-section3-box h4{
	background-image: url(../img/index/top-service-jidou-deco.png);
	font-size: 1.63em;
	background-position: bottom center;
	background-repeat: no-repeat;
	padding-bottom: 18px;
	margin: 15px 0 30px;
	display: inline-block;
	background-size: 100%;
}
.top-section3-box:nth-last-of-type(1) h4{
	padding-bottom: 28px;
}

/**那覇・浦添施設の一覧**/
#top-section4-inner{
	width: 1300px;
	margin: 0 auto;
	padding: 77px 0 57px;
	background-color: #fefefe;
	text-align: center;
}
#top-section4-inner img{
	width: auto;
}
#top-section4-inner #top-section4-menu li{
	display: inline-block;
	background-image: url("../img/index/tab_off.png");
	background-repeat: no-repeat;
	background-position: center;
	color: #fefefe;
	width: 295px;
	height: 59px;
	font-size:20px;
	padding-top: 22px;
	text-align: center;
	margin-left: 5px;
	margin-right: 5px;
}
#top-section4-inner #top-section4-menu{
	margin: auto;
	background-image: url("../img/index/tab_line.png");
	background-repeat: no-repeat;
	background-position: center bottom 1px;
	text-align: left;
	padding-left: 10px;
	padding-right: 10px;
	margin-top: 40px;
}
#top-section4-inner #top-section4-menu .tab_active{
	background-image: url("../img/index/tab_on.png");
	color: #ae8249;
}
#top-facility-wrap{
	width: 1088px;
	margin: auto;
	position: relative;
	height: 800px;
	padding-top: 60px;
}
.top-facility-box{
	width: 1088px;
	position: absolute;
}
.top-facility-box address,
.top-facility-box div{
	display: inline-block;
}
.top-facility-box .address{
	width: 520px;
	text-align: left;
	padding-left: 90px;
	font-size: 22px;
	font-family: "MPLUS-B-ex", "Noto Sans", "Noto Sans CJK JP", "Noto Sans CJK JP Subset", sans-serif;
}
.top-facility-box .address li{
	font-size: 20px;
	font-family: "MPLUS", "Noto Sans", "Noto Sans CJK JP", "Noto Sans CJK JP Subset", sans-serif;
	margin-bottom: 10px;
}
.top-facility-box .address ul{
	margin-top: 20px;
}
.top-facility-box .address li:nth-child(1){
	background-image: url("../img/index/section4_address.png");
	background-position: left;
	background-repeat: no-repeat;
	padding-left: 30px;
}
.top-facility-box .address li:nth-child(2){
	background-image: url("../img/index/section4_phone.png");
	background-position: left;
	background-repeat: no-repeat;
	padding-left: 30px;
}
.top-facility-box .address li:nth-child(3){
	background-image: url("../img/index/section4_fax.png");
	background-position: left;
	background-repeat: no-repeat;
	padding-left: 30px;
}
.top-facility-box .btn_wrap{
	vertical-align: top;
	padding-top: 50px;
}
#facility_1{
	display: none;
}

/*---------------- ブログエリア ----------------*/
#top-blog{
	padding: 64px 0;
	background-image: url(../img/index/top-blog-bg.jpg);
}
#top-blog-inner{
	width: 968px;
	margin: 0 auto;
	padding: 60px;
	position: relative;
	background-color: rgba(255,255,255,0.85);
	text-align: right;
}
#top-blog-inner:before{
	content: "";
	display: block;
	width: 160px;
	height: 339px;
	position: absolute;
	bottom: -80px;
	left: 130px;
	background-image: url(../img/index/top-blog-deco.png);
	background-size: 100%;
	background-repeat: no-repeat;
}
#top-blog h3{
	width: 189px;
	position: absolute;
	top: -43px;
	left: 53px;
	font-size:28px;
}
#top-blog h3 div{
	position: absolute;
	top: 90px;
	left: 50px;
}
#top-blog h3 #top-blog-b{
	font-size: 40px;
}
#top-blog .top-blog-btn{
	width: 130px;
	position: absolute;
	top: 104px;
	left: 21px;
}
#top-blog .top-blog-btn:hover {transform: translate(3px,3px);}
#top-blog ul{
	width: 720px;
	text-align: left;
	display: inline-block;
}
#top-blog ul li{
	background-image: url(../img/common/top-blog-deco-line.png);
	background-position: left bottom;
	background-repeat: repeat-x;
	padding: 0 0 25px;
	margin-bottom: 25px;
}
#top-blog ul li:last-child{
	margin-bottom: 0;
	padding-bottom: 0;
	background-image: none;
}
.index_blog_a{
	line-height: 1.75em !important;
}


