@charset "utf-8";

/*---------------- メインビジュアル ----------------*/
#main{
	min-width: 1300px;
	background-image: url(../img/index/mainvisual-bg.png);
	background-position: top center;
	background-repeat: no-repeat;
	background-size: 100% auto;
}
#main #main-inner{
	width: 100%;
	margin: 0 auto;
	padding: 190px 0 8em;
	position: relative;
	max-width: 1700px;
}
#main:after {
	content: "";
	display: block;
	width: auto;
	height: 230px;
	margin: -190px auto 0;
	background-image: url(../img/index/main-inner-bg_20260224up.png);
	background-position: bottom center;
	background-repeat: no-repeat;
	background-size: auto 100%;
	z-index: -1;
	position: relative;
	
}
#mainvisual{
	z-index: 1;
}
#mainvisual h2,#mainvisual .lead{
	position: absolute;
	z-index: 52;
}
#mainvisual .copy{
	position: absolute;
	z-index: 52;
}
#mainvisual h2{
	bottom: -220px;
	left: 50%;
	transform: translateX(-50%);
	width: min(38%, 555px);
	z-index: 111;
}
#mainvisual .copy{
	width: min(32.566%, 474px);
	bottom: 22.5%;
	left: 50%;
	transform: translateX(-50%);
}
/* イラスト配置 */
.mainvisual-deco{
	width: 100%;
	position: absolute;
	height: 100%;
	top: 0;
	left: 0;
	overflow-x: hidden;
	pointer-events: none;
}
.mainvisual-deco img:not(#mainvisual-deco-bg){ position: absolute;}
#mainvisual-deco-wood{
	width: min(19%, 275px);
	bottom: 10px;
	right: 3%;
	z-index: 53;
}
#mainvisual-deco-snail-sp{ display: none;}
#mainvisual-deco-giraffe{
	width: min(20%, 313px);
    bottom: 0;
    left: 6%;
	z-index: 53;
}
#mainvisual-deco-airplane{
	width: 4%;
	top: 9%;
	right: 11%;
}
#mainvisual-deco-butterfly-left{
	width: 42px;
	bottom:227px;
	left: 0;
}
#mainvisual-deco-butterfly-right{
	width: 42px;
	bottom: 127px;
	right: 20px;
}
#mainvisual-deco-green{
	width: 11%;
	top: 34%;
	right: 0%;
}
#mainvisual-deco-rain-left{
    width: 15%;
    top: 170px;
    left: 0;
    opacity: .7;
}
#mainvisual-deco-snail{
    width: 5.6%;
    bottom: 57px;
    right: 21%;
    z-index: 53;
}

#mainvisual-deco-bud01{
    width: 5%;
    bottom: 88px;
    left: 65%;
}
#mainvisual-deco-bud02{
	width: 4%;
    bottom: 99px;
    left: 57%;
}
#mainvisual-deco-bud03{
	width: 2.3%;
	bottom: 103px;
	left: 38.5%;
}

#mainvisual-deco-flower{
	width: 6.2%;
    bottom: 30px;
    left: 24%;
    z-index: 2;
}
#mainvisual-deco-rain{
    width: 15%;
    top: -2.6%;
    right: 20%;
    opacity: .8;
}
/* アニメーション */
#mainvisual-deco-butterfly-left, #mainvisual-deco-wood, #mainvisual-deco-giraffe{animation:FloatRightUp 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-green{animation:FloatLeftDown 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)}
}

/*	スライダー */
.bx-wrapper {
	width: min(90%, 1300px);
	margin: 0 auto;
	position: relative;
	background: none;
	border: 0;
	box-shadow: none;
	overflow: hidden;
	border-radius: 30px;
}
#mainvisual,#mainvisual-slide{ position: relative;}

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

/*	スライダーページャーカスタム */
.custom-pager{
	width: 100%;
	z-index: 99;
	padding-top: 2em;
}
.custom-pager .bx-pager {
	text-align: center;
	font-size: .85em;
	font-family: Arial;
	font-weight: bold;
	color: #ae8249;
	display: flex;
	justify-content: center;
}
.custom-pager .bx-default-pager a {
	width: 7px;
	height: 7px;
	margin: 0 8px;
	text-indent: -9999px;
	display: inline-block;
	outline: 0;
	-moz-border-radius: 7px;
	-webkit-border-radius: 7px;
	border-radius: 7px;
}
.custom-pager .bx-pager .bx-pager-item{
	display: flex;
	align-items: center;
	justify-content: center;
}
.custom-pager .bx-default-pager a.active {
	width: 12px;
	height: 12px;
	background: #ae8249;
}
.custom-pager .bx-default-pager a:link, .custom-pager .bx-default-pager a:visited {background: #ae8249;}
.custom-pager .bx-default-pager a:hover,.custom-pager .custom-pager .bx-default-pager a:active, .bx-default-pager a:focus {background: #ae8249;}


/*---------------- 2つの支援サービス ----------------*/
#top-service{
	position: relative;
	min-width: 1300px;
}
#top-service #top-service-inner {
	width: 1300px;
	margin: 150px auto 0;
	text-align: center;
}
#top-service:after{
	content: "";
	display: block;
	width: 179px;
	height: 323px;
	background-image: url(../img/index/top-service-bg-dot.png);
	background-size: auto 100%;
	position: absolute;
	background-repeat: no-repeat;
	top: -90px;
	right: 0;
	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;
}


