@charset "UTF-8";

html {
	font-size: 10px;
	line-height: 1.6;
	letter-spacing: 1px;
	overflow-x: hidden;
	font-family: "Zen Kaku Gothic New", sans-serif;
	color: #000;
}

body{
	word-wrap: break-word;
	-webkit-text-size-adjust: 100%;
	overflow-x: hidden;
	-webkit-tap-highlight-color:rgba(0,0,0,0);
	background: #fff;
	position: relative;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

.grecaptcha-badge { visibility: hidden; }

#wrapper a:link      { text-decoration: none; color: #970c10; }
#wrapper a:visited   { text-decoration: none; color: #970c10; }
#wrapper a:hover     { text-decoration: none; }
#wrapper a:active    { text-decoration: none; }

a[href^="tel:"] {
	pointer-events: none;
}

a,:focus {
	outline: none;
}

::-webkit-search-cancel-button {
	-webkit-appearance: none;
}

.img img {
	width: 100%;
	height: auto;
}

.tb   { display: none!important;}
.tbsp { display: none!important;}
.sp   { display: none!important;}

.pc   { display: block!important;}
.pctb { display: block!important;}
.pcsp { display: block!important;}

.opacity a:hover,
.opacity input:hover {
	opacity: 0.60;
	filter: alpha(opacity=60);
	-ms-filter: "alpha(opacity=60)";
	-moz-opacity: 0.60;
	-khtml-opacity: 0.60;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
	text-decoration: none!important;
}

.fadein {
	opacity: 0;
	filter: alpha(opacity=0);
	-ms-filter: "alpha(opacity=0)";
	-moz-opacity:0;
	-khtml-opacity: 0;
	transform : translate(0, 50px);
	transition : all 500ms;
}

/* mdlAra */
.menu, .menu span {
	display: inline-block;
	-webkit-transition: all .2s;
	transition: all .2s;
	box-sizing: border-box;
}

.menu {
	position: fixed;
	top: 0;
	right: 0;
	width: 120px;
	height: 120px;
	background: #000;
	z-index: 2000;
	cursor: pointer;
}

.menu:hover {
	background: #970c10;
	transition: all 0.3s ease;
}

.menu span {
	width: 40px;
	height: 2px;
	position: absolute;
	left: 40px;
	background: #fff;
	z-index: 100;
}

.mdlBtnTtl {
	text-align: center;
	position: absolute;
	bottom: 25px;
	left: 40px;
	font-family: "brandon-grotesque", sans-serif;
	font-weight: 700;
	font-size: 1.2rem;
	color: #fff;
	letter-spacing: 0.1em;
	transition: all 0.3s ease;
}

button {
	border: none;
	background: none;
}

.menu span:nth-of-type(1) {
	top: 44px;
}

.menu span:nth-of-type(2) {
	width: 30px;
	top: 54px;
}

.menu span:nth-of-type(3) {
	top: 64px;
}

.menu.active span:nth-of-type(1) {
	-webkit-transform: translateY(10px) rotate(45deg);
	transform: translateY(10px) rotate(45deg);
}

.menu.active span:nth-of-type(2) {
	opacity: 0;
}

.menu.active span:nth-of-type(3) {
	-webkit-transform: translateY(-10px) rotate(-45deg);
	transform: translateY(-10px) rotate(-45deg);
}

.mdlNavBox {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 2000;
	width: 100% ;
	height: 100vh;
	opacity: 0;
	padding: 100px 50px;
	overflow-y: scroll;
	box-sizing: border-box;
	background: rgba(0,0,0,0.75);
	background-size: cover;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
	visibility: hidden;
}

.mdlNavBox.active {
	right: 0;
	opacity: 1;
	-moz-transform: translateX(0);
	-webkit-transform: translateX(0);
	transform: translateX(0);
	visibility: visible;
}

.mdlNavInr {
	max-width: 1100px;
	height: auto;
	margin: 0 auto;
	padding: 30px 30px 60px;
	box-sizing: border-box;
	overflow: hidden;
	background: #fff;
}

.mdlLg {
	max-width: 250px;
	margin: 0 auto 30px;
}

.mdlNav {
	font-family: "brandon-grotesque", sans-serif;
	font-weight: 900;
	font-size: 3.6rem;
	line-height: 1;
	overflow: hidden;
	margin: 0 0 -35px;
}

.mdlNav a {
	display: block;
	padding: 0 0 15px;
	background: url(../images/arw_rt_bk.png) right no-repeat;
	background-size: 30px auto;
	z-index: 1;
}

.mdlNav a:link,
.mdlNav a:visited {
	color: #000!important;
}

.mdlNav a:hover {
	color: #970c10!important;
	transition: all 0.3s ease;
}

.mdlNav li {
	margin: 0 0 35px;
	border-bottom: solid 2px #000;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.menu {
		width: 100px;
		height: 100px;
	}

	.menu span {
		left: 30px;
	}

	.mdlBtnTtl {
		bottom: 17px;
		left: 30px;
	}

	.menu span:nth-of-type(1) {
		top: 34px;
	}

	.menu span:nth-of-type(2) {
		top: 44px;
	}

	.menu span:nth-of-type(3) {
		top: 54px;
	}

	.mdlNavBox {
		padding: 80px 30px;
	}

	.mdlNavInr {
		padding: 30px 30px 60px;
	}

	.mdlLg {
		max-width: 200px;
		margin: 0 auto 20px;
	}

	.mdlNav {
		font-size: 3.4rem;
		margin: 0 0 -30px;
	}

	.mdlNav a {
		background-size: 25px auto;
	}

	.mdlNav li {
		margin: 0 0 30px;
	}
}

