@charset "UTF-8";
/*-----------------------------------------------------------
div
------------------------------------------------------------*/
div {
	text-align: left;
}
/*-----------------------------------------------------------
clearfix
------------------------------------------------------------*/
.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
	line-height: 0;
}
.clearfix {
	display: inline-block;
}
/* exlude MacIE5 \*/
* html .clearfix {
	height: 1%
}
.clearfix {
	display: block;
}
/* end MacIE5 */
/*-----------------------------------------------------------
reset
------------------------------------------------------------*/
img {
	margin: 0;
	padding: 0;
	vertical-align: bottom;
	border: 0;
}
table img {
	margin: 0;
	padding: 0;
	vertical-align: bottom;
	border: 0;
}
p {
	margin: 0;
	padding: 0;
}
ol, ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
input, textarea {
	margin: 0;
	font-size: 100%;
	resize: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
	font-size: 100%;
}
dl, dt, dd, th, td {
	margin: 0;
	padding: 0;
}
h1, h2, h3, h4, h5, h6 {
	font-size: 150%;
	font-weight: normal;
	margin: 0;
	padding: 0;
}
pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, dialog, figure, footer, header, hgroup, menu, nav, section, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}
article, aside, dialog, figure, footer, header, hgroup, nav, section {
	display: block;
}
nav ul {
	list-style: none;
}
/*-----------------------------------------------------------
Link
------------------------------------------------------------*/
a:link {
	color: #444;
	text-decoration: none;
}
a:visited {
	color: #444;
	text-decoration: none;
}
a:hover {
	color: #aaa;
	text-decoration: none;
}
a:active {
	color: #64AB18;
	text-decoration: none;
}
/*-----------------------------------------------------------
margin
------------------------------------------------------------*/
.t0b5 {
	margin: 0 0 5px 0;
	overflow: hidden;
}
.t0b10 {
	margin: 0 0 10px 0;
	overflow: hidden;
}
.t0b15 {
	margin: 0 0 15px 0;
	overflow: hidden;
}
.t0b20 {
	margin: 0 0 20px 0;
	overflow: hidden;
}
.t0b25 {
	margin: 0 0 25px 0;
	overflow: hidden;
}
.t0b30 {
	margin: 0 0 30px 0;
	overflow: hidden;
}
.t0b35 {
	margin: 0 0 35px 0;
	overflow: hidden;
}
.t0b40 {
	margin: 0 0 40px 0;
	overflow: hidden;
}
.t0b45 {
	margin: 0 0 45px 0;
	overflow: hidden;
}
.t0b50 {
	margin: 0 0 50px 0;
	overflow: hidden;
}
.t0b55 {
	margin: 0 0 55px 0;
	overflow: hidden;
}
.t0b60 {
	margin: 0 0 60px 0;
	overflow: hidden;
}
.t0b65 {
	margin: 0 0 65px 0;
	overflow: hidden;
}
.t0b70 {
	margin: 0 0 70px 0;
	overflow: hidden;
}
.t0b75 {
	margin: 0 0 75px 0;
	overflow: hidden;
}
.t0b80 {
	margin: 0 0 80px 0;
	overflow: hidden;
}
.t0b85 {
	margin: 0 0 85px 0;
	overflow: hidden;
}
.t0b90 {
	margin: 0 0 90px 0;
	overflow: hidden;
}
.t0b95 {
	margin: 0 0 95px 0;
	overflow: hidden;
}
.t0b100 {
	margin: 0 0 100px 0;
	overflow: hidden;
}
.t5b0 {
	margin: 5px 0 0 0;
	overflow: hidden;
}
.t5b10 {
	margin: 5px 0 10px 0;
	overflow: hidden;
}
.t5b20 {
	margin: 5px 0 20px 0;
	overflow: hidden;
}
.t5b30 {
	margin: 5px 0 30px 0;
	overflow: hidden;
}
.t5b40 {
	margin: 5px 0 40px 0;
	overflow: hidden;
}
.t5b50 {
	margin: 5px 0 50px 0;
	overflow: hidden;
}
.t10b0 {
	margin: 10px 0 0 0;
	overflow: hidden;
}
.t10b10 {
	margin: 10px 0;
	overflow: hidden;
}
.t10b20 {
	margin: 10px 0 20px 0;
	overflow: hidden;
}
.t10b30 {
	margin: 10px 0 30px 0;
	overflow: hidden;
}
.t10b40 {
	margin: 10px 0 40px 0;
	overflow: hidden;
}
.t10b50 {
	margin: 10px 0 50px 0;
	overflow: hidden;
}
.t20b0 {
	margin: 20px 0 0 0;
	overflow: hidden;
}
.t20b5 {
	margin: 20px 0 5px 0;
	overflow: hidden;
}
.t20b10 {
	margin: 20px 0 10px 0;
	overflow: hidden;
}
.t20b20 {
	margin: 20px 0;
	overflow: hidden;
}
.t20b30 {
	margin: 20px 0 30px 0;
	overflow: hidden;
}
.t20b40 {
	margin: 20px 0 40px 0;
	overflow: hidden;
}
.t30b0 {
	margin: 30px 0 0 0;
	overflow: hidden;
}
.t30b5 {
	margin: 30px 0 5px 0;
	overflow: hidden;
}
.t30b10 {
	margin: 30px 0 10px 0;
	overflow: hidden;
}
.t30b20 {
	margin: 30px 0 20px 0;
	overflow: hidden;
}
.t30b30 {
	margin: 30px 0;
	overflow: hidden;
}
.t30b40 {
	margin: 30px 0 40px 0;
	overflow: hidden;
}
.t30b50 {
	margin: 30px 0 50px 0;
	overflow: hidden;
}
.mt10 {
	margin-top: 10px !important;
}
.mt15 {
	margin-top: 15px !important;
}
.mt20 {
	margin-top: 20px !important;
}
.mt30 {
	margin-top: 80px !important;
}
.mt40 {
	margin-top: 40px !important;
}
.mt50 {
	margin-top: 50px;
}
.mt60 {
	margin-top: 60px !important;
}
.mt70 {
	margin-top: 70px;
}
.mt80 {
	margin-top: 80px;
}
.mt90 {
	margin-top: 90px;
}
.mt100 {
	margin-top: 100px;
}
.mb10 {
	margin-bottom: 10px;
}
.mb20 {
	margin-bottom: 20px;
}
.mb30 {
	margin-bottom: 30px;
}
.mb40 {
	margin-bottom: 40px !important;
}
.mb50 {
	margin-bottom: 50px;
}
.mb60 {
	margin-bottom: 60px;
}
.mb70 {
	margin-bottom: 70px;
}
.mb80 {
	margin-bottom: 80px;
}
.mb90 {
	margin-bottom: 90px;
}
.mb100 {
	margin-bottom: 100px;
}
.mr10 {
	margin-right: 10px;
}
.mr20 {
	margin-right: 20px;
}
.mr30 {
	margin-right: 30px;
}
.mr40 {
	margin-right: 40px;
}
.mr50 {
	margin-right: 50px;
}
.mr60 {
	margin-right: 60px;
}
.mr70 {
	margin-right: 70px;
}
.mr80 {
	margin-right: 80px;
}
.mr90 {
	margin-right: 90px;
}
.mr100 {
	margin-right: 100px;
}
.ml10 {
	margin-left: 10px;
}
.ml20 {
	margin-left: 20px;
}
.ml30 {
	margin-left: 30px;
}
.ml40 {
	margin-left: 40px;
}
.ml50 {
	margin-left: 50px;
}
.ml60 {
	margin-left: 60px;
}
.ml70 {
	margin-left: 70px;
}
.ml80 {
	margin-left: 80px;
}
.ml90 {
	margin-left: 90px;
}
.ml100 {
	margin-left: 100px;
}
/*-----------------------------------------------------------
padding
------------------------------------------------------------*/
.p10b10 {
	padding: 10px 0;
	overflow: hidden;
}
.p20b20 {
	padding: 20px 0;
	overflow: hidden;
}
.p30b30 {
	padding: 30px 0;
	overflow: hidden;
}
.p40b40 {
	padding: 40px 0;
	overflow: hidden;
}
.p50b50 {
	padding: 50px 0;
	overflow: hidden;
}
.p0b10 {
	padding: 0 0 10px 0;
	overflow: hidden;
}
.p0b20 {
	padding: 0 0 20px 0;
	overflow: hidden;
}
.p0b30 {
	padding: 0 0 30px 0;
	overflow: hidden;
}
.p0b40 {
	padding: 0 0 40px 0;
	overflow: hidden;
}
.p0b50 {
	padding: 0 0 50px 0;
	overflow: hidden;
}
/*-----------------------------------------------------------
line height
------------------------------------------------------------*/
.line14 {
	line-height: 14px
}
.line15 {
	line-height: 15px
}
.line16 {
	line-height: 16px
}
.line17 {
	line-height: 17px
}
.line18 {
	line-height: 18px
}
.line19 {
	line-height: 19px
}
.line20 {
	line-height: 20px
}
.line21 {
	line-height: 21px
}
.line22 {
	line-height: 22px
}
.line23 {
	line-height: 23px
}
.line24 {
	line-height: 24px
}
.line25 {
	line-height: 25px
}
.line26 {
	line-height: 26px
}
.line27 {
	line-height: 27px
}
.line28 {
	line-height: 28px
}
.line29 {
	line-height: 29px
}
.line30 {
	line-height: 30px
}
/*-----------------------------------------------------------
FONT Weight
------------------------------------------------------------*/
.fwB {
	font-weight: bold !important;
}
/*-----------------------------------------------------------
FONT Size
------------------------------------------------------------*/
.fz10 {
	font-size: 10px;
}
.fz11 {
	font-size: 11px;
}
.fz12 {
	font-size: 12px;
}
.fz13 {
	font-size: 13px;
}
.fz14 {
	font-size: 14px;
}
.fz15 {
	font-size: 15px;
}
.fz16 {
	font-size: 16px;
}
.fz17 {
	font-size: 17px;
}
.fz18 {
	font-size: 18px;
}
.fz19 {
	font-size: 19px;
}
.fz20 {
	font-size: 20px;
}
.fz21 {
	font-size: 21px;
}
.fz22 {
	font-size: 22px;
}
.fz23 {
	font-size: 23px;
}
.fz24 {
	font-size: 24px;
}
.fz25 {
	font-size: 25px;
}
.fz26 {
	font-size: 26px;
}
.fz27 {
	font-size: 27px;
}
.fz28 {
	font-size: 28px;
}
.fz29 {
	font-size: 29px;
}
.fz30 {
	font-size: 30px;
}
/*-----------------------------------------------------------
FONT family
------------------------------------------------------------*/
.ffN {
	font-family: "メイリオ", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.ffM {
	font-family: "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", serif;
}
/*-----------------------------------------------------------
FLOAT
------------------------------------------------------------*/
.floatL {
	float: left !important;
	display: inline-block;
}
.floatR {
	float: right !important;
	display: inline-block;
	text-align: left;
}
/*-----------------------------------------------------------
Text-Align
------------------------------------------------------------*/
.taL {
	text-align: left  !important;
}
.taC {
	text-align: center !important;
}
.taR {
	text-align: right  !important;
}
/*-----------------------------------------------------------
PAGE BOOT
------------------------------------------------------------*/
/* MovableType */
div#pageBoot {
	margin: 35px 0 60px 0;
	text-align: center;
}
div#pageBoot a {
	color: #aaa;
	text-decoration: none !important;
}
span.current_page {
	color: #FFFFFF;
	padding: 5px;
	border: 1px solid #aaa;
	background-color: #aaa;
}
a.link_page {
	padding: 5px;
	border: 1px solid #aaa !important;
}
a.link_page:hover {
	padding: 5px;
	border: 1px solid #aaa;
	background-color: #aaa;
	color: #FFFFFF !important;
}
/* WordPress */
.wp-pagenavi {
	clear: both;
	text-align: center;
}
.wp-pagenavi a, .wp-pagenavi span {
	text-decoration: none;
	border: 1px solid #BFBFBF;
	padding: 5px 5px;
	margin: 2px;
}
.wp-pagenavi a:hover, .wp-pagenavi span.current {
	border-color: #aaa;
}
.wp-pagenavi span.current {
	font-weight: bold;
	color: #aaa;
}
/*-----------------------------------------------------------
Body
-------------------------------------------------------------*/
body {
	width: 100%;
	margin: 0;
	padding: 0;
	text-align: center;
	line-height: 2.0;
	letter-spacing: 0.3;
	font-family: "メイリオ", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 75%;
	height: 100%;
	min-width: 1000px;
}
/*-----------------------------------------------------------
Header
-------------------------------------------------------------*/
#headerWrap {
	width: 90%;
	margin: 8px auto;
}
.logo {
	float: left;
	width: 50%;
}
.logo a {
	float: left;
}
.logo h1 {
	float: left;
	font-size: 100%;
	width: 45%;
	/*font-weight: bold;*/
	padding-left: 10px;
	padding-top: 5px;
}
.hSection {
	float: right;
	width: 50%;
	padding-top: 20px;
}


