@charset "utf-8";
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
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, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, figure {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 1em;
}
body, table, input, textarea, select, option {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 1em;
}
article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary {
	display: block;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
:focus {
	outline: 0;
}
ins {
	text-decoration: none;
}
del {
	text-decoration: line-through;
}
img {
	vertical-align: top;
	max-width: 100%;
	height: auto;
	width: auto\9; /* ie8 */
}
table {
	border-collapse: collapse;
}
a, a:link {
	color: #3d9bde;
	text-decoration: none;
}
a:visited {
	color: #3d9bde;
}
a:hover {
	color: #3d9bde;
	text-decoration: underline;
}
a:active {
	color: #3d9bde;
}
a:hover img {
	filter: alpha(opacity=70);
	-moz-opacity: 0.7;
	opacity: 0.7;
}
/*------------------------------------------------------------
	PC/スマホ共通
------------------------------------------------------------*/

/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/

body {
	color: #333;
	font-size: 14px;
	line-height: 1.5;
	background: url(../img/common/bg_header.jpg) repeat-x left top;
	-webkit-text-size-adjust: none;
	padding: 11px 0 0;
}
#wrapper {
	position: relative;
	background: url(../img/common/bg_body.png) repeat left top;
	z-index: 0;
}
/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/
header {
	box-shadow: 0px 0px 5px rgba(0,0,0,0.2);
	padding-top: 0.294%;
	border-bottom: 1px solid #fff;
	background: url(../img/common/bg_header.jpg) repeat-x left top #FFF;
	position: fixed;
    z-index: 9999;
    width: 100%;
	top: 0;
}
/*------------------------------------------------------------
	breadcrumbs
------------------------------------------------------------*/


.breadcrumbs {
	background: #6db5e8;
	color: #287ab6;
	padding: 10px 0;
	overflow: hidden;
	box-shadow: 0px 0px 5px rgba(0,0,0,0.2) inset;
	font-size: 10px;
}
.breadcrumbs .inner {
	max-width: 1000px;
	margin: 0 auto;
}
.breadcrumbs a {
	background: #6db5e8;
	color: #fff;
}
/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/


footer {
	background: url(../img/common/bg_footer.png) repeat left top;
	box-shadow: 0px 0px 5px rgba(77,158,219,1) inset;
	overflow: hidden;
	clear: both;
}
footer a {
}
footer a:hover {
	text-decoration: underline;
}
footer .footer_info {
	color: #fff;
	font-size: 16px;
	overflow: hidden;
	border-bottom: 1px solid #115b99;
}
footer .f_navi {
	overflow: hidden;
}
footer .f_navi li {
	float: left;
	font-size: 13px;
	font-weight: bold;
	margin: 0 10px 0 0;
}
footer .f_navi li a {
	text-shadow: 2px -2px 1px rgba(76,157,217,1);
	color: #fff;
	padding: 0 0 0 16px;
	background: url(../img/common/icon_arrow02.png) no-repeat left center;
}
footer #map img {
	max-width: inherit;
	height: auto;
}
footer .copyright {
	text-align: right;
	clear: both;
	color: #fff;
	font-size: 12px;
	border-top: 1px solid #578bb7;
	padding: 6px 0 0;
	background: url(../img/common/bg_copy.png) repeat left top;
}
/*------------------------------------------------------------
	各ページ共通パーツ
------------------------------------------------------------*/

.conts_wrap a, .conts_wrap a:link {
	text-decoration: underline;
}
.conts_wrap a:hover {
	text-decoration: none;
}
.fl, .alignleft {
	float: left;
}
.fr, .alignright {
	float: right;
}
.conts_wrap {
	margin: 0 0 20px;
	overflow: hidden;
	clear: both;
}
.conts_wrap .inner {
	overflow: hidden;
}
.wrap_box {
	box-shadow: 0 0 2px rgba(232, 224, 203, 1);
	padding: 20px 5.03%;
	overflow: hidden;
	margin: 0 2px 20px;
	background: #fff;
}
/* 方眼紙 */

.wrap_box02 {
	background: #f4f2e8;
	overflow: hidden;
	margin: 2px 0 20px;
	box-shadow: -2px 2px 2px rgba(230,230,230,1);
}
.wrap_box02 .hole_wrap {
	background: #f4f2e8 url(../img/index/bg_voice01.png) repeat-x left top;
}
.wrap_box02 .glid_wrap {
	background: #f4f2e8 url(../img/index/bg_voice02.png) repeat left top;
	overflow: hidden;
	border-bottom: 1px solid #ebe8d8;
}
/* 方眼紙PC */

