@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,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
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: 12px verdana,"ヒラギノ丸ゴ ProN W4","Hiragino Maru Gothic ProN","メイリオ","Meiryo","ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
    line-height: 1.5;
    border-top: 5px solid #08913D;
    background: #fff;
    -webkit-text-size-adjust: none;
}
html { background: #08913D }
/***************************************
/* リンク設定
***************************************/
a {
    color: #08913D;
    text-decoration: none;
}
a:hover { color: #003300 }
a:active,
a:focus { outline: 0 }

/***************************************
/* 全体
***************************************/
#wrapper {
    margin: 0 auto;
    padding: 0 1%;
    width: 98%;
    position: relative;
}
.inner {
    margin: 0 auto;
    width: 100%;
}
.min_height{
	min-height:450px;
}
/***************************************
/* ヘッダー
***************************************/
#header {
    margin-top: -5px;
    overflow: hidden;
}
* html #header { height: 1% }

/***************************************
/* ロゴ
***************************************/
#header .logo {
    float: left;
    padding: 20px 0 0;
		text-align:center;
		width:89%;
}

#header .vl {
		width:78%;
}
.logo a {
    font-size: 20px;
    font-weight: bold;
    line-height: 1;
}
.logo span {
    font-size: 12px;
    font-weight: normal;
}
#header h1 {
    font-size: 14px;
		text-align:center;
    color: #444;
}

/***************************************
/* メイン画像（トップページ+サブページ）
***************************************/
#mainBanner {
    margin: 0 auto 30px;
    padding: 0;
    width: 100%;
    line-height: 0;
    border-top: 3px solid #08913D;
    border-bottom: 3px solid #08913D;
}
#mainBanner .inner { position: relative }
#mainBanner img {
    max-width: 100%;
    height: auto;
}
.slogan {
    position: absolute;
    max-width: 100%;
    height: auto;
    bottom: 0;
    left: 0;
    padding: 5px 10px;
    line-height: 1.4;
    z-index: 100;
}
.slogan p {
    padding-bottom: 5px;
    color: #333;
    font-size: 14px;
		width:50%;
}
/* サブページ スローガン*/
.subImg .slogan {
    left: auto;
    right: 0;
}

/***************************************
/* グリッド
***************************************/
.gridWrapper {
    padding-bottom: 20px;
    overflow: hidden;
}
* html .gridWrapper { height: 1% }
.grid { float: left }
.grid h3 {
    padding: 3px 0;
    margin-bottom: 5px;
    font-weight: bold;
    border-top: 1px solid #08913D;
    border-bottom: 1px solid #08913D;
}
.grid p { padding: 5px 0 }
.grid p.img {
    float: left;
    margin: 3px 5px 0 0;
}

.grid2 {
 float: left;
 width: 45%;
}

.readmore { clear: both }
.readmore a {
    padding: 3px 5px;
    border-radius: 3px;
    color: #fff;
    background: #08913D;
}
.readmore a:hover { background: #789632 }
/***************************************
/* リンク設定
***************************************/
#footer .grid {
    color: #fff;
    border: 0;
    background: transparent;
}
#footer .grid p { padding: 0 }

/***************************************
/* メイン コンテンツ
***************************************/
section.content {
    padding: 10px 0;
    margin-bottom: 20px;
    border-radius: 6px;
    overflow: hidden;
    font-size: 115%;/*14px;*/
}
* html section.content { height: 1% }
section.content p { margin-bottom: 2px }
h3.heading {
  position: relative;
  padding: .25em 0 .5em .75em;
  border-left: 6px solid #08913D;
	font-size:20px;
}
h3.heading::after {
  position: absolute;
  left: 0;
  bottom: 0;
  content: '';
  width: 100%;
  height: 0;
  border-bottom: 1px solid #ccc;
}
/*
h3.heading {
    padding: 3px 5px;
    margin-left: 10px;
    font-size: 16px;
    border-bottom: 2px solid #08913D;
		color: #08913D;
		text-shadow: 0 0 5px white;
		border-left: solid 7px #08913D;
}
*/
h3.f_20{font-size: 20px;}
section.content img {
    max-width: 90%;
    height: auto;
}
.tnews{ padding:5px 0;}
section.content #gallery .grid img { max-width: 212px }
img.frame,
#gallery img {
    border: 1px solid #789632;
    background: #08913D;
    padding: 3px;
}
#gallery .grid { margin-bottom: 10px }
.alignleft {
    float: left;
    clear: left;
    margin: 3px 10px 10px 0;
}
.alignright {
    float: right;
    clear: right;
    margin: 3px 0 10px 10px;
}

