@charset "UTF-8";
	
/* メイン
---------------------------------*/

/* loading */
#loader-bg {
  display: none;
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
  background: #fff;
  z-index: 1;
}
#loader {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  width: 300px;
  height: 300px;
  margin-top: -150px;
  margin-left: -150px;
  text-align: center;
  z-index: 2;
}

/* visual */
#visual {
	position: relative;
	height: 710px;
	margin-bottom: 40px;
}
#message {
	width: 760px;
	height: 140px;
	line-height: 140px;
	top: 170px;
	left: 50%;
	margin-left: -380px;
	
	text-align: center;
	z-index: 40;
	
	font-size: 60px;
	position: relative;
	color: #fff;
	border: 4px solid #fff;
	letter-spacing: 10px;
	font-weight: bold;
	position: absolute;
}

#logo {
	width: 360px;
	height: 230px;
	top: 490px;
	left: 50%;
	margin-left: -180px;
	text-align: center;
	z-index: 30;
	
	position: relative;
}

#logo h1 {
	background: url(../img/logo.png) no-repeat top center;
	background-size: 360px 230px;
	width: 360px;
	height: 230px;
	text-indent: -9999px;
		
	z-index: 30;
	
}

#logo #animal {
	width: 96px;
	height: 109px;
	overflow: hidden;
	
	
	position: absolute;
	top: 0px;
	right: 73px;
}

#logo .dog {
	background: url(../img/logo_dog.png) no-repeat top right;
	background-size: 200px 130px;
	width: 200px;
	height: 130px; 
	z-index: 10;
	
	position: absolute;
	top: 22px;
	right: 7px;
	
	animation: translate1 1.3s ease 0s 1 normal;
	-webkit-animation: translate1 1.3s ease 0s 1 normal;
	/*animation-name: translate1;
	animation-duration: 1.3s;
	animation-timing-function: ease;
	animation-iteration-count: 1;
	animation-delay: 0s;
	animation-direction: normal;*/
	
}
@keyframes translate1 { 
	0%   { transform:  translate(-91px, 90px); opacity:0;    } 
	25%   { transform:  translate(-91px, 90px); opacity:0;    } 
	50%   { transform:  translate(6px, -6px);   }
	100%  { transform:  translate(0px, 0px); opacity:1;   } 
} 

@-webkit-keyframes translate1 { 
	0%   { -webkit-transform:  translate(-91px, 90px); opacity:0;    } 
	25%   { -webkit-transform:  translate(-91px, 90px); opacity:0;    } 
	50%   { -webkit-transform:  translate(6px, -6px);   }
	100%  { -webkit-transform:  translate(0px, 0px); opacity:1;   } 
}
#logo .cat {
	background: url(../img/logo_cat.png) no-repeat top right;
	background-size: 150px 100px;
	width: 150px;
	height: 100px; 
	z-index: 20;
	
	position: absolute;
	top: 50px;
	right: 33px;
	
	animation: translate2 1s ease 0s 1 normal;
	-webkit-animation: translate2 1s ease 0s 1 normal;
	/*animation-name: translate2;
	animation-duration: 1s;
	animation-timing-function: ease;
	animation-iteration-count: 1;
	animation-delay: 0s;
	animation-direction: normal; */
}
@keyframes translate2 { 
	0%   { transform:  translate(-63px, 56px); opacity:0;    } 
	25%   { transform:  translate(-63px, 56px); opacity:0;    } 
	75%   { transform:  translate(6px, -6px);   }
	100%  { transform:  translate(0px, 0px);opacity:1;   } 
} 
@-webkit-keyframes translate2 { 
	0%   { -webkit-transform:  translate(-63px, 56px); opacity:0;    } 
	25%   { -webkit-transform:  translate(-63px, 56px); opacity:0;    } 
	75%   { -webkit-transform:  translate(6px, -6px);   }
	100%  { -webkit-transform:  translate(0px, 0px);opacity:1;   } 
} 

#visual .front {
	position: absolute;
	width: 100%;
	height: 150px;
	bottom: 110px;
	left: 0;
	z-index: 20;
	background: url(../img/bg_visual.png) repeat-x bottom center;
}
#visual .front2 {
	position: absolute;
	width: 100%;
	height: 150px;
	bottom: 110px;
	left: 0;
	z-index: 15;
	background: url(../img/bg_visual02.png) repeat-x bottom center;
}
#visual #fade {
	position: absolute;
	width: 100%;
	height: 500px;
	top: 0px;
	z-index: 0;
	
}

