@charset "utf-8";
html{
    height:100%;
}
body {
	height:100%;
	font-family: Verdana , Arial, "メイリオ"  ,Meiryo  ,"ヒラギノ角ゴPro W3" , "Hiragino Kaku Gothic Pro","ＭＳ Ｐゴシック",sans-serif;
	margin: 0;
	padding: 0;
	text-align: center;
	font-size: 16px;
	color: #666;
	background: #FaFaFa;
	line-height: 1.3;
}
* html body {
	font-size: 88%;
	}
* html #contents{
    height:100%;
}
body > #contents {
        height: auto;
}
.number {
	font-family: 'Comfortaa';
}
.w-960,
#main,
footer #upper {
	margin: 0 auto;
	width: 960px;
}


#contents {
	position:relative;
	min-height: 100%;
	width: 100%;
}
div, ol, ul, dl, form {
	margin: 0px;
	padding: 0px;
	}
p ,h1 ,h2 ,h3 ,h4 ,h5 ,h6, dt, dd, input, textarea, figure {
	margin: 0px;
	padding: 0px;
	font-size: 100%;
	}
em {
	font-style: normal;
	font-weight: bold;
	}
th, td {
	margin: 0px;
	padding: 0px;
	line-height: normal;
	font-weight: normal;
	}
a img {
	border: none;
	}
li {
	list-style-type: none;
}
img {
	border: 0px;
	vertical-align: bottom;
}
.clearfix:after,
header .upper:after,
header nav:after {
  content: "";
  clear: both;
  display: block;
}
.left{
	float:left;
	}
.right {
	float:right;
	}
sup {
	line-height: 1;
}
header .zen_logo {
	text-align: right;
	width:100%;
	padding: 0 30px 0 0;
	background: #FFF;
	}
header h1 {
	float: left;
	padding: 10px 0 20px 10px;
}
header li {
	display: table-cell;
	vertical-align: middle;
}

header li a:hover{
	opacity: 0.7;
}
header .upper ul{
	float: right;
	margin: 10px 10px 0 0;
	display: table;
}
header .map {
	padding: 0 5px;
}
header .map div{
	border: 1px solid #B7D5CC;
	padding: 5px;
}
header .map div a{
	background: #9FC7BB;
	display: block;
	padding: 5px;
}
header .contact {
	padding: 0 5px;
}
header .contact div{
	border: 1px solid #D98484;
	padding: 5px;
}
header .contact div a{
	background: #D98484;
	display: block;
	padding: 5px;
}
header .item {
	display: table;
	width: 100%;
}
header .item li {
	width: 14.2%;
}
header .item li a{
	padding: 5px 0;
	display: block;
}
#main {
	padding-bottom: 120px;
	text-align: left;
}
footer {
	position: absolute;
	bottom: 0px;
	height: 80px;
	padding-top: 10px;
	width: 100%;
	border-top: 1px dotted #8D725A;
}
footer #upper {
	display: table;
	text-align: center;
}
footer #upper address,
footer #upper p{
	display: table-cell;
	vertical-align: bottom;
}
footer #upper address{
	font-size: 0.9em;
	font-style:normal;
}
footer #upper address .tel{
	font-family: "Gentium Basic";
	font-size: 2.8em;
	color: #333;
	text-decoration: none;
	padding-left: 40px;
	background: url(../img/freedial.gif) no-repeat left 13px;
}
footer #upper address div {
	display: table;
	margin: 0 auto;
}
footer #upper address div span {
	display: table-cell;
	vertical-align: middle;
}
footer #upper address div .detail {
	font-size: .7em;
	line-height: 1;
}
footer #upper p {
	padding-bottom: 10px;
}
footer #bottom {
	text-align: center;
	bottom: 0;
	width: 100%;
	margin-top: 10px;
}
footer #bottom ul {
	float: right;
}
footer #bottom li {
	display: inline-block;
	text-align: center;
}
footer #bottom a {
	background: url(../../img/footer_icon.gif) no-repeat left center;
	padding-left: 15px;
	margin-left: 10px;
	color: #8c715a;
	font-size: 0.9em;
	text-decoration: none;
}
footer #bottom p {
	float: left;
}
/*===============================================
画面の横幅が960pxまで
===============================================*/
@media screen and (max-width: 960px) {
* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

img {
	max-width: 100%;
	height: auto;
	width /***/: auto;　
}
.w-960,
#main,
footer,
footer #upper {
	width:100%;
}
header .item img{
	height: 15px;
}
#main {
	margin: 0 2% 30px;
	width: 96%;
	padding-bottom: 0;
}
footer {
	height: auto;
	position: static;
}
footer #upper address div {
	margin: 0 auto;
}
footer #bottom p {
	width: 40%;
}
footer #bottom ul {
	width: 60%;
}
}
/*===============================================
画面の横幅が768pxまで
===============================================*/
@media screen and (max-width: 768px) {
header .upper ul img{
	height: 22px;
}
header .upper ul div img {
	padding: 5px 10px;
}
header .item img{
	height: 12px;
}
footer,
footer #upper,
footer #bottom {
	height: auto;
}
}
/*===============================================
画面の横幅が700pxまで
===============================================*/
@media screen and (max-width: 700px) {
header .zen_logo {
	display: none;
}
}
/*===============================================
画面の横幅が600pxまで
===============================================*/
@media screen and (max-width: 600px) {
header h1{
	float: none;
	width: 100%;
	margin: 0;
	text-align: center;
}
header .upper ul{
	float: none;
	width: 100%;
	margin: 0;
}
header .map{
	width: 49%;
	margin:  0 .5%;
}
header .map div {
	display: block;
}
header .contact{
	width: 49%;
	margin: 0 .5%;
}

header .item nav {
	display: inherit;
	margin-top: 10px;
}
header .item li {
	display: inline-block;
	width: 48.5%;
	margin-top: 5px;
}
header .item li:nth-child(2n-1) {
	margin-right: 1%;
}
header .item a{
	background: #f2b3bf;
	display: block;
	width: 100%;
	height: 38px;
}
footer #upper address,
footer #upper p {
	width: 100%;
	display: inherit;
}
footer #bottom ul,
footer #bottom p {
		display: block;
		width: 100%;
}
}
/*===============================================
画面の横幅が480pxまで
===============================================*/
@media screen and (max-width: 480px) {
header h1 {
	width: 80%;
	margin: 0 10%;
}
header .upper ul{
	margin: 10px 0 0;
}
header .upper ul div img {
	padding: 5px 0;
}
header .map{
	width: 50%;
	margin:  0;
}
header .contact{
	width: 50%;
	margin: 0;
}
footer #upper {
	display: inherit;
}

footer #upper address{
	font-size: 0.8em;
}
footer #upper address .tel{
	font-size: 2em;
	background: url(../img/freedial.gif) no-repeat left 5px;
}
}
/*===============================================
画面の横幅が320pxまで
===============================================*/
@media screen and (max-width: 320px) {
header .item img{
	height: 10px;
}
footer #bottom ul {
	font-size: 0.8em;
}
}