/***************************************
/* テーブル
***************************************/
.table-style01{
	margin:15px 0;
	border-top:1px solid #000;
	border-right:1px solid #000;
	width:100%;
	
}
.table-style01 th, .table-style01 td{
	padding:15px;
	border-bottom:1px solid #000;
	border-left:1px solid #000;
}
.table-style01 th {
	background-color:#f4f4f4;
	width:25%;
}
.table-style01 td {
	width:25%;
}
.table-style01 .td_img {
	text-align:center;
}
.table-style01 .f1{
	font-size:120%;
	font-weight:700;
}
/***************************************
/* ボランティア一覧
***************************************/
#v_table{
	width: 100%;
	border-collapse: collapse;
	padding-top:10px;
	margin-top:15px;
}
#v_table td,
#v_table th
{
	padding: 5px;
	border: 1px solid #333;
}
#v_table th{
	font-weight: bold;
}
#v_table thead th{
	background:#e6e6e6;
}
#v_table th.th1{
	width: 30%;
}
#v_table th.th2{
	width: 70%;
}

.clear{
	clear:both;
}
/***************************************
/* フッター
***************************************/
#footer {
    clear: both;
    padding: 20px 0;
    background: #08913D;
}
#footer .copyright { font-size: 14px;color: #fff }

/***************************************
/*検索条件
***************************************/
#seek{
	text-align:left;
	padding:10px 10px 10px 30px;
	border:1px solid #333;
	background: #F0FECF url(../images/seek_back.png) no-repeat;
	background-position: bottom right;
}

.gp{float:left; padding-right:10px;}

/***************************************
/* ページナビゲーション 
***************************************/
div.pagination{
	padding:0;
	margin: 10px auto;
}

div.pagination a:link{text-decoration:none;color:#4D9420;}
div.pagination a:visited{text-decoration:none;color:#4D9420;}
div.pagination a:active{text-decoration:none;color:#4D9420;}
div.pagination a:hover{text-decoration:none;color:#4D9420;}

div.pagination ul {
	float:right;
	margin: 0;
	padding: 0;
	list-style-type: none;
	text-align:center;
}

div.pagination ul li {
	float:left;
	margin-right: 5px;
	padding: 8px;
	border: 1px #CCCCCC solid;
	background-color:#FFFFFF;
	color:#4D9420;
	text-align:center
}
div.pagination ul li.count {
	border:none;
	color:#000000;
}

div.pagination ul li.currentpage {
	background-color:#4D9420;
	color:#FFFFFF;
}
div.pagination ul li.nextpage {
}
div.pagination ul li.arr {
}
div.pagination ul li:hover
{
	border-color:#4D9420;
} 
div.pagination ul li.currentpage:hover
{
	border-color:#CCCCCC;
}
p.p1{
	line-height:1.5;
}

p.p2{
line-height:2.5;
}
#fsize {
    margin: 5px 0 0 0;
    float: right;
}
#fsize ul {
    display: block;
    list-style: none;
}
#fsize li {
    display: block;
    float: left;
    padding-right: 3px;
		vertical-align:top;
}
span.memo{
	font-size:80%;
	padding-left:20px;
}
.text-right{text-align:right;}
.text-center{text-align:center;}
.text-left{text-align:left;}
img.e_img{max-width:100%;}

@media only screen and (max-height:700px) { 
	.min_height{
		min-height:auto;
	}
}
/***************************************
/* PC用 
***************************************/
@media only screen and (min-width:960px) { 
	#wrapper,
	.inner {
	    width: 940px;
	    padding: 0;
	}
	#wrapper { padding-bottom: 20px }
	nav div.panel {
	    display: block !important;
	    float: right;
	}
	a#menu { display: none }
	nav#mainNav ul {
	    float: right;
	    overflow: hidden;
	}
	* html nav#mainNav ul { height: 1% }
	nav#mainNav ul li {
	    float: left;
	    text-align: center;
	}
	nav#mainNav ul a {
	    font-size: 13px;
	    display: block;
	    padding: 25px 10px 15px;
	    line-height: 1.2;
	    border-top: 5px solid #08913D;
	}
	nav#mainNav ul span {
	    font-size: 10px;
	    color: #a5a5a5;
	}
	nav#mainNav ul li.active a,
	nav#mainNav ul a:hover {
	    background: #F1FEF2;
	    border-color: #789632;
	    color: #789632;
	}
	.slogan { top: 100px }
	.subImg .slogan {
	    left: auto;
	    right: 0;
	    top: 70px;
	}
	/* グリッド全体 */
	.gridWrapper {
	    width: 960px;
	    margin: 0 0 0 -20px;
	}
	/* グリッド共通 ベース:トップページ4カラム */
	.grid {
	    float: left;
	    width: 220px;
	    margin-left: 20px;
	}
	#header{border-bottom:1px solid #08913D;}
}