@media screen and (max-width:767px) {
	.menu {
		width: 60px;
		height: 60px;
	}

	.menu span {
		width: 30px;
		left: 15px;
	}

	.mdlBtnTtl {
		bottom: 8px;
		left: 15px;
		font-size: 1rem;
	}

	.menu span:nth-of-type(1) {
		top: 15px;
	}

	.menu span:nth-of-type(2) {
		width: 20px;
		top: 23px;
	}

	.menu span:nth-of-type(3) {
		top: 31px;
	}
	
	.menu.active span:nth-of-type(1) {
		-webkit-transform: translateY(8px) rotate(45deg);
		transform: translateY(8px) rotate(45deg);
	}

	.menu.active span:nth-of-type(3) {
		-webkit-transform: translateY(-8px) rotate(-45deg);
		transform: translateY(-8px) rotate(-45deg);
	}
	
	.mdlNavBox {
		padding: 80px 20px;
	}

	.mdlNavInr {
		padding: 15px 15px 30px;
	}

	.mdlLg {
		max-width: 160px;
		margin: 0 auto 20px;
	}

	.mdlNav {
		font-size: 2.4rem;
		margin: 0 0 -20px;
	}

	.mdlNav a {
		padding: 0 0 5px;
		background-size: 15px auto;
	}

	.mdlNav li {
		margin: 0 0 20px;
		border-bottom: solid 1px #000;
	}
}

/*======================================================
  common
======================================================*/

.cntWrp {
	max-width: 1300px;
	margin: 0 auto;
}

.morBtn {
	width: 270px;
	display: block;
	position: relative;
	font-family: "brandon-grotesque", sans-serif;
	font-weight: 700;
	font-size: 2.4rem;
	line-height: 1;
	overflow: hidden;
	background: #000;
	border-radius: 5px;
	transition: all 0.3s ease;
}

.morBtn:before {
	content: "";
	position: absolute;
	top: 20px;
	right: 70px;
	width: 1px;
	height: calc(100% - 40px);
	background: rgba(255,255,255,0.3);
	z-index: 3;
}

.morBtn:after {
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background: #970c10;
	transform: scaleX(0);
	transform-origin: right;
	transition: all 0.5s ease;
	transition-property: transform;
	z-index: 1;
}

.morBtn:hover:after {
	transform: scaleX(1);
	transform-origin: left;
}

.morBtn a {
	position: relative;
	display: block;
	padding: 20px 20px 20px 50px;
	background: url(../images/arw_rt_wt.png) right 25px center no-repeat ;
	background-size: 15px auto;
	z-index: 2;
}

.morBtn a:link,
.morBtn a:visited {
	color: #fff!important;
}

.wtLnk a:link,
.wtLnk a:visited {
	color: #fff!important;
}

.bkLnk a:link,
.bkLnk a:visited {
	color: #000!important;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.morBtnBox {
		display: flex;
		justify-content: flex-end;
	}
	
	.morBtn {
		width: 220px;
		font-size: 2rem;
	}

	.morBtn:before {
		right: 55px;
	}

	.morBtn a {
		padding: 17px 17px 17px 45px;
		background: url(../images/arw_rt_wt.png) right 20px center no-repeat ;
		background-size: 15px auto;
	}
}

@media screen and (max-width:767px) {
	.morBtnBox {
		display: block;
	}
	
	.morBtn {
		width: 100%;
		font-size: 1.8rem;
		border-radius: 4px;
	}

	.morBtn:before {
		right: 55px;
	}

	.morBtn a {
		padding: 17px;
		background: url(../images/arw_rt_wt.png) right 20px center no-repeat ;
		background-size: 15px auto;
	}
}

/*======================================================
  header
======================================================*/

.hdr {
	position: absolute;
	top: 20px;
	left: 30px;
	z-index: 4;
}

.hdrLg {
	max-width: 250px;
	transition: all 0.3s ease;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.hdrLg {
		max-width: 200px;
	}
}

@media screen and (max-width:767px) {
	.hdr {
		top: 5px;
		left: 15px;
	}

	.hdrLg {
		max-width: 160px;
	}
}

/*======================================================
  mnAra
======================================================*/

.mnAra {
	width: 100%;
	height: 100vh;
	position: relative;
	padding: 0 50px;
	background: #000;
	box-sizing: border-box;
	z-index: 1;
}

.mnCvr {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background: rgba(199,199,199,0.9);
	mix-blend-mode: color-burn;
	z-index: 3;
}

.mnAra video {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	object-fit: cover;
	z-index: 2;
}

.mnWrp {
	max-width: 1300px;
	height: 100%;
	position: relative;
	margin: 0 auto;
	z-index: 3;
}

.mnCth {
	position: absolute;
	bottom: 80px;
	left: 0;
	font-family: "brandon-grotesque", sans-serif;
	font-weight: 900;
	font-size: 7.5rem;
	line-height: 1.2;
	color: #fff;
}

.scrBtnBox {
	position: absolute;
	bottom: 60px;
	right: 0;
	z-index: 4;
}

.scrBtnBox:before {
	animation: scroll 2s infinite;
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -80px;
	width: 1px;
	height: 70px;
	background: #fff;
	margin: auto;
	z-index: 4;
}

