@charset "UTF-8";
@import url(http://fonts.googleapis.com/earlyaccess/notosansjapanese.css);

body, html {
    width: 100%;
	margin:0;
	padding: 0;
	font-family: brandon-grotesque, a-otf-gothic-bbb-pr6n, sans-serif, "游ゴシック", "ヒラギノ角ゴ Pro W3", "メイリオ",Meiryo,'ＭＳ Ｐゴシック', sans-serif;
	font-size: 14px;
	line-height: 1.8em;
	min-width: 360px;
	scroll-behavior: smooth;
}
	

*, *:before, *:after {
            box-sizing: border-box;
}
/*              clearfix                         */ 

.clearfix:after {
  content: ".";  
  display: block; 
  clear: both;
  height: 0;
  visibility: hidden;
}

.clearfix {
  min-height: 1px;
}

* html .clearfix {
  height: 1px;
  /*\*//*/
  height: auto;
  overflow: hidden;
  /**/
}

/*             Pagetop                        */ 

#pagetop {
	width: 60px;
    position: fixed;
    bottom: 2%;
    right: 3%;
    padding: 10px;
    -ms-filter: "alpha(opacity=80)";
    -moz-opacity: 0.8;
    -khtml-opacity: 0.8;
    opacity: 0.8;
	z-index: 10001;
	font-size: 48px;
}

#pagetop a{ color: #ccc;}


#pagetop img{ width: 100%;}

@media screen and (max-width: 600px) {
    #pagetop {bottom: 60px;}
}


header {
	position: relative;
}

@media screen and (min-width: 769px) {
	header.notop {
		height: 150px;
		overflow: hidden;
	}
}
@media screen and (max-width: 768px) {
	header.notop {
		height: 100px;
		overflow: hidden;
	}
}


header img {
	width: 100%;
}

header h1 a{
	position: absolute;
	top: 3vw;
	left: 5%;
	text-decoration: none;
	color: #fff;
	text-shadow:5px 5px 2px #555; 
}

@media screen and (min-width: 769px) {header h1 a{	font-size: 3vw;}}
@media screen and (max-width: 768px) {header h1 a{	font-size: 6vw; top: 7vw;}}

nav .menu{
	display: flex;
	justify-content: end;
	background: #000;
}

nav .menu li a{
	text-decoration: none;
	display: block;
	padding: 5px 20px 10px 0;
	color: #fff;
	font-weight: 600;
}
nav .menu li a:hover{
	color: #ff0;
}




#container {
	max-width: 1000px;
	margin: auto;
}

.about, .add {
	padding: 25px 40px;
}

.about h1, .add h1, .contractor h1, .link h1, .members h1 {
	border-bottom: solid 1px #ccc;
	font-size: 18px;
	border-left: solid 10px #ccc;
	padding: 10px 0 5px 10px;
	margin: 25px 0;
}

.gmap {
	margin: 15px auto;
	width: 96%;
	padding: 0;
}

.gmap iframe {
	width: 100%;
	margin: 0;
	height: 100%;
	border: solid 3px #aaa;
	height: 360px;
}

p.exp {
	text-align: right;
	color: #555;
}

.contractor, .link {padding: 5px;}

.contractor h2 {
	border-bottom: dashed 1px #ccc;
	font-size: 16px;
	border-left: solid 5px #46f9d0;
	padding: 5px 0 5px 10px;
	margin: 15px 0 15px 5px;
	
}

.contractor table {
	width: 100%;
	max-width: 800px;
	margin: auto;
}

.contractor tr:nth-child(odd) {
	background: #e2fef8;
}

.contractor td {
	padding: 5px;
}
.contractor tr td:last-child { width: 100px;}
.contractor tr td:nth-child(2) { width: 150px;}
.contractor tr td:first-child { width: calc(100% - 230px);}


.link ul {
	list-style: none;
}

.link ul li a{
	text-decoration: none;
	font-size: 14px;
	color: #004f75;
}

.members table {
	width: 98%;
	margin: auto;
}

.members tbody tr:nth-child(odd) { background: #d1f5e0;}
.cooperative-list thead {
	background: #004000;
	color: #fff;
}


.members table th, .members table td{
	padding: 7px;
}

@media screen and (max-width: 600px) {
	.members table th, .members table td{
		display: block;
		padding: 4px;
	}
}

.members a {
	text-decoration: none;
	color: #004080;
}
.members a:hover { color: #e9c416;}


.db-navi {
	margin: 25px auto 50px auto;
	text-align: center;
}
.linklist strong{ border: solid 1px #aaa;	padding:5px;}

.linklist a, a.bn{
	text-decoration: none;
	color: #fff;
}

.linklist a{
	background: #aaa;
	padding:5px;
	border: none;
	margin: 0 5px;
}

a.bn {
	text-align: center;
	border: solid 1px #000;
	background: #004000;
	border-radius: 7px;
	padding:5px 10px;
	margin: 5px;
	color: #fff;
}

a.bn:hover, .linklist a:hover { background: #575700;}

.pagination {
    margin: 20px 0;
    text-align: center;
}
.pagination a,
.pagination span {
    display: inline-block;
    padding: 4px 8px;
    margin: 0 2px;
    border: 1px solid #ccc;
}
.pagination .current {
    background: #333;
    color: #fff;
    border-color: #333;
}
.pagination .prev,
.pagination .next {
    font-weight: bold;
}



footer {
	text-align: center;
	padding: 15px;
}