@charset "utf-8";

/* =Reset default browser CSS.
Based on work by Eric Meyer:http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td{border:0;font-family:inherit;font-size:100%;font-style:inherit;font-weight:inherit;margin:0;outline:0;padding:0;vertical-align:baseline;}
:focus{outline:0;}

ol, ul{list-style:none;}
table{border-collapse:separate;border-spacing:0;}
caption, th, td{font-weight:normal;text-align:left;}
blockquote:before, blockquote:after,q:before, q:after{content:"";}
blockquote, q{quotes:"" "";}
a img{border:0;}
figure{margin:0}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section{display:block;}
/* -------------------------------------------------------------- */

body{
color:#555;
font-size:14px;
font-family:verdana,"ヒラギノ丸ゴ ProN W4","Hiragino Maru Gothic ProN","メイリオ","Meiryo","ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
line-height:1.5;
-webkit-text-size-adjust:100%;
}


/* リンク設定
------------------------------------------------------------*/
a{color:#6caefe;text-decoration:none;}
a:hover{color:#488fdd;}
a:active, a:focus {outline:0;}


/* 全体
------------------------------------------------------------*/
#wrapper{
margin:0 auto;
padding:0%;
width:98%;
position:relative;
}

.inner{
margin:0 auto;
width:100%;
}


/*************
/* ヘッダー
*************/
#header{
}

#header h1{
padding:0px 0 10px;
font-size:12px;
font-weight:normal;
}



/*************
/* ロゴ
*************/
.logo{
float:left;
}

.logo a{
color:#555;
}

.logo p{float:left;}

.logo span{display:block;}


/*************
/* 電話番号
*************/
.info{
float:right;
padding-right:20px;
text-align:right;
}

.info .open{font-size:11px;}


/*************
/* ロゴ+電話番号
*************/
.logo,.info .tel{
margin-top:6px;
font-size:20px;
font-weight:bold;
}

.logo span,.info span{
font-size:.6em;
font-weight:normal;
}


/**************************
/* メイン画像（トップページ+サブページ）
**************************/
#mainBanner{
clear:both;
margin:25px auto 40px;
padding:0;
position:relative;
text-align:center;
}
#mainBanner .inner{position:relative;}

#mainBanner img{
max-width:100%;
height:auto;
}

.slogan{
color:#fff;
font-weight:bold;
position:absolute;
max-width:100%;
height:auto;
bottom:42%;
left:40px;
padding:5px 10px;
line-height:1.4;
text-align:left;
}

.slogan h2{
padding-bottom:5px;
font-size:22px;
}

.kakarituke { background: #69b4ee; padding: 10px; color:#fff; margin-bottom: 10px;}
.kakarituke .kakat { text-align: center; font-weight: bold; olor:#4588CF; margin-bottom: 0px; font-size:15px; margin-bottom: 10px;}

/**************************
/* グリッド
**************************/
.gridWrapper{
clear:both;
padding-bottom:20px;
overflow:hidden;
}

* html .gridWrapper{height:1%;}
	
.grid{
overflow:hidden;
}

.box{
padding:10px;
}

.box img{
max-width:100%;
height:auto;
}

.box h3{
font-size:16px;
padding:10px 0 15px;
}

.box h3, .box p{text-align:left;}

p.readmore{
padding:10px 5px 5px;
font-size: 12px;
text-align:right;
}

p.readmore a{
padding:3px 7px;
	background: #ED7700; color: #fff;
border-radius:3px;
}


/*************
メイン コンテンツ
*************/
section.content {
padding:30px 0 20px 0;
margin-bottom:10px;
overflow:hidden;
}

section.toppage article,section.content .archive{border:0;}


/* アーカイブページ */
section.content .archive{
padding:0;
}

section.content p{margin-bottom:5px;}

h3.heading{
font-size:16px;
font-weight:normal;
padding:15px 0;
margin-bottom:5px;
border-top:2px solid #ebebeb;
border-bottom:2px solid #ebebeb;
}

.alignleft{
float:left;
clear:left;
margin:3px 10px 10px 0;
}

.alignright{
float:right;
clear:right;
margin:3px 0 10px 10px;
}
.aligncenter{
	text-align: center;
}


/*************
/* サイドバー
*************/
#sidebar article{
clear:both;
margin-bottom:20px;
}

#sidebar ul{padding:15px 0;}

#sidebar li{
margin-bottom:10px;
padding-bottom:10px;
list-style:none;
border-bottom:1px dashed #ebebeb;
}

