/*
<meta name="viewport" content="width=device-width, user-scalable=yes, maximum-scale=1.0, minimum-scale=1.0, target-densitydpi=device-dpi">
<link rel="stylesheet" href="./css/main-style.css" type="text/css" media="screen">
*/
@charset "utf-8";

* {
	margin:0;
	padding:0;
}

body {
	font-family: "Yu Gothic", "YuGothic", meiryo,  serif;
	letter-spacing: 0.1em;
}

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

.clearfix{
	display: inline-block;
}

/* Hides from IE Mac */
* html .clearfix{
	height: 1%;
}

.clearfix{
	display:block;
}

img { 
	max-width: 100%; 
	height: auto; 
}

.shadow {
	margin-top: 0px; /* 画像の上の余白*/
	display: inline-block; 
	box-shadow: 0px 5px 15px -5px rgba(0, 0, 0, 0.8); /*横方向　下方向　ぼかし　広がり　色 */
}

.text-center {
	text-align: center;
}

.text-left {
	text-align: left;
}

.text-right {
	text-align: right;
}

.box-center {
	margin-left: auto;
	margin-right: auto;
	margin-top: auto;
	margin-bottom: auto;
}

.link-style {
	text-decoration: none;
	display: block;
}

a:link,
a:visited {
	color: black;
	text-decoration:none;
}

a:hover,
a:active {
	color: orangered;
	transition: all  0.5s ease;
}

a img {
	border:none;
}

a:hover img {
	opacity: 0.8;
	filter: alpha(opacity=80);
	-moz-opacity:0.8;
}

#page-top {
    position: fixed;
    bottom: 57px;
    right: 10px;
    font-size: 70%;
}

#page-top a {
    background: rgba(10,10,10,0.8);
    text-decoration: none;
    color: #fff;
    width: 100px;
	height: 15px;
    padding: 10px 0px;
    text-align: center;
    display: block;
    border-radius: 5px;
}

#page-top a:hover {
    text-decoration: none;
    background: rgba(200,200,200,0.6);
}

/* ▽▽▽　PC用CSS START */
@media only screen and (min-width:960px){
	.h1-div {
		background-color: black;
		height: auto;
		padding-top: 10px;
		padding-bottom: 10px;
		width: 100%;
		float: left
	}
	
	.h1-layout {
		font-size: 30px;
	}
	
	.h2-div {
		background-color: lightgray;
		height: 70px;
		outline: solid 1px black;
		float: left;
		display: block;
	}

	.h2-div-round {
		background-color: lightgray;
		height: 70px;
		float: left;
		display: block;
		border-radius: 50px;
		box-shadow: 0 0 0 1px black;
		margin: 5px 0px;
	}
	
	.h2-layout {
		height: 30px;
		font-size: 25px;
		padding-top: 20px;
		padding-bottom: 20px;
	}
	
	.text-size {
		font-size: 18px;
	}
	
	.menu-size {
		font-size: 15px;
	}
	
	.text-color0 {
		color: black;
	}
	
	.text-color1 {
		color: white;
	}
	
	.text-margin {
		margin: 5px;
	}
}
/* △△△　PC用CSS END */
/* ▽▽▽　Tablet用CSS START */
@media only screen and (max-width:960px){
	.h1-div {
		background-color: black;
		height: auto;
		padding-top: 10px;
		padding-bottom: 10px;
		width: 100%;
		float: left
	}
	
	.h1-layout {
		font-size: 30px;
	}
	
	.h2-div {
		background-color: lightgray;
		height: 70px;
		outline: solid 1px black;
		float: left;
		display: block;
	}
	
	.h2-layout {
		height: 30px;
		font-size: 25px;
		padding-top: 20px;
		padding-bottom: 20px;
	}
	
	.text-size {
		font-size: 16px;
	}
	
	.menu-size {
		font-size: 11.5px;
	}
	
	.text-color0 {
		color: black;
	}
	
	.text-color1 {
		color: white;
	}
	
	.text-margin {
		margin: 5px;
	}
}
/* △△△　Tablet用CSS END */
/* ▽▽▽　Tablet用CSS START */
@media only screen and (max-width:600px){
	.h1-div {
		background-color: black;
		height: auto;
		padding-top: 10px;
		padding-bottom: 10px;
		width: 100%;
		float: left
	}
	
	.h1-layout {
		font-size: 30px;
	}
	
	.h2-div {
		background-color: lightgray;
		height: 70px;
		outline: solid 1px black;
		float: left;
		display: block;
	}
	
	.h2-layout {
		height: 20px;
		font-size: 20px;
		padding-top: 25px;
		padding-bottom: 25px;
	}
	
	.text-size {
		font-size: 15px;
	}
	
	.menu-size {
		font-size: 9.5px;
	}
	
	.text-color0 {
		color: black;
	}
	
	.text-color1 {
		color: white;
	}
	
	.text-margin {
		margin: 5px;
	}
}
/* △△△　Tablet用CSS END */
/* ▽▽▽　smartphone用CSS START */
@media only screen and (max-width:480px){
	.h1-div {
		background-color: black;
		height: auto;
		padding-top: 10px;
		padding-bottom: 10px;
		width: 100%;
		float: left
	}
	
	.h1-layout {
		font-size: 30px;
	}
	
	.h2-div {
		background-color: lightgray;
		height: 70px;
		outline: solid 1px black;
		float: left;
		display: block;
	}
	
	.h2-layout {
		height: 20px;
		font-size: 20px;
		padding-top: 25px;
		padding-bottom: 25px;
	}
	
	.text-size {
		font-size: 15px;
	}
	
	.menu-size {
		font-size: 13px;
	}
	
	.text-color0 {
		color: black;
	}
	
	.text-color1 {
		color: white;
	}
	
	.text-margin {
		margin: 5px;
	}
}
/* △△△　smartphone用CSS END */
/* ▽▽▽　old-device用CSS START */
@media only screen and (max-width:320px){
	.h1-div {
		background-color: black;
		height: auto;
		padding-top: 10px;
		padding-bottom: 10px;
		width: 100%;
		float: left
	}
	
	.h1-layout {
		font-size: 30px;
	}
	
	.h2-div {
		background-color: lightgray;
		height: 70px;
		outline: solid 1px black;
		float: left;
		display: block;
	}
	
	.h2-layout {
		height: 20px;
		font-size: 15px;
		padding-top: 25px;
		padding-bottom: 25px;
	}
	
	.text-size {
		font-size: 18px;
	}
	
	.menu-size {
		font-size: 15px;
	}
	
	.text-color0 {
		color: black;
	}
	
	.text-color1 {
		color: white;
	}
	
	.text-margin {
		margin: 5px;
	}
}
/* △△△　old-device用CSS END */