/* CSS Document */

/* all
---------------------------------------------------------------------------*/
html {
	font-size: 62.5%;/*10pxと同様*/
}
body {
	font-family:メイリオ, Meiryo, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', 游ゴシック体, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	font-family: 'Outfit', sans-serif;
    background-color: #202E6A;
    color: #FFF;
}
img {
	max-width: 100%;
	height: auto;
	border: none;
	line-height: 0;
	vertical-align: bottom;
}
a {
	text-decoration: none;
    color: #FFF;
}
h2 {
	font-weight: 600;
}
h3 {
	font-weight: 500;
}
#wrapper {
	overflow: hidden;
}
main {
    width: auto;
	margin: 0 auto;
}
.site_wrapper {
	width:1200px;
	margin: 0 auto;
}
.site_wrapper02 {
	width: 700px;
	margin: 0 auto;
}
.tit {
	text-align: center;
	font-size: 8.0em;
	margin-bottom: 50px;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
    main {width: auto;margin: 0 auto;}
	.site_wrapper {width: 90%;margin: 0 auto;}
	.site_wrapper02 {width: 60%;margin: 0 auto;}
	.tit {font-size: 4.0em;}
}
@media screen and (max-width: 767px) {
.site_wrapper {width: 95%;margin: 0 auto;}
.site_wrapper02 {width: 95%;margin: 0 auto;}
.tit {font-size: 4.0em;}
}

/* header
---------------------------------------------------------------------------*/
.header {
	position: fixed;
	width: 100%;
	height: 80px;
    box-sizing: border-box;
	transition: all .5s;
    padding-right: 30px;
    margin: auto;
	z-index: 100;
}
.header .header_nav {
	position: relative;
	width: 100%;
	display: flex;
	justify-content: flex-end;
    align-items: center;
	padding-top: 10px;
    margin: 0 auto;
}
.header .header_nav_list {
	display: flex;
	justify-content: space-between;
	margin: 0;
}
.header .header_nav_items {
	padding: 20px 30px;
    font-size: 2.2rem;
}
.header .header_nav_items a {
    position: relative;
}
.header .header_nav_items a::after {
	content: '';
    position: absolute;
	width: 100%;
    height: 2px;
	bottom: -5px;
    left: 0;
    background: #FFF;
    transition: all .3s;
    transform: scale(0, 1);
    transform-origin: center top;
}
.header .header_nav_items a:hover::after {
	transform: scale(1, 1);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
	.header .header_nav_items {padding: 20px 20px;font-size: 1.8rem;}
}
@media screen and (max-width: 767px) {
	.header {background: none;}
}
/*---menubar---*/
.header .header_nav_sp {
	position: fixed;
	width: 50px;
	top: 0px;
	right: 0px;
	transition: all 0.8s 0.4s ease;
	padding: 15px;
	z-index: 100;
}
.header .header_nav_sp .bar_icon {
    fill: #fff;
}
.bar_icon .cls-1 {
	transition: all 1s 0s ease;
}
.bar_icon .cls-2 {
	transition: all 1s 0s ease;
}
.bar_icon .cls-3 {
	transition: all 1s 0s ease;
}
.header_nav_sp.active .cls-1 {
	transform: translate(-11px,-7px);
}
.header_nav_sp.active .cls-3{
	transform: translate(-11px,-35px);
}
.nav_sp_menu {
	visibility: hidden;
	position: fixed;
    top: 0;
    z-index: 100;
    opacity: 0;
	background-color: #202E6A;
    width: 100%;
    height: 100vh;
	transition: opacity .6s ease, visibility .6s ease;
}
.nav_sp_menu .sp_menu_inner {
	position: relative; 
    padding: 120px 20px 30px;
}
.nav_sp_menu .sp_menu_inner .sp_menu_tit {
	width: 200px;
	margin: 0 auto 100px;
}
.nav_sp_menu .sp_menu_inner .sp_menu_tit img{
	padding-left: 15px;
}
.nav_sp_menu .sp_menu_inner ul {
	display: flex;
    flex-direction: column;
    align-items: center;
}
.nav_sp_menu .sp_menu_inner ul li {
	margin-bottom: 50px;
}
.nav_sp_menu .sp_menu_inner ul li span {
	font-size: 3.0rem;
}
.nav_sp_menu.panelactive {
	visibility: visible;
	opacity: 100;
	position: fixed;
    z-index: 90;
	transition: opacity .6s ease, visibility .6s ease;
  }