#sidebar li:last-child{
border:0;
margin-bottom:0px;
}

#sidebar li a{
color:#555;
font-size:12px;
display:block;
}

#sidebar li a:hover{
color:#999;
font-size:12px;
display:block;
}


/*************
/* フッター
*************/
#footer{
clear:both;
}

#footer a{
color:#555;
}

#footer a:hover{
color:#999;
}

#footer .inner{
padding:40px 0;
overflow:hidden;
}

#footer .grid{
margin:0;
}

#footer #info{float:left;}

#footer #info .info{float:none;}

#footer #info .info{
clear:both;
padding:5px 0 0;
text-align:left;
}

#footer .logo{font-size:18px;}

#footer .info .tel,#footer .info .tel span,#footer #info .open{
font-size:12px;
}

ul.footnav{
float:right;
width:620px;
padding:10px 0;
}
ul.footnav ul{display:none;}

ul.footnav li{
float:left;
margin:10px 0 10px 0;
padding:0 7px 0 8px;
border-right:1px solid #ebebeb;
}

#copyright{
clear:both;
padding:20px 0 60px 0;
text-align:center;
font-style:normal;
font-size:10px;
color:#555;
}


/* page navigation
------------------------------------------------------------*/
.pagenav{
clear:both;
width:100%;
height:30px;
margin:5px 0 20px;
}

.prev{float:left}
.next{float:right;}

#pageLinks{
clear:both;
text-align:center;
}


/* タイポグラフィ
*****************************************************/
.dateLabel{
margin:0 0 10px;
text-align:right;
font:italic 1em "Palatino Linotype", "Book Antiqua", Palatino, serif;
}
.post {overflow: hidden;}
.post p{padding-bottom:10px;}

.post ul{margin:0 0 10px 10px;}

.post ul li{
margin-bottom:5px;
padding-left:15px;
background:url(images/bullet.png) no-repeat 0 8px;
}

.post ol{margin:0 0 10px 30px;}

.post ol li{list-style:decimal;}

.post h1{
margin:20px 0;
padding:5px 0;
font-size:150%;
color:#000;
border-bottom:3px solid #cf6a88;
}

.post h2{
margin:10px 0;
padding-bottom:2px;
font-size:130%;
font-weight:normal;
color:#333;
border-bottom:2px solid #46b2e0;
}

.post h3{
margin:10px 0 25px 0;
padding:10px 0 10px 0;
font-size:120%;
font-weight:normal;
border-bottom:1px solid #ddd;
}

.post h4{
margin:10px 0 15px 0;
padding:10px 0 0px 0;
font-size:115%;
font-weight:bold;
 color: #46b2e0;
}

.post blockquote{
clear:both;
padding:10px 0 10px 15px;
margin:10px 0 25px 30px;
border-left:5px solid #ccc;
}
 
.post blockquote p{padding:5px 0;}

.post table{
border-collapse:collapse;
margin:5px auto 15px auto;
}

.post table td{
border-collapse:collapse;
background-color:#F9F9F9;
text-align:left;
padding:8px;
border:1px solid #D6D6D6;
line-height:20px;
}

.post table th{
background-color:#F5F5F5;
text-align:right;
padding:8px;
white-space:nowrap;
color: #151515;
border-top:1px solid #D4D4D4;
border-right:4px solid #D4D4D4;
border-bottom:1px solid #D4D4D4;
border-left:1px solid #D4D4D4;
font-size:13px;
font-weight:normal;
letter-spacing:1px;
background-repeat:repeat-x;
background-position:top;
}


.post dt{font-weight:bold;}

.post dd{padding-bottom:10px;}

.post img{max-width:100%;height:auto;}

img.aligncenter{
display:block;
margin:5px auto;
}

