@charset "utf-8";

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

style.css

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

header.bottom{
    background-color: #262626;
}
header.scrolled{
    background: rgba(0,0,0,0.2);
}
header.open{
    background: rgba(0,0,0,0.4);
    transition: all 0.2s linear;
	-webkit-transition: all 0.2s linear;
	-moz-transition: all 0.2s linear;
}

.openingLogo {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100vh;
	width: 100%;
	background-color: #FFFFFF;
	display: block;
	position: fixed;
	z-index: 10000;
}
.openingLogo h1{
	width: 100%;
	max-width: 800px;
    text-align: center;
	font-weight: bold;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%); /* Safari用 */
	transform: translate(-50%, -50%);
    font-size: 40px;
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    letter-spacing: 2.5px;
    color: #343434;
    z-index: 10000;
}
@media  (max-width: 769px) {
    .openingLogo h1 {
        font-size: 30px;
    }
}

/*========= くるくる回るテキスト ===============*/

.rollAnime.roll span {
    transition-property: opacity,transform;
    transform: rotateY(360deg);
    transition: all .8s cubic-bezier(.77,0,.175,1);
    transition-timing-function: cubic-bezier(.77,0,.175,1);
    display: inline-block;
}


.loading {
    width: 100vw;
    height: 100vh;
    /*animation: bgAnime 1s linear 1.8s forwards;*/
	position: fixed;
	z-index: 1000000;
	background: url("/images/video/motion-2.mp4");
	display: block;
}
.loading video {
    width: 100%;
}
.loadText {
    text-align: center;
    font-size: 10px;
    letter-spacing: 5px;
    color: #000;
    height: 1em;
    line-height: 1.2;
    position: absolute;
    top: 120px;
    left: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    z-index: 7;
    opacity: 1;
}
 
.loadText span{
    display: inline-block;
}
 
.loadText span:nth-child(1){
    animation: textAnime2 2.6s ease-in-out .5s infinite;
}
 
.loadText span:nth-child(2){
    animation: textAnime2 2.6s ease-in-out .6s infinite;
}
 
.loadText span:nth-child(3){
    animation: textAnime2 2.6s ease-in-out .7s infinite;
}
 
.loadText span:nth-child(4){
    animation: textAnime2 2.6s ease-in-out .8s infinite;
}
.loadText span:nth-child(5){
    animation: textAnime2 2.6s ease-in-out .9s infinite;
}
.loadText span:nth-child(6){
    animation: textAnime2 2.6s ease-in-out 1s infinite;
}
.loadText span:nth-child(7){
    animation: textAnime2 2.6s ease-in-out 1.1s infinite;
}
.loadText span:nth-child(8){
    animation: textAnime2 2.6s ease-in-out 1.2s infinite;
}
.loadText span:nth-child(9){
    animation: textAnime2 2.6s ease-in-out 1.3s infinite;
}
.loadText span:nth-child(10){
    animation: textAnime2 2.6s ease-in-out 1.4s infinite;
}
 
/*keyframe*/
@keyframes textAnime1{
0%{
		opacity: 0;
	}
	100%{
		opacity: 1;
	}
}
 
@keyframes textAnime2 {
0% {
    transform: translateY(0);
}
10%{
    transform: translateY(-30%);
}
20% {
    transform: translateY(30%);
}
30%{
    transform: translateY(0);
}
100%{
    transform: translateY(0);
}

}
 
@keyframes bgAnime{
	0%{
		opacity: 1;
	}
	99%{
		opacity: 0;
	}
	100%{
		opacity: 0;
		display: none;
	}
}



.wrapper{

}
.mainBgBox {
   
    
}



.scrollFix {
    margin-top: -60px;
    padding-top: 60px;
    display: table;
}













.workBox h1,
.crientsBox h1{
    font-size: 36px;
    text-align: center;
    font-weight: bold;
    margin-bottom: 40px;
}
.workBox h1 span,
.crientsBox h1 span{
    font-size: 14px;
    display: block;
    font-weight: normal;
    padding-top: 10px;
}
.workBox ul li h2 {
    font-size: 15px;
    padding-left: 40px;
    position: relative;
    margin-bottom: 10px;
    font-weight: bold;
}
.workBox ul li h2::before {
    content: '';
    width: 26px;
    height: 1px;
    background-color: #000000;
    position: absolute;
    top: 10px;
    left: 0;
}
.workBox ul li .imgBox {
    margin-bottom: 15px;
    border-radius: 10px;
    overflow: hidden;
}
.workBox ul li p {
    line-height: 2;
    font-size: 14px;
}






.btn {
    display: inline-block;
    padding: 6px 12px;
    margin-bottom: 0;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.42857143;
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    -ms-touch-action: manipulation;
    touch-action: manipulation;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    background-image: none;
    border: 1px solid transparent;
    border-radius: 4px;
}

.btn {
    border-radius: 50px;
    line-height: 1.3;
    padding-left: 30px;
    padding-right: 30px;
    padding-top: 7px;
    padding-bottom: 6px;
}

.btn-white {
    background-color: #FFFFFF;
    color: #262626;
    line-height: 1;
}

.btn svg {
    width: 16px;
    height: auto;
    vertical-align: middle;
	margin-right: 10px;
}



/* gNav
-------------------------------------*/
.gNav {
	display: none;
    position: relative;
    top: auto;
    left: 0;
    right: 0;
    z-index: 1000;
    
    margin-left: 0;
    margin-right: 0;
    width: 100%;
}
.gNav ul {
	display: block;
	padding: 0;
	margin: 0;
}
.gNav ul li {
	min-width: inherit;
	margin: 0;
	line-height: 1.5;
	text-align: left;
}
	.gNav ul li:first-child{
		border-bottom: 0;
		margin-top: 10px;
	}
	.gNav ul li:last-child{
		border-bottom: 0;
		margin-bottom: 10px;
	}
