@charset "utf-8";
/************************************************************
PC
************************************************************/
@media all and (min-width:769px){
.sp {
	display: none;
}
/*news*/
#news {
	width: 100%;
	max-width: 1500px;
	margin: 0 auto;
	padding: 220px 0px 165px;
}
	#news h2 {
		width: 100%;
		max-width: 1262px;
		margin: auto auto 90px;
		text-align: center;
		line-height: 1.2;
	}
	#news h2 .news-en {
		font-size: 50px;
		letter-spacing: 0.1em;
		font-family: 'Lato', sans-serif;
		vertical-align: middle;
	}
	#news h2 .news-ja {
		font-size: 14px;
		font-weight: 400;
		vertical-align: middle;
	}
	#news .inner {
		width: 90%;
		max-width: 1262px;
		margin: auto;
	}
	#news .inner .container {
		width: 100%;
		max-width: 840px;
		margin: auto;
		text-align: justify;
	}
	#news .inner .detail-text h1,
	#news .inner .detail-text h2,
	#news .inner .detail-text h3{margin-bottom: 3%; text-align: left;}
	#news .inner .detail-text h1{font-size: 24px; letter-spacing: 0.1em; margin-bottom: 2%; line-height: 1.4em; color:#333;border-left: 3px solid #e94c07; padding-left: 2%;}
	#news .inner .detail-text h2{font-size: 22px; letter-spacing: 0.1em; margin-bottom: 2%; line-height: 1.4em; color:#333;border-left: 3px solid #e94c07; padding-left: 2%;}
	#news .inner .detail-text h3{font-size: 20px; letter-spacing: 0.1em; margin-bottom: 2%; line-height: 1.4em; color:#333;border-left: 3px solid #e94c07; padding-left: 2%;}
	#news .inner .detail-text h4{font-size: 18px; letter-spacing: 0.1em; margin-bottom: 2%; line-height: 1.4em; color:#333;border-left: 3px solid #e94c07; padding-left: 2%;}
	#news .inner .container strong{
	}
	#news .inner .container .text-1 {
		font-size: 14px;
		font-family: 'Lato', sans-serif;
		letter-spacing: 0.1em;
		margin-bottom: 5px;
	}
	#news .inner .container .category-name {
		padding: 4px 15px;
		margin-left: 5px;
		font-size: 12px;
		color: #ffffff;
		background-color: #fbc429;
		border-radius: 2px;
	}
	#news .inner .container .text-2 {
		clear: left;
		font-size: 32px;
		font-weight: 600;
		margin-bottom: 25px;
		letter-spacing: 0.1em;
	}
	#news .inner .container .image-1 {
		width: 100%;
		margin-bottom: 10px;
	}
	#news .inner .container .image-1 img {
		width: 100%;
	}
	#news .inner .container .text-3 {
		font-size: 16px;
		margin: 12px auto 50px;
		line-height: 1.9em;
	}
	#news .inner .container .image-2 {
		width: 100%;
	}
	#news .inner .container .image-2 img {
		width: 100%;
	}
	#news .inner .container .text-4 {
		font-size: 16px;
		margin: 12px auto 50px;
		line-height: 1.9em;
	}
	#news .inner .container .detail-text p {
		font-size: 16px;
		margin: 0 auto 50px;
		line-height: 1.9em;
	}
		#news .inner .container .detail-text p strong{
		font-weight: bold;
    background-color: #ffff00;
	}
	#news .inner .buttons {
width: 100%;
    display: flex;
    max-width: 840px;
    margin: 80px auto 0;
    }
	#news .inner .buttons .back {
		display: inline-block;
		width: 35%;
		max-width: 400px;
		padding: 30.5px 0px;
		margin: auto auto auto 0px;
		background-color: #333333;
		font-size: 16px;
		text-align: center;
		color: #ffffff;
		border-radius: 3px;
	}
	#news .inner .buttons .contact {
		display: inline-block;
		width: 62%;
		max-width: 600px;
		padding: 30.5px 0px;
		margin: auto 0px auto auto;
		background-color: #e60012;
		font-size: 16px;
		text-align: center;
		color: #ffffff;
		border-radius: 3px;
	}
	#news .background {
		width: 100%;
		text-align: right;
		position: absolute;
		top: 65px;
		right: 0;
		z-index: -1;
	}
	#news .background img {
		width: 510px;
	}