img.alignright, img.alignleft{
padding:4px;
margin:0 0 2px 7px;
display:inline;
}

img.alignleft{margin:0 7px 2px 0;}

.alignright{float:right;}
.alignleft{float:left;}


/* PC用
------------------------------------------------------------*/
@media only screen and (min-width:960px){
	nav div.panel{
	display:block !important;
	float:left;
	}

	a#menu{display:none;}
	
  #mainNav{
	clear:both;
	z-index:200;
	position:relative;
	}

	#mainNav li{
	float:left;
	position:relative;
	}

	#mainNav li a{
	color:#555;
	display: block;
	text-align: center;
	_float:left;
	font-size:13px;
	width:160px;
	height:30px;
	padding:15px 0;
	border-top:2px solid #ebebeb;
	border-bottom:2px solid #ebebeb;
	}

	#mainNav li a span,#mainNav li a strong{display:block;}

	#mainNav li a span{
	color:#bababa;
	font-size:10px;
	}
	
	#mainNav ul ul{width:160px;background:#fff;}
	#mainNav li ul{display:none;}

	#mainNav li:hover ul{
	display:block;
	position:absolute;
	top:64px;
	z-index:500;
	}
	
	#mainNav li li{
	margin:0;
	float:none;
	width:160px;
	border:0;
	}
  #mainNav li li:last-child{border:0;}
	
	#mainNav li li a{
	width:auto;
	height:auto;
	padding:10px;
	font-size:95%;
	text-align:left;
	border:0;
	}

	#mainNav li li span{padding:0 10px;}
	
	#mainNav li.current-menu-item a{
	border-color:#555;
	}

	#mainNav li.current-menu-item a,#mainNav li a:hover,#mainNav li.current-menu-item li a:hover{
	color:#999;
	}

	#header,#wrapper,.inner{
	width:960px;
	padding:0;
	margin:0 auto;
	}
	
	#wrapper{clear:both; padding:20px 0;}
	
	#main{
	float:right;
	width:680px;
	padding:15px 0 0 0;
	}
	
	#sidebar{
	float:left;
	width:250px;
	padding:15px 0;
	overflow:hidden;
	}
	
	#sidebar article{
	margin-bottom:20px;
	overflow:hidden;
	}
	
	.logo{width:500px;}
	
	/* グリッド全体 */
	.gridWrapper{
	display:table;
	border-collapse:separate;
	border-spacing:0px;
	}
	
	/* グリッド */
	.grid{
	width:320px;
	display:table-cell;
	}

}


