@charset "utf-8";
 
/*----------------------------------------------------
	base	
----------------------------------------------------*/
* {
}
html,
body {
 overflow-x: hidden;
}
body{
	font-size:14px;
	font-family: Verdana, "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	line-height:1.6;
	-webkit-text-size-adjust: 100%;/*iphone 調整用*/
	color:#000;
}
@media screen and (max-width: 768px) {
body{
	font-size:13px;
	overflow:hidden;
}
}
select,input,button,textarea,button{
	font:99% arial,helvetica,clean,sans-serif;
}

table{
	font-size:inherit;font:100%;
}
caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}

/* link*/
a {
	color:#fff;
}

a:link {
}

a:visited {
}

a:hover, #side1 a:hover{
	color:#ccc;
}

section{
	margin-bottom:30px;
}

@media screen and (max-width: 768px) {
img{
	max-width:100%;
	height:auto;
}
}

/*----------------------------------------------------
	layout
----------------------------------------------------*/
header{
	width:990px;
	margin:auto;
}
#main-visual,#g-nav{
	width:100%;
}
#contents{
	width:990px;
	margin:auto;
}

#main {
	/*float:right;*/
}

/*下層分割用　side1メニュー、side2バナー*/
footer{
	width:100%;
}
.inner{
	width:990px;
	margin:auto;
}

@media screen and (max-width: 768px) {
header,#contents{
	width:100%;
}
#main {
	float:none;
	margin-left:0px;
}
.inner{
	width:100%;
}
}

/*----------------------------------------------------
	header
----------------------------------------------------*/

header{
	height:39px;
}

header .title img{
	float:left;
}
header .title p{
	float:left;
	margin:25px 0 0 5px;
	font-size:12px;
	color:#000;
}

header nav{
	float:right;
	margin-top:25px;
}
header nav li{
	display:inline-block;
	background:url(../img/common/icon_arrowgray_right.png) no-repeat 13px center;
	background-size:9px 10px;
	padding-left:25px;
	font-size:12px;
}
header nav li a{
	color:#555;
	text-decoration:none;
}

@media screen and (max-width: 768px) {
header{
	height:45px;
	position:relative;
}
header .title {
	position:absolute;
	top:0;
	left:5px;
	width:80%;
}
header .title img {
    width: 203px;
    margin-top: 7px;
}
header .title p{
	font-size:77%;
}
}

/*----------------------------------------------------
	#contetnts
----------------------------------------------------*/

#contents{
	margin:20px auto 20px;
}


@media screen and (max-width: 768px) {
#contents{
	margin-top:10px;
}
}

/*各カラー付き見出し*/
h2{
	border-left:10px solid #555;
	padding-left:3px;
	margin:0 0 15px 0px;
	font-size: 114.3%;
	box-sizing: border-box;
	color:#000;
}
@media screen and (max-width: 768px) {
	h2{
		margin-left:10px;
		/*line-height:30px;*/
	}
}

/*----------------------------------------------------
	#main
----------------------------------------------------*/
#main,#main-wide {
	padding-bottom:40px;
	color:#555;
}
@media screen and (max-width: 768px) {
	#main,#main-wide {
	padding:5px;
}
}

/*PC 兼用左右パディングbox*/
.box{
	padding:0 10px;
}
.pp{
	padding:0 0 20px;
}

@media screen and (max-width: 768px) {
/*スマホ用左右パディングbox*/
.sp-box{
	padding:0 10px;
}
.pp{
	padding:0 0 10px;
}
}

/*可変aタグボタン全体調整*/

.btn a{
	 text-decoration:none;
}


/* table 表組基本
-----------------------------------------*/	
table {
	border-collapse: collapse;
	width:100%;
	box-sizing: border-box;
}
table th {
	width: 150px;
	padding: 10px;
	vertical-align:middle;
	border: 1px solid #ccc;
	background:#e6e6e6;
	text-align: center;
}
table td {
    padding: 5px;
    vertical-align: middle;
    border: 1px solid #ccc;
}
@media screen and (max-width: 768px) {
table th {
		width:20%;
		padding: 3px 0;
	}
table td {
	font-size:12px;
	padding: 3px 2px;
}
}

/*	都道府県から探す
----------------------------------------------------*/
ul.prefect {
	margin: 0;
	padding: 10px 0px 10px;
	background: #fff;
}
ul.prefect li {
	display: inline;
	margin-right: 10px;
	padding: 0;
}
ul.prefect li span,
ul.prefect li a {
	display: inline-block;
	margin-bottom: 5px;
	padding: 6px 30px;
	background: #077;
	text-decoration: none;
	vertical-align: middle;
	font-size: 120%;
}

ul.prefect li a.spCardBtn {
	padding: 6px 10px;
	font-size: 110%;
}