.wrap_box02 {
	padding: 12px 13px 2px;
}
.wrap_box02 .hole_wrap {
	padding: 20px 2px 10px;
}
.wrap_box02 .glid_wrap {
	padding: 18px 14px;
}
.conts_wrap p {
	margin: 0 0 1em;
}
.btn, .photo {
	text-align: center;
}
.att {
	color: #e40000;
	font-weight: normal;
}
#main .conts_wrap .ttl_lv01 {
	background: url(../img/common/icon_ttl_01.png) no-repeat 10px center #fff;
	padding: 15px 15px 13px 40px;
	font-size: 18px;
	font-weight: 800;
	box-shadow: 0px 0px 2px rgba(232,224,203,1);
	margin: 2px 2px 13px;
	position: relative;
	border-bottom: 2px solid #6eb4e7;
}
#main .conts_wrap .ttl_lv01 span.r_txt {
	color: #6db5e8;
	position: absolute;
	font-size: 60%;
	right: 2%;
	top: 40%;
	font-weight: normal;
}
#main .conts_wrap .ttl_lv01 span.btn01 {
	position: absolute;
	right: 2%;
}
#main figure {
	margin: 0 0 1em;
	width: 100%;
	box-sizing: border-box;
	padding: 0px;
}
#main figure img {
	width: 100%;
	height: auto;
	box-sizing: border-box;
}
.btn01 {
	text-align: right;
}
.conts_wrap .btn01 a {
	color: #fff;
	background: url(../img/common/bg_btn.png) repeat left top;
	padding: 3px 8px 3px 14px;
	margin: 0 auto 0 auto;
	border-radius: 20px;
	right: 0;
	font-size: 11px;
	text-decoration: none;
	display: inline-block;
}
.btn01 a:hover, .btn02:hover {
	filter: alpha(opacity=70);
	-moz-opacity: 0.7;
	opacity: 0.7;
}
.btn01 a span {
	background: url(../img/common/icon_arrow01.png) no-repeat right center;
	padding: 0 20px 0 0;
	color: #fff;
	display: block;
	text-shadow: 1px -1px 1px rgba(0,0,0,.3);
}
.truncate_more_link {
	text-align: right;
}
.conts_wrap .truncate_more_link {
	color: #fff;
	background: url(../img/common/btn_more.png) no-repeat left top;
	padding-top: 4px;
	text-align: center;
	right: 0;
	font-size: 11px;
	display: inline-block;
	text-decoration: none!important;
	width: 102px;
	height: 23px;
	float: right;
	clear: both;
}
.truncate_more_link a:hover, .truncate_more_link:hover {
	filter: alpha(opacity=70);
	-moz-opacity: 0.7;
	opacity: 0.7;
}
.btn02 {
	position: relative;
	font-size: 14px;
	color: #ffffff;
	padding: 7px 10px;
	background: url(../img/common/bg_btn02.png) repeat left top #f3999f;
	border-radius: 5px;
	border: 1px solid #f6bbbf;
	margin: 5px !important;
	box-shadow: 1px 1px 0px 1px rgba(240,138,145,1), -1px -1px 0px 1px rgba(240,138,145,1);
}
.btn02 a {
	text-decoration: none !important;
	color: #fff;
	text-shadow: 1px -1px 0px rgba(204,66,77,0.5), 0px 1px 0px rgba(255,255,255,0.3);
	background: url(../img/beginners/icon_arrow02.png) no-repeat left center;
	padding: 0 30px 0 10px;
	display: inline-block;
}
.btn02 a:after {
	content: "";
	display: inline-block;
	background: url(../img/beginners/icon_acrobat.png) no-repeat left top;
	width: 26px;
	position: absolute;
	top: 0%;
	right: 10px;
	margin: 3px;
	height: 26px;
}
#main .conts_wrap .border_box {
	border: 6px solid #9bd1f8;
}
#main .conts_wrap .border_box .inner {
	background: #fff;
	padding: 10px;
	box-shadow: 0px 0px 6px rgba(103,172,220,1);
	overflow: scroll;
	height: 300px;
}
#main .conts_wrap .border_box .news {
	background: #fff;
	padding: 10px;
	box-shadow: 0px 0px 6px rgba(103,172,220,1);
	overflow: scroll;
	height: 332px;
}
.ttl_lv01 .btn01 {
	display: none;
}
 @media screen and (min-width: 681px) {
/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/

#container {
	margin: 160px auto 0;
	max-width: 1000px;
	overflow: hidden;
}
#main {
	float: right;
	/* [disabled]overflow: hidden;
*/
	width: 76%;
}
/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/