@keyframes scroll {
	0% {
		transform: scale(1, 0);
		transform-origin: 0 0;
	}
	50% {
		transform: scale(1, 1);
		transform-origin: 0 0;
	}
	51% {
		transform: scale(1, 1);
		transform-origin: 0 100%;
	}
	100% {
		transform: scale(1, 0);
		transform-origin: 0 100%;
	}
}

.scrBtn {
	font-family: "brandon-grotesque", sans-serif;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.7;
	padding: 0 55px 0 0;
	transform: rotate(90deg);
}

.scrBtn:hover a {
	transition: all 0.3s ease;
	color: #970c10!important;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.mnAra {
		padding: 0 30px;
	}

	.mnCth {
		bottom: 50px;
		font-size: 7rem;
	}

	.scrBtnBox {
		bottom: 65px;
		right: -20px;
	}

	.scrBtnBox:before {
		bottom: -70px;
		height: 60px;
	}
}

@media screen and (max-width:767px) {
	.mnAra {
		padding: 0 20px;
	}

	.mnCth {
		bottom: 100px;
		font-size: 4.5rem;
	}

	.scrBtnBox {
		bottom: 110px;
		right: -30px;
	}

	.scrBtnBox:before {
		bottom: -110px;
		height: 100px;
	}
	
	.scrBtn {
		font-size: 1.5rem;
		padding: 0 45px 0 0;
	}
}

/*======================================================
  content
======================================================*/

/* msnAra */
.msnAra {
	position: relative;
	padding: 100px 50px 50px;
}

.msnTtlEn {
	max-width: 1030px;
	position: absolute;
	top: 70px;
	right: -10px;
	z-index: 1;
}

.msnBox {
	position: relative;
	margin: 0 0 80px;
	padding: 0 50px;
	z-index: 2;
}

.msnInfBox {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	margin: 0 0 70px;
}

.msnTtlBox {
	margin: 0 20px 0 0;
}

.msnTtl {
	position: relative;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1;
	margin: 0 0 50px;
	padding: 0 0 0 30px;
}

.msnTtl:before {
	content: "";
	position: absolute;
	top: calc(50% - 0.5px);
	left: 0;
	width: 15px;
	height: 1px;
	background: #970c10;
}

.cntCth {
	opacity: 0;
	font-weight: 900;
	font-size: 5.5rem;
	line-height: 1.3;
	letter-spacing: -0.005em;
}

.fadCth {
	opacity: 1;
	display: flex;
	overflow: hidden;
}

.fadCth span {
	transform: translateY(2em);
	animation: textanimation 1s forwards;
}

.fadCth span:nth-child(1) {
    animation-delay: 0s
}

.fadCth span:nth-child(2) {
    animation-delay: 0.04s
}

.fadCth span:nth-child(3) {
    animation-delay: 0.08s
}

.fadCth span:nth-child(4) {
    animation-delay: 0.12s
}

.fadCth span:nth-child(5) {
    animation-delay: 0.16s
}

.fadCth span:nth-child(6) {
    animation-delay: 0.2s
}

.fadCth span:nth-child(7) {
    animation-delay: 0.24s
}

.fadCth span:nth-child(8) {
    animation-delay: 0.28s
}

.fadCth span:nth-child(9) {
    animation-delay: 0.32s
}

.fadCth span:nth-child(10) {
    animation-delay: 0.36s
}

.fadCth span:nth-child(11) {
    animation-delay: 0.4s
}

.fadCth span:nth-child(12) {
    animation-delay: 0.44s
}

.fadCth span:nth-child(13) {
    animation-delay: 0.48s
}

.fadCth span:nth-child(14) {
    animation-delay: 0.52s
}

.fadCth span:nth-child(15) {
    animation-delay: 0.56s
}

@keyframes textanimation {
    0% {
        transform: translateY(2em);
    }

    100% {
        transform: translateY(0);
    }
}

.msnTxtLst {
	display: flex;
}

.msnTxtLst li {
	display: flex;
	justify-content: center;
}

.msnTxtLst li:first-child {
	width: 50%;
	position: relative;
	padding: 20px;
	box-sizing: border-box;
}

.msnTxtLst li:first-child:after {
	content: "";
	position: absolute;
	top: 30px;
	right: 0;
	width: 1px;
	height: calc(100% - 60px);
	background: #e1e2e2;
}

.msnTxtLst li:last-child {
	width: 50%;
	padding: 20px;
	box-sizing: border-box;
}

.msnTxt {
	font-weight: 400;
	font-size: 1.6rem;
	line-height: 2.5;
}

.abtImgBox {
	height: 700px;
	background: url(../images/img_mission.jpg) center no-repeat;
	background-size: cover;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.msnAra {
		padding: 160px 30px 30px;
	}

	.msnTtlEn {
		top: 50px;
		right: 0;
		padding: 0 30px;
	}

	.msnBox {
		margin: 0 0 60px;
		padding: 0;
	}

	.msnInfBox {
		display: block;
		margin: 0 0 50px;
	}

	.msnTtlBox {
		margin: 0 0 20px;
	}
	
	.msnTtl {
		font-size: 1.7rem;
		margin: 0 0 40px;
		padding: 0 0 0 25px;
	}

	.cntCth {
		font-size: 5rem;
	}
	
	.msnTxtLst li:first-child {
		padding: 0 30px 0 0;
	}

	.msnTxtLst li:last-child {
		padding: 0 0 0 30px;
	}

	.msnTxt {
		line-height: 2;
	}

	.abtImgBox {
		height: 500px;
		background-size: cover;
	}
}