/*archive*/
#archive {
	width: 100%;
	padding: 60px 0px 90px;
	margin: 0 auto;
	background-color: #f1f1f1;
}
	#archive h2 {
		width: 90%;
		max-width: 1000px;
		margin: auto auto 35px;
	}
	#archive h2 .news-en {
		font-size: 32px;
		letter-spacing: 0.1em;
		font-family: 'Lato', sans-serif;
		margin-right: 15px;
		vertical-align: middle;
	}
	#archive h2 .news-ja {
		font-size: 15px;
		font-weight: 400;
		vertical-align: middle;
	}
	#archive .inner {
		width: 90%;
		max-width: 1000px;
		margin: auto;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	#archive .inner::after {
		content: "";
		display: block;
		width: 31%;
		max-width: 310px;
	}
	#archive .inner .container {
		width: 31%;
		max-width: 310px;
	}
	#archive .inner .container .image {
		width: 100%;
	}
	#archive .inner .container .image img {
		width: 100%;
	}
	#archive .inner .container .detail {
		padding: 20px 15px 15px;
		background-color: #ffffff;
	}
	#archive .inner .container .detail .text-1 {
		font-size: 11px;
		font-family: 'Lato', sans-serif;
		letter-spacing: 0.1em;
		margin-bottom: 5px;
	}
	#archive .inner .container .detail .text-2 {
		font-size: 16px;
		font-weight: 600;
		margin-bottom: 15px;
		line-height: 1.3;
		letter-spacing: 0.1em;
	}
	#archive .inner .container .detail .text-3 {
		font-size: 12px;
		margin-bottom: 30px;
	}
	#archive .inner .container .detail .text-4 {
		font-size: 14px;
		font-weight: 600;
	}
/*category*/
#category {
	width: 100%;
	padding: 48px 0px;
	margin: 0 auto;
	background-color: #fbc429;
}
	#category .inner {
		width: 90%;
		max-width: 840px;
		margin: auto;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	#category .inner::after {
		content: "";
		display: block;
		width: 33%;
		max-width: 278px;
	}
	#category .inner a {
		display: inline-block;
		width: 33%;
		max-width: 278px;
		padding: 22px 0px;
		margin-bottom: 3px;
		background-color: #ffffff;
		color: #000000;
		font-size: 16px;
		font-weight: 600;
		text-align: center;
		transition: .2s;
	}
	#category .inner a:hover {
		background-color: #f1f1f1;
	}
#category .category {
		width: 100%;
		max-width: 1262px;
		margin: 0 auto auto;
	}
	#category .category .category-box {
    max-width: 1200px;
    text-align: center;
    margin: 0 auto;
    padding: 0;
    display: block;}
	#category .category .category-box .btn {
    width: 12%;
    padding: 24px 0px;
    margin: 0px;
    display: inline-block;
    font-size: 14px;
    color: #000000;
    letter-spacing: 0.15em;
    background-color: #ffffff;
    text-decoration: none;
    transition: .2s;
    outline: none;	}
	#category .category .category-box .btn:hover{
		color: #ffffff;
		background-color: #e94c07;
	}}