/***************************************
/* モニター幅940px以下 
***************************************/
@media only screen and (max-width:940px) { 
	* {
	    -webkit-box-sizing: border-box;
	    -moz-box-sizing: border-box;
	    -o-box-sizing: border-box;
	    -ms-box-sizing: border-box;
	    box-sizing: border-box;
	}
	
	#header { padding: 10px 0 }
	#header .logo,
	#footer .logo {
	    float: none;
	    text-align: center;
	    padding: 10px 5px;
	}
	nav#mainNav {
	    clear: both;
	    width: 100%;
	    margin: 0 auto;
	    padding: 0;
			background-color:#08913D;
	    background: -webkit-gradient(linear, left top, left bottom, color-stop(1, #08913D), color-stop(0.00, #789632));
	    background: -webkit-linear-gradient(top, #789632 0%, #08913D 100%);
	    background: -moz-linear-gradient(top, #789632 0%, #08913D 100%);
	    background: -o-linear-gradient(top, #789632 0%, #08913D 100%);
	    background: -ms-linear-gradient(top, #789632 0%, #08913D 100%);
	    background: linear-gradient(top, #789632 0%, #08913D 100%);
	}
	nav#mainNav a.menu {
	    width: 100%;
	    display: block;
	    height: 40px;
	    line-height: 40px;
	    font-weight: bold;
	    text-align: left;
	    color: #fff;
	}
	nav#mainNav a#menu span { padding-left: 10px }
	nav#mainNav a.menu span:before { content: "→ " }
	nav#mainNav a.menuOpen span:before { content: "↓ " }
	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 li {
	    float: none;
	    clear: both;
	    width: 100%;
	    height: auto;
	    line-height: 1.2;
	}
	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 #fff;
	    color: #fff;
	    background: #08913D;
	}
	nav#mainNav ul li a span { padding-left: 10px }
	nav#mainNav ul li:first-child a { border-top: 1px dashed #fff }
	nav#mainNav ul li:last-child a { border: 0 }
	nav#mainNav ul li.active a,
	nav#mainNav ul li a:hover { background: #789632 }
	nav div.panel { float: none }
	.grid {
	    float: left;
	    width: 48%;
	    margin: 10px 2% 0 0;
	}
	#footer .grid,
	#footer .grid p {
	    float: none;
	    width: 100%;
	    text-align: center;
	    border: 0;
	}
	#footer .grid:last-child { padding-top: 20px }
	
	img.v_img{
	    width: 90%;
	    height: auto;
	}
/* 2015/01/07
	#fsize{
		display:none;
	}
*/
}

/***************************************
/* iPad 縦
***************************************/
@media only screen and (max-width:768px) { 
	#header { padding-bottom: 0 }
	#header h1 { text-align: center }
	#header .logo {
	    float: none;
	    text-align: center;
	    padding: 10px 5px 20px;
	}
}

/***************************************
/* スマートフォン 横(ランドスケープ) 
***************************************/
@media only screen and (max-width:640px) { 
	#footer .grid p { text-align: center }
	.grid img {
	    float: none;
	    margin: 0 auto;
	}
	.grid p,
	#sub .grid li { text-align: left }
	.alignleft,
	.alignright {
	    float: none;
	    display: block;
	    margin: 0 auto 10px;
	}
/*
	.table-style01 th {
		width:auto;
	}
	.table-style01 th, .table-style01 td{
		display:block;
	}
	.table-style01 td.td_img img{
		width:100%;
	}
*/
/*ボランティア一覧*/
	#v_table{
		display: block;
	}
	#v_table thead{
		display: none;
	}
	#v_table tbody{
		display: block;
	}
	#v_table tbody tr{
		display: block;
		margin-bottom: 1.5em;
	}
	#v_table tbody th,
	#v_table tbody td{
		display: list-item;
		border: none;
	}
	#v_table tbody th{
		margin-bottom: 5px;
		list-style-type: none;
		color: #fff;
		background: #95CD22;
	}
	#v_table tbody th a{
		color: #fff;
	}
	
	#v_table tbody td{
		margin-left: 20px;
		padding: 0;
		list-style-type: none;
	}
	#v_table tbody td:nth-of-type(1):before { content: "【概要】 "; }
	
	.gp{ float:none;}
}