@media screen and (max-width:767px) {
	.msnAra {
		padding: 120px 20px 30px;
	}

	.msnTtlEn {
		top: 30px;
		right: 0;
		padding: 0 20px;
	}

	.msnBox {
		margin: 0 0 30px;
		padding: 0;
	}

	.msnInfBox {
		display: block;
		margin: 0 0 30px;
	}

	.msnTtlBox {
		text-align: center;
		margin: 0 0 20px;
	}
	
	.msnTtl {
		display: inline-block;
		position: relative;
		font-weight: 700;
		font-size: 1.8rem;
		line-height: 1;
		margin: 0 0 20px;
		padding: 0 0 10px;
	}
	
	.msnTtl:before {
		top: auto;
		left: calc(50% - 6px);
		bottom: 0;
		width: 12px;
	}
	
	.cntCth {
		text-align: center;
		justify-content: center;
		font-size: 2.2rem;
	}
	
	.msnTxtLst {
		display: block;
	}
	
	.msnTxtLst li:first-child {
		width: 100%;
		margin: 0 0 40px;
		padding: 0;
	}
	
	.msnTxtLst li:first-child:after {
		top: auto;
		bottom: -20px;
		right: auto;
		left: 20px;
		width: calc(100% - 40px);
		height: 1px;
	}

	.msnTxtLst li:last-child {
		width: 100%;
		padding: 0;
	}

	.msnTxt {
		font-size: 1.5rem;
		line-height: 1.8;
	}

	.abtImgBox {
		height: 200px;
	}
}

/* bsnAra */
.bsnAra {
	padding: 150px 50px 70px;
}

.bsnTtlBox {
	text-align: center;
	margin: 0 0 100px;
}

.bsnTtlEn {
	max-width: 1120px;
	margin: 0 auto 60px;
}

.bsnTtl {
	display: inline-block;
	position: relative;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1;
	margin: 0 0 20px;
	padding: 0 0 10px;
}

.bsnTtl:after {
	content: "";
	position: absolute;
	bottom: 0;
	left: calc(50% - 7.5px);
	width: 15px;
	height: 1px;
	background: #970c10;
}

.bsnTtlBox .cntCth {
	justify-content: center;
}

.bsnInfBox {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin: 0 0 40px;
}

.cntSubTtl {
	position: relative;
	font-weight: 900;
	font-size: 3.4rem;
	line-height: 1.3;
	padding: 0 0 0 30px;
	margin: 0 0 30px;
}

.cntSubTtl:before {
	content: "";
	position: absolute;
	top: calc(50% - 2px);
	left: 0;
	width: 20px;
	height: 4px;
	background: #970c10;
}

.bsnInfBox .cntSubTtl {
	margin: 0;
}

.bsnLst {
	display: flex;
	flex-wrap: wrap;
	margin: 0 0 60px;
}

.bsnLst li {
	width: 33.3%;
	margin: 0 0 70px;
}

.bsnLst li:nth-child(3n){
	margin-right: 0.1%;
}

.bsnLstCntBox {
	padding: 30px 20px 0 0;
}

.bsnLstTtl {
	font-weight: 700;
	font-size: 2.4rem;
	line-height: 1.3;
	margin: 0 0 40px;
}

.bsnLstTxt {
	font-weight: 400;
	font-size: 1.6rem;
	line-height: 1.8;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.bsnAra {
		padding: 100px 30px 20px;
	}

	.bsnTtlBox {
		margin: 0 0 80px;
	}
	
	.bsnTtlEn {
		margin: 0 auto 40px;
	}
	
	.bsnTtl {
		font-size: 1.7rem;
	}

	.bsnInfBox {
		margin: 0 0 30px;
	}
	
	.cntSubTtl {
		font-size: 3rem;
	}

	.bsnLst {
		margin: 0 0 30px;
	}
	
	.bsnLst li {
		margin: 0 0 50px;
	}
	
	.bsnLstCntBox {
		padding: 20px 15px 0 0;
	}

	.bsnLstTtl {
		font-size: 2rem;
		margin: 0 0 30px;
	}
}

@media screen and (max-width:767px) {
	.bsnAra {
		padding: 40px 20px 20px;
	}

	.bsnTtlBox {
		margin: 0 0 50px;
	}
	
	.bsnTtlEn {
		margin: 0 auto 20px;
	}

	.bsnTtl {
		font-size: 1.6rem;
	}
	
	.bsnTtl:after {
		left: calc(50% - 6px);
		width: 12px;
	}
	
	.bsnInfBox {
		display: block;
		margin: 0 0 30px;
	}

	.cntSubTtl {
		font-size: 2rem;
		margin: 0 0 20px!important;
		padding: 0 0 0 25px;
	}

	.cntSubTtl:before {
		top: calc(50% - 1.5px);
		width: 15px;
		height: 3px;
	}

	.bsnLst {
		display: block;
		margin: 0 0 30px;
	}
	
	.bsnLst li {
		width: 100%;
		margin: 0 0 40px;
	}
	
	.bsnLstImg {
		margin: 0 0 15px;
	}
	
	.bsnLstCntBox {
		padding: 0;
	}

	.bsnLstTtl {
		font-size: 2.4rem;
		margin: 0 0 15px;
	}
}

/* rslAra */
.rslAra {
	position: relative;
	padding: 100px 50px 0;
	z-index: 1;
}

