@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;
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	font: 12px/1.5 "メイリオ", "Meiryo", arial, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
	color: #333;
	-webkit-text-size-adjust: none;
	background: #fcfdf3;
}
/* リンク設定
------------------------------------------------------------*/
a {
	margin: 0;
	padding: 0;
	text-decoration: none;
	outline: 0;
	vertical-align: baseline;
	background: transparent;
	font-size: 100%;
	color: #313131;
}
a:hover, a:active {
	outline: none;
	color: #6f6f6f;
}
/**** Clearfix ****/
nav .panel:after, nav#mainNav:after, .newsTitle:after, .bg:after, .post:after, ul.post li:after, nav#mainNav .inner:after {
	content: "";
	display: table;
	clear: both;
}
nav .panel, nav#mainNav, .newsTitle, .bg, .post, ul.post li, nav#mainNav .inner {
	zoom: 1;
}
.clearfix:after {
  clear: both;
  content: '';
  display: block;
}

/* レイアウト
------------------------------------------------------------*/
.img_boder {
	border:#ccc solid 1px;
	padding:1px;
}
.taC {
	text-align:center;
}
.mb5 {
	margin-bottom:5px;
}
.mb15 {
	margin-bottom:15px;
}
.mt15 {
	margin-top:15px;
}
.f_small {
	font-size:10px;
}
#wrapper, .inner {
	margin: 0 auto;
	width: 960px;
}
#header {
	overflow: hidden;
}
#content {
	float: right;
	width: 703px;
	padding: 22px 0 50px;
}
#sidebar {
	float: left;
	width: 233px;
	padding: 22px 0 50px;
}
#footer {
	clear: both;
}
/* ヘッダー
*****************************************************/

/* サイト説明文
----------------------------------*/
#header h1 {
	padding: 14px 0 0;
	font-size: 80%;
	font-weight: normal;
	text-align: center;
}
/* ロゴ (サイトタイトル)
----------------------------------*/
#header h2 {
	clear: both;
	padding: 5px 0 5px;
	color: #515151;
	font-size: 150%;
	font-weight: bold;
	text-align: center;
}
/* トップページ　メイン画像
----------------------------------*/
#mainImg {
	clear: both;
	line-height: 0;
	text-align: center;
	z-index: 0;
}
.post {
	margin: 0 0 20px 0;
	padding: 20px 10px 20px 10px;
	border: 1px solid #d5d5d5;
	background: #fff;
}
.toppage h4 {
	margin: 0 0 10px;
	font-size: 16px;
	font-weight: normal;
	color: #333;
}
.toppage {
	padding: 10px 10px 20px 20px;
}
/* 記事
*****************************************************/
.list {
	padding: 10px 0;
	border-bottom: 1px dashed #dcdcdc;
}
.list:last-child {
	border: 0;
}
.post .list p {
	padding: 0;
}
.list span {
	padding-left: 10px;
}
/* タイポグラフィ
*****************************************************/

dl.faq__list {
	padding: 15px;
}
dl.faq__list dt {
	background: url(../images/faq/question.png) left center no-repeat #f3f3f1;
	padding:  5px 5px 5px 29px;
	margin-bottom: 15px;
}
dl.faq__list dd {
	background: url(../images/faq/answer.jpg) left top no-repeat;
	padding-left: 29px;
	border-bottom: #ccc 1px dotted;
	padding-bottom: 30px;
	margin-bottom: 30px;
}