html.smallview {
	font-size: 80% !important;
}

html.mediumview {
	font-size: 100% !important;
}

html.largeview {
	font-size: 120% !important;
}

.fontSize {
	background: url(../img/txt_size.png) no-repeat 10px 10px;
	padding: 10px 0 0 45px;
	float: left;
	width: 99px;
    	margin-left: 50px;
}
.fontSize li {
	float: left;
	margin-left: 6px;
}

.fontSize a {
	display: block;
	height: 27px;
	text-indent: -9999em;
	width: 27px;
}

.fontSize li#fontM a {
	background: #fff url(../img/btn_m_on.png) no-repeat center center;
}

html.mediumview .fontSize li#fontM a,
.fontSize li#fontM a:hover {
	background: #000 url(../img/btn_m.png) no-repeat center center !important;
}

.fontSize li#fontS a {
	background: #fff url(../img/btn_s_on.png) no-repeat center center;
}

html.smallview .fontSize li#fontS a,
.fontSize li#fontS a:hover {
	background: #000 url(../img/btn_s.png) no-repeat center center !important;
}

.fontSize li#fontL a {
	background: #fff url(../img/btn_l_on.png) no-repeat center center;
}

html.largeview .fontSize li#fontL a,
.fontSize li#fontL a:hover {
	background: #000 url(../img/btn_l.png) no-repeat center center !important;
}
/*-----------------------------------------------------------
global Navi
-------------------------------------------------------------*/
#gNaviWrap {
	width: 100%;
	margin-top: 25px;
	font-size: 1.2em;
}
/*-----------------------------------------------------------
global Navi
-------------------------------------------------------------*/
#gNavi {
	width: 100%;
	margin: 0 auto;
	text-align: center;
}
#gNavi > li {
	float: left;
	position: relative;
}
#gNavi > li > a {
	height: 36px;
	display: block;
	background: url(../img/90032bg_gNavi.png) 0 0;
}
#gNavi > li:hover > a {
	opacity: 0.7;
}
#gNavi01 > a {background-position: 0 0 !important; width: 150px;}
#gNavi02 > a {background-position: -150px 0 !important; width: 150px;}
#gNavi03 > a {background-position: -300px 0 !important; width: 150px;}
#gNavi04 > a {background-position: -450px 0 !important; width: 150px;}
#gNavi05 > a {background-position: -600px 0 !important; width: 150px;}
#gNavi06 > a {background-position: -750px 0 !important; width: 150px;}
/*-----------------------------------------------------------
 Container/Maincontent
------------------------------------------------------------*/
div#container {
	width: 1000px;
	height: auto;
	padding: 0 30px;
	text-align: center;
	margin: 0 auto 10px auto;
}
div#mainContent {
	width: 700px;
	height: auto;
	margin: 0;
	float: right;
}
/*-----------------------------------------------------------
SubNavi
------------------------------------------------------------*/
#subNavi {
	width: 300px;
	float: left;
}
/*-----------------------------------------------------------
Footer
------------------------------------------------------------*/
#footerWrap {
	width: 100%;
	margin-top: 100px;
	background: #fbf7f5;
	padding: 25px 0 20px;
}
.copyright {
	background: url(../img/bg_dotted.png) repeat center center!important;
	padding: 10px 0;
	text-align: center;
	font-size: 90%;
}
#footerWrap .two_third2 {
	margin: 0;
	float: left;
}
#footerWrap .one_third {
	margin: 0;
	float: right;
	font-size: 120%;
}
.fNavi li:first-child a {
	background: url(../img/footer_bg_line.png) no-repeat 0 center;
	padding-left: 10px;
}
.fNavi li {
	float: left;
	background: url(../img/footer_bg_line.png) no-repeat right center;
	padding: 0 10px;
}
.fNavi li:first-child {
	padding-left: 0;
}
.fNavi li a {
	font-size: 120%;
}