header .inner {
	max-width: 1000px;
	padding: 4px 0 0;
	margin: 0 auto;
	overflow: hidden;
}
.h_logo {
	float: left;
	width: 39%;
	margin: 20px 0 17px 0;
}
.h_info {
	float: right;
	font-size: 12px;
	width: 51%;
}
/*------------------------------------------------------------
	gNavi
------------------------------------------------------------*/
header .g_navi {
	padding: 3px 0 0 0px;
	overflow: hidden;
	clear: both;
}
header .g_navi ul {
	overflow: hidden;
	display: flex;
	flex-wrap: wrap;
}
header .g_navi ul li {
	/*float: left;*/
	box-sizing: border-box;/*margin: 0 0 0 0.2%;*/
}
header .g_navi ul li a {
	display: block;
	margin: 0 0 8px;
}
header .g_navi ul li a span {
	display: block;
	border-left: dotted 1px #cbcbcb;
	text-align: center;
	box-sizing: border-box;
}
/* 24.08.07 globalnavi width-hidden  */
/*header .g_navi ul li.nav01 {
	width: 7.7%;
}
header .g_navi ul li.nav02 {
	width: 9.4%;
}
.g_navi ul li.nav03 {
	width: 9.8%;
}*/
.g_navi ul li.nav04 {
		border-bottom: 3px solid #6eb4e7;
		/*width:19.2%;*/
}
.g_navi ul li.nav05 {
		border-bottom: 3px solid #6eb4e7;
		/*width:19.6%;*/
}
.g_navi ul li.nav06 {
	border-bottom: 3px solid #6eb4e7;
	/*width:22.6%;*/
}

header .g_navi ul li.nav07 {
	border-bottom: 3px solid #6eb4e7;
	/*width:11.4%;*/
}

header .g_navi ul li.nav01 img {
/* width: 88.1%; */
}
header .g_navi ul li.nav02 img, .g_navi ul li.nav03 img {
/*width: 46.38%; */
}
header .g_navi ul li.nav04 img, .g_navi ul li.nav05 img {
/*width: 76.82%; */
}
header .g_navi ul li.nav06 img {
/*width: 54.79%; */
}
header .g_navi ul li a span {
	display: block;
}
header .g_navi ul li:last-child span {
	margin: 0;
	border-right: dotted 1px #cbcbcb;
}
header .u_navi {
	overflow: hidden;
	width: 410px;
	float: right;
	margin: 15px 0 0;
}
header .u_navi li {
	float: right;
	margin: 0 0 6px 7px;
}
header .inner .h_info .list, header div.sp_navi {
	display: none;
}
/*------------------------------------------------------------
	sub
------------------------------------------------------------*/
#sub {
	float: left;
	width: 22%;
}
#sub .sub_info {
	box-shadow: 0px 0px 2px rgba(203,203,203,.8);
	padding: 15px 13px 12px;
	background: #fff;
	margin: 3px 3px 13px;
}
#sub .btn_navi li {
	margin: 0 0 5px;
}
/*------------------------------------------------------------
	pagenavi
------------------------------------------------------------*/



.wp-pagenavi {
	text-align: center;
	clear: both;
	font-size: 16px;
	margin: 0 0 17px;
	overflow: hidden;
}
.wp-pagenavi a, .wp-pagenavi span {
	margin: 2px;
	padding: 8px 12px;
	text-decoration: none;
	background: none repeat scroll 0 0 #ccf5ff;
	display: inline-block;
	border: 5px solid #E6FAFF;
	border-radius: 5px;
}
.wp-pagenavi a:hover, .wp-pagenavi span.current {
	border: 5px solid #E6FAFF;
	background: #ff8300;
	color: #fff;
}
.wp-pagenavi span.current {
	font-weight: bold;
}
/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/

footer .inner {
	max-width: 1000px;
	margin: 0 auto;
	padding: 12px 0px;
}
footer .f_info {
	float: left;
	margin: 0 0 20px;
	overflow: hidden;
}
footer .footer_info .s_flogo {
	display: none;
}
footer .f_info .address {
	text-shadow: 2px -2px 1px rgba(76,157,217,1);
	margin: 30px 0 30px 20px;
	font-size: 15px;
}
footer #map {
	background: #999;
	width: 390px;
	height: 200px;
	border: 3px solid #fff;
	color: #000;
	border-radius: 5px;
	float: right;
	margin: 30px 0 20px;
}
/* 上へ戻る */
.page_top {
	position: fixed;
	right: 10%;
	padding: 0 0 10px 0;
}
#main .u_navi {
	display: none;
}
.pc_img {
	display: none;
}
}
/* ▼表示領域が680px未満の場合 */
@media screen and (max-width: 680px) {
/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body {
	color: #333;
	font-size: 14px;
	line-height: 1.5;
	background: url(../img/common/bg_header.jpg) repeat-x left top;
	-webkit-text-size-adjust: none;
	padding: 11px 0 0;
}
#wrapper {
	position: relative;
	background: url(../img/common/bg_body.png) repeat left top;
}
#container {
	margin: 54px auto 0;
	max-width: 1000px;
}
#main {
	padding: 0 2.94% 0px;
	overflow: hidden;
}
/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/