h2.title {
	clear: both;
	margin: 0;
	padding: 7px 10px 7px 10px;
	font-size: 110%;
	color: #000;
	border: 1px solid #d5d5d5;
	border-bottom: 0;
	background: #fff url(../images/headingBg.png) repeat-x 0 100%;
}
.dateLabel {
	text-align: right;
	font-weight: bold;
	color: #858585;
}
.post p {
	padding-bottom: 15px;
}
.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 #000;
}
.post h2 {
	margin: 10px 0;
	padding-bottom: 2px;
	font-size: 130%;
	font-weight: normal;
	color: #333;
	border-bottom: 2px solid #515151;
}
.post h3.ttl3 {
	clear:both;
	margin: 10px 0;
	font-size: 100%;
	font-weight: normal;
	color: #2e2c2c;
	border-bottom: 1px solid #515151;
}
.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: 1px #ccc solid;
	border-collapse: collapse;
	border-spacing: 0;
	margin: 0 0 20px;
	width:100%;
}
.post table th {
	padding: 10px;
	border: #ccc solid;
	border-width: 0 0 1px 1px;
	background: #f2f2f2;
}
.post table td {
	padding: 10px;
	border: 1px #ccc solid;
	border-width: 0 0 1px 1px;
	background: #fff;
}
.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 {
	margin: 10px 10px 15px 15px;
	display: inline;
}
img.alignleft {
	margin: 10px 15px 15px 10px;
}
.alignright {
	float: right;
}
.alignleft {
	float: left;
}
#gallery-1 img {
	border: 1px solid #eaeaea !important;
	padding: 5px;
	background: #fff;
}
#gallery-1 img:hover {
	background: #fffaef;
}
/* サイドバー　ウィジェット
*****************************************************/
section.widget ul, .widget_search, #calendar_wrap, .textwidget {
	margin: 0 0 20px 0;
	padding: 10px 10px 10px 17px;
	border: 1px solid #d5d5d5;
	background: #fff;
}
section.widget ul ul {
	border: 0;
	margin: 0;
	padding: 0 0 0 10px;
}
section.widget h3 {
	clear: both;
	margin: 0;
	padding: 7px 10px 7px 10px;
	font-size: 110%;
	border: 1px solid #d5d5d5;
	border-bottom: 0;
	color: #000;
	background: #fff url(../images/headingBg.png) repeat-x 0 100%;
}
section.widget li a {
	display: block;
	padding: 7px 0 7px 12px;
	background: url(../images/arrow.gif) no-repeat 0 12px;
	border-bottom: 1px dashed #dcdcdc;
}
section.widget li:last-child a {
	border: 0;
}
#searchform input[type="text"] {
	line-height: 1.7;
	height: 24px;
	width: 90px;
	vertical-align: bottom;
}
/* お知らせ　
-------------*/
.newsTitle {
	clear: both;
	margin: 0;
	padding: 7px 10px 7px 10px;
	font-size: 110%;
	border: 1px solid #d5d5d5;
	border-bottom: 0;
	color: #000;
	background: #fff url(../images/headingBg.png) repeat-x 0 100%;
}
.newsTitle h3 {
	float: left;
	font-weight: normal;
}
.newsTitle p {
	float: right;
	padding: 0 0 0 10px;
	font-size: 80%;
	background: url(../images/arrow.gif) no-repeat 0 5px;
}
.news p {
	clear: both;
	padding-bottom: 2px;
	border-bottom: 1px dashed #dcdcdc;
}
.news p:last-child {
	border: 0;
}
.news p a {
	display: block;
	padding: 5px 0;
	color: #333;
	font-style: italic;
	font: italic 110% "Palatino Linotype", "Book Antiqua", Palatino, serif;
}
.news a span {
	color: #515151;
	font: normal 90% Arial, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', sans-serif;
}
.news span {
	padding-left: 10px;
}
.news a:hover span {
	color: #6f6f6f;
}
/* フッター
*****************************************************/

#copyright {
	clear: both;
	padding: 10px 0 37px;
	text-align: center;
	color: #000;
	font-size: 10px;
}
/* page navigation
------------------------------------------------------------*/
.pagenav {
	clear: both;
	width: 100%;
	height: 30px;
	margin: 5px 0 20px;
}
.prev {
	float: left
}
.next {
	float: right;
}
#pageLinks {
	clear: both;
	color: #4f4d4d;
	text-align: center;
}
/* トップページ 最新記事4件
------------------------------------------------------------*/
ul.post {
	padding: 0;
}
ul.post li {
	margin: 0 10px;
	padding: 20px 0 15px;
	border-bottom: 1px dashed #dcdcdc;
}
ul.post li:last-child {
	border: 0;
}
ul.post img {
	float: left;
	margin: 0 15px 5px 10px;
}
ul.post h3 {
	margin: 0 0 10px 10px;
	font-size: 14px;
	font-weight: normal;
	color: #333;
	border: 0;
}
div.utility p.header_tel span{
	color:#900;
	font-size:large;
	font-weight:bold;
}
div.utility p.language_btn{
	font-size:16px;
	text-align:right;
}
div.utility p.language_btn a{
	background:url(../images/common/arrow.gif) left 5px no-repeat;
	padding-left:16px;
}
.defaultlist
,.defaultlist li{
	padding:0px;
	margin:0px;
}
 
.defaultlist li{
	list-style-type:none !important;
	list-style-image:none !important;
	margin: 5px 0px 12px 0px !important;
}
 
.list8{
	counter-reset:li;
	margin-left:20px !important;
}
 
.list8 li{
	position:relative;
	display: block;
	padding:8px 0px 8px 40px;
}
 
li.list8-count:after{
	counter-increment: li;
	content: counter(li);
	position: absolute;	
	left: -16px;
	top: 2px;
	background: #f5eafb;
	height: 30px;
	width: 30px;
	line-height: 32px;
	border: 2px solid #ffccff;
	text-align: center;
	font-weight: bold;
	border-radius: 30px;
}
 