#visual #fade ul {
	margin:0;
	padding:0;
}
#visual #fade ul li {
	position: absolute;
	top: 0;
	width: 100%;
	height: 600px;
	background-position: center top;
	background-repeat: no-repeat;
	background-attachment: fixed;
	/*background-size:cover;*/
	background-color:#2dafb0;
}

#visual #fade ul li#item1 { background-image: url(../img/visual01.jpg);}
#visual #fade ul li#item2 { display: none; background-image: url(../img/visual02.jpg);}
#visual #fade ul li#item3 { display: none; background-image: url(../img/visual03.jpg);}
#visual #fade ul li#item4 { display: none; background-image: url(../img/visual04.jpg);}
#visual #fade ul li#item5 { display: none; background-image: url(../img/visual05.jpg);}
#visual #fade ul li#item6 { display: none; background-image: url(../img/visual06.jpg);}
#visual #fade ul li#item7 { display: none; background-image: url(../img/visual07.jpg);}
#visual #fade ul li#item8 { display: none; background-image: url(../img/visual08.jpg);}
#visual #fade ul li#item9 { display: none; background-image: url(../img/visual09.jpg);}
#visual #fade ul li#item10 { display: none; background-image: url(../img/visual10.jpg);}
#visual #fade ul li#item11 { display: none; background-image: url(../img/visual11.jpg);}

#visual p {
	position: absolute;
	top: 0;
	right: 0;
	color: #fff;
	font-weight: bold;
	padding: 20px 20px 0 0;
	font-size: 120%;
	font-weight: normal;
	z-index: 20;
	text-shadow: 0.5px 0.866px 5px rgba(0, 0, 0, 0.54);
}
#visual p strong {
	font-size: 140%;
	margin-left: 10px;
}
#visual p a {
	pointer-events:none;
	color: #fff;
}

/* gnav */
#gnav h1 a {
	cursor:default;
}

/* menulist */
#content #menulist {
	background: url(../img/menulist_bg.gif) repeat-x 0 50px;
	clear: both;
	margin-top: 40px;
}
#content #menulist ul {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 56px;
	overflow:hidden;
	_zoom:1;
}
#content #menulist ul li {
	width: 326px;
	float: none;
}
#content #menulist ul li p {
	text-align: center;
	padding: 0 0 30px 28px;
}
#content #menulist ul li h2 {
	text-align: center;
	margin-bottom: 10px;
}
#content #menulist ul li dl {
}


#content #menulist ul li dl dt {
	padding: 10px 20px;
}
#content #menulist ul li dl dd {
	padding: 4px 20px;
}
#content #menulist ul li dl dd a {
	position: relative;
	padding-left: 20px;
}

#content #menulist ul li dl dd a:before {
	content: ' ';
	display: block;
	position: absolute;
	background: url(/common/img/sprite.png) no-repeat -50px 0;
	width: 10px;
	height: 10px;
	top: 0;
	left: 0;
	bottom: 0;
	margin: auto 0;
}

/* topics */
#content #topics {
	overflow:hidden;
	_zoom:1;
	padding-bottom: 40px;
}
#content #topics #blog {
	width: 430px;
	float: left;
	overflow:hidden;
	_zoom:1;
	padding-right: 60px;
}
#content #topics #blog dl {
	overflow:hidden;
	_zoom:1;
	margin: 0 0 10px 0;
	padding: 0 0 10px 0;
	border-bottom: 1px dotted #ddd;
}
#content #topics #blog dl dt {
	font-size: 90%;
	padding: 0 0 0 20px;
}
#content #topics #blog dl dd {
}
#content #topics #blog dl dd a {
	position: relative;
	padding-left: 20px;
}

#content #topics #blog dl dd a:before {
	content: ' ';
	display: block;
	position: absolute;
	background: url(/common/img/sprite.png) no-repeat -50px 0;
	width: 10px;
	height: 10px;
	top: 2px;
	left: 3px;
}

#content #topics #fb {
	width: 490px;
	float: left;
}
#content #topics #fb p {
	font-size: 90%;
	margin-top: 10px;
}
#content #topics #fb p a {
	position: relative;
	padding-left: 20px;
}

#content #topics #fb p a:before {
	content: ' ';
	display: block;
	position: absolute;
	background: url(/common/img/sprite.png) no-repeat 0 -150px;
	width: 10px;
	height: 10px;
	top: 2px;
	left: 3px;
}