/* main
---------------------------------------------------------------------------*/
.mv {
	position: relative;
	background: linear-gradient(to bottom, transparent 0%, transparent 60%, #202E6A 95%), url(../images/mvbg_img.jpg);
	background-size: cover;
	width: 100%;
	height: 100vh;
	margin-bottom: 100px;
}
.mv .mv_inner {
	position: relative;
	width: 100%;
	height: 100%;
	margin: 0 auto;
}
.mv .mv_inner_txt {
	position: absolute;
	bottom: 40%;
	right: 5%;
	font-size: 16px;
}

@media screen and (max-width: 767px) {
    .mv .mv_inner_txt {bottom: 50%;}
}

/*--ourbusiness--*/
.kps-business {
    margin-bottom: 200px;
}
.kps-business .kps-business_inner {
	width: auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.kps-business .kps-business_inner_items{
	position: relative;
	margin-bottom: 40px;
}
.kps-business .kps-business_inner_items img {
	object-fit: cover;
	transition: 0.5s;
	width: 320px;
	height: 320px;
}
.kps-business .kps-business_inner_items img:hover{
	box-shadow: 0px 0px 20px 2px rgba(255,255,255,0.2);
	transform: scale(0.95);
}
.kps-business .kps-business_inner_txt{
	position: absolute;
	bottom: 80px;
	right: -18px;
	display: inline-block;
	font-size: 1.8rem;
	line-height: 25px;
	background-color: #202E6A;
	box-shadow: 4px 4px #fff;
	padding: 8px;
}
.kps-business .kps-business_inner_arrow{
	font-size: 2rem;
	line-height: 4rem;
	text-align: right;
}
.lineArrow {
	width: 40%;
	height: 15px;
	border-bottom: 1px solid #fff;
	border-right: 1px solid #fff;
	transform: skew(45deg);
	margin: -3px 0 0 190px;
}
.kps-business .kps-business_inner_logo{
	width: auto;
	text-align: center;
	padding-left: 30px;
}
@media only screen and (min-width: 768px) and (max-width: 1280px) {
	.kps-business .kps-business_inner{width: 760px;margin: 0 auto;}
	.kps-business .kps-business_inner_txt{left: 0;right: auto;}
}
@media screen and (max-width: 767px) {
	.kps-business .kps-business_inner{flex-direction: column;align-items: center;}
	.kps-business .kps-business_inner_items img{width: 220px;height: 220px;}
	.kps-business .kps-business_inner_txt{font-size: 1.4rem;}
	.lineArrow{	margin: -3px 0 0 120px;}
}


/*--companyinfo--*/
.kps-info {
	margin-bottom: 200px;
}
.kps-info .kps-info_inner {
	margin: auto;
}
.kps-info  .kps-info_inner .kps-info_table table {
	width: 100%;
	text-align: left;
	border-bottom: solid 1px #FFF;
	font-size: 1.4rem;
	padding: 15px 0;
	margin-bottom: 30px;
}
.kps-info  .kps-info_inner .kps-info_table tr {
	display: table-row;
}
.kps-info .kps-info_table th {
	width: 190px;
	display: table-cell;
	vertical-align: top;
	border-bottom: solid 1px #FFF;
	padding: 40px 10px 20px 10px;
}
.kps-info .kps-info_table td {
	display: table-cell;
	border-bottom: solid 1px #FFF;
	padding: 40px 10px 20px 10px;
}
@media screen and (max-width: 767px) {
	.kps-info {
		margin-bottom: 100px;
	}
	.kps-info  .kps-info_inner .kps-info_table table {
		font-size: 1.3rem
	}
	.kps-info .kps-info_table th {
		width: 30%;
		padding: 30px 10px 10px 10px;
	}
	.kps-info .kps-info_table  td{
		padding: 30px 10px 10px 10px;
	}
}
/*--newarrivals--*/
.kps-arrivals {
	margin-bottom: 200px;
}
.kps-arrivals .kps-arrivals_inner {
	width: 500px;
	margin: 0 auto;
}
.kps-arrivals .kps-arrivals_list {
	display: flex;
	font-size: 1.4rem;
	padding: 15px 0;
}
.kps-arrivals .kps-arrivals_list .date {
	width: 8em;
	text-align: left;
}
.kps-arrivals .kps-arrivals_list .news {
	width: calc(100% - 8em);
	text-align: left;
}
.kps-arrivals .kps-arrivals_list .news:hover{
	text-decoration: underline;
}
@media screen and (max-width: 767px) {
	.kps-arrivals {
	    margin-bottom: 100px;
	}
	.kps-arrivals .kps-arrivals_inner {
	    width: auto;
	}
	.kps-arrivals .kps-arrivals_list {
	    display: block;
	    font-size: 1.4rem;
	}
	.kps-arrivals .kps-arrivals_list .date {
	    width: auto;
	    text-align: left;
	    padding-bottom: 10px;
	}
	.kps-arrivals .kps-arrivals_list .news {
	    width: auto;
	    text-align: left;
	}
}
/*--contact--*/
.kps-contact {
	margin-bottom: 200px;
}
.kps-contact .rec-txt {
	text-align: center;
	line-height: 1.6;
	font-size: 1.2rem;
	margin-bottom: 30px;
}
.kps-contact .rec-txt a{
	color:  #B88E12;
	font-weight: bold;
}
.kps-contact .kps-contact_input {
	width: 470px;
	margin: 0 auto;
}
.kps-contact .kps-contact_input_inner {
	margin-bottom: 20px;
}
.kps-contact .kps-contact_input_inner .cool {
	width: 100%;
	height: 60px;
	border: 1px solid #ddd;
    box-sizing: border-box;
    flex: 1;
    background: #eaedf2;
	color: #999;
    font-size: 1.4rem;
	padding: 0 15px;
}
.kps-contact .kps-contact_input_inner .kps-contact_textarea {
	width: 100%;
	height: 250px;
	border: 1px solid #ddd;
    box-sizing: border-box;
    flex: 1;
    background: #eaedf2;
    font-size: 1.4rem;
	padding: 20px 15px 0;
}
input[type=text]:focus {
    outline: none;
	border: 1px solid #ddd;
}
textarea[type=text]:focus {
    outline: none;
	border: 1px solid #ddd;
}
.kps-contact .kps-contact_input .kps-contact_input_but {
	text-align: center;
}
.input_but {
	display: inline-block;
    width: 50%;
    height: 40px;
    text-align: center;
    text-decoration: none;
    outline: none;
	background-color: #FFF;
    border: 1px solid #212D71;
    color: #999;
    line-height: 40px;
	font-size: 1.2rem;
	letter-spacing: 2px;
	cursor: pointer;
}
.input_but:hover {
    background-color: #212D71;
    border-color: #FFF;
    color: #FFF;
}
.input_but::before,
.input_but::after {
    position: absolute;
    z-index: -1;
    display: block;
    content: '';
}
.input_but, 
.input_but::before, 
.input_but::after {
     -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
     box-sizing: border-box;
     -webkit-transition: all .5s;
     transition: all .5s;
}
@media screen and (max-width: 767px) {
	.kps-contact {
		margin-bottom: 100px;
	}
	.kps-contact .kps-contact_input {
		width: auto;
		margin: 0 auto;
	}
	.kps-contact .rec-txt {
		text-align: left;
	}
}
/* footer
---------------------------------------------------------------------------*/
.footer {
	margin-bottom: 50px;
}
.footer .footer_logo {
	text-align: center;
	margin: 0 auto 150px;
	width: 200px;
}
.footer .footer_logo img{
	padding-left: 15px;
}
.footer .link_box {
	margin-bottom: 50px;
}
.footer .link_box .link_box_list {
	display: flex;
	justify-content: space-between;
}
.footer .link_box_list .link_box_items:hover {
    text-decoration: underline;
}
.footer .link_box_list .link_box_items span {
    font-size: 1.5rem;
}
.footer .privacypolicy {
	text-align: right;
	margin-bottom: 70px;
}
.footer .privacypolicy:hover{
	text-decoration: underline;
}
.footer .privacypolicy span {
	font-size: 1.3rem;
}
.footer .copyright {
	text-align: center;
	font-size: 1.5rem;
}




/* PC
------------------------------------------*/
@media only screen and (min-width: 767px) {
	/* .pc_only{} */
	.tb_only{display:none !important;}
	.sp_only{display:none !important;}
	/* .tb_pc{} */
	.sp_tb{display:none !important;}
	}
	
	/* Tablet (Portrait : 縦表示)
	------------------------------------------*/
	@media only screen and (min-width: 768px) and (max-width: 1023px) {
	.pc_only{display:none !important;}
	.tb_only{display:inherit !important;}
	.sp_only{display:none !important;}
	/* .tb_pc{} */
	.sp_tb{display:inherit !important;}
	}
	
	/* Mobile (Portrait : 縦表示)
	------------------------------------------*/
	@media only screen and (max-width: 767px) {
	.pc_only{display:none !important;}
	.tb_only{display:none !important;}
	.sp_only{display:inherit !important;}
	.tb_pc{display:none !important;}
	.sp_tb{display:inherit !important;}
	}