li.list8-count:before{
	content:''; 
	display:block; 
	position:absolute; 
	box-shadow: 0 0 2px 2px rgba(255,255,255,0.2) inset;
	top:11px; 
	left:15px; 
	height:0; 
	width:0; 
	border-top: 8px solid transparent;
	border-right: 7px solid transparent;
	border-bottom: 8px solid transparent;
	border-left: 13px solid #ffccff;
}
p.contact_tel span{
	font-size:large;
	color:#900;
}

ul.voice__list li img {
	width:20%;
}

span.title_span {
	float:right;
	font-weight:900;
	
}


.contactText a {
	color:red;
	text-decoration:underline;
}

/* メインメニュー　PC用
------------------------------------------------------------*/
@media only screen and (min-width: 1025px) {
	/* サイト説明文
----------------------------------*/
#header .inner{
	position:relative;
}
.accent_box {
	width: 960px;
	margin: 0 auto;
	position: relative;
	height:auto;
}
.accent_img_01 {
	position: absolute;
	top: 3px;
	left: 10px;
	width: 100px;
}
.accent_img_02 {
	position: absolute;
	top: 78px;
	right: 10px;
	width: 190px;
}


#header h1 {
	padding: 14px 0 10px;
	font-size: 80%;
	font-weight: normal;
	text-align: left;
}
/* ロゴ (サイトタイトル)
----------------------------------*/
#header h2 {
	clear: both;
	padding: 5px 0 5px;
	color: #515151;
	font-size: 150%;
	font-weight: bold;
	text-align: left;
}
#header h2 img{
	width:300px;
}
div.utility {
	position:absolute;
	top:36px;
	right:0;
}



nav#mainNav {
	clear: both;
	position: relative;
	z-index: 200;
	width: 100%;
}
nav#mainNav .inner {
	background: url(../images/mainNavSep.png) no-repeat 0 5px;
}
nav#mainNav ul li {
	width: 160px;
	float: left;
	position: relative;
	background: url(../images/mainNavSep.png) no-repeat 100% 5px;
}
nav#mainNav ul li a {
	display: block;
	text-align: center;
	_float: left;
	color: #000;
	height: 20px;
	line-height: 20px;
	font-size: 110%;
	padding: 20px 0;
}
nav#mainNav ul li a span, nav#mainNav ul li a strong {
	display: block;
	font-size: 90%;
	line-height: 1.4;
}
nav#mainNav ul li a span {
	font-size: 70%;
	color: #888;
	font-weight: normal;
	font-family: "Times New Roman", Times, serif;
}
nav div.panel {
	display: block !important;
	float: left;
}
a#menu {
	display: none;
}
nav#mainNav ul li.current-menu-item a, nav#mainNav ul li a:hover span, nav#mainNav ul li a:hover, nav#mainNav ul li.current-menu-parent a {
	color: #4c4c4c;
}
nav#mainNav ul ul {
	width: 160px;
	border: 1px solid #e0e0e0;
	border-top: 0;
}
nav#mainNav ul li ul {
	display: none;
}
nav#mainNav ul li:hover ul {
	display: block;
	position: absolute;
	top: 42px;
	left: -1px;
	z-index: 500;
}
nav#mainNav ul li li {
	margin: 0;
	float: none;
	height: 40px;
	line-height: 40px;
	width: 160px;
	background: #f2f2f2;
	border-bottom: 1px dotted #e0e0e0;
}
nav#mainNav ul li li:last-child {
	border: 0;
}
nav#mainNav ul li li a {
	width: 100%;
	height: 40px;
	padding: 0 0 0 10px;
	line-height: 40px;
	font-size: 95%;
	text-align: left;
}
nav#mainNav ul li li.current-menu-item a, nav#mainNav ul li li a:hover {
	color: #6f6f6f
}
}

/* メインメニュー iPadサイズ以下から
------------------------------------------------------------*/
@media only screen and (max-width:1024px) {
	
.accent_box {
	width: 100%;
	position:relative;
}
.accent_img_01 {
	position: absolute;
	top: 3px;
	left: 10px;
	width: 17%;
}
.accent_img_02 {
	position: absolute;
	top: 41px;
	right: 10px;
	width: 20%;
}
	
#header h2 img{
	width:46%;
}
div.utility p.header_tel{
	font-size:16px;
	text-align:center;
}
div.utility p.language_btn{
	font-size:16px;
	text-align:center;
}