.bgFooter {
	height: 4px;
	background: #00b3e1; /* Old browsers */
	background: -moz-linear-gradient(left,  #00b3e1 0%, #00b2e1 33%, #ff6a6f 34%, #ff6a6f 66%, #90dc49 67%, #90dc49 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, right top, color-stop(0%,#00b3e1), color-stop(33%,#00b2e1), color-stop(34%,#ff6a6f), color-stop(66%,#ff6a6f), color-stop(67%,#90dc49), color-stop(100%,#90dc49)); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(left,  #00b3e1 0%,#00b2e1 33%,#ff6a6f 34%,#ff6a6f 66%,#90dc49 67%,#90dc49 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(left,  #00b3e1 0%,#00b2e1 33%,#ff6a6f 34%,#ff6a6f 66%,#90dc49 67%,#90dc49 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(left,  #00b3e1 0%,#00b2e1 33%,#ff6a6f 34%,#ff6a6f 66%,#90dc49 67%,#90dc49 100%); /* IE10+ */
	background: linear-gradient(to right,  #00b3e1 0%,#00b2e1 33%,#ff6a6f 34%,#ff6a6f 66%,#90dc49 67%,#90dc49 100%); /* W3C */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00b3e1', endColorstr='#90dc49',GradientType=1 ); /* IE6-9 */
}
/*-----------------------------------------------------------
Bread
------------------------------------------------------------*/
#bread {
	max-width:1000px;
	margin:15px auto 50px auto;
	font-size:13px;
}
#bread li {
	float: left;
}
#bread .home {
	padding: 0 10px 0 0;
}
#bread .next {
	background:url(../img/ico_bread.png) no-repeat left center;
	padding: 0 10px 0 20px;
}
#bread a {
	color:#0071bc;
	text-decoration:underline;
}