.rslGrdCvr {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background: #000;
	background: linear-gradient(0deg,rgba(0, 0, 0, 1) 20%, rgba(0, 0, 0, 0) 100%);
	z-index: 4;
}

.rslCvr {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background: #000;
	mix-blend-mode: soft-light;
	z-index: 3;
}

.rslAra video {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	object-fit: cover;
	opacity: 0.9;
	z-index: 2;
}

.rslAra .cntWrp {
	position: relative;
	z-index: 4;
}

.rslInfBox {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	margin: 0 0 70px;
}

.rslTtlBox {
	display: flex;
	align-items: flex-end;
	margin: 0 20px 0 0;
}

.rslTtlEn {
	font-family: "brandon-grotesque", sans-serif;
	font-weight: 900;
	font-size: 8.5rem;
	line-height: 0.75;
	color: #fff;
}

.rslTtl {
	position: relative;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1;
	color: #fff;
	margin: 0 0 0 20px;
	padding: 0 0 0 30px;
}

.rslTtl:before {
	content: "";
	position: absolute;
	top: calc(50% - 0.5px);
	left: 0;
	width: 15px;
	height: 1px;
	background: #fff;
}

.rslInfBox .morBtn {
	background: none;
	box-sizing: border-box;
	border: solid 1px rgba(255,255,255,0.3);
	transition: all 0.8s ease;
}

.rslInfBox .morBtn:hover {
	border: solid 1px rgba(255,255,255,0);
}

.rslLst {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -25px -80px;
}

.rslLst li {
	width: calc(33.3% - 50px);
	margin: 0 25px 80px;
}

.rslLstImg {
	margin: 0 0 30px;
}

.rslLstTtlBox {
	margin: 0 0 30px;
	padding: 0 0 50px;
	border-bottom: solid 1px rgba(255,255,255,0.3);
}

.rslLstTtl {
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.3;
	color: #fff;
}

.rslLstTypBox {
	text-align: right;
}

.rslLstTyp {
	text-align: center;
	display: inline-block;
	font-weight: 400;
	font-size: 1.5rem;
	line-height: 1;
	color: #fff;
	padding: 3px 8px 6px;
	background: #970c10;
	border-radius: 2px;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.rslAra {
		padding: 80px 30px 0;
	}

	.rslInfBox {
		margin: 0 0 50px;
	}

	.rslTtlEn {
		font-size: 8rem;
	}

	.rslTtl {
		font-size: 1.7rem;
		line-height: 1;
		color: #fff;
		padding: 0 0 0 25px;
	}

	.rslLst {
		margin: 0 -15px -60px;
	}

	.rslLst li {
		width: calc(50% - 30px);
		margin: 0 15px 60px;
	}
	
	.rslLstImg {
		margin: 0 0 20px;
	}

	.rslLstTtlBox {
		margin: 0 0 20px;
		padding: 0 0 30px;
	}

	.rslLstTtl {
		font-size: 1.8rem;
	}
	
	.rslLstTyp {
		font-size: 1.4rem;
	}
}

@media screen and (max-width:767px) {
	.rslAra {
		padding: 40px 20px 0;
	}

	.rslInfBox {
		display: block;
		margin: 0 0 30px;
	}
	
	.rslTtlBox {
		text-align: center;
		margin: 0 0 20px;
	}
	
	.rslTtlEn {
		display: inline-block;
		font-size: 4.5rem;
	}
	
	.rslTtl {
		font-size: 1.6rem;
		line-height: 1;
		color: #fff;
		padding: 0 0 0 20px;
	}
	
	.rslTtl:before {
		width: 12px;
	}

	.rslLst {
		margin: 0 0 -30px;
	}

	.rslLst li {
		width: 100%;
		margin: 0 0 30px;
	}
	
	.rslLstBox {
		display: flex;
	}
	
	.rslLstImg {
		max-width: 120px;
		margin: 0 15px 0 0;
	}
	
	.rslLstCntBox {
		width: calc(100% - 135px);
	}

	.rslLstTtlBox {
		margin: 0 0 15px;
		padding: 0 0 10px;
	}

	.rslLstTtl {
		font-size: 1.6rem;
	}
	
	.rslLstTypBox {
		text-align: left;
	}
	
	.rslLstTyp {
		font-size: 1.3rem;
		padding: 2px 6px 4px;
	}
}

/*======================================================
  footer
======================================================*/

.ptpBtn {
	text-align: center;
	position: fixed;
	right: 50px;
	bottom: 30px;
	z-index: 150;
}

.ptpBtn a {
	width: 60px;
	height: 60px;
	display: block;
	padding: 20px 0 0;
	box-sizing: border-box;
	background: #191919;
	border: solid 1px #333;
	border-radius: 5px;
}

.ptpBtn a:hover {
	background: #970c10;
	border: solid 1px #970c10;
	transition: all 0.3s ease;
}

.ptpBtn img {
	width: 15px;
}

.ftrAra {
	position: relative;
	margin: -1px 0 0;
	padding: 100px 50px 120px;
	background: #000;
	z-index: 2;
}

.ftrWrp {
	max-width: 1300px;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	margin: 0 auto;
	padding: 0 0 25px;
	border-bottom: solid 1px rgba(255,255,255,0.3);
}

.ftrNav {
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1;
}

.ftrNav li:not(:last-child) {
	margin: 0 0 25px; 
}

.ftrNav li a {
	display: inline-block;
}

.ftrNav li a:hover {
	color: #970c10!important;
	transition: all 0.3s ease;
}

.ftrNav li span {
	position: relative;
}

