/* HTML初期化 */
body {
	line-height: 1;
	margin: 0;
	zoom:1;
}

h1, h2, h3, h4, h5, h6 {
	margin: 0;
	padding: 0;
	font-weight:normal;
	font-style:normal;
}

p, dl, dt, dd, em, form, address,ul,li, figure {
	margin: 0;
	padding: 0;
	font-style:normal;
}

/* HTML5用 */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}

fieldset {
	border:0;
	margin: 0;
	padding: 0;
}

hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #cccccc;
	margin: 1em 0;
	padding: 0;
}

ul {
	list-style: none;
	padding: 0;
	margin: 0;
	border: 0;
}

li {
	padding: 0;
	margin: 0;
}

input, select {
	vertical-align: middle;
}

/* tableタグ*/
th,td{
	padding:0;
}

caption{
	text-align:left;
} 


/* リンク設定 */
a {
	outline:0;
	border:0;
	transition: all 0.3s ease;
}

@media screen and (max-width: 800px) {
a {
	transition:none;
}
}

a img {
	border:0;
}

img {
	border:0;
	max-width:100%;
}

html {
-webkit-text-size-adjust: none;
zoom:1;
}


/*============================================
基本CSS
===========================================*/
body {
font-family: "Noto Sans Japanese", YuGothic,'Yu Gothic',"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "sans-serif";
font-display: swap;
position: relative;
}

.innerBox {
max-width: 1200px;
min-width: 1000px;
margin: auto;
overflow: hidden;
position: relative;
box-sizing: border-box;
padding-left: 20px;
padding-right: 20px;
clear: both;
}

/*============================================
ヘッダー
===========================================*/
header {
border-top: 5px solid #0068B6;
overflow: hidden;
padding-top: 30px;
padding-bottom: 20px;
}

header h1 {
font-size: 2.3em;
font-weight: 700;
width: 50%;
float: left;
line-height: 1.2;
}

header .logo {
	width: 260px;
}

header .logo img {
	display: block;
}

header h1 a {
color: #0068B6;
text-decoration: none;
}

header h1 a:hover {
	opacity: 0.7;
}

header h1 span {
font-size: 0.4em;
display: block;
}

header address {
width: 50%;
float: right;
text-align: right;
}

header address img {
height: 68px;
}

/*============================================
グローバルナビゲーション
===========================================*/
#MainNavi {
background: rgb(239,239,239); /* Old browsers */
background: -webkit-linear-gradient(top, rgba(239,239,239,1) 0%,rgba(219,219,219,1) 50%,rgba(209,209,209,1) 51%,rgba(232,232,232,1) 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(to bottom, rgba(239,239,239,1) 0%,rgba(219,219,219,1) 50%,rgba(209,209,209,1) 51%,rgba(232,232,232,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
padding-top: 5px;
padding-bottom: 5px;
overflow: hidden;
border-top: 1px solid #DDD;
border-bottom: 1px solid #DDD;
}

#MainNavi a {
color: #222;
font-size: 0.85em;
line-height: 1.8;
text-decoration: none;
display: block;
text-align: center;
padding: 10px;
padding-left: 0;
padding-right: 0;
border: 2px solid #FFF;
border-left: 0;
letter-spacing: -0.05em;
font-weight: 500;
text-shadow: 0 1px 0 rgba(255,255,255,0.5);
box-shadow: 0 0 6px rgba(0,0,0,0.1) inset;
}

#MainNavi a:hover,
#MainNavi .Now a {
background: rgba(0,0,0,0.2);
text-shadow: 0 1px 0 rgba(255,255,255,0.7);
}

#MainNavi li:first-child a {
border-left: 2px solid #FFF;
}

#MainNavi li {
width: calc(100%/7);
float: left;
box-sizing: border-box;
}

/*============================================
サイドバー
===========================================*/
#SideBar {
width:220px;
border-right: 20px solid #0068B6;
padding-right: 20px;
padding-bottom: 100px;
position: absolute;
left: 20px;
top:0;
}

.SideCont {
overflow: hidden;
clear: both;
padding-top: 15px;
padding-bottom: 15px;
}

/* 水道局指定 */
#SideShitei h2 {
background:url(../img/side_shitei_header.png) no-repeat center top;
padding-top: 70px;
text-align: center;
margin-bottom: 10px;
}

#SideShitei h2 strong {
display: block;
color: #FFF;
font-weight: 700;
padding: 10px;
font-size: 1.4em;
background: #0068B6;
}

#SideShitei ul {
line-height: 1.6;
font-size: 1.2em;
font-weight: 700;
text-align: center;
}

/* FAQ */
.SideFaqBox {
border: 5px solid #009844;
position: relative;
overflow: hidden;
height: 160px;
margin-bottom: 10px;
}

.SideFaqBox a {
display: block;
padding: 10px;
text-decoration: none;
color: #222;
}

.SideFaqBox:hover {
background: rgba(255,249,219,1.00);
}

.SideFaqBox p {
margin-left: 100px;
font-size: 0.8em;
line-height: 1.7;
}

.SideFaqBox strong {
position: absolute;
bottom:10px;
right: 10px;
color: #FFF;
font-size: 0.8em;
padding: 3px;
padding-top: 2px;
padding-left: 7px;
padding-right: 7px;
line-height: 1.5;
background: #EC6C00;
font-weight: 500;
z-index: 10;
}