nav#mainNav {
	clear: both;
	width: 880px;
	margin: 0 auto 10px;
	border: 1px solid #d5d5d5;
}
nav#mainNav a.menu {
	width: 100%;
	display: block;
	height: 37px;
	line-height: 37px;
	font-weight: bold;
	text-align: left;
	background: url(../images/menuOpen.png) no-repeat 5px 8px;
}
nav#mainNav a#menu span {
	padding-left: 35px;
}
nav#mainNav a.menuOpen {
	background: url(../images/menuOpen.png) no-repeat 5px -34px;
}
nav#mainNav a#menu:hover {
	cursor: pointer;
}
nav .panel {
	display: none;
	width: 100%;
	position: relative;
	right: 0;
	top: 0;
	z-index: 1;
}
nav#mainNav ul {
	margin: 0;
	padding: 0;
}
nav#mainNav ul li {
	float: none;
	clear: both;
	width: 100%;
	height: auto;
	line-height: 1.2;
}
nav#mainNav ul li:first-child {
	border-top: 1px solid #d5d5d5;
}
nav#mainNav ul li li:first-child {
	border-top: 0;
}
nav#mainNav ul li a, nav#mainNav ul li.current-menu-item li a {
	display: block;
	padding: 15px 10px;
	text-align: left;
	border-bottom: 1px dashed #ccc;
	background: #fff;
}
nav#mainNav ul li:last-child a {
	border: 0;
}
nav#mainNav ul li li:last-child a {
	border: 0;
}
nav#mainNav ul li li:last-child a {
	border-bottom: 1px dashed #ccc;
}
nav#mainNav ul li a span {
	display: none;
}
nav#mainNav ul li.current-menu-item a, nav#mainNav ul li a:hover, nav#mainNav ul li.current-menu-item a, nav#mainNav ul li a:active, nav#mainNav ul li li.current-menu-item a, nav#mainNav ul li.current-menu-item li a:hover, nav#mainNav ul li.current-menu-item li a:active {
	background: #f6f6f6;
}
nav#mainNav ul li li {
	float: left;
	border: 0;
}
nav#mainNav ul li li a, nav#mainNav ul li.current-menu-item li a, nav#mainNav ul li li.current-menu-item a {
	padding-left: 40px;
	background: #fff url(../images/sub1.png) no-repeat 20px 18px;
}
nav#mainNav ul li li.current-menu-item a, nav#mainNav ul li li a:hover, nav#mainNav ul li.current-menu-item li a:hover {
	background: #f6f6f6 url(../images/sub1.png) no-repeat 20px -62px;
}
nav#mainNav ul li li:last-child a {
	background: #fff url(../images/subLast.png) no-repeat 20px 20px;
}
nav#mainNav ul li li:last-child.current-menu-item a, nav#mainNav ul li li:last-child a:hover, nav#mainNav ul li.current-menu-item li:last-child a:hover {
	background: #f6f6f6 url(../images/subLast.png) no-repeat 20px -65px;
}
nav div.panel {
	float: none;
}
#mainImg {
	margin-bottom: 20px;
}
}


/* 959px以下から 1カラム表示
------------------------------------------------------------*/
@media only screen and (max-width: 959px) {
#wrapper, .inner {
	width: 100%;
}
#header {
	width: 96%;
	padding: 0 2%;
}
.contact {
	padding: 10px 0 10px;
}
nav#mainNav {
	width: 95%;
}
nav#mainNav ul {
	margin: 0 auto;
}
nav#mainNav ul ul {
	padding: 0;
}
nav div.panel {
	float: none;
}
#mainImg img {
	width: 98%;
	height: auto;
}
#content, #sidebar {
	clear: both;
	width: 95%;
	float: none;
	margin: 0 auto;
	padding: 10px 0;
}
.banner {
	width: 100%;
	margin: 0 auto;
	text-align: center;
}
p.banner img {
	width: 100%;
	height: auto;
}
section.widget_search {
	text-align: center;
}
#calendar_wrap table {
	width: 260px;
}
#footer li {
	margin-bottom: 10px;
}
}


/* 幅644px以下から ヘッダー等微調節
------------------------------------------------------------*/
@media only screen and (max-width: 644px) {
	
.accent_img_02 {
	position: absolute;
	top: 20px;
	right: 10px;
	width: 20%;
}
	
#header h2 img{
	width:60%;
}
	
	
nav#mainNav {
	width: 98%;
}
#header {
	text-align: center;
	background-image: none;
}
#header h2, .contact {
	float: none;
}
.contact {
	padding: 0 0 20px;
}
.contact p {
	text-align: center;
}
#headerInfo {
	width: 250px;
	margin: 0 auto;
}
img.alignright, img.alignleft {
	display: block;
	margin: 5px auto;
}
.alignright, .alignleft {
	float: none;
}
table {
	width: 100%;
}

table th {
	display: block;
	text-align: left !important;
	border-right: 1px solid #D4D4D4 !important;
	white-space: normal;
}

table td {
	display: block;
	background-color:#fff;
}

}