.ftrNav li span:after {
	content: "/";
	position: absolute;
	bottom: 4px;
	right: -12px;
	font-size: 1.4rem;
	color: rgba(255,255,255,0.3);
}

.cpyTxt {
	font-weight: 700;
	font-size: 1.4rem;
	line-height: 1;
	color: #fff;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.ptpBtn {
		right: 30px;
		bottom: 25px;
	}

	.ptpBtn a {
		width: 50px;
		height: 50px;
		padding: 17px 0 0;
	}
	
	.ptpBtn img {
		width: 13px;
	}

	.ftrAra {
		padding: 80px 30px 100px;
	}

	.ftrWrp {
		padding: 0 0 20px;
	}
	
	.ftrNav {
		font-size: 1.6rem;
	}
	
	.ftrNav li:not(:last-child) {
		margin: 0 0 20px; 
	}

	.cpyTxt {
		font-size: 1.3rem;
	}
}

@media screen and (max-width:767px) {
	.ptpBtn {
		right: 20px;
		bottom: 20px;
	}

	.ptpBtn a {
		width: 40px;
		height: 40px;
		padding: 14px 0 0;
	}
	
	.ptpBtn img {
		width: 10px;
	}

	.ftrAra {
		padding: 40px 20px 20px;
	}

	.ftrWrp {
		display: block;
		padding: 0 0 20px;
		border-bottom: none;
	}
	
	.ftrNav {
		font-size: 1.6rem;
		margin:0 0 30px;
	}
	
	.ftrNav li:not(:last-child) {
		margin: 0 0 10px; 
	}
	
	.ftrNav li a {
		display: block;
		padding: 15px;
		background: url(../images/arw_rt_wt.png) right 15px center no-repeat;
		background-size: 15px auto;
		border: solid 1px rgba(255, 255, 255, 0.3);
		border-radius: 50px;
	}
	
	.ftrNav li a:hover {
		color: #fff!important;
		background: url(../images/arw_rt_wt.png) right 15px center no-repeat #970c10;
		background-size: 15px auto;
		border: solid 1px #970c10;
		transition: all 0.3s ease;
	}

	.cpyTxt {
		text-align: center;
		font-size: 1.3rem;
	}
}

/*======================================================
  lower
======================================================*/

.lwrMnWrp {
	max-width: 1300px;
	height: 400px;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	margin: 0 auto 50px;
	padding: 0 50px;
}

.lwrMnTtlBox {
	text-align: center;
}

.lwrMnTtlEn {
	font-family: "brandon-grotesque", sans-serif;
	font-weight: 900;
	font-size: 20rem;
	line-height: 0.75;
	letter-spacing: -0.025em;
	margin: 0 0 10px;
}

.lwrMnTtl {
	font-weight: 700;
	font-size: 4.2rem;
	line-height: 1.6;
}

.lwrMnImgBox {
	width: 100%;
	height: 500px;
	position: relative;
	z-index: 1;
}

.lwrMnCvr {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	mix-blend-mode: color-burn;
	z-index: 3;
}

.lwrMnImgBox video {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	object-fit: cover;
	z-index: 2;
}

.lwrAra {
	padding: 50px;
	background: #f7f9f8;
}

.lwrWrp {
	max-width: 1300px;
	position: relative;
	margin: -150px auto 0;
	padding: 100px;
	box-sizing: border-box;
	background: #fff;
	z-index: 4;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.lwrMnWrp {
		height: 350px;
		margin: 0 auto 40px;
		padding: 0 30px;
	}

	.lwrMnTtlEn {
		font-size: 15rem;
	}

	.lwrMnTtl {
		font-size: 3.5rem;
	}

	.lwrMnImgBox {
		height: 400px;
	}

	.lwrAra {
		padding: 30px;
	}

	.lwrWrp {
		margin: -100px auto 0;
		padding: 50px;
	}
}

@media screen and (max-width:767px) {
	.lwrMnWrp {
		height: 180px;
		margin: 0 auto 20px;
		padding: 0 20px;
	}

	.lwrMnTtlEn {
		font-size: 4.5rem;
		margin: 0 0 5px;
	}

	.lwrMnTtl {
		font-size: 1.8rem;
	}

	.lwrMnImgBox {
		height: 200px;
	}

	.lwrAra {
		padding: 20px;
	}

	.lwrWrp {
		margin: -50px auto 0;
		padding: 20px 15px;
	}
}

/*======================================================
  company
======================================================*/

.cmpMnCvr {
	background: url(../images/bg_main_company.jpg) center no-repeat;
	background-size: cover;
}

.cmpLst li:not(.cmpNbrLst li,.cmpLstTxtLst li) {
	display: flex;
	padding: 40px 0;
	border-top: solid 1px #e1e2e2;
}

.cmpLstTtl {
	max-width: 280px;
	width: 100%;
	margin: 0 20px 0 0;
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.4;
	box-sizing: border-box;
}

.cmpLstCntBox {
	width: calc(100% - 300px);
}

.cmpLstTxt {
	font-weight: 500;
	font-size: 2rem;
	line-height: 1.4;
}

.cmpLstMapBox {
	position: relative;
	width: 100%;
	height: 0;
	margin: 15px 0 0;
	padding-top: 55%;
}
 
.cmpLstMapBox iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.cmpLstMinTtl {
	display: inline-block;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.3;
	color: #fff;
	margin: 15px 0 5px;
	padding: 3px 8px;
	background: #000;
}