.SideFaqBox strong i {
padding-left: 3px;
font-size: 1.2em;
}

.SideFaqBox img {
position: absolute;
left:3px;
bottom:0;
z-index: 1;
max-height: 156px;
max-width: 100px;
}

/* ナビゲーション */
#SideNavi {
background: #D3EDFB;
padding: 15px;
}

#SideNavi a {
color: #222;
text-decoration: none;
line-height: 1.8;
font-size: 0.9em;
background: url(../img/side_navi_icon.png) no-repeat left center;
background-size: 1em;
padding-left: 1.4em;
}

#SideNavi a:hover {
text-decoration: underline;
}

/* お問い合わせから解決までの流れ */
#SideFlow h2 {
background: #00A0E9;
padding: 3px;
margin-top: 10px;
margin-bottom: 10px;
}

#SideFlow h2 strong {
display: block;
text-align: center;
color: #FFF;
font-size: 0.85em;
line-height: 1.4;
border: 1px solid #FFF;
padding: 10px;
}

.SideFlowBox {
padding-bottom: 10px;
}

.SideFlowBox p {
font-size: 0.8em;
line-height: 1.6;
padding-top: 5px;
}

.SideBottomNavi {
padding-bottom: 10px;
}

.SideBottomNavi a {
background: #00A0E9;
padding: 15px;
color: #FFF;
font-size: 0.85em;
font-weight: 700;
text-decoration: none;
display: block;
padding-left: 42px;
padding-right: 0;
line-height: 1.6;
}

#SideBottomNavi01 a {
background: #00A0E9 url(../img/side_bottom_navi01.png) no-repeat 10px center;
}

#SideBottomNavi02 a {
background: #00A0E9 url(../img/side_bottom_navi02.png) no-repeat 10px center;
}

#SideBottomNavi03 a {
background: #00A0E9 url(../img/side_bottom_navi03.png) no-repeat 10px center;
}

#SideBottomNavi01 a:hover {
background: #0068B6 url(../img/side_bottom_navi01.png) no-repeat 10px center;
}

#SideBottomNavi02 a:hover {
background: #0068B6 url(../img/side_bottom_navi02.png) no-repeat 10px center;
}

#SideBottomNavi03 a:hover {
background: #0068B6 url(../img/side_bottom_navi03.png) no-repeat 10px center;
}


/*============================================
ページコンテンツ
===========================================*/
#MainCont {
margin-left: 280px;
padding-bottom: 100px;
}

#MainContHeader {
}

.BnrCont {
padding-bottom: 15px;
}

.BnrCont a:hover {
opacity: 0.7;
}

/*============================================
フッター
===========================================*/
footer {
background: url(../img/footer_BG.png) repeat-x center 0;
padding-top: 160px;
position: relative;
margin-top: -100px;
}

#FooterCont {
background: #0068B6;
text-align: center;
color: #FFF;
padding-bottom: 80px;
}

#FooterCont ul,
#FooterCont li {
display: inline-block;
line-height: 1em;
}

#FooterCont li:first-child {
border-left: 0;
}

#FooterCont li {
padding-left: 13px;
padding-right: 10px;
border-left: 1px solid #FFF;
}

#FooterCont li a {
color: #FFF;
text-decoration: none;
font-size: 0.8em;
position: relative;
top:-1px;
}

#FooterCont li a:hover {
text-decoration: underline;
}

#FooterCont p {
font-size: 0.7em;
padding-top: 20px;
line-height: 1.5;
font-weight: 300;
}

/*============================================
フッターバナー
===========================================*/
#FooterBnr {
position: fixed;
bottom:-80px;
left: 0;
width: 100%;
text-align: center;
opacity: 0.7;
z-index: 100;
transition: all 0.3s ease;
}

#FooterBnr.open {
bottom:0;
opacity: 1;
box-sizing: border-box;
}

#FooterBnr.open img {
width: 100vw;
}

#FooterBnr a {
position: relative;
z-index: 10;
display: block;
width: 100%;
}

#FooterBnr:hover {
opacity: 1;
bottom: 0;
}

#FooterBnr:hover #FooterBnrObi {
box-shadow: 0 0 8px rgba(0,0,0,0.2);
}

#FooterBnrObi {
background: #FFE200;
height: 124px;
width: 100%;
position: absolute;
bottom:0;
left: 0;
z-index: 1;
transition: all 0.3s ease;
}

/* スマホページ リンク*/
#spLink {
display: none;
}
#spLink a {
background: -webkit-linear-gradient(top, rgba(0,64,152,1) 0%,rgba(0,64,152,1) 50%,rgba(0,91,172,1) 51%,rgba(0,91,172,1) 100%); 
background: linear-gradient(to bottom, rgba(0,64,152,1) 0%,rgba(0,64,152,1) 50%,rgba(0,91,172,1) 51%,rgba(0,91,172,1) 100%);
text-align: center;
font-size: 3em;
font-weight: 700;
color: #FFF;
text-decoration: none;
display: block;
padding: 10px;
padding-top: 5px;
padding-bottom: 20px;
}

#spLink a i {
font-size: 1.8em;
position: relative;
padding-right: 10px;
top:10px;
}