/************************************************************
SP
************************************************************/
@media all and (max-width:768px){
/*news*/
#news {
	width: 100%;
	max-width: 1500px;
	margin: 0 auto;
	padding: 25px 0px 80px;
}
	#news h2 {
		width: 90%;
		max-width: 600px;
		margin: auto auto 45px;
		text-align: center;
		line-height: 1.2;
	}
	#news h2 .news-en {
		font-size: 36px;
		letter-spacing: 0.1em;
		font-family: 'Lato', sans-serif;
		vertical-align: middle;
	}
	#news h2 .news-ja {
		font-size: 16px;
		font-weight: 400;
		vertical-align: middle;
	}
	#news .inner {
		width: 90%;
		max-width: 600px;
		margin: auto;
	}
	#news .inner .container {
		width: 100%;
		margin-bottom: 18%;
		text-align: justify;
		
	}
	#news .inner .container .text-1 {
		font-size: 12px;
		font-family: 'Lato', sans-serif;
		letter-spacing: 0.1em;
		margin-bottom: 5px;
	}
	#news .inner .container .category-name {
		font-size: 12px;
		padding: 4px 15px;
		margin-left: 5px;
		color: #ffffff;
		background-color: #fbc429;
		border-radius: 2px;
	}
	#news .inner .container .text-2 {
		clear: left;
		font-size: 24px;
		font-weight: 600;
		margin-bottom: 15px;
		letter-spacing: 0.1em;
		line-height: 1.4em;
	}
	#news .inner .container .image-1 {
		width: 100%;
	}
	#news .inner .container .image-1 img {
		width: 100%;
	}
	#news .inner .container .text-3 {
		font-size: 12px;
		margin: 15px auto 35px;
		line-height: 2.0;
	}
	#news .inner .container .image-2 {
		width: 100%;
	}
	#news .inner .container .image-2 img {
		width: 100%;
	}
	#news .inner .container .text-4 {
		font-size: 12px;
		margin: 15px auto 35px;
		line-height: 2.0;
	}
	#news .inner .buttons {
		width: 100%;
		display: flex;
		flex-flow: column nowrap;
	}
	#news .inner  .buttons .back {
		display: inline-block;
		width: 100%;
		padding: 20px 0px;
		margin: auto auto 10px;
		background-color: #333333;
		font-size: 14px;
		text-align: center;
		color: #ffffff;
		border-radius: 3px;
	}
	#news .inner .buttons .contact {
		display: inline-block;
		width: 100%;
		padding: 20px 0px;
		margin: auto auto auto;
		background-color: #e60012;
		font-size: 14px;
		text-align: center;
		color: #ffffff;
		border-radius: 3px;
	}
	#news .background {
		width: 100%;
		text-align: right;
		position: absolute;
		top: 65px;
		right: 0;
		z-index: -1;
	}
	#news .background img {
		width: 90%;
	}
	#news .inner .detail-text h1,
	#news .inner .detail-text h2,
	#news .inner .detail-text h3{margin-bottom: 3%}
	#news .inner .detail-text h1{font-size: 20px; letter-spacing: 0.1em; margin-bottom: 4%; line-height: 1.4em; color:#333;border-left: 3px solid #e94c07; padding-left: 2%;}
	#news .inner .detail-text h2{font-size: 18px; letter-spacing: 0.1em; margin-bottom: 4%; line-height: 1.4em; color:#333;border-left: 3px solid #e94c07; padding-left: 2%;}
	#news .inner .detail-text h3{font-size: 16px; letter-spacing: 0.1em; margin-bottom: 4%; line-height: 1.4em; color:#333;border-left: 3px solid #e94c07; padding-left: 2%;}
	#news .inner .detail-text h4{font-size: 14px; letter-spacing: 0.1em; margin-bottom: 4%; line-height: 1.4em; color:#333;border-left: 3px solid #e94c07; padding-left: 2%;}
/*archive*/
#archive {
	width: 100%;
	padding: 30px 0px 45px;
	margin: 0 auto;
	background-color: #f1f1f1;
}
	#archive h2 {
		width: 90%;
		max-width: 600px;
		margin: auto auto 40px;
		text-align: center;
		line-height: 1.2;
	}
	#archive h2 .news-en {
		font-size: 32px;
		letter-spacing: 0.1em;
		font-family: 'Lato', sans-serif;
		vertical-align: middle;
	}
	#archive h2 .news-ja {
		font-size: 15px;
		font-weight: 400;
		vertical-align: middle;
	}
	#archive .inner {
		width: 90%;
		max-width: 1000px;
		margin: auto;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
/*	#archive .inner::after {
		content: "";
		display: block;
		width: 31%;
		max-width: 310px;
	}
*/
	#archive .inner .container {
		width: 100%;
		max-width: 450px;
		margin: auto auto 25px;
	}
	#archive .inner .container .image {
		width: 100%;
	}
	#archive .inner .container .image img {
		width: 100%;
	}
	#archive .inner .container .detail {
		padding: 20px 15px 15px;
		background-color: #ffffff;
	}
	#archive .inner .container .detail .text-1 {
		font-size: 10px;
		font-family: 'Lato', sans-serif;
		letter-spacing: 0.1em;
		margin-bottom: 5px;
	}
	#archive .inner .container .detail .text-2 {
		font-size: 16px;
		font-weight: 600;
		margin-bottom: 10px;
		line-height: 1.3;
		letter-spacing: 0.1em;
	}
	#archive .inner .container .detail .text-3 {
		font-size: 12px;
		margin-bottom: 30px;
	}
	#archive .inner .container .detail .text-4 {
		font-size: 14px;
		font-weight: 600;
	}