@media only screen and (max-width:959px){
	*{
    -webkit-box-sizing:border-box;
       -moz-box-sizing:border-box;
         -o-box-sizing:border-box;
        -ms-box-sizing:border-box;
            box-sizing:border-box;
	}
	
	#mainNav{
	clear:both;
	width:100%;
	margin:0 auto;
	padding:0;
	border-left:0;
	border-right:0;
		background: #46afdc;
		color:#fff;
	}

	#mainNav a.menu{
	color:#555;
	width:100%;
	display:block;
	height:40px;
	line-height:40px;
	font-weight: bold;
	text-align:left;
		color:#fff;
	}

	#mainNav a#menu span{
	padding-left:10px;
	}
	#mainNav a.menu span:before{content:"≡ ";}
	#mainNav a.menuOpen span:before{content:"× ";}

	#mainNav a#menu:hover{cursor:pointer;}

	nav .panel{
	display:none;
	width:100%;
	position:relative;
	right:0;
	top:0;
	z-index:1;
	}
	
	#mainNav ul{margin:0;padding:0;}

  #mainNav li{
	float:none;
	clear:both;
	width:100%;
	height:auto;
	line-height:1.2;
	  		background: #fff;
	}

	#mainNav li a,#mainNav li.current-menu-item li a{
	color:#555;
	display: block;
	padding:12px 10px;
	text-align:left;
	border-bottom:1px dashed #ccc;
	}
	
 	#mainNav li a span{padding-left:10px;}
	
	
	#mainNav ul > li:last-child a{border:0;}
	#mainNav li li:last-child a{border-bottom:1px dashed #ccc;}
 
	#mainNav li.current-menu-item a,#mainNav li a:hover,#mainNav li.current-menu-item a,#mainNav li a:active, #mainNav li li.current-menu-item a, #mainNav li.current-menu-item li a:hover, #mainNav li.current-menu-item li a:active{
	color:#555;
	}

	#mainNav li li{
	float:left;
	border:0;
	}

	#mainNav li li a, #mainNav li.current-menu-item li a, #mainNav li li.current-menu-item a{
	padding-left:40px;
	background:url(images/sub1.png) no-repeat 20px 18px;
	}

	#mainNav li li.current-menu-item a,#mainNav li li a:hover, #mainNav li.current-menu-item li a:hover{background:url(images/sub1.png) no-repeat 20px -62px;}

	#mainNav li li:last-child a{background:url(images/subLast.png) no-repeat 20px 20px;}
	#mainNav li li:last-child.current-menu-item a,#mainNav li li:last-child a:hover,#mainNav li.current-menu-item li:last-child a:hover{background:url(images/subLast.png) no-repeat 20px -65px;}

	nav div.panel{float:none;}
	
	
	#main{padding-top:15px;}
	section.toppage{margin:0;}
	#sidebar{padding-bottom:15px;}
	#sidebar article{padding:7px 8px;}
	
	#footer .grid,#footer ul.footnav{float:none;width:100%;text-align:center;}
	ul.footnav li{float:none;display:inline-block;}
	
	.grid{
	float:left;
	width:32%;
	margin:10px 0 0 1%;
	}

	#footer .grid img,#footer .info{float:none;}
	#footer .grid p{display:block;}
	#footer #info .info{float:none;text-align:center;}
	#footer.logo,#footer .info{width:100%;float:none;}
	#footer .logo p{float:none;display:block;	}
	#footer .logo img{float:none;padding:0;}
}