.gNav ul li a {
	display: block;
	align-items: center;
	color: #fff;
	padding: 11px 20px 11px 17px;
}
.gNav ul li.current a:before {
	display: none;
}
.gNav ul li .en {
	margin-left: auto;
	font-size: 10px;
}

.gNav .contactBtn {
	position: relative;
	top: auto;
	right: auto;
	padding: 22px 10px;
	text-align: center;
}
.gNav .contactBtn a {
	display: inline-block;
	min-width: 225px;
	padding: 3px 30px;
	color: #1b1d2e;
	font-size: 16px;
	background: url(../images/icn_contact03.png) no-repeat 12px center / 18px 18px #fff;
	box-sizing: border-box;
}
	.gNav .kanae a{
		min-width: 20px;
	}
	

/* headerSp
-------------------------------------*/
.headerSpBtn {
	display: block;
	position: absolute;
	top: 10px;
	right: 0px;
	z-index: 3;
	width: 31px;
	height: 27px;
	cursor: pointer;
}
.headerSpBtn,
.headerSpBtn span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
/* headerSp
-------------------------------------*/
.headerSpBtn {
	display: block;
    position: absolute;
    top: 19px;
    right: 20px;
    z-index: 3;
    width: 31px;
    height: 27px;
    cursor: pointer;
}
.headerSpBtn,
.headerSpBtn span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
.headerSpBtn span {
	position: absolute;
	width: 100%;
	height: 3px;
	background-color: #FFFFFF;
    filter: drop-shadow(1px 1px 2px #777777);
}
.headerSpBtn span:nth-of-type(1) {
	top: 0;
}
.headerSpBtn span:nth-of-type(2) {
	display: none;
}
.headerSpBtn span:nth-of-type(3) {
	top: 11px;
}
.headerSpBtn.open{
    top: 12px;
}
.headerSpBtn.open span:nth-of-type(1) {
	top: 12px;
	transform: rotate(45deg);
}
.headerSpBtn.open span:nth-of-type(2) {
	opacity: 0;
}
.headerSpBtn.open span:nth-of-type(3) {
	top: 12px;
	transform: rotate(-45deg);
}




#bottomContents {
    padding-top: 100px;
    padding-bottom: 100px;
    min-height: 60vh;
    background-color: #f9f9f9;
}
#bottomContents.notContact{
    background-color: #FFFFFF;
}
#bottomContents .boxInner{
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
}

#bottomContents h1{
    font-size: 26px;
    font-weight: bold;
    margin-bottom: 50px;
    text-align: center;
}
.brandRegFormBox {
    padding: 4%;
    background-color: #FFFFFF;
    border-radius: 20px;
    margin: 0 auto;
    margin-bottom: 20px;
    background-color: #FFFFFF;
    box-shadow: 0px 0px 10px 0px rgb(0 0 0 / 10%);
    border: transparent;
    max-width: none;
    margin-left: 4%;
    margin-right: 4%;
    box-sizing: border-box;
}
.brandRegFormBox fieldset{
    margin-bottom: 30px;
}

.formGroup label {
    display: block;
    text-align: left;
    margin-bottom: 15px;
    font-size: 13px;
    line-height: 1;
		
}


input[type="text"], input[type="email"], select, textarea, textarea.form-control {
    height: auto;
    margin: 0;
    padding: 0 20px;
    vertical-align: middle;
    background: #F8F8F8;
    border: 1px solid #DDDDDD;
    font-size: 16px;
    font-weight: normal;
    line-height: 50px;
    color: #000000;
    border-radius: 5px;
    -o-transition: all .3s;
    -moz-transition: all .3s;
    -webkit-transition: all .3s;
    -ms-transition: all .3s;
    transition: all .3s;
    box-sizing: border-box;
}
textarea, textarea.form-control{
    line-height: 1.6;
    min-height: 300px;
    padding: 10px 20px;
    min-height: 200px;
}

.formGroup input[type="text"], .formGroup input[type="email"], .formGroup textarea {
    width: 100%;
}


.formGroup {
    margin-bottom: 30px;
}


#bottomContents .thanksLeadBox {
    border: 3px #dcdcdc solid;
    padding: 30px;
    background-color: #FFFFFF;
    margin-bottom: 50px;
    line-height: 2;
    margin-left: 4%;
    margin-right: 4%;
}
#bottomContents h2{
    margin-bottom: 30px;
    text-align: center;
}

#contactSendBox{
    background-color: #262626;
    color: #FFFFFF;
    font-size: 18px;
}
.btn-primary{
    background-color: #262626;
    color: #FFFFFF;
    font-size: 18px;
}

.companyDataList dl{
    display: grid;
    grid-template-columns: 33% 67%;
    margin-bottom: 0;
}
.companyDataList dl:first-child dt{
    border-top: 2px solid #262626;
}
.companyDataList dl:first-child dd{
    border-top: solid 2px #dcdcdc;
}
.companyDataList dt{
    border-bottom: 2px solid #262626;
    padding: 20px;
}
.companyDataList dd{
    border-bottom: 2px solid #dcdcdc;
    padding: 20px;
    margin-bottom: 0;
}
.companyDataList a{
    color: #27a933;
}

.work__container {
    display: grid;
    grid-template-columns: repeat(3 , 1fr);
}