@charset "utf-8";

body{
	background: url(../img/common/bg.png) repeat-x center top #ffffff;
}
#header{
	background:#eee6cf;
}
#header h2{
	padding:0 1em;
}
#header .centering{
	background:url(../img/common/header.png) no-repeat right top;
	padding:1em 0;
	display: flex;
	flex-wrap:wrap;
	justify-content:space-between;
}
@media screen and (max-width: 767px) {
#header .centering{
	position:relative;
	padding:1.5em 0 1em;
}
#header .centering #member_login{
	position:absolute;
	right:0;
	top:0;
	width:40%;
	max-width:204px;
}
}


#global_navi{
	background: url(../img/common/navi/navi_bg.png) repeat-x;
}
#global_navi ul{
	display: flex;
	flex-wrap:nowrap;
	justify-content:space-between;
}
#global_navi ul li{
	line-height:1;
	flex:1 1 auto;
}
#global_navi ul li a{
	display:block;
	text-align:center;
	padding:8px 0 13px;
	height:16px;
	font-size:16px;
	line-height:1;
	width:100%;
	background:url(../img/common/navi/border.png) no-repeat right center;
	color:#ffffff;
	text-decoration:none;
}
#global_navi ul li:first-child a{
	background:url(../img/common/navi/border.png) no-repeat left center, url(../img/common/navi/border.png) no-repeat right center;
}
#global_navi ul li a:hover{
	background-color:rgba(255,255,255,0.2);
}
#global_navi ul li a img{
	vertical-align:middle;
}
@media screen and (max-width: 767px) {
	#menubtn,
	#closebtn a{
		background:#452913;
	}

#global_navi{
	background:#274927;
}
#global_navi ul{
	display: flex;
	flex-wrap:wrap;
	justify-content:space-between;
}
#global_navi ul li{
	line-height:1;
	flex:0 1 auto;
	width:50%;
}
#global_navi ul li a{
	display:block;
	text-align:center;
	padding:1em 0;
	height: auto;
	line-height:1;
	width:100%;
	background:none;
	box-sizing:border-box;
	border-right:1px solid #ffffff;
	border-bottom:1px solid #ffffff;
}
#global_navi ul li:first-child a{
	background:none;
}
#global_navi ul li:nth-child(2n) a{
	border-right:none;
}
}


#contents{
	min-height:500px;
	padding-bottom:4em;
	background:#ffffff;
}
@media screen and (max-width: 767px) {
#contents{
	min-height: inherit;
	padding-bottom:2em;
	background:#ffffff;
}
}


#footer{
	background:#3e6143;
	position:relative;
}
#footer #footer_info{
	padding:2em 0 1em;
	margin-bottom:1em;
	display: flex;
	flex-wrap:nowrap;
	border-bottom:2px solid #91a594;
}
#footer #footer_info p{
	color:#ffffff;
	padding-left:2em;
}
@media screen and (max-width: 767px) {
#footer #footer_info{
	display: block;
	border-bottom:none;
	padding-bottom:0;
}
#footer #footer_info h2{
	text-align:center;
}
#footer #footer_info p{
	color:#ffffff;
	padding-left:2em;
}
}


#footer #footer_navi{
	width:90%;
	max-width:960px;
	margin:0 auto 1em;
}
#footer #footer_navi ul.flex{
	display: flex;
	flex-wrap:nowrap;
	justify-content:space-between;
}
#footer #footer_navi ul.flex li.item{
	flex:1 1 auto;
}
#footer #footer_navi ul.flex li.item a{
	color:#ffffff;
	font-weight:bold;
	text-decoration:none;
}
#footer #footer_navi ul.flex li.item ul li::before{
	content:"・";
	color:#ffffff;
}
#footer #footer_navi ul.flex li.item ul li a{
	font-weight: normal;
	font-size:90%;
}
@media screen and (max-width: 767px) {
#footer #footer_navi{
	display:none;
}
}

#pagetop{
	width:100%;
	position:absolute;
	top:0px;
}
#pagetop p{
	text-align:right;
}



#copyright{
	background:url(../img/common/copyright.png) repeat-x left bottom;
	padding:5px 0 10px;
	line-height:1;
	text-align:center;
	border-top:1px solid #e0d2af;
}
#copyright small{
	font-size:90%;
	color:#ffffff;
}
@media screen and (max-width: 767px) {
}



/* 複数ページ共通レイアウト */
/* 共通style */
#contents article,
#contents section,
#contents aside,
#contents .section{
	margin-bottom:2em;
	padding:1em;
}
#page_title{
	padding-top:0;
}

#contents h3.title{
	padding:10px 0 7px 74px;
	min-height:23px;
	margin-bottom:1em;
}
#contents h3.title.dog{background:url(../img/common/ico_dog.png) no-repeat left bottom, url(../img/common/title.png) repeat-x left bottom;}
#contents h3.title.bird{background:url(../img/common/ico_bird.png) no-repeat left bottom, url(../img/common/title.png) repeat-x left bottom;}
#contents h3.title.cat{background:url(../img/common/ico_cat.png) no-repeat left bottom, url(../img/common/title.png) repeat-x left bottom;}
#contents h3.title.rabbit{background: url(../img/common/ico_rabbit.png) no-repeat left bottom, url(../img/common/title.png) repeat-x left bottom;}
#contents h3.title.dog2{background:url(../img/common/ico_dog2.png) no-repeat left bottom, url(../img/common/title.png) repeat-x left bottom;}
#contents h3.title.serif{
	font-size:140%;
	font-weight:bold;
	letter-spacing:0.1em;
	text-shadow:0 0 3px #f9e5b9;
	color:#000000;
}
h4.title{
	border-bottom:1px solid #81863e;
	border-left:5px solid #81863e;
	font-size:120%;
	padding:0.5em 1em;
	line-height:1;
	font-weight:bold;
	margin-bottom:1em;
}
h4.title time{
	display:block;
	color:#666666;
	font-weight:normal;
	font-size:90%;
	margin-bottom:0.5em;
}