.cmpNbrLst {
	font-weight: 500;
	font-size: 2rem;
	line-height: 1.4;
	padding: 0 0 0 20px;
}

.cmpNbrLst li:not(:last-child) {
	margin: 0 0 10px;
}

.cmpLstTxtLst {
	font-weight: 500;
	font-size: 2rem;
	line-height: 1.4;
}

.cmpLstTxtLst li:not(:last-child) {
	margin: 0 0 15px;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.cmpLst li:not(.cmpNbrLst li,.cmpLstTxtLst li) {
		padding: 30px 0;
	}

	.cmpLstTtl {
		max-width: 180px;
		font-size: 1.8rem;
	}

	.cmpLstCntBox {
		width: calc(100% - 200px);
	}

	.cmpLstTxt {
		font-size: 1.8rem;
	}
	
	.cmpLstMinTtl {
		font-size: 1.5rem;
	}

	.cmpNbrLst {
		font-size: 1.8rem;
	}
	
	.cmpLstTxtLst {
		font-size: 1.8rem;
	}

	.cmpLstTxtLst li:not(:last-child) {
		margin: 0 0 10px;
	}
}

@media screen and (max-width:767px) {
	.cmpLst li:not(.cmpNbrLst li,.cmpLstTxtLst li) {
		display: block;
		padding: 20px 0;
	}

	.cmpLstTtl {
		max-width: 100%;
		font-size: 1.8rem;
		margin: 0 0 10px;
	}

	.cmpLstCntBox {
		width: 100%;
	}

	.cmpLstTxt {
		font-size: 1.6rem;
	}

	.cmpLstMinTtl {
		font-size: 1.4rem;
	}

	.cmpNbrLst {
		font-size: 1.6rem;
	}
	
	.cmpLstTxtLst {
		font-size: 1.6rem;
	}

	.cmpLstTxtLst li:not(:last-child) {
		margin: 0 0 10px;
	}
}

/*======================================================
  comming-soon
======================================================*/

.cmgMnTtlEn {
	font-size: 10rem;
	line-height: 0.85;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.cmgMnTtlEn {
		font-size: 8rem;
	}
}

@media screen and (max-width:767px) {
	.cmgMnTtlEn {
		font-size: 4rem;
	}
	
	.cmgMnImgBox {
		height: 400px;
	}
}

/*======================================================
  contact
======================================================*/

.cctMnCvr {
	background: url(../images/bg_main_contact.jpg) center no-repeat;
	background-size: cover;
}

.cctCapTxt {
	text-align: right;
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1;
	margin: 0 0 10px;
}

.cctCapTxt .eslIcn {
	margin: 0;
}

.eslIcn {
	color: #970c10;
	margin: 0 0 0 10px;
}

.errBox {
	margin: 0 0 30px;
	padding: 15px;
	border: solid 1px #ec0000;
}

.errLst {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.3;
	color: #ec0000;
}

.errLst li:not(:last-child) {
	margin: 0 0 10px;
}

.errTxt {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.3;
	color: #ec0000;
	margin: 10px 0 0;
}

.cctLst li {
	display: flex;
}

.cctLst li:not(:last-child) {
	margin: 0 0 40px;
	padding: 0 0 40px;
	border-bottom: solid  1px #e1e2e2;
}

.cctLst li:nth-last-child(2) {
	margin: 0 0 60px;
	padding: 0;
	border-bottom: none;
}

.cctLstTtl {
	width: 280px;
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.4;
	margin: 25px 20px 0 0;
}

.cctLstCntBox {	
	width: calc(100% - 300px);
}

.frmBox01 {
	width: 100%;
	height: 70px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	font-size: 1.8rem;
	line-height: 1.4;
	color: #000;
	padding: 15px;
	box-sizing: border-box;
	background: #f7f9f8;
	border: none;
	border-radius: 4px;
}

.frmBox02 {
	width: 100%;
	height: 250px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	font-size: 1.8rem;
	line-height: 1.4;
	color: #000;
	padding: 15px;
	box-sizing: border-box;
	background: #f7f9f8;
	border: none;
	border-radius: 4px;
}

input::placeholder,
textarea::placeholder {
	color: #c8c8c8;
}

.frmSndBtn {
	text-align: center;
	position: relative;
	max-width: 270px;
	z-index: 1;
}

.frmSndBtn:before {
	content: "";
	position: absolute;
	top: 20px;
	right: 70px;
	width: 1px;
	height: calc(100% - 40px);
	background: rgba(255, 255, 255, 0.3);
	z-index: 2;
}

.frmSndBtn input {
	width: 100%;
	display: block;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1;
	color: #fff;
	padding: 25px 75px 25px 15px;
	background: url(../images/arw_rt_wt.png) right 25px center no-repeat #000;
	background-size: 15px auto;
	border: none;
	border-radius: 5px;
	transition: all 0.3s ease;
	cursor: pointer;
}