/***************************************
/* スマートフォン 縦(ポートレート)
***************************************/
@media only screen and (max-width:480px) { 
	#mainBanner { margin-left: 1px }
	#mainBanner h2,
	#mainBanner h3 { font-size: 75% }
	.subImg .slogan { right: -30px }
	.grid2 {
	 		float: none;
 			width: 98%;
	}
	#header h1 {
			font-size: 10px;
	}
	.table-style01 {
		table-layout:fixed;
		word-break:break-all;
	}
	span{
		display:block;
		padding-left:0;
	}
	#mini-calendar .calendar-year-month span{
		display:inline;
	}
	.table-style01 th, .table-style01 td{
		width:auto;
	}

}

/* ========================================
 * #mini-calendar
 * ========================================*/
#mini-calendar .calendar-year-month {
	text-align: center;
	font-size: 150%;
/*	margin-bottom: 20px;*/
	font-weight: bold;
}
#mini-calendar .calendar-year-month span{
	padding:0 30px;
}

#mini-calendar table {
	width: 100%;
	border-spacing: 0;
	border-left: 1px solid #ccc;
	border-top: 1px solid #ccc;
	margin-bottom: 0;
	line-height: 1.5;
	border-collapse: separate;
}
#mini-calendar th,
#mini-calendar td {
	background: #fff;
	padding: 7px;
	border-bottom: 1px solid #ccc;
	border-right: 1px solid #ccc;
}
#mini-calendar th {
	color: #fff;
	background: #08913D;
	vertical-align: top;
	text-align:center;
	padding-top: 7px;
	padding-bottom: 7px;
	font-size:120%;
}



/*
#mini-calendar th.calendar-sun {
	color: #DF0D2D;
	background: #F8E4E4;
}
#mini-calendar th.calendar-sat {
	color: #2574D3;
	background: #E2F3FC;
}
*/
#mini-calendar td {
	width: 14.3%;
	height: 80px;
	vertical-align: top;
}
#mini-calendar td.calendar-day-off {
	background: #F4F3F2;
	color: #555;
}
#mini-calendar td.calendar-holiday,
#mini-calendar td.calendar-sun {
	color: #CE2727;
	background: #FCF3F3;
}
#mini-calendar td.calendar-sat {
	color: #54AFC8;
	background: #F5FBFE;
}