/* css for sp */
@media only screen and (max-width: 767px) {
	#bread {
		margin:0 0 20px 0;
		padding:0 15px;
		border-top:#262626 1px solid;
		border-bottom:#262626 1px solid;
		color:#191919;
	}
	#bread .home {
		padding:6px 10px 6px 0;
	}
	#bread .next {
		background:url(../img/ico_bread_sp.png) no-repeat left center;
		background-size:14px 33px;
		padding:6px 10px 6px 25px;
		text-decoration:none;
	}
	#bread a {
		color:#191919;
		text-decoration:none;
	}
}

.pageTop {
	bottom: 28%;
	position: fixed;
	right: 0;
	z-index: 110;
	display: none;
}





/* =========================
   header 上部の横並び・潜り込み防止（HTML変更なし）
   ========================= */

/* 1) 行を flex 化して中央の空白をなくし、常に1行で並べる */
#headerWrap .hSection{
  display:flex;
  align-items:center;
  justify-content:flex-end; /* 右寄せで空白をつくらない */
  gap:14px;
  flex-wrap:nowrap;         /* 折り返さない＝下に潜らない */
}

/* 2) .fontSize 側の旧 float / 余白を無効化して、縮み過ぎないように最低幅も確保 */
#headerWrap .hSection .fontSize{
  display:flex;             /* li を素直に横並び */
  gap:6px;
  list-style:none;
  margin:0 !important;      /* 既存の margin-left:50px を打ち消し */
  padding:10px 0 0 45px;    /* 既存のアイコン分の左パディングは維持 */
  float:none !important;    /* 旧レイアウトを無効化 */
  min-width:120px;          /* 潰れて見えなくなるのを防止 */
  flex:0 1 auto;            /* 多少は縮むが消えない */
  position:relative; 
  z-index:1;                /* 念のため前面に */
}