.frmSndBtn input:hover {
	background: url(../images/arw_rt_wt.png) right 25px center no-repeat #970c10;
	background-size: 15px auto;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.cctCapTxt {
		font-size: 1.5rem;
	}

	.cctLst li:not(:last-child) {
		margin: 0 0 30px;
		padding: 0 0 30px;
	}

	.cctLst li:nth-last-child(2) {
		margin: 0 0 40px;
		padding: 0;
	}

	.cctLstTtl {
		width: 180px;
		font-size: 1.8rem;
		margin: 20px 20px 0 0;
	}

	.cctLstCntBox {	
		width: calc(100% - 200px);
	}

	.frmBox01 {
		height: 60px;
		font-size: 1.6rem;
	}

	.frmBox02 {
		height: 200px;
		font-size: 1.6rem;
	}

	.frmSndBtn {
		max-width: 220px;
	}

	.frmSndBtn:before {
		right: 55px;
	}

	.frmSndBtn input {
		font-size: 1.6rem;
		padding: 20px 70px 20px 20px;
		background: url(../images/arw_rt_wt.png) right 20px center no-repeat #000;
		background-size: 15px auto;
	}

	.frmSndBtn input:hover {
		background: url(../images/arw_rt_wt.png) right 20px center no-repeat #970c10;
		background-size: 15px auto;
	}
}

@media screen and (max-width:767px) {
	.cctCapTxt {
		font-size: 1.4rem;
	}
	
	.cctLst li {
		display: block;
	}

	.cctLst li:not(:last-child) {
		margin: 0 0 20px;
		padding: 0 0 20px;
	}

	.cctLst li:nth-last-child(2) {
		margin: 0 0 20px;
		padding: 0;
	}

	.cctLstTtl {
		width: 100%;
		font-size: 1.8rem;
		margin: 0 0 10px;
	}

	.cctLstCntBox {	
		width: 100%;
	}

	.frmBox01 {
		height: 50px;
		font-size: 1.6rem;
		padding: 15px 10px;
	}

	.frmBox02 {
		height: 160px;
		font-size: 1.6rem;
		padding: 15px 10px;
	}

	.frmSndBtn {
		max-width: 100%;
	}

	.frmSndBtn:before {
		right: 55px;
	}

	.frmSndBtn input {
		text-align: left;
		font-size: 1.5rem;
		padding: 17px;
		background: url(../images/arw_rt_wt.png) right 20px center no-repeat #000;
		background-size: 15px auto;
		border-radius: 4px!important;
	}

	.frmSndBtn input:hover {
		background: url(../images/arw_rt_wt.png) right 20px center no-repeat #970c10;
		background-size: 15px auto;
	}
}

/* cctTnkAra */
.cctTnkAra {
	padding: 150px 50px 50px;
	background: #f7f9f8;
}

.cctTnkWrp {
	max-width: 1300px;
	position: relative;
	margin: 0 auto;
	padding: 100px 50px;
	box-sizing: border-box;
	background: #fff;
	z-index: 4;
}

.cctTnkBox {
	text-align: center;
}

.cctTnkTtlEn {
	text-align: center;
	font-family: "brandon-grotesque", sans-serif;
	font-weight: 900;
	font-size: 18rem;
	line-height: 0.8;
	letter-spacing: -0.05em;
	color: #ebeceb;
	margin: 0 0 20px;
}

.cctTnkTtl {
	font-weight: 900;
	font-size: 3.6rem;
	line-height: 1.3;
	margin: 0 0 30px;
}

.cctTnkTxt {
	font-weight: 500;
	font-size: 2rem;
	line-height: 1.8;
	margin: 0 0 50px;
}

.cctTnkBtnBox .morBtn {
	margin: 0 auto;
}

.cctTnkBtnBox .morBtn a {
	padding: 20px 50px 20px 20px;
}

@media screen and (min-width:768px) and (max-width:1040px) {
	.cctTnkAra {
		padding: 120px 30px 30px;
	}

	.cctTnkWrp {
		padding: 50px;
	}

	.cctTnkTtlEn {
		font-size: 15rem;
		margin: 0 0 15px;
	}

	.cctTnkTtl {
		font-size: 3.2rem;
		margin: 0 0 20px;
	}

	.cctTnkTxt {
		font-size: 1.8rem;
		margin: 0 0 40px;
	}
}

@media screen and (max-width:767px) {
	.cctTnkAra {
		padding: 80px 20px 20px;
	}

	.cctTnkWrp {
		padding: 20px 15px;
	}

	.cctTnkTtlEn {
		font-size: 6.5rem;
		margin: 0 0 15px;
	}

	.cctTnkTtl {
		font-size: 2rem;
		margin: 0 0 20px;
	}

	.cctTnkTxt {
		text-align: left;
		font-size: 1.5rem;
		margin: 0 0 30px;
	}
}

/*=========================================================

TB

=========================================================*/

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

	.pc   { display: none!important;}
	.pcsp { display: none!important;}
	.sp   { display: none!important;}
	
	.pctb { display: block!important;}
	.tb   { display: block!important;}
	.tbsp { display: block!important;}

}

/*=========================================================

SP

=========================================================*/

@media screen and (max-width:767px) {
	
	.pc   { display: none!important;}
	.tb   { display: none!important;}
	.pctb { display: none!important;}
	
	.pcsp { display: block!important;}
	.tbsp { display: block!important;}   
	.sp   { display: block!important;}
	
	.opacity a:active {
		opacity: 0.50;
		filter: alpha(opacity=50);
		-ms-filter: "alpha(opacity=50)";
		-moz-opacity: 0.50;
		-khtml-opacity: 0.50;
		-webkit-transition: all 0.2s ease;
		-moz-transition: all 0.2s ease;
		-o-transition: all 0.2s ease;
		transition: all 0.2s ease;
		text-decoration: none!important;
	}
	
	a[href^="tel:"] {
		pointer-events: auto!important;
	}
	
	input[type="button"],input[type="text"],input[type="submit"],input[type="image"],textarea, select {
		-webkit-appearance: none;
		border-radius: 0;
	}

}