ul.prefect li a:hover {
	opacity: 0.4;
}
ul.p-top {
	margin: 0 0 25px 0;
}
ul.p-bottom {
	margin: 25px 0 0 0;
}
@media screen and (max-width: 768px) {
	ul.prefect {
    margin: 0;
    /*padding: 10px 8px 0;*/
    background: #fff;
}
ul.prefect li {
    display: inline;
    margin: 0;
    padding: 0;
}
ul.prefect li span, ul.prefect li a {
    /*display: inline-block;
    margin-bottom: 3px;
    padding: 5px 4px;
    background: #eee;
    text-decoration: none;
    vertical-align: middle;
    font-size: 90%;*/
}
}

/*----------------------------------------------------
	footer
----------------------------------------------------*/
footer{
	padding-bottom:1px;
}
footer .title {
    padding: 15px 0;
}
footer .inner{
	position:relative;
	height:1px;
}
footer .qr{
	position:absolute;
	left:0;
	top:20px;
}
footer nav{
	position:absolute;
	right:0px;
	top:30px;
}
footer nav li{
	display:inline-block;
	font-size:12px;
	background:url(../img/common/icon_arrowgray_right.png) no-repeat 13px center;
	background-size:9px 10px;
	padding-left:25px;
}
footer nav li a{
	color:#555;
	text-decoration:none;
}
footer p{
	position:absolute;
	color:#999999;
	bottom:5px;
	right:0;
	font-size:12px;
}
.copy{
	padding:10px 0;
	background-color: #077;
	color: #fff;
	/*width: 990px;*/
}

/*TOPへ戻るボタン*/
.totop{
	position:fixed;
	right:30px;
	bottom:90px;
}
.totop a img{
	width:65px;
}

@media screen and (max-width: 768px) {
footer .title {
    padding: 8px;
}
footer .qr{
	display:none;
}
footer .inner{
	position:static;
	height:auto;
	padding: 1px 0;
}
footer nav{
	position:static;
	width:100%;
}
footer nav li{
	display:block;
	font-size:85%;
	background:url(../img/common/icon_arrowgray_right.png) no-repeat 15px center;
	background-size:9px 10px;
	height:35px;
	line-height:35px;
	border-bottom:1px solid #cccccc;
	padding-left:0;
}
footer nav li:first-child{
	border-top:1px solid #cccccc;
}
footer nav li a{
	display:block;
	width:100%;
	padding-left:28px;
}
footer p{
	position:static;
	color:#999999;
	font-size:85%;
	text-align:center;
	margin:30px 0 20px;	
}
footer{
	padding-bottom:0;
}
.totop{
	bottom:55px;
}
.totop a img{
	width:56px;
}
.floatL {
    float: left;
    width: 190px;
}
.floatR {
    float: right;
    width: 90px;
}
}

/*----------------------------------------------------
	汎用クラス
----------------------------------------------------*/
/* clerfix */

.clear {
  clear: both;
}
.cf:after{
	content: "";
	display: block;
	clear: both;
}
.cf:before {
  display: inline-table;
}
.cf {
	zoom:1;
}

/* float */

.floatL {
	float: left;
}
.floatR {
	float: right;
}

/*位置*/
.imgC {
	margin:0 auto 20px;
}

.alL{
	text-align: left;
}

.alC{
	text-align: center;
}
.alR{
	text-align: right;
}
/*fontsize*/
.ss-font{
	font-size:80% ;
}
.s-font{
	font-size:85.7% ;
}
.l-font{
	font-size:114.3%;
}
@media screen and (max-width: 768px) {
.s-font{
	font-size:85% ;
}
.l-font{
	font-size:116% ;
}
}

/*PCだけ非表示*/
.pc-none{
	display:none;
}
@media screen and (max-width: 768px) {
.pc-none{
	display:block;
}
}
/*SPだけ非表示*/

@media screen and (max-width: 768px) {
.sp-none{
	display:none;
}
}

/* よく使いそうなCSS3
----------------------------------------------------*/
#selectors {
/* 角丸 */
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	border-radius: 10px;

/* 角丸個別 */
	-webkit-border-top-right-radius: 15px;
	-moz-border-radius-topright: 15px;
	border-top-right-radius: 15px;

/* ボックスに影 */
	-webkit-box-shadow: 1px 1px 3px #999;
	-moz-box-shadow: 1px 1px 3px #999;
	box-shadow: 1px 1px 3px #999;

/* テキストに影 */
	text-shadow: 1px 1px 0px #999;
}

/*印刷用*/

@media print {
	html,body{
		zoom:0.84;
	} 
}

/*スマホのみtelリンク*/
@media(min-width: 768px){
  a[href^="tel:"]{
    pointer-events: none;
    text-decoration: none;
    color: #555;
  }
}