header .inner {
	padding: 4px 0 0;
	margin: 0 auto;
	overflow: hidden;
}
.h_logo {
	float: left;
	width: 78.125%;
	margin: 17px 0;
}
.h_info {
	float: right;
	font-size: 12px;
	width: 20%;
	margin-right: 5px;
}
/*------------------------------------------------------------
	gNavi
------------------------------------------------------------*/


header .inner .h_info .u_navi, header .g_navi .pc_navi ul {
	display: none;
}
header .inner .h_info .list {
	width: 78.125%;
	margin: 17px 0;
	float: right;
}
header div.sp_navi {
	position: fixed;
	left: 0;
	top: 0px;
	z-index: 1000;
	width: 100%;
	height: 100%;
	display: none;
	padding: 0;
	background: rgba(253,251,246, 1);
	overflow: scroll;
}
header div.sp_navi .floatingBlk {
	/*position: absolute;*/
	width: 100%;
	margin-top: calc(1px * 1vh );
}
header div.sp_navi ul {
	margin: 40px 20px 15px;
}
header div.sp_navi li {
	text-align: center;
	box-shadow: 0px 0px 3px rgba(232,224,203,1);
	margin: 0 0 8px;
}
header div.sp_navi p.clsGnList {
	width: 160px;
	margin: 0 auto 150px!important;
	box-shadow: 0px 0px 3px rgba(232,224,203,1);
	text-align: center;
}
header div.sp_navi p.clsGnList a {
	display: block;
}
/*------------------------------------------------------------
	sub
------------------------------------------------------------*/
#sub {
	display: none;
}
/*------------------------------------------------------------
	breadcrumbs
------------------------------------------------------------*/


.breadcrumbs .inner {
	padding: 0 2.94% 0px;
}
/*------------------------------------------------------------
	pagenavi
------------------------------------------------------------*/



.wp-pagenavi {
	text-align: center;
	clear: both;
	font-size: 16px;
	margin: 0 0 17px;
	overflow: hidden;
}
.wp-pagenavi a, .wp-pagenavi span {
	margin: 2px;
	padding: 8px 12px;
	text-decoration: none;
	background: none repeat scroll 0 0 #ccf5ff;
	display: inline-block;
	border: 5px solid #E6FAFF;
	border-radius: 5px;
}
.wp-pagenavi a:hover, .wp-pagenavi span.current {
	border: 5px solid #E6FAFF;
	background: #ff8300;
	color: #fff;
}
.wp-pagenavi span.current {
	font-weight: bold;
}
/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/

footer .inner {
	margin: 0 auto;
	padding: 12px 2.94%;
}
footer .f_info {
	margin: 0 0 20px;
	overflow: hidden;
}
footer .footer_info .s_flogo {
	margin: 0 auto 1em;
}
/*footer .f_navi {
	display: none;
}*/
footer .f_info .address {
	text-shadow: 2px -2px 1px rgba(76,157,217,1);
	margin: 10px 0 0 20px;
	font-size: 15px;
}
footer #map {
	background: #999;
	/* width: 100% !important; 
	height: auto !important; */
	border: 3px solid #fff;
	color: #000;
	/* min-width: 320px; */
	min-height: 300px;
	border-radius: 5px;
	margin: 30px 10px 20px;
}
/* 上へ戻る */
.page_top img {
	display: none;
}
/*------------------------------------------------------------
	各ページ共通パーツ
------------------------------------------------------------*/


#main .u_navi {
	text-align: center;
	overflow: hidden;
	margin: 15px auto 30px;
}
#main .u_navi li {
	display: inline-block;
	padding: 0 1%;
	box-sizing: border-box;
}
#main .u_navi li.contact {
	width: 49.84%;
}
#main .u_navi li.request {
	width: 42.03%;
}
#main .u_navi li.tel {
	width: 70.63%;
}
.ttl_lv01 .pc_txt {
	display: none;
}
.pc_img {
	display: inherit;
}
.img_none {
	display: none;
}

.news_text{
	display: inline-block;
}

}
/*------------------------------------------------------------
	追加
------------------------------------------------------------*/
.nav10 a span img, .nav11 a span img{
	width:100%
}
.inner.full_box{
	height: auto !important;
	overflow: auto !important;
}

/* お問い合わせフォーム */
@media screen and (max-width: 680px){
	.table_form th{
		width: 100% !important;
		box-sizing: border-box;
	}
	.table_form td{
		width: 100% !important;
		box-sizing: border-box;
    	padding: 15px 10px !important;
	}
}
@media all and (-ms-high-contrast: none){
	.table_form{
		table-layout: fixed;
	}
	.table_form td input,
	.table_form td textarea{
		max-width: 100%;
	}
}