@media only screen and (max-width:768px){
	
	#header{ margin-top:0; background:url(images/bg.gif) top left repeat; padding:10px 0 0; }
	#header h1 { text-align:center; }
	.logo {clear:both;float:none;}
	
/* page common　*/
	
.h4Title01 {padding:7px 2px 7px !important;  border-bottom: 1px solid #21A7E6; border-top: 1px solid #21A7E6;}
#wrapper{clear:both; padding:20px 0;}
	
section.content {
margin-bottom:20px;
padding: 0 10px;
overflow:hidden;
}
section.contents {
margin-bottom:20px;
padding: 0 0px;
overflow:hidden;
}
section.content p, section.contents p { margin-bottom: 14px;}

.grid{
float:left;
width:48%;
margin:10px 1% 0;
}
	ul.list { margin-left: -10px!important; }
	
	/* 交通あクセス　*/
	.bgAccess {background:#f6f2e9;}
	.accesstime { padding:20px 10px;}
	.accesstime h3 { color:#3d2a19; font-weight: bold; font-size:18px;  margin-bottom: 15px; }
	dl.densha { margin:0 0 15px;}
	dl.densha dt {font-weight: bold; margin-bottom: 5px; padding: 0em 0 0em .5em; border-left: 3px solid #3d2a19;}
	.pink { color:#f4416b;}
	
/* 　フッターメニュー */
ul.footer_menu { margin: 0 auto; padding: 6px 0; width: 100%; overflow: hidden; display: table; }
ul.footer_menu li:first-child {border-left:0px;}
ul.footer_menu li { margin: 0; padding: 0; display: table-cell; vertical-align:middle; list-style-type: none; font-size: 10px; border-left:1px solid #fff; color:#fff; }
ul.footer_menu li a i { font-size: 20px;  }
ul.footer_menu li a { border: none; display: block; text-align: center; text-decoration: none; color:#fff; }
.footer_menu { position: fixed; bottom: 0; left:0; background: #46afdc; z-index: 9999999999; -moz-opacity: 0.9; opacity: 0.9; }


	
	
/* 下層ページ 共通　*/	
	.bg_sub {background: #faf7f2;}
	#header .logo p { margin:-10px 0 5px; text-align: center!important; padding: 0px 30px 0; }
	.logo p{float:none;}
	
/* 歯科医院案内　*/
h4.name { font-size:16px; color:#46b2e0;}
	
/* よくある質問　*/
	.faq {  margin-bottom: 20px;}
 	dl.a { margin-bottom: 10px; font-weight: bold; color:#046c98;}
	dl.a dt {position: absolute; }
	dl.a dd { margin:5px 0 0 20px; padding-top: 1px;}
	
/* 審美歯科 */
	div.border03 {
	padding: 5px 5px;
	margin-right: 7px;
	margin-bottom: 25px;
	background-color: #C4EAFD;
}

div.whiteningTxt2 {
	border: 2px solid #6BC1E7;
	padding-top: 15px;
	padding-right: 15px;
	padding-bottom: 7px;
	padding-left: 15px;
	background-color: #FFF;
}
p.implantTitle2 {
	font-size: 1.0em;
	line-height: 1.6;
	color: #46B2E0;
	font-weight: bold;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
	border-bottom-color: #89CDEB;
	margin-bottom: 6px;
}
	ul.flowList2 { width:100%; margin: 0;}
	ul.flowList2 li { width:33%; float: left; padding: 0; margin: 0;}
/* 歯周病治療 */
	ul.tokucho li { width:40%; float: left; margin: 10px 15px;}
	dl.shishuBox {margin-bottom: 20px;}
dl.shishuBox dt {
	font-size: 1.0em;
	line-height: 1.6;
	color: #8E7D5E;
	font-weight: bold;
}
dl.shishuBox dd {
	border: 2px solid #c2b7a3;
	background-color: #F8F4ED;
	font-size: 0.9em;
	padding: 11px 5px 5px;
}
	.step h4 { background:#46b2e0; padding: 5px 5px; color: #fff;}
	div.border02 {
	padding: 5px;
	margin-right: 7px;
	margin-bottom: 25px;
	background-color: #efe7d4;
}

div.whiteningTxt {
	border: 2px solid #c2b7a3;
	padding-top: 11px;
	padding-right: 15px;
	padding-bottom: 7px;
	padding-left: 15px;
	background-color: #fff;
/*Androidブラウザフォントバグ対策*/
max-height: 999999px;

}
p.implantTitle {
	font-size: 1.0em;
	line-height: 1.6;
	color: #8E7D5E;
	font-weight: bold;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
	border-bottom-color: #C2B7A3;
	margin-bottom: 6px;
}
table.whiteningCharge {
	width: 100%;
	margin-left: 10px;
	margin-top: 20px;
}
table.whiteningCharge th {
	background-color: #AEE2FC;
	text-align: center;
	padding-top: 6px;
	padding-bottom: 4px;
	padding-right: 4px;
	padding-left: 4px;
}
table.whiteningCharge td {
	text-align: center;
	border: 1px solid #AEE2FC;
	padding-top: 6px;
	padding-bottom: 4px;
	padding-right: 4px;
	padding-left: 4px;
	background-color: #FFF;
}	
/* 入れ歯 */
.grid .hgrid { height:150px!important;}
	table.irebaBox {background: #fff!important; }
	table.irebaBox th { border-right:1px solid #ccc; text-align: center; background: #0089c4; color:#fff; font-weight: bold; }
	able.irebaBox td.w40 { width:40%; vertical-align: top; }
	table.irebaBox td.w60 { width:60%; vertical-align: top;}
	table.irebaBox ul {margin-left: 5px; margin-top: 0px !important;}
	table.irebaBox ul li { list-style-type: circle; margin-left: 10px; padding-left:0px !important;}
	
/* インプラント */
	ul.subMenu { overflow:hidden; margin-bottom: 20px;}
	ul.subMenu li { float: left; width: 49% ; text-align: center; padding: 7px 0; background: #f2f2f2; margin: 0.5%; }
	ul.subMenu li a { display: block; padding: 7px 0;}
	
table.implantBox {background: #fff!important; }
	table.implantBox th { border-right:1px solid #ccc; text-align: center; background: #0451af; color:#fff; font-weight: bold; }
	table.implantBox td.w50 { width:50%;}
	table.implantBox ul li { list-style-type: circle; margin-left: 10px; padding-left:0px !important;}
	
		table.implantBox2 th { border-right:1px solid #ccc; text-align: center; background: #3a0013; color:#fff; font-weight: bold; }
	table.implantBox2 td.w50 { width:50%;}
	table.implantBox2 ul li { list-style-type: circle; margin-left: 10px; padding-left:0px !important;}
	h4.H4title01 {color:#000; }
	
/* インプラントよくある質問 */	
	.qa {　}
	.qa h4 { background: url(images/implant/faq/quetion.gif) left top no-repeat; padding:4px 0 0 35px; margin-bottom: 0px; margin-left: -10px;} 
	
/* インプラント料金表 */	
	dl.cost { margin-bottom: 20px;}
	dl.cost dt { background: #0d5b9c; text-align: center; padding:5px 0; color: #fff;}
	dl.cost dd { border-left:1px solid #ccc; border-right:1px solid #ccc; padding: 8px 10px; background: #fff;}
	dl.cost dd.price { background:#f2f2f2; color:#464545; text-align: center; border-top:1px solid #ccc; border-bottom:1px solid #ccc;  }
	}
div.border04 {
	padding: 5px;
	margin-right: 7px;
	margin-bottom: 25px;
	background-color: #D1F49D;
/*Androidブラウザフォントバグ対策*/
max-height: 999999px;
}

div.whiteningTxt3 {
	border: 2px solid #8FCE0D;
	padding-top: 7px;
	padding-right: 15px;
	padding-bottom: 7px;
	padding-left: 15px;
	background-color: #FFF;
}
p.implantTitle3 {
	font-size: 1.2em;
	line-height: 1.6;
	color: #60B825;
	font-weight: bold;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
	border-bottom-color: #97D345;
	margin-bottom: 6px;
}
.red { color:red;}

table.whitBox {background: #fff!important; }
table.whitBox th { border-right:1px solid #ccc; text-align: center; background: #aee2fc; color:#3C3C3C; }
table.whitBox td { text-align: center;}
.bg01 { background:#0085bd!important; color: #fff !important;}

}


@media only screen and (max-width:480px){
#header .logo p {text-align: center!important;}
.alignleft{float:left !important; clear:left; margin:1px 10px 10px 0 !important;}
	.align-center {text-align: center!important;}
.grid img { width: 100% !important;}
#mainBanner h2,#mainBanner p{font-size:80%;}
	
	table.tableBox { margin-bottom: 20px;}
	table.tableBox th { text-align: left; vertical-align: top; border-bottom: 1px dotted #ccc; padding:7px 7px 5px; }
	table.tableBox td { border-bottom: 1px dotted #ccc; padding:7px 7px 5px;}
	table.tableBox a { color:#000;}


}

.news h3 { margin:0px 0 15px 0;
padding:0px 0 10px 0;
font-size:120%;
font-weight:normal;
border-bottom:2px solid #4bb0da;}
.news p.data { margin-bottom: 10px;}
.news h4 { margin: 7px 0 10px; font-weight: bold; font-size: 110%; } 
.newsList { padding: 20px 0 !important; }
.newsList h4 {
	border-bottom: 1px solid #ccc;
 color: #4bb0da;
 font-size: 1.1em;
 margin: 0 0 8px;
 padding: 5px 0 3px 0px;
}
.newsList dl.category {
 font-size: 0.9em;
 margin-bottom: 15px;
 margin-left: 0px;
}
.newsList dl.category dt {
 width: auto;
 color: #015e5e;
 float: left;
}

.mt20 { margin-top:20px!important;}

    #pageTop {

      position: fixed;
      bottom: 50px;
      right: 0px;
    }

     

    #pageTop a {
      display: block;
      z-index: 999;
      padding: 8px 0 0 0px;
      width: 40px;
      height: 40px;
      background-color: #9FD6D2;
      color: #fff;
      font-weight: bold;
      text-decoration: none;
      text-align: center;
    }

     

    #pageTop a:hover {
      text-decoration: none;
      opacity: 0.7;
    }