@charset "UTF-8";
/* CSS Document */


body{
	font-size: 16px;
	font-family:'小塚ゴシック Pro L','Kozuka Gothic Pro L',sans-serif ;
}

@font-face {font-family: "Acumin Variable Concept Thin";
	src:url("../font/AcuminVariableConcept.woff") format("woff"), 
	url("../font/AcuminVariableConcept.otf") format("opentype"); 
}

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

header{
	background: url( ../img/main.png) no-repeat;
	background-size: cover;
	height: 43vw;
}

h1{
	margin: 0 auto;
	display: block;
	position: absolute;
	top: 50px;
	left: 12%;
	width: 50%;
}

h1 img{
	width: 55%;
}

h1 span{
	display: block;
	width: 53%;
	text-align: center;
	margin-top: 15px;
	font-size: 23px;
}

main{
	max-width: 1000px;
	width: 100%;
	margin: 80px auto 0;
	
}

h2{
	font-family: 'Raleway', sans-serif;
	font-size: 32px;
	text-align: center;
	font-weight: 100;
	margin-bottom: 54px;
}

h2 span{
	border-bottom: 2px solid #000;
	padding: 0 0 7px 0;
}

h2 span::after {
	content: "";
	border-bottom: 2px solid #000;
	position: relative;
	top: 11px;
	width: 151px;
	height: 3px;
	display: block;
	text-align: center;
	margin: 0 auto;
}

h2 span.ttl_works::after {
	content: "";
	border-bottom: 2px solid #000;
	position: relative;
	top: 11px;
	width: 118px;
	height: 3px;
	display: block;
	text-align: center;
	margin: 0 auto;
}

.ttl_jp{
	text-align: center;
	margin-top: 27px;
	font-size: 20px;
	display: block;
	font-style: normal;
}

h3{
	line-height: 1.4;
    text-align: center;
	margin-bottom: 20px;
	font-size: 20px;
}

.concept p{
	text-align: center;
	line-height: 2.5;
	margin-bottom: 70px;
}

.concept{
	margin-bottom: 110px;
}

.works{
	margin-bottom: 110px;
}

.works ul{
	display: flex;
	justify-content: space-around;
	width: 90%;
	margin: 0 auto;
}

.works ul span{
	display: block;
	text-align: center;
	margin-top: 20px;
}

.works p{
	border: 2px solid #999;
	padding: 30px;
	border-radius: 50%;
}

.works li{
	width: 24%;
}

h2 span.ttl_company::after {
	content: "";
	border-bottom: 2px solid #000;
	position: relative;
	top: 11px;
	width: 333px;
	height: 3px;
	display: block;
	text-align: center;
	margin: 0 auto;
}

.company{
	margin-bottom: 110px;
}

table {
	  margin: 20px auto;

}
.tbl-r02 th {
	  border: solid 1px #999;
	  padding: 15px;
	vertical-align: middle;
}
.tbl-r02 td {
	  border: solid 1px #999;
	  padding: 10px 15px;
	width: 74%;
	line-height: 2;
	box-sizing: border-box;
}

td span{
	margin-left: 15px;
}

h2 span.ttl_access::after {
	content: "";
	border-bottom: 2px solid #000;
	position: relative;
	top: 11px;
	width: 123px;
	height: 3px;
	display: block;
	text-align: center;
	margin: 0 auto;
}

.access p{
	text-align: center;
	margin-bottom: 20px;
	line-height: 1.7;
}

.access ul{
	margin-bottom: 30px;
}

.access li{
	text-align: center;
	line-height: 2;
}

iframe{
	width: 100%;
	height: 30vw;
}

footer p{
	width: 10%;
	margin: 20px auto 20px;
}

small{
	display: block;
	text-align: center;
	margin-top: 10px;
	padding-bottom: 10px;
}



@media screen and (max-width: 768px){


.works li {
    width: 26%;
}
	table {
    margin: 20px auto;
}

.tbl-r02 td {
    border: solid 1px #999;
    padding: 10px 15px;
    width: auto;
    line-height: 2;
    box-sizing: border-box;
}
}

@media screen and (max-width: 640px) {
.last td:last-child {
    border-bottom: solid 1px #ccc;
    width: 100%;
  }

  .tbl-r02 {
    width: 80%;
  }

  .tbl-r02 th,
  .tbl-r02 td {
　　border-bottom: none;
    display: block;
    width: 100%;
	  box-sizing: border-box;
	  text-align: center;
  }
	
h1 span{
	display: block;
	width: 53%;
	text-align: center;
	margin-top: 15px;
	font-size: 23px;
}
}

@media screen and (max-width:575px){
h1 span{
	display: block;
	width: 53%;
	text-align: center;
	margin-top: 15px;
	font-size: 17px;
}
}

@media screen and (max-width:425px){
h1 {
    margin: 0 auto;
    display: block;
    position: absolute;
    top: 18px;
    left: 12%;
    width: 50%;
}
	
h1 span{
	display: block;
	width: 53%;
	text-align: center;
	margin-top: 15px;
	font-size: 4vw;
}

main{
		padding: 0 20px;
		box-sizing: border-box;
}
.works ul {
    display: inline-block;
    width: 100%;
    margin: 0 auto;
}
	
.works li {
    text-align: center;
    width: 54%;
    margin: auto;
}
	
.works p {
    border: 2px solid #999;
    padding: 30px 32px;
    border-radius: 50%;
    display: inline-block;
}
	
.works ul span {
    display: block;
    text-align: center;
    margin-top: 10px;
    margin-bottom: 40px;
}
	
.tbl-r02 th, .tbl-r02 td {
	line-height: 1.5;
}
	
.tbl-r02 th {
    border-bottom: none;
    display: block;
    width: 100%;
    box-sizing: border-box;
    text-align: center;
	background: #ccc;
}

td span{
	display: block;
	margin-left: 0;
}
	
iframe {
    width: 100%;
    height: 70vw;
}
	
footer p {
    width: 30%;
    margin: 20px auto 0;
}
}

@media screen and (max-width:375px){
header {
    background: url(../img/main.png) no-repeat;
    background-size: cover;
    height: 55vw;
    background-position: -71px 0;
}

h2 span::after {
    width: 124px;
}
h1 {
    margin: 0 auto;
    display: block;
    position: absolute;
    top: 20px;
    left: 6%;
    width: 50%;
}
	
h1 span{
	display: block;
	width: 53%;
	text-align: center;
	margin-top: 15px;
	font-size: 14px;
}

h2 span.ttl_company::after {
    width: 273px;
}

.address{
	font-size: 14px;
	}
	
h2{
	font-size: 26px;
}
	
.concept p {
    text-align: left;
}
	
h2 span.ttl_works::after {
    width: 96px;
}
	
.access ul {
    font-size: 14px;
}
	
.access li {
    text-align: center;
    line-height: 2;
    font-size: 14px;
}
	
.tbl-r02 {
    width: auto;
}
	
h2 span.ttl_access::after {
    width: 99px;
}
}

@media screen and (max-width:350px){
	h1 span{
	display: block;
	width: 53%;
	text-align: center;
	margin-top: 15px;
	font-size: 12px;
}
}

