@import "base.css";
@import "//fonts.googleapis.com/css?family=Kosugi+Maru";
@import "//fonts.googleapis.com/css?family=Yusei+Magic";
@import "//fonts.googleapis.com/icon?family=Material+Icons";
@font-face{
	font-display:swap;
}
html, body, input, select, textarea{
	font-family:"Kosugi Maru", sans-serif;
	line-height:1.5em;
}
body{
	font-size:16px;
	background-image:url("../img/kabe.jpg");
	background-size:cover;
	background-attachment:fixed;
	margin:0;
}
::placeholder{
	color:#ccc;
}
a{
	color:#0172d3;
	text-decoration:none;
}
ul, li{
	list-style:outside none none;
	margin:0;
	padding:0;
}
[data-ruby]{
	position:relative;
}
[data-ruby]::before{
	content:attr(data-ruby);
	font-size:0.5em;
	font-weight:bold;
	white-space:nowrap;
	text-align:center;
	top:-2em;
	width:100%;
	position:absolute;
}
table{
	background:#fff;
	border:3px solid #ccc;
	border-collapse:collapse;
}
table th{
	background:#eee;
	text-align:center;
}
table th, table td{
	border:2px solid #ddd;
	padding:5px 10px 5px 10px;
}
.table{
	font-size:14px;
	border-width:1px;
}
.table th, .table td{
	border:1px solid #ddd;
	padding:5px;
}
.clearfix:after{
	content:"";
	display:block;
	clear:both;
}
.indent{
	padding-left:1em;
	text-indent:-1em;
}
.material-icons{
	vertical-align:top;
}
.pdf, .html{
	margin:0 5px;
}
.pdf{
	color:#b30b00;
}
.html{
	color:#0172d3;
}
.big{
	font-size:20px;
}
.small{
	font-size:14px;
}
.sup{
	font-size:14px;
	color:#666;
}
.mkr1{
	font-size:20px;
	font-weight:bold;
	color:tomato;
	background:linear-gradient(transparent 70%, #ffff00 0%);
}
.mkr2{
	background:#ffff00;
	margin:0 2px;
	padding:3px 5px;
	border-radius:5px;
}
.mkr3{
	background:linear-gradient(transparent 90%, tomato 0%);
	margin:0 2px;
}
.li ul{
	position:relative;
}
.li ul li{
	list-style-type:none;
	line-height:1.7em;
	margin:10px 0 10px 2.5em;
}
.li ul li:before{
	content:"\e892";
	font-family:"Material Icons";
	color:#dedede;
	left:1em;
	position:absolute;
}
.link_err{
	font-size:12px;
	font-weight:bold;
	color:red;
	background:yellow;
	margin:5px;
	padding:5px 12px;
	display:inline-block;
	border-radius:5px;
}
.btn{
	text-align:center;
	margin-top:20px;
}
.btn a{
	font-size:16px;
	color:#fff;
	background:#0172d3;
	border:2px solid #fff;
	padding:15px 0;
	width:220px;
	position:relative;
	display:inline-block;
	border-radius:10px;
	box-shadow:0 5px 0 #cdcfe5;
	box-sizing:border-box;
}
.btn .material-icons{
	top:15px;
	right:20px;
	position:absolute;
	opacity:0.5;
}
.cite{
	margin-top:50px;
}
.cite_s, .cite_m{
	text-align:center;
}
.cite_s{
	font-size:14px;
}
.cite_l{
	font-weight:bold;
	color:#fff;
	background:#2fab68;
	padding-bottom:6px;
	display:block;
	border-radius:10px;
	box-shadow:0 5px 0 #28975b;
}
.cite_l span:first-child{
	color:#2fab68;
	background:#fff;
	margin-bottom:5px;
	border:2px solid #2fab68;
	display:block;
	border-radius:10px 10px 0 0;
}
.cite_l .material-icons{
	line-height:22px;
	margin-left:10px;
}
.cite_m{
	font-size:12px;
	margin-top:10px;
}
.breadcrumb{
	font-size:12px;
	top:0;
	left:8px;
	position:absolute;
}
.breadcrumb li{
	margin-right:15px;
	position:relative;
	display:inline-block;
}
.breadcrumb li:after{
	content:"";
	margin-left:6px;
	top:9px;
	border:4px solid transparent;
	border-left-color:#888;
	position:absolute;
}
.breadcrumb li:last-child:after{
	content:none;
}
.breadcrumb li a{
	text-decoration:none;
}
.breadcrumb li > span{
	color:#555;
}
.breadcrumb li a:hover{
	color:palevioletred;
}
.left{
	text-align:center;
}
.right{
	padding-top:10px;
}
#acd{
	font-size:17px;
	background:rgba(198, 186, 221, 0.7);
	border:3px solid #fff;
	width:200px;
	border-radius:10px;
}
#acd li{
	border-bottom:1px solid #ccc;
	cursor:pointer;
}
#acd .link{
	padding:5px 0;
}
#acd li:last-child li:last-child, #acd li:last-child li:last-child a{
	border-radius:0px 0px 10px 10px;
}
#acd li:last-child, #acd .sub_acd li:last-child{
	border-bottom:0;
}
#acd .default .link:after, #acd .sub_acd a.active:after, #acd .sub_acd a:hover:after{
	content:"";
	margin-top:5px;
	border-style:solid;
	border-width:7px 10px 7px 10px;
	left:210px;
	position:absolute;
}
#acd .default .link:after{
	border-color:transparent transparent transparent #a99bb3;
}
#acd .sub_acd a.active:after, #acd .sub_acd a:hover:after{
	border-color:transparent transparent transparent #0172d3;
}
#acd .sub_acd a:hover:after{
	opacity:0.5;
}
#acd .sub_acd a.active{
	transition:.5s;
}
#acd .default .sub_acd{
	display:block;
}
#acd .sub_acd{
	background:#fff;
	display:none;
}
#acd .sub_acd li{
	border-bottom:1px solid #ddd;
}
#acd .sub_acd a{
	padding:5px 0;
	display:block;
}
.left .qr{
	font-size:12px;
	line-height:15px;
	margin:20px auto;
}
.left .qr div:nth-child(n + 2){
	margin-top:20px;
}
.left .qr img{
	background:#fff;
	padding:10px;
	border-radius:5px;
}
.logo{
	position:relative;
}
.logo div{
	position:absolute;
	z-index:1;
}
.logo img{
	filter:drop-shadow(0px 0px 5px #fff);
}
.topics{
	margin-left:10px;
	float:left;
}
.topics_t, .weather_t{
	text-align:center;
	border-bottom:1px solid #ccc;
}
.topics_c{
	overflow-y:scroll;
}
.topics_c li{
	margin:1px;
	text-indent:calc(-1em - 3px);
	padding-left:calc(1em + 3px);
}
.topics_c li:before{
	content:"\e050";
	font-family:"Material Icons";
	color:#ed6d2a;
	vertical-align:top;
	margin-right:3px;
}
.topics_c .garbage{
	padding:1px 3px;
	border-radius:2px;
}
.topics_c .garbage span{
	font-weight:bold;
	margin-left:2px;
}
.weather{
	text-align:center;
	margin-right:10px;
	float:right;
}
.weather_t{
	margin-bottom:2px;
}
.weather_1, .weather_2, .weather_3{
	padding:0 5px;
	display:inline-block;
}
.weather_days{
	font-size:14px;
	line-height:15px;
	padding-top:3px;
}
.weather_days span{
	font-size:12px;
	margin-left:2px;
}
.weather img{
	vertical-align:middle;
	height:30px;
}
.weather_s3 img, .weather_s4 img{
	padding-top:4px;
	padding-bottom:4px;
	height:22px;
}
.weather_s5 img{
	padding-top:6px;
	padding-bottom:6px;
	height:18px;
}
.weather_s6 img, .weather_s7 img{
	padding-top:9px;
	padding-bottom:9px;
	height:12px;
}
.weather_s5 .weather_c, .weather_s6 .weather_c, .weather_s7 .weather_c{
	margin:0 2px;
}
.search{
	background:#fff;
	margin:10px auto;
	border:1px solid #dfdfdf;
	width:210px;
	position:relative;
	border-radius:50px;
	overflow:hidden;
}
.search input[type="text"]{
	font-size:16px;
	border:none;
	padding:5px 0 5px 15px;
	display:block;
}
.search input[type="text"]:focus{
	outline:0;
}
.search input[type="submit"]{
	font-family:"Material Icons";
	font-size:25px;
	color:#555;
	background:transparent;
	line-height:25px;
	border:none;
	padding:0;
	top:4px;
	right:8px;
	position:absolute;
	cursor:pointer;
	outline:none;
}
.content{
	background:#fff;
	margin-top:7px;
	padding:10px;
	min-width:280px;
	border-radius:5px;
	box-shadow:0 0 10px 0 #ddd;
}
.h1{
	font-size:24px;
	color:#fff;
	background:#1d75b5;
	margin:10px 0 20px -18px;
	padding:15px 20px 15px 15px;
	position:relative;
	display:inline-block;
	box-shadow:3px 3px 2px rgba(0, 0, 0, .2);
	-webkit-box-shadow:3px 3px 2px rgba(0, 0, 0, .2);
}
.h1:before{
	content:"";
	border-top:8px solid #1d75b5;
	border-left:8px solid transparent;
	bottom:-8px;
	left:0;
	width:0;
	height:0;
	position:absolute;
}
h2{
	font-size:22px;
	line-height:1.4;
	margin:60px 0 20px 0;
	-webkit-box-reflect:below -15px -webkit-linear-gradient(top, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0) 10%, rgba(0, 0, 0, 0.2));
}
.con_img{
	margin:20px 10px 10px 30px;
	float:right;
}
.con_img img{
	max-width:300px;
}
.map_b{
	border:1px solid #ddd;
	padding:5px;
	height:calc(100vh - 200px);
	min-height:500px;
	border-radius:10px;
}
.map_s{
	border:1px solid #ddd;
	padding:5px;
	height:350px;
	border-radius:10px;
}
.sdgs{
	text-align:center;
	margin-top:75px;
}
.sdgs div:first-child span{
	margin:0 3px;
}
.sdgs div:nth-child(2) img{
	margin:20px auto 10px auto;
	height:35px;
}
.sdgs div:nth-child(n + 3){
	display:inline-block;
}
.sdgs div:nth-child(n + 3) img{
	height:120px;
}
.sdgs div:nth-child(n + 4) img{
	margin-left:5px;
}
.footer_nav{
	text-align:center;
}
.footer_nav_item{
	vertical-align:top;
	padding:10px 0;
	width:105px;
	display:inline-block;
}
.footer_nav_item div{
	font-size:15px;
}
.footer_nav_item ul{
	font-size:13px;
	margin-top:3px;
}
.footer_sha, .footer{
	font-size:14px;
	text-align:center;
	margin:25px 0;
}
.footer{
	letter-spacing:2px;
	padding-left:2px;
}
.slidetable_guide{
	font-size:16px;
	color:green;
	text-align:right;
	margin-top:20px;
	right:0;
	position:relative;
	animation-name:return;
	animation-duration:1s;
	animation-iteration-count:infinite;
	animation-timing-function:ease;
}
@keyframes return{
	50%{
		right:20px;
	}
	100%{
		right:0px;
	}
}
@media (max-width:800px){
	.topics{
		width:calc(100% - 20px) !important;
	}
	.weather{
		display:none;
	}
}
@media (max-width:767px){
	body.fixed{
		width:100%;
		height:100%;
		position:fixed;
	}
	#hbg{
		background:rgba(255, 255, 255, 0.5);
		border:2px solid #fff;
		top:5px;
		right:5px;
		width:50px;
		height:50px;
		position:fixed;
		z-index:503;
		border-radius:50px;
	}
	.hbg1, .hbg2, .hbg3{
		background:#000;
		right:12px;
		width:26px;
		height:3px;
		position:absolute;
		transition:.5s;
	}
	.hbg1{
		top:13px;
	}
	.hbg2{
		top:23px;
	}
	.hbg3{
		top:33px;
	}
	.open .hbg1{
		top:23px;
		transform:rotate(-45deg);
	}
	.open .hbg2{
		opacity:0;
	}
	.open .hbg3{
		top:23px;
		transform:rotate(45deg);
	}
	.nav_list{
		background-image:url("../img/kabe.jpg");
		background-size:cover;
		background-attachment:fixed;
		border-right:2px solid #fff;
		padding-top:10px;
		top:0;
		left:-100%;
		width:260px;
		height:100vh;
		position:fixed;
		overflow-y:auto;
		z-index:502;
		transition:.5s;
	}
	.open .nav_list{
		left:0;
	}
	#nav_bg{
		background:#000;
		top:0;
		left:0;
		width:100vw;
		height:100vh;
		position:fixed;
		z-index:501;
		opacity:0;
		transition:.5s;
		visibility:hidden;
	}
	.open #nav_bg{
		opacity:0.3;
		visibility:visible;
	}
	#acd{
		margin:15px auto 120px auto;
	}
	.cite_s, .cite_m{
		width:100%;
	}
	.left{
		padding-top:35px;
	}
	.logo div{
		font-size:10px;
		line-height:10px;
		top:-3px;
		right:calc(50% - 45px);
	}
	.logo img{
		height:125px;
	}
	.home_guide{
		font-size:12px;
		color:rgb(240, 180, 180);
		line-height:15px;
		top:40px;
		left:50px;
		position:absolute;
	}
	.home_guide span{
		margin-left:35px;
		transform:rotate(200deg);
	}
	.nav_guide{
		font-size:12px;
		color:rgb(240, 180, 180);
		top:65px;
		right:25px;
		position:absolute;
	}
	.nav_guide .material-icons{
		transform:rotate(90deg);
	}
	.topics{
		width:calc(100% - 155px) !important;
		display:block;
	}
	.topics_t, .weather_t{
		font-size:14px;
	}
	.topics_c{
		font-size:13px;
		padding:3px;
		height:115px;
	}
	.topics_c li{
		line-height:14px;
	}
	.weather{
		width:130px;
		display:block;
	}
	.weather_1, .weather_2, .weather_3{
		height:36px;
	}
	.weather_days, .weather_icon{
		float:left;
	}
	.weather_days{
		width:45px;
	}
	.weather_c{
		margin:0 2px 0 3px;
	}
	.weather_icon{
		width:75px;
	}
	.qr, #page_top{
		display:none;
	}
	.content{
		margin:10px;
	}
	.con_img{
		text-align:center;
		margin:20px 0 10px 0;
		float:none;
	}
	.con_img img{
		width:100%;
	}
	.con{
		padding:10px;
	}
	.map_b{
		margin:10px auto;
		width:calc(100% - 20px);
	}
	.map_s{
		width:calc(100% - 10px);
	}
	.footer, .footer a, .footer_sha, .footer_sha a{
		color:#eee;
	}
	.slidetable_guide:before{
		content:"スワイプしてご覧ください →";
	}
	.slidetable{
		overflow-x:scroll;
	}
	.slidetable table:first-child{
		min-width:600px;
	}
	.slidetable table th{
		white-space:nowrap;
	}
	.insert-pc{
		display:none;
	}
}
@media (min-width:768px){
	body::-webkit-scrollbar, div::-webkit-scrollbar{
		width:10px;
	}
	body::-webkit-scrollbar-track, div::-webkit-scrollbar-track{
		background:transparent;
		//background-image:url("../img/kabe_scroll.png");
	}
	body::-webkit-scrollbar-thumb, div::-webkit-scrollbar-thumb{
		background:#ccc;
		border-radius:50px;
	}
	.cite_s, .cite_m{
		width:250px;
	}
	.left{
		vertical-align:top;
		padding:50px 10px 0 10px;
		width:240px;
		display:inline-block;
	}
	.logo div{
		font-size:14px;
		line-height:14px;
		top:-5px;
		right:calc(50% - 60px);
	}
	.logo img{
		height:150px;
	}
	.home_guide, .nav_guide{
		display:none;
	}
	#acd{
		margin:15px auto 30px auto;
	}
	#page_top{
		bottom:-100px;
		left:80px;
		position:fixed;
	}
	#page_top img{
		width:100px;
		opacity:0.7;
	}
	#page_top img:hover{
		margin-bottom:10px;
		opacity:1;
		transition:.5s;
	}
	.topics{
		width:calc(100% - 310px);
	}
	.topics_t, .weather_t{
		font-size:16px;
	}
	.topics_c{
		font-size:14px;
		margin-top:2px;
		height:70px;
	}
	.topics_c li{
		line-height:15px;
	}
	.weather{
		width:275px;
	}
	.weather_t{
		position:relative;
	}
	.weather_t::before, .weather_t::after{
		font-size:12px;
		margin-left:5px;
		top:0;
		position:absolute;
		opacity:0;
		transition:.5s;
	}
	.weather_t::before{
		content:attr(data-left);
		left:0;
	}
	.weather_t::after{
		content:attr(data-right);
		right:0;
	}
	.weather_t:hover::before, .weather_t:hover::after{
		opacity:1;
	}
	.weather_days{
		margin-right:5px;
	}
	.weather_c{
		margin:0 5px;
	}
	.weather_1, .weather_2, .weather_3{
		position:relative;
		cursor:pointer;
	}
	.weather_1::after, .weather_2::after, .weather_3::after{
		content:attr(data-tooltip);
		font-size:13px;
		line-height:14px;
		color:#fff;
		background:#555;
		margin-left:-50px;
		padding:6px;
		top:0;
		width:80px;
		position:absolute;
		border-radius:5px;
		z-index:100;
		opacity:0;
		transition:.5s;
		white-space:pre-wrap;
	}
	.weather_1:hover::after, .weather_2:hover::after, .weather_3:hover::after{
		top:40px;
		opacity:1;
	}
	.weather_icon{
		margin-top:3px;
	}
	.right{
		width:calc(100% - 280px);
		display:inline-block;
	}
	.h1{
		letter-spacing:3px;
	}
	.con_img img{
		width:calc(100vw - 770px);
		min-width:150px;
	}
	.con{
		padding:20px;
		max-width:900px;
	}
	.map_b{
		margin:10px auto 20px auto;
		width:calc(100% - 150px);
	}
	.map_s{
		width:calc(100vw - 500px);
		max-width:600px;
		min-width:280px;
	}
	.slidetable_guide{
		display:none;
	}
	.slidetable_guide:before{
		content:"スライドしてご覧ください →";
	}
	.insert-sp{
		display:none;
	}
}