/* テーブル */
table{
	width:100%;
	margin-bottom:1em;
}
table th{
	width:30%;
	padding:0.5em 1em;
	white-space:nowrap;
	font-weight:normal;
	background:#eaeaea;
	text-align:left;
	border:2px solid #ffffff;
}
table td{
	padding:0.5em 1em;
	background:#f7f7f7;
	border:2px solid #ffffff;
}
@media screen and (max-width: 767px) {
table,table tr,table th,table td,table thead,table tbody{
	display:block;
}
table th{
	width:100%;
	padding:0.5em 1em;
	box-sizing:border-box;
	white-space:nowrap;
	border:none;
	border-bottom:2px solid #ffffff;
}
table td{
	width:100%;
	box-sizing:border-box;
	padding:0.5em 1em;
	background:#f7f7f7;
	border:none;
	border-bottom:2px solid #ffffff;
}
}

/* -----------
	トップページ
	----------- */

/* お知らせ */
#news{
}
#news dl{
	display: flex;
	flex-wrap:wrap;
}
body.home #news dl{
	height:15em;
	overflow: auto;
}
#news dt{
	font-weight:bold;
	width:8em;
	padding-left:1em;
}
#news dd{
	margin-bottom:1em;
	width:calc(100% - 9em);
}

/* 憲章 */
#charter ul{
	background:url(../img/index/rainbow.jpg) no-repeat right top;
	background-size:contain;
	font-size:120%;
	font-weight:bold;
	width:80%;
	margin:0 auto;
	padding:1em;
}
#charter ul li{
	margin-bottom:1em;
}

/* 協会の存在意義 */
@media screen and (max-width: 767px) {
	#meaning img{
		float:none;
		display:block;
		margin:0 auto 1em;
	}
}


/* リンクバナー */
#banners{
	margin-bottom:1em;
}
#banners ul{
	display: flex;
	flex-wrap:wrap;
	justify-content:space-between;
}
#banners ul li{
	width:33.3%;
	text-align:center;
}
@media screen and (max-width: 574px) {
	#banners ul li{
		width:50%;
		padding:0 5px;
		box-sizing:border-box;
		max-width:287px;
		text-align:center;
		margin-bottom:0.5em;
	}
}


/* -----------
	加盟案内
	----------- */

/* 加盟相談について */
#consultation small{
	color:#999999;
	font-size:90%;
}
#consultation blockquote{
	border:1px solid #f0da96;
	background:#f8f0d8;
	padding:1em 2em;
	margin:1em 0;
}


/* -----------
	会員・賛助会員
	----------- */

/* 一覧 */
.member_list{
	border-top:1px solid #777777;
}
.member_list li{
	display: flex;
	flex-wrap:wrap;
	padding-bottom:0.5em;
	border-bottom:1px solid #777777;
}
.member_list li:nth-child(2n){
	background:#e8e8e8;
}
.member_list li span{
	display:block;
	background:#777777;
	border-radius:0 0 3px 3px;
	color:#ffffff;
	padding:0.5em 1em;
	font-size:90%;
	line-height:1;
	width:5em;
	text-align:center;
    align-self: flex-start;
}
.member_list li h6{
	width:calc(100% - 7em);
	padding:0 1em;
	box-sizing:border-box;
}
.member_list li h6 a{
	font-size:110%;
	font-weight:bold;
}
.member_list li p.address{
	flex:1 1 auto;
}
.member_list li p.tel{
	width:20%;
}
@media screen and (max-width: 767px) {
.member_list li p.tel{
	width:100%;
}
}

/* -----------
	お問い合わせ
	----------- */

/* 地図レイアウト */
.map_flex{
	display: flex;
	width:100%;
	flex-wrap:nowrap;
}
.map_flex p.info{
	width:50%;
	text-align:right;
	padding-right:2em;
	box-sizing:border-box;
}
.map_flex b{
	font-weight:bold;
	font-size:110%;
}
.map_flex div{
	width:50%;
}
.map_flex iframe{
	width:100%;
	height:320px;
}
@media screen and (max-width: 767px) {
.map_flex{
	display: block;
}
.map_flex p.info{
	width:100%;
	text-align:left;
	padding-right:0;
}
.map_flex div{
	width:100%;
}
.map_flex iframe{
	width:100%;
	height:30vh;
	display:block;
	margin:0 auto;
}
}

/* プライバシーポリシー */
#privacy p{
	margin-bottom:1em;
}

/* リンクバナー */
#link li{
	margin-bottom: 1em;
}

/* -----------
	ログインページ
	----------- */

/* ログインフォーム */

.loginform{
	padding:4em 0;
}
.loginform dl{
	text-align:center;
	margin-bottom:1em;
}
.loginform dl dt,
.loginform dl dd{
	display:inline-block;
}