/* 3) li の旧 float を無効化（flex で十分） */
#headerWrap .hSection .fontSize li{ float:none; }

/* 4) clearfix のダミー生成を止める（flexでは不要） */
#headerWrap .hSection .fontSize.clearfix:after{ content:none; }

/* 5) 右側2ボタンはサイズ・位置を変えない（縮ませない） */
#headerWrap .hSection p{
  margin:0;
  flex:0 0 auto;            /* ここが shrink すると重なりや潜りの原因になる */
}

/* 6) A4以下でも“潜らない”余白調整だけ（サイズは触らない） */
@media (max-width:1030px){
  /* 行の左右余白を少し詰めるだけ。ボタンの大きさは変更しない */
  #headerWrap .hSection{ gap:10px; }

  /* 行に収まる“横幅”を確保：PCヘッダーの右カラムを少し広くする */
  #headerWrap .logo{     width:44% !important;
                         padding-top: 20px; }  /* 左ロゴ側を少しだけ狭める */  
  #headerWrap .hSection{ width:46% !important; }  /* 右カラムを広げて潜り込み回避 */
}


/* ▼ 寄付バナー画像を左右センターに（HTML変更なし） */
.container.topContent03 .innerWrap.topContent01 .one_half.floatL{
  float: none !important;     /* 左2カラム化を解除 */
  width: 100% !important;     /* 親を全幅化して中央寄せ可能に */
  text-align: center;         /* 中身を中央寄せ */
}
.container.topContent03 .innerWrap.topContent01 .one_half.floatL a,
.container.topContent03 .innerWrap.topContent01 .one_half.floatL img{
  display: inline-block;      /* 中央寄せのための行内ブロック化 */
  vertical-align: middle;
}