/* service */
#content #service {
}
#content #service ul {
	width: 880px;
	margin: 0 auto;
}
#content #service ul li {
	border-radius: 50%;
	border: 4px solid #E7F6F6;
	width: 132px;
	height: 132px;
	float: left;
	text-align: center;
	margin: 0 18px;
}
#content #service ul li:hover {
	border: 4px solid #4FBBB5;
	background-color: #4FBBB5;
}
#content #service ul li span {
	display: block;
	padding-top: 55px;
	color: #333;
}
#content #service ul li:hover span {
	color: #fff;
	font-weight: bold;
}


/* target */
#content #target {
}
#content #target p {
	text-align: center;
}
#content #target p span.notes {
	font-size: 80%;
}

/* accessmap */
#content #accessmap {
	padding: 20px 0 60px 0;
}
#content #accessmap p {
	text-align:center;
	margin-bottom: 20px;
}
#content #accessmap p a {
	pointer-events:none;
	color: #666;
}

#content #accessmap #gm1{
	width: 100%;
	height: 600px;
}
#content #accessmap ul {
	text-align: right;
}
#content #accessmap ul li {
	display: inline-block;
}
#content #accessmap ul li a:hover {
	-moz-opacity: 0.8;
	opacity: 0.8;
}

/* gcal */
#content #gcal {
	width: 980px;
	margin: 0 auto;
}

/* map */
.infoWindow {
  width: 300px;
}
.infoWindow dl {
  margin: 0;
  padding: 0;
}
.infoWindow dl dt {
  margin: 0;
  padding: 0;
  font-size: 14px;
  line-height: 150%;
  color:#33b8ba;
}
.infoWindow dl dd {
  margin: 0;
  padding: 0;
  font-size: 12px;
  line-height: 160%;
}

/* recruit */
#recruit {
	clear: both;
}
#recruit p {
	margin-bottom: 1em;
	text-align: center;
	font-size: 18px;
}
#recruit h3 {
	text-align: center;
	border-bottom: 1px solid #ddd;
	padding-bottom: 15px;
	margin-bottom: 10px;
}
#recruit #recruitinfo {
	border: 4px solid #eee;
	padding: 30px;
	width: 912px;
	overflow:hidden;
	_zoom:1;
	border-radius: 20px;
}
#recruit #recruitinfo #recruitinfo_l {
	width: 445px;
	float: left;
}
#recruit #recruitinfo #recruitinfo_r {
	width: 445px;
	float: right;
}

#recruit dl {
	width: 445px;
	overflow:hidden;
	_zoom:1;
	margin: 0 0 4px 0;
	padding: 0 0 4px 0;
	border-bottom: 1px dotted #ddd;
	font-size: 90%;
}
#recruit dl dt {
	background-color: #33b8ba;
	color: #fff;
	padding: 1px 10px;
	float: left;
	width: 110px;
}
#recruit dl dd {
	float: left;
	width: 270px;
	padding: 1px 20px;
}

/* price */
#price .list {
	overflow:hidden;
	_zoom:1;
	margin-bottom: 40px;
}
#price .accounts,
 #price .insurance {
	margin-bottom: 40px;
}
#price .list p.hedanotes {
	text-align: right;
	padding-bottom: 30px;
}	

#price .list .list_left {
	width: 460px;
	float: left;
}
#price .list .list_right {
	width: 460px;
	float: right;
}
#price .list .listbox {
	margin: 0 0 40px 0;
}

#price .list table {
	border-collapse: collapse;
	width: 100%;
	margin-bottom: 10px;
}
#price .list table th,
#price .list table td {
	padding: 10px 40px 10px 20px;
}
#price .list table th {
}
#price .list table td {
	border-bottom: 1px dotted #ddd;
	background-color: #fff;
}
#price .list table .fee {
	width: 35%;
}
#price .list table td.fee {
	text-align: right;
	background-color: #e8f6f6;
	border-left: 1px solid #fff;
	font-size: 100%;
}
#price .list table td span {
	position: relative;
	padding-left: 20px;
}
#price .list table td span:before {
	content: ' ';
	display: block;
	position: absolute;
	background: url(/common/img/sprite.png) no-repeat 0 -50px;
	width: 8px;
	height: 8px;
	top: 0;
	left: 0;
	bottom: 0;
	margin: auto 0;
}
#price .list  strong {
	color: #33b8ba;
	font-size: 120%;
}
#price #wrapper #content #content_block p.notes {
	font-size: 90%;
	color: #999;
	padding-left:1em;
	text-indent:-1em;
	margin-bottom: 0;
}

.night p.lead {
	text-align: center;
	padding: 20px 0;
	border: 4px solid #E7F6F6;
	margin-bottom: 1em;
}
.night ul li {
	padding-left: 26px;
	background: url(/common/img/icon_green.png) no-repeat 6px 7px;
}
.night p.notes {
	font-size: 80%;
}