/*category*/
#category {
	width: 100%;
	padding:5% 0px;
	margin: 0 auto;
	background-color: #fbc429;
}
	#category .inner {
		width: 90%;
		max-width: 600px;
		margin: auto;
		text-align: center;
	}
/*
	#category .inner::after {
		content: "";
		display: block;
		width: 33%;
		max-width: 278px;
	}
*/
	#category .inner a {
		display: inline-block;
		width: 100%;
		max-width: 288px;
		padding: 20px 0px;
		margin-bottom: 5px;
		background-color: #ffffff;
		color: #000000;
		font-size: 16px;
		font-weight: 600;
		text-align: center;
		transition: .2s;
	}
	#category .inner a:hover {
		background-color: #f1f1f1;
	}
		#news .inner .container .detail-text p {
		font-size: 14px;
		margin: 12px auto 20px;
		line-height: 1.7em;
	}
		#news .inner .container .detail-text p strong{
    background-color: #ffff00;
    font-weight: bold;
	}
	#category .category {
		width: 100%;
		max-width: 1262px;
		margin: 0 auto auto;
	}
	#category .category .category-box {
		width: 90%;
		text-align: center;
		margin: 0 auto auto;
		padding: 0;
	}
	#category .category .category-box .btn {
		width: 32%;
		padding: 20px 0px;
		margin-bottom: 2%;
		display: inline-block;
		font-size: 12px;
		color: #000000;
		letter-spacing: 0.15em;
		background-color: #ffffff;
		text-decoration: none;
		transition: .2s;
		outline: none;
	}
	#category .category .category-box .btn:hover{
		color: #ffffff;
		background-color: #fbc429;
	}
	#category .category .category-box .active {
		color: #ffffff;
		background-color: #fbc429;
	}
}

/************************************************************
HTML TAGS
************************************************************/
*{
	margin:0;
	padding:0px;
}

body {
	margin: 0px;
	padding: 0px;
	background-color: #f9f9f9;
	color:#000000;
	font-style: normal;
	font-size: 16px;
	line-height: 1.7;
	letter-spacing:1px;
	font-feature-settings : "palt";
	letter-spacing: 0.075em;
	-webkit-text-size-adjust: 100%;
	font-family: "游ゴシック体", "Yu gosic", Yugosic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
	font-weight: 400;
	font-style: normal;
	-webkit-font-feature-settings: 'pkna';
	font-feature-settings: 'pkna';
}


::selection {
	background: #000033; /* Safari */
	color: #fff;
}

::-moz-selection {
	background: #000033; /* Firefox */
	color: #fff;

}

h1{}

h2{}

h3{}

h4{}

h5{}

p{
	font-weight: normal;
	letter-spacing: 0.01em;
	font-size: 16px;
	line-height: 1.7;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

th{line-height:1.5;}

td{line-height:1.5;}

ul,ol{list-style-type:none;	color:#666666;
}

li img, dt img, dd img{vertical-align:bottom;}

hr{margin:0px;padding:0px;}


a{
	outline:none;
	text-decoration:none;
}
img {
	vertical-align: top;
}
a img{
	border:none;
}
button{
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	font-family: "游ゴシック体", "Yu gosic", Yugosic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
	font-weight: 400;
}
/* custom size*/
p,li,dt,dd,th,td{
	font-size:16px;
	letter-spacing: 0.01em;
}

textarea{
	font-size:93%;
}

.clear{
	clear:both;
	font-size:0;
	line-height:0;
	height:0;
}

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

.clearfix {
  min-height: 1px;
}

* html .clearfix {
  height: 1px;
  /*ﾂ･*//*/
  height: auto;
  overflow: hidden;
  /**/
}