#mini-calendar .calendar-day-number {
	font-style: normal;
	font-family: "Helvetica Neue", Arial, sans-serif;
	font-weight: bold;
	font-size: 120%;
	display: block;
	padding: 0 3px;
	line-height: 1.2;
}
#mini-calendar td.calendar-holiday .day,
#mini-calendar td.calendar-sun .day {
	color: #DF0D2D;
}
#mini-calendar td.calendar-sat .day {
	color: #2574D3;
}
#mini-calendar td span {
	font-size:90%;
	line-height: 1.3;
	display: block;
}
#mini-calendar [class*=calender-label] {
	font-size: 90%;
	line-height: 1.3;
	color: #000;
	background: #FCEBCF;
	border: solid 1px #D2AC8E;
	display: block;
	padding: 3px;
	margin-top: 3px;
	border-radius: 4px;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
	-o-border-radius: 4px;
	-ms-border-radius: 4px;
}
#mini-calendar td span.calender-label-red {
	background-color: #FCCFD1;
	border-color: #D28EA6;
}
#mini-calendar td span.calender-label-blue {
	background-color: #CFE4FC;
	border-color: #8E9BD2;
}
#mini-calendar td span.calender-label-green {
	background-color: #E5FCCF;
	border-color: #99C170;
}
#mini-calendar td span.calender-label-orange {
	background-color:#FFDBB7;
	border-color:#FF6600;
}
/* 何もない日 */
#mini-calendar td.calendar-none {
	background: #FBFAF7;
}
#mini-calendar td.calendar-today {
	background: #FEFBDA;
}
.w50{width:50%; float:left;}
.w33{width:33.3333333%; float:left; 	font-size: 150%;}
.text-center{text-align:center;}
.text-right{text-align:right;}
.text-left{text-align:left;}

.news dt{  
  padding-top : 5px;    
  padding-bottom : 5px;
  padding-left : 5px;
  width : 115px;
  float : left;/* 左に寄せる */
  clear : both;/* フロートの解除 */
}

.news dd{  
  padding-top : 5px;
  padding-left : 5px;
  padding-right : 7px;
  padding-bottom : 5px;
  margin-left : 100px;/* DTの幅分の設定 */}

@media screen and (max-width: 600px) {
	#mini-calendar thead {
		display: none;
	}
	#mini-calendar th,
	#mini-calendar td {
		display: block;
		width: 100%;
		padding: 0;
	}
	#mini-calendar td {
		height: auto;
		display: -webkit-flex;
		display: flex;
	}
	#mini-calendar .calendar-none {
		display: none
	}

	#mini-calendar .calendar-labels {
		padding: 5px;
	}
	#mini-calendar [class*=calender-label] {
		display: inline-block;
		padding: 5px;
		margin-top: 0;
		margin-right: 5px;
		font-size: 100%;
	}
.w33{font-size: 110%;}

	/* 日付 */
	#mini-calendar td .calendar-day-number {
		font-weight: normal;
		padding: 7px;
		font-size: 160%;
		display: block;
		background: #08913D;
		margin-bottom: 0;
		width: 85px;
		height: auto;
		color:#fff;
	}
	#mini-calendar td.calendar-holiday .calendar-day-number,
	#mini-calendar td.calendar-sun .calendar-day-number {
		background: #f8c7c7;
	}

	#mini-calendar td.calendar-sat .calendar-day-number {
		background: #c8ebfe;
	}
	#mini-calendar td{
	font-size:80%;}
	/* モバイル用曜日を追加 */
	#mini-calendar td i:after {
		font-size: 80%;
		position: relative;
		left: 3px;
	}
	#mini-calendar td:nth-child(1) i:after {
		content: "（日）";
	}
	#mini-calendar td:nth-child(2) i:after {
		content: "（月）";
	}
	#mini-calendar td:nth-child(3) i:after {
		content: "（火）";
	}
	#mini-calendar td:nth-child(4) i:after {
		content: "（水）";
	}
	#mini-calendar td:nth-child(5) i:after {
		content: "（木）";
	}
	#mini-calendar td:nth-child(6) i:after {
		content: "（金）";
	}
	#mini-calendar td:nth-child(7) i:after {
		content: "（土）";
	}
	.w50{ width:100%;}
}