/* ==============================
   ロゴ位置調整（1030px以上でも余白を確保）
   ============================== */
@media (min-width:1030px) {
  .logo {
    padding-top: 20px !important;
  }
}

/* ==============================
   グローバルメニュー中央寄せ
   ============================== */
#gNavi {
  display: flex;
  justify-content: center;  /* 横中央揃え */
  gap: 10px;                /* 項目間の余白 */
  padding: 0;
  margin: 0 auto;
  list-style: none;
}
#gNavi > li {
  float: none;              /* 旧floatを無効化 */
}

/* ==============================
   グローバルメニュー文字色
   ============================== */
#gNavi a {
  color: #4064b8 !important;
  text-decoration: none;
}
#gNavi a:hover {
  opacity: 0.7;  /* 既存のhover演出を活かす */
}

/* スマホ用メニュー初期状態を非表示にする */
#menusubSp {
  display: none;
}

/* ▼ 通常（閉じているとき）のアイコン */
#menumainSp {
  background: url("../img/arrow_down.png") no-repeat right center;
  background-size: 16px auto; /* アイコンサイズ調整 */
  cursor: pointer;
  padding-right: 20px; /* アイコン分の余白 */
}

/* ▲ 開いているときのアイコン */
#menumainSp.menumainon {
  background: url("../img/arrow_up.png") no-repeat right center;
  background-size: 16px auto;
}

