@charset "UTF-8";
/* CSS Document */
@keyframes zoomUp {
0% {
transform: scale(1);
}
100% {
transform: scale(1.15);
}
}
@keyframes img-wrap {
100% {
transform: translateX(-100%);
}
}
@-webkit-keyframes ttb01 {
0% {
transform: translateX(100%);
}
to {
transform: translateX(-100%);
}
}
@keyframes ttb01 {
0% {
transform: translateX(100%);
}
to {
transform: translateX(-100%);
}
}
@-webkit-keyframes ttb02 {
0% {
transform: translateX(0);
}
to {
transform: translateX(-200%);
}
}
@keyframes ttb02 {
0% {
transform: translateX(0);
}
to {
transform: translateX(-200%);
}
}
@-webkit-keyframes ttb01-pc {
0% {
transform: translateY(100%);
}
to {
transform: translateY(-100%);
}
}
@keyframes ttb01-pc {
0% {
transform: translateY(100%);
}
to {
transform: translateY(-100%);
}
}
@-webkit-keyframes ttb02-pc {
0% {
transform: translateY(0);
}
to {
transform: translateY(-200%);
}
}
@keyframes ttb02-pc {
0% {
transform: translateY(0);
}
to {
transform: translateY(-200%);
}
}
/*PC*/
@media print, screen and (min-width: 768px) {
/* SLIDER
--------------------------------------------*/
#mv {
position: relative;
width: 100%;
height: 100vh;
margin: 0 auto 200px;
overflow: hidden;
box-sizing: border-box;
min-width: 1400px;
}

#mv .slider_txt_box {
position: absolute;
left: 50%;
top: 25%;
z-index: 2;
width: 420px;
margin-left: -210px;
}

#mv .fv_ttl{
width: 100%;
margin:0 auto 10px;
}

#mv .slider_txt_box .slider_read_txt {
font-size: .8rem;
line-height: 1.8;
color: #fff;
font-weight: 600;
letter-spacing: .2rem;
text-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
}

#mv .slider_txt_box .slider_read_txt span {
display: block;
}

#mv .add-animation {
animation: zoomUp 10s linear 0s normal both;
}

#mv .move {
overflow: hidden;
position: relative;
width:100%;
height:100vh;
height:100svh;
min-height: 50vh;
margin: 0 auto;
}

#mv .move::before{
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0,0,0,.2);
z-index: 1;
}

#mv .move video {
position: absolute;
top: 50%;
left: 50%;
object-fit: cover;
transform: translate(-50%, -50%);
width: 100%;
height: 100%;
}


/*-------about--------*/
#about {
min-width: 1400px;
overflow: hidden;
position: relative;
}
#about .section_tit .bg_bk {
background: #333;
display: inline-block;
padding: 7px 15px;
box-sizing: border-box;
color: #fff;
font-size: 1.1rem;
position: absolute;
top: 82px;
left: 297px;
letter-spacing: 2px;
}
#about .section_tit {
margin-left: 5%;
}
#about .img_item {
width: 75%;
margin: 60px auto 0 5%;
position: relative;
z-index: 2;
}
#about .img_item_02 {
width: 75%;
margin: 60px 0 0 auto;
position: absolute;
right: 0;
}
#about .tower01 {
position: absolute;
top: -30px;
right: 50px;
opacity: 0.1;
width: 1370px;
}
#about .tower02 {
position: absolute;
bottom: 0;
right: 0;
opacity: .2;
width: 100%;
z-index: 1;
}
#about .section_tit {
font-size: 5.2rem;
color: #333;
line-height: 1.3;
position: relative;
font-weight: 800;
z-index: 1;
}
#about .section_tit .sb {
font-size: 2.2rem;
display: block;
}
#about .box01 {
position: relative;
padding-top: 50px;
}
#about .asirai {
position: absolute;
top: 0%;
width: 50%;
right: 3%;
z-index: 1;
}
#about .img-wrap {
opacity: 0; /* 最初は非表示 */
}
#about .img-wrap_js {
opacity: 1; /* 最初は非表示 */ overflow: hidden;
position: relative;
}
#about .img-wrap_js::before {
animation: img-wrap 1.5s cubic-bezier(0.4, 0, 0.2, 1) forwards;
background: #121212;
content: '';
inset: 0;
pointer-events: none;
position: absolute;
z-index: 1;
}
#about .background {
background: #121212;
width: 95%;
overflow: hidden;
position: relative;
border-radius: 0 80px 0 0;
}
#about .box02 {
color: #fff;
margin: 0 auto 0 0;
position: relative;
z-index: 2;
display: flex;
padding:5%;
box-sizing: border-box;
}
#about .box02 .box_item {
padding: 15px;
position: relative;
}
#about .box02 .box_item .number {
font-size: 4rem;
font-weight: 700;
line-height: 1;
position: relative;
text-align: center;
}
#about .box02 .box_item .number span {
font-size: 0.9rem;
display: block;
}
#about .box02 .box_item .number::after {
content: "";
background: #fff;
width: 50px;
height: 1px;
position: absolute;
bottom: 0;
left: 50%;
transform: translateX(-50%);
-webkit-transform: translateX(-50%);
-ms-transform: translateX(-50%);
}
#about .box02 .box_item .flex_wrap {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
#about .box02 .box_item .flex_wrap .nom_box {
width: 15%;
}
#about .box02 .box_item .flex_wrap .english p {
padding-top: 30px;
}
#about .box02 .box_item .flex_wrap .text_box {
width: 80%;
}
#about .box02 .box_item .flex_wrap .text_box p {
font-size: 1.1rem;
}
#about .box02 .box_item .btn_04 {
margin: 40px 0 0 auto;
}
#about .box02 .box_item .img_box {
margin-top: 30px;
}
#about .box02 .box_item .paint {
position: absolute;
width: 280px;
right: 120px;
opacity: 0.4;
}
/* スライドの動き等速 */
#about .swiper-wrapper {
transition-timing-function: linear;
}
/* 画像のサイズ調整 */
#about .swiper-slide img {
height: auto;
width: 100%;
}
#about .swiper-slide {
margin-left: 20px;
}
#about .swiper-slide.mt30 {}
#about .swiper_about {
padding: 130px 0 170px;
}
/*-----#parallax-----*/
#parallax2 {
position: relative;
width: 100%;
margin: 50px auto 0;
overflow: hidden;
z-index: 3;
}
#parallax2 .img-bg-02 {
background-image: url("../images/index/parallax.jpg");
}
#parallax2 .parallax-bg {
background-attachment: fixed;
background-position: center;
background-size: cover;
background-repeat: no-repeat;
height: 550px;
}
#parallax2::after {
content: "";
background: rgba(61, 61, 61, .5);
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
z-index: 1;
}
/*-----#works---*/
#works {
position: relative;
min-width: 1400px;
display: block;
padding: 200px 0;
overflow: hidden;
}
/*#works::after{background: #ddd; width: 50%; height: 100%; content: ""; position: absolute; right: 0; top: 0;}*/
#works .asirai_bg {
position: absolute;
top: 0;
}
#works .sb_tit {
margin-left: 5%;
}
#works .com_tit {
margin-left: 5%;
}

#works .asirai {
position: absolute;
left: 140px;
width: 250px;
top: 110px;
}

#works .card01 {
position: relative;
-webkit-box-sizing: content-box;
box-sizing: content-box;
margin: 0 auto;
width: 90%;
}

#works .card01 .swiper {
  overflow: visible;
}

#works .card01 .slide-content {
margin-top: 10px;
}
#works .swiper-button-next::after {
content: '';
margin-right: 0.4rem;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}
#works .swiper-button-prev::after {
margin-left: 0.4rem;
-webkit-transform: rotate(-135deg);
transform: rotate(-135deg);
}
#works .swiper-button-prev::after, .swiper-button-next::after {
width: 1.2rem;
height: 1.2rem;
content: "";
border: solid 1px #333;
border-top-width: 1px;
border-right-width: 1px;
border-bottom-width: 1px;
border-left-width: 1px;
border-width: 3px 3px 0 0;
}
#works .swiper-button-prev::before, .swiper-button-next::before {
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
content: "";
border-radius: 50%;
-webkit-box-shadow: var(--box-shadow);
box-shadow: var(--box-shadow);
}
#works .swiper-button-next {
position: absolute;
right: 9%;
top: -140px;
}
#works .swiper-button-prev {
position: absolute;
left: 83%;
z-index: 10;
top: -140px;
}
#works .swiper-button-next {
display: grid;
place-content: center;
width: 60px;
height: 60px;
border: 1px solid #4CCBA7;
border: 1px solid var(--clr-lgr);
border-radius: 50vw;
transition: all 0.4s ease-out;
transition: var(--transit-default);
cursor: pointer;
}
#works .swiper-button-prev, .swiper-button-next {
display: grid;
place-content: center;
width: 3.5rem;
height: 3.5rem;
cursor: pointer;
-webkit-transition: var(--transition);
transition: .8s var(--easing);
border-radius: 50px;
}
#works .swiper-controller {
display: flex;
gap: 1.6rem;
align-items: center;
justify-content: flex-end;
}
#works .swiper-pagination {
display: -webkit-box;
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
-webkit-flex-wrap: wrap;
-ms-flex-wrap: wrap;
flex-wrap: wrap;
-webkit-box-pack: start;
-webkit-justify-content: flex-start;
-ms-flex-pack: start;
justify-content: flex-start;
margin: 0 auto 0 0;
text-align: center;
position: absolute;
left: 65%;
top: -80px;
height: 50px;
}
#works .swiper-pagination-bullet-active {
width: 6rem;
background-color: #0b2e74;
}
#works .swiper-pagination-bullet {
width: 6%;
height: 2px;
cursor: pointer;
-webkit-transition: var(--transition);
transition: var(--transition);
vertical-align: top;
background-color: #333;
border-radius: 0;
margin: 0;
}
#works .more_btn {
position: absolute;
top: -160px;
right: 19%;
font-size: 1rem;
border: solid 2px #333;
border-radius: 50px;
padding: 10px 15px;
z-index: 3;
}
#works .more_btn:hover {
border: solid 2px #333;
color: #fff;
background: #333;
transition: 0.5s;
}
#works .slide-title {
font-size: 1.2rem;
padding-left: 15px;
position: relative;
}
#works .slide-title::before {
content: "";
position: absolute;
height: 25px;
background: #333;
width: 2px;
left: 0;
top: 7px;
}
/* reason
--------------------------------------------*/
#reason {
position: relative;
margin-bottom: 200px;
min-width: 1400px;
}
#reason .com_tit {
font-size: 3rem;
}
#reason .reason_bg {
background: url("../images/index/reason_bg.jpg");
background-size: cover;
height: 950px;
width: 100%;
position: relative;
}
#reason .reason_bg::after {
content: "";
display: block;
width: 100%;
height: 100%;
backdrop-filter: blur(30px);
-webkit-backdrop-filter: blur(30px);
background: rgba(0, 0, 0, 0.3);
top: 0;
position: absolute;
left: 0;
}
#reason .com_tit::after {
display: none;
}
#reason ul {
position: relative;
z-index: 1;
display: flex;
flex-wrap: wrap;
width: 90%;
margin: -420px auto 0;
justify-content: space-between;
}
#reason ul li:nth-child(-n + 2) {
width: 48%;
margin-top: 0;
}
#reason ul li {
width: 32%;
margin-top: 50px;
position: relative;
}
#reason .text_box {
position: absolute;
top: 150px;
left: 50%;
transform: translateX(-50%);
-webkit-transform: translateX(-50%);
-ms-transform: translateX(-50%);
color: #fff;
z-index: 2;
text-align: center;
}
#reason .text_box .top_text {
font-size: 1.4rem;
font-weight: 500;
letter-spacing: 3px;
line-height: 1.7;
}
#reason .reason_bg .text_box .text {
font-size: 1rem;
line-height: 1.5;
margin-top: 20px;
letter-spacing: 2px;
}
#reason ul li .number {
background: #121212;
color: #fff;
width: 80px;
height: 80px;
position: absolute;
top: 0;
z-index: 2;
right: 0;
text-align: center;
padding-top: 22px;
box-sizing: border-box;
font-size: 1.5rem;
line-height: 1;
font-weight: 600;
}
#reason ul li .number span {
display: block;
font-size: 0.9rem;
}
#reason ul li a .image {
position: relative;
overflow: hidden;
}
#reason ul li a .image::after {
bottom: 0;
left: 0;
width: 100%;
height: 80%;
background: linear-gradient(to bottom, rgba(0, 164, 180, 0), rgba(0, 0, 0, 0.6));
content: "";
z-index: 1;
position: absolute;
z-index: 5;
}
#reason ul li a .image img {
position: relative;
z-index: 2;
height: auto;
transition: transform .6s ease;
}
#reason ul li a .job {
position: absolute;
bottom: 5%;
right: 5%;
z-index: 15;
color: #fff;
width: 90%;
}
#reason ul li:nth-child(-n+2) a .job h3 {
font-size: 1.9rem;
}
#reason ul li a .job h3 {
font-size: 1.5rem;
}
#reason ul li a .image:hover .bg {
transform: scale(1.1); /* 拡大 */
}
/* ----------------------
history SECTION STYLES
--------------------- */
#history .com_tit {
line-height: 1.3;
padding-bottom: 20px;
}
#history .concept-company {
position: relative;
z-index: 10;
color: #fff;
height: 900px;
overflow: hidden;
background: #151515;
z-index: 3;
}
#history .concept-company::before {
content: "";
width: 70%;
height: 100%;
background: linear-gradient(270deg, rgb(0, 0, 0), rgba(0, 0, 0, 0));
position: absolute;
right: 0;
z-index: 2;
top: 0;
}
#history .concept-company__inner {
position: relative;
height: 994px;
}
#history .concept-company__hed_text {
position: absolute;
right: 0;
top: 50%;
transform: translateY(-50%);
z-index: 3;
width: 480px;
color: #fff;
}
#history .concept-company__hed_text .section_tit {
font-size: 7em;
font-weight: 800;
text-shadow: 4px 5px 13px rgba(255, 255, 255, 0.2);
letter-spacing: 0;
line-height: 1;
}
#history .concept-company__hed_text .text {
text-shadow: 4px 5px 13px rgba(255, 255, 255, 0.2);
font-weight: 500;
line-height: 2.2;
font-size: 1rem;
}
#history .concept-company__hed_text {
margin-right: 10%;
color: #fff;
}
#history .concept-company__text {
font-weight: 500;
line-height: 180%;
margin-top: 36px;
}
#history .concept-company__slider {
display: flex;
width: 75%;
margin-left: 0;
position: relative;
transform: rotate(25deg);
}
#history .concept-company__slider {
margin-left: -10%;
}
#history .concept-company__slide {
flex: 0 0 30%;
padding: 0 7px;
}
#history .concept-company__slide.-ttb .slide__container:first-child {
-webkit-animation: ttb01-pc 40s -20s linear infinite;
animation: ttb01-pc 40s -20s linear infinite;
}
#history .concept-company__slide.-ttb .slide__container:last-child {
-webkit-animation: ttb02-pc 40s linear infinite;
animation: ttb02-pc 40s linear infinite;
}
#history .concept-company__slide.-btt .slide__container:first-child {
animation: ttb01-pc 40s -20s linear infinite reverse;
}
#history .concept-company__slide.-btt .slide__container:last-child {
animation: ttb02-pc 40s linear infinite reverse;
}
#history .concept-company .slide__container {
padding: 0;
margin: 0;
list-style: none;
}
#history .concept-company .slide__items {
padding: 6px 0;
width: 100%;
}
#history .concept-company .slide__items img {
width: 100%;
}
#history .concept-company .btn_04 {
margin: 50px auto 0 0;
}
/*----news-----*/
#news {
position: relative;
width: 76%;
margin: 150px auto 160px;
padding: 60px 60px;
box-sizing: border-box;
border-radius: 20px;
background-color: rgba(0, 0, 0, .15);
backdrop-filter: blur(4px);
-webkit-backdrop-filter: blur(4px);
}
#news .section_tit {
font-size: 2rem;
}
#news .section_tit span {
display: block;
}
#news .section_wrap {
position: relative;
width: 100%;
margin: 0 auto;
}
#news .section_wrap h2 {
font-size: 2.4rem;
font-weight: 700;
line-height: 1.4;
margin: 0 0 60px -5px;
}
#news .section_wrap .news_wrap {
width: 100%;
height: 200px;
overflow-x: hidden;
margin: 0 auto 60px;
}
#news .section_wrap .news_wrap dl {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
line-height: 1;
margin: 0 0 20px;
border-bottom: 1px solid rgba(0, 0, 0, .08);
padding-bottom: 16px;
box-sizing: border-box;
}
#news .section_wrap .news_wrap dl dt {
position: relative;
width: 12%;
font-family: "Poppins", sans-serif;
font-weight: 500;
}
#news .section_wrap dl dd {
position: relative;
width: 88%;
}
#news .btn_04 {
margin: 0 0 0 auto;
}
/*-----recruit-----*/
#recruit {
min-width: 1400px;
position: relative;
margin-top: 200px;
background: #121212;
padding: 70px 0;
box-sizing: border-box;
overflow: hidden;
}
#recruit .section_tit {
background: #121212;
color: #fff;
display: inline-block;
font-size: 2rem;
font-weight: 800;
line-height: 1;
}
#recruit .read_text_box {
margin-left: 5%;
position: relative;
z-index: 2;
color: #fff;
}
#recruit .read_text_box h3 {
font-size: 5rem;
font-weight: 700;
margin-top: 20px;
letter-spacing: 2px;
line-height: 1.1;
}
#recruit .read_text_box .text {
font-size: 1.6rem;
margin-top: 60px;
font-weight: 300;
}
#recruit .read_text_box .strong {
font-size: 1.3rem;
font-weight: 700;
margin-top: 30px;
}
#recruit .wave_01 {
position: absolute;
top: -5%;
width: 100%;
z-index: 1;
left: 0;
}
#recruit .wave_02 {
position: absolute;
bottom: 0;
width: 110%;
z-index: 1;
}
#recruit .cont_box {
position: relative;
width: 48%;
}
#recruit .cont_box .job_text_box .read {
font-size: .9rem;
line-height: 1;
padding: 0;
font-weight: 400;
margin: 0 0 30px;
}
#recruit .cont_box .job_text_box .read span {
background: #01a6da;
padding: 3px 5px;
color: #FFF;
}

#recruit .cont_box .job_text_box h3 {
font-weight: 800;
font-size: 3.3rem;
letter-spacing: 4px;
margin: 15px 0;
line-height: 1;
color: #fff;
}
#recruit .cont_box .job_text_box p {
font-size: 1.2rem;
color: #fff;
font-weight: 300;
}
#recruit .cont_box .img_flex {
display: flex;
flex-wrap: wrap;
z-index: 2;
position: relative;
justify-content: space-between;
}
#recruit .cont_box .img01 {
width: 100%;
}
#recruit .cont_box .flex_box {
display: flex;
flex-wrap: wrap;
align-items: center;
width: 90%;
margin: 60px auto 30px;
}
#recruit .cont_box .flex_box .img_flex {
width: 60%;
}
#recruit .cont_box .flex_box .job_text_box {
width: 40%;
position: relative;
z-index: 3;
}
#recruit .cont_box .bg_font {
position: absolute;
font-weight: 800;
font-size: 10rem;
color: rgba(222, 222, 222, .8);
-webkit-text-fill-color: #FFF;
-webkit-text-stroke: 2px rgba(222, 222, 222, .8);
-webkit-writing-mode: vertical-rl;
-moz-writing-mode: vertical-rl;
-ms-writing-mode: tb-rl;
-ms-writing-mode: vertical-rl;
writing-mode: vertical-rl;
white-space: pre;
-webkit-text-orientation: upright;
right: 0;
top: -170%;
}
#recruit .cont_box .job_text_box {
margin-top: 30px;
}
#recruit .cont_flex {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
width: 90%;
margin: 50px auto 80px;
position: relative;
z-index: 1;
}
#recruit .center {
text-align: center;
}
#recruit .top_text {
font-size: 2.3rem;
font-weight: 700;
background: #121212;
color: #fff;
z-index: 3;
left: 30%;
margin: 0 auto;
display: inline-block;
line-height: 1;
}
#recruit .cont03 {
background: url("../images/index/recruite_bg.jpg") center;
background-size: cover;
padding: 100px;
position: relative;
}
#recruit .cont03::after {
content: "";
display: block;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.6);
position: absolute;
top: 0;
left: 0;
}
#recruit .cont03 .text {
margin: 0 auto;
text-align: center;
font-size: 1.5rem;
font-weight: 700;
color: #fff;
position: relative;
z-index: 3;
letter-spacing: 2px;
line-height: 2;
}
#recruit .cont03 .btn_04 {
position: relative;
z-index: 3;
margin: 60px auto 0;
}
}
/*sp*/
@media only screen and (max-width: 767px) {
/* SLIDER
--------------------------------------------*/
#mv {
position: relative;
width: 100%;
height: 100vh;
margin: 0 auto 120px;
overflow: hidden;
box-sizing: border-box;
}

#mv .slider_txt_box {
position: absolute;
left: 50%;
top: 30%;
z-index: 2;
width: 70%;
margin-left: -35%;
}

#mv .fv_ttl{
width: 80%;
margin:0 auto 10px;
}

#mv .slider_txt_box .slider_read_txt {
font-size: .6rem;
line-height: 1.8;
color: #fff;
font-weight: 500;
letter-spacing: .1rem;
text-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
text-align: center;
}


#mv .move {
overflow: hidden;
position: relative;
width:100%;
height:100vh;
height:100svh;
min-height: 50vh;
margin: 0 auto;
}

#mv .move::before{
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0,0,0,.2);
z-index: 1;
}

#mv .move video {
position: absolute;
top: 50%;
left: 50%;
object-fit: cover;
transform: translate(-50%, -50%);
width: 100%;
height: 100%;
}


/*-------about--------*/
#about {
position: relative;
overflow: hidden;
}
#about .section_tit .bg_bk {
background: #333;
display: inline-block;
padding: 7px 15px;
box-sizing: border-box;
color: #fff;
font-size: .9rem;
letter-spacing: 2px;
position: absolute;
top: 49px;
left: 0;
z-index: 2;
}
#about .section_tit {
margin-left: 5%;
}
#about .img_item {
width: 75%;
margin: 60px auto 0 5%;
position: relative;
z-index: 2;
}
#about .img_item_02 {
width: 75%;
margin: 60px 0 0 auto;
position: absolute;
right: 0;
}
#about .tower01 {
opacity: 0.1;
margin-top: -200px;
width: 870px;
}
#about .tower02 {
position: absolute;
bottom: 0;
right: 0;
opacity: .4;
width: 790px;
z-index: 1;
}
#about .section_tit {
font-size: 2.8rem;
color: #333;
line-height: 1.3;
position: relative;
font-weight: 800;
z-index: 1;
}
#about .section_tit .sb {
font-size: 2.2rem;
display: block;
margin-bottom: 50px;
}
#about .box01 {
position: relative;
padding-top: 50px;
}
#about .asirai {
position: absolute;
top: 0px;
right: -15%;
z-index: 1;
width: 70%;
}
#about .img-wrap {
opacity: 0; /* 最初は非表示 */
}
#about .img-wrap_js {
opacity: 1; /* 最初は非表示 */ overflow: hidden;
position: relative;
}
#about .img-wrap_js::before {
animation: img-wrap 1.5s cubic-bezier(0.4, 0, 0.2, 1) forwards;
background: #121212;
content: '';
inset: 0;
pointer-events: none;
position: absolute;
z-index: 1;
}
#about .background {
background: #121212;
width: 98%;
overflow: hidden;
position: relative;
border-radius: 0 60px 0 0;
}
#about .box02 {
color: #fff;
margin: 0 auto 0 0;
position: relative;
z-index: 2;
box-sizing: border-box;
}
#about .box02 .box_item {
padding: 5%;
position: relative;
margin-top: 20px;
}
#about .box02 .box_item .number {
font-size: 2.5rem;
font-weight: 700;
line-height: 1;
position: relative;
text-align: center;
}
#about .box02 .box_item .number span {
font-size: 0.9rem;
display: block;
}
#about .box02 .box_item .number::after {
content: "";
background: #fff;
width: 50px;
height: 1px;
position: absolute;
bottom: 0;
left: 50%;
transform: translateX(-50%);
-webkit-transform: translateX(-50%);
-ms-transform: translateX(-50%);
}
#about .box02 .box_item .flex_wrap .english p {
padding-top: 30px;
}
#about .box02 .box_item .flex_wrap .text_box p {
font-size: 1rem;
margin-top: 30px;
}
#about .box02 .box_item .btn_04 {
margin: 33px auto 40px;
}
#about .box02 .box_item .paint {
position: absolute;
width: 280px;
right: 120px;
opacity: 0.4;
}
/* スライドの動き等速 */
#about .swiper-wrapper {
transition-timing-function: linear;
}
/* 画像のサイズ調整 */
#about .swiper-slide img {
height: auto;
width: 100%;
}
#about .swiper-slide {
margin-left: 20px;
}
#about .swiper-slide.mt30 {}
#about .swiper_about {
padding: 100px 0 150px;
}
#about /*-----#parallax-----*/
#parallax2 {
position: relative;
width: 100%;
margin: 50px auto 0;
overflow: hidden;
z-index: 3;
}
#parallax2 .img-bg-02 {
background-image: url("../images/index/parallax.jpg");
}
#parallax2 .parallax-bg {
background-attachment: fixed;
background-position: center;
background-size: cover;
background-repeat: no-repeat;
height: 550px;
}
#parallax2::after {
content: "";
background: rgba(61, 61, 61, .5);
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
z-index: 1;
}
/*-----#works---*/
#works {
position: relative;
display: block;
padding: 150px 0 150px;
overflow: hidden;
}
/*#works::after{background: #ddd; width: 50%; height: 100%; content: ""; position: absolute; right: 0; top: 0;}*/
#works .asirai_bg {
position: absolute;
top: 0;
}
#works .sb_tit {
margin-left: 5%;
}
#works .com_tit {
margin-left: 5%;
padding-bottom: 20px;
}
#works .asirai {
position: absolute;
left: 0;
width: 150px;
top: 140px;
}
#works .card01 {
position: relative;
width: 90%;
margin: 80px auto 100px;
}
#works .card01 .slide-content {
margin-top: 10px;
}
#works .swiper-button-next::after {
content: '';
margin-right: 0.4rem;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}
#works .swiper-button-prev::after {
margin-left: 0.4rem;
-webkit-transform: rotate(-135deg);
transform: rotate(-135deg);
}
#works .swiper-button-prev::after, .swiper-button-next::after {
width: 1rem;
height: 1rem;
content: "";
border: solid 1px #333;
border-top-width: 1px;
border-right-width: 1px;
border-bottom-width: 1px;
border-left-width: 1px;
border-width: 3px 3px 0 0;
}
#works .swiper-button-prev::before, .swiper-button-next::before {
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
content: "";
border-radius: 50%;
-webkit-box-shadow: var(--box-shadow);
box-shadow: var(--box-shadow);
}
#works .swiper-button-next {
position: absolute;
left: 83%;
top: -58px;
}
#works .swiper-button-prev {
position: absolute;
left: 70%;
z-index: 10;
top: -51px;
}
#works .swiper-button-next {
display: grid;
place-content: center;
width: 60px;
height: 60px;
border: 1px solid #4CCBA7;
border: 1px solid var(--clr-lgr);
border-radius: 50vw;
transition: all 0.4s ease-out;
transition: var(--transit-default);
cursor: pointer;
}
#works .swiper-button-prev, .swiper-button-next {
display: grid;
place-content: center;
width: 3rem;
height: 3rem;
cursor: pointer;
-webkit-transition: var(--transition);
transition: .8s var(--easing);
border-radius: 50px;
}
#works .swiper-controller {
display: flex;
gap: 1.6rem;
align-items: center;
justify-content: flex-end;
}
#works .swiper-pagination {
display: -webkit-box;
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
-webkit-flex-wrap: wrap;
-ms-flex-wrap: wrap;
flex-wrap: wrap;
-webkit-box-pack: start;
-webkit-justify-content: flex-start;
-ms-flex-pack: start;
justify-content: flex-start;
margin: 0 auto 0 0;
text-align: center;
position: absolute;
left: 60%;
top: -20px;
}
#works .swiper-pagination-bullet-active {
width: 6rem;
background-color: #0b2e74;
}
#works .swiper-pagination-bullet {
width: 6%;
height: 2px;
cursor: pointer;
-webkit-transition: var(--transition);
transition: var(--transition);
vertical-align: top;
background-color: #333;
border-radius: 0;
margin: 0;
}
#works .more_btn {
position: absolute;
bottom: -100px;
left: 50%;
transform: translateX(-50%);
-webkit-transform: translateX(-50%);
-ms-transform: translateX(-50%);
font-size: .9rem;
border: solid 2px #333;
border-radius: 50px;
padding: 10px 15px;
z-index: 3;
width: 70px;
}
#works .more_btn:hover {
border: solid 2px #333;
color: #fff;
background: #333;
transition: 0.5s;
}
#works .slide-title {
font-size: 1.2rem;
padding-left: 15px;
position: relative;
}
#works .slide-title::before {
content: "";
position: absolute;
height: 25px;
background: #333;
width: 2px;
left: 0;
top: 7px;
}
/* reason
--------------------------------------------*/
#reason {
position: relative;
margin-bottom: 150px;
}
#reason .reason_bg {
background: url("../images/index/reason_bg.jpg");
background-size: cover;
height: 1100px;
width: 100%;
position: relative;
}
#reason .reason_bg::after {
content: "";
display: block;
width: 100%;
height: 100%;
backdrop-filter: blur(30px);
-webkit-backdrop-filter: blur(30px);
background: rgba(0, 0, 0, 0.3);
top: 0;
position: absolute;
left: 0;
}
#reason .reason_bg .com_tit::after {
display: none;
}
#reason .reason_content {
margin: -980px auto 0;
width: 96%;
}
#reason ul {
position: relative;
z-index: 1;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
#reason ul li:nth-child(-n + 2) {}
#reason ul li {
margin-top: 30px;
position: relative;
}
#reason .text_box {
color: #fff;
z-index: 2;
position: relative;
}
#reason .text_box .top_text {
font-size: 1.2rem;
font-weight: 500;
letter-spacing: 3px;
line-height: 1.7;
}
#reason .text_box .text {
font-size: .9rem;
line-height: 1.5;
margin-top: 20px;
letter-spacing: 2px;
}
#reason ul li .number {
background: #121212;
color: #fff;
width: 80px;
height: 80px;
position: absolute;
top: 0;
z-index: 2;
right: 0;
text-align: center;
padding-top: 22px;
box-sizing: border-box;
font-size: 1.5rem;
line-height: 1;
font-weight: 600;
}
#reason ul li .number span {
display: block;
font-size: 0.9rem;
}
#reason ul li a .image {
position: relative;
overflow: hidden;
}
#reason ul li a .image::after {
bottom: 0;
left: 0;
width: 100%;
height: 80%;
background: linear-gradient(to bottom, rgba(0, 164, 180, 0), rgba(0, 0, 0, 0.6));
content: "";
z-index: 1;
position: absolute;
z-index: 5;
}
#reason ul li a .image img {
position: relative;
z-index: 2;
height: auto;
transition: transform .6s ease;
}
#reason ul li a .job {
position: absolute;
bottom: 5%;
right: 5%;
z-index: 15;
color: #fff;
width: 90%;
}
#reason ul li a .job h3 {
font-size: 1.5rem;
}
#reason ul li a .image:hover .bg {
transform: scale(1.1); /* 拡大 */
}
/* history
--------------------------------------------*/
#history .concept-company {
position: relative;
z-index: 3;
color: #fff;
overflow: hidden;
background: #151515;
padding-bottom:60px;
box-sizing: border-box;
}
#history .concept-company::before {
content: "";
width: 100%;
height: 100%;
background: linear-gradient(180deg, rgba(28, 28, 28, .2), rgba(0, 0, 0, 1));
position: absolute;
left: 0;
z-index: 2;
top: 0;
}
#history .concept-company__inner {
position: relative;
height: 700px;
}
#history .concept-company__hed_text {
position: absolute;
left: 3%;
top: 40%;
z-index: 3;
color: #fff;
width: 90%;
}
#history .concept-company__hed_text .section_tit {
font-size: 7em;
font-weight: 800;
text-shadow: 4px 5px 13px rgba(255, 255, 255, 0.2);
letter-spacing: 0;
line-height: 1;
}
#history .concept-company__hed_text .text {
text-shadow: 4px 5px 13px rgba(255, 255, 255, 0.2);
font-weight: 500;
line-height: 2.2;
}
#history .concept-company__text {
font-weight: 500;
line-height: 180%;
margin-top: 36px;
}
#history .concept-company__slider {
display: flex;
width: 75%;
margin-left: 0;
position: relative;
margin-top: 50px;
display: block;
width: 100%;
transform: rotate(0deg);
}
#history .concept-company__slide {
flex: 0 0 100%;
display: flex;
overflow: hidden;
padding-bottom: 16px;
padding-bottom: 3px;
}
#history .concept-company__slide.-ttb .slide__container:first-child {
-webkit-animation: ttb01 40s -20s linear infinite;
animation: ttb01 40s -20s linear infinite;
}
#history .concept-company__slide.-ttb .slide__container:last-child {
-webkit-animation: ttb02 40s linear infinite;
animation: ttb02 40s linear infinite;
}
#history .concept-company__slide.-btt .slide__container:first-child {
animation: ttb01 40s -10s linear infinite reverse;
}
#history .concept-company__slide.-btt .slide__container:last-child {
animation: ttb02 40s linear infinite reverse;
width: 60%;
}
#history .concept-company .slide__container {
padding: 0;
margin: 0;
list-style: none;
display: flex;
}
#history .concept-company .slide__items {
padding: 0 6px;
width: 50vw;
}
#history .concept-company .slide__items img {
width: 100%;
}
#history a.btn_04 {
margin: 30px 0 150px 0;
}
#history .com_tit {
line-height: 1.3;
padding-bottom: 10px;
}
/*----news-----*/
#news {
position: relative;
width: 94%;
margin: 90px auto 160px;
padding: 40px 20px;
box-sizing: border-box;
border-radius: 10px;
background-color: rgba(0, 0, 0, .15);
backdrop-filter: blur(4px);
-webkit-backdrop-filter: blur(4px);
overflow: hidden;
}
#news .section_tit {
font-size: 2rem;
}
#news .section_tit span {
display: block;
}
#news .section_wrap {
position: relative;
width: 100%;
margin: 0 auto;
}
#news .section_wrap h2 {
font-size: 2rem;
font-weight: 700;
line-height: 1.4;
}
#news .section_wrap .news_wrap {
width: 100%;
height: 280px;
overflow-x: hidden;
margin: 0 auto 60px;
}
#news .section_wrap .news_wrap dl {
line-height: 1;
margin: 0 0 20px;
border-bottom: 1px solid rgba(0, 0, 0, .08);
padding-bottom: 16px;
box-sizing: border-box;
}
#news .section_wrap .news_wrap dl dt {
position: relative;
font-family: "Poppins", sans-serif;
font-weight: 500;
margin-bottom: 10px;
}
#news .section_wrap dl dd {
position: relative;
width: 88%;
}
#news .btn_04 {
margin: 0 auto;
}
/*-----recruit-----*/
#recruit {
position: relative;
margin-top: 150px;
background: #121212;
box-sizing: border-box;
overflow: hidden;
}
#recruit .section_tit {
background: #121212;
color: #fff;
display: inline-block;
font-size: 1.8rem;
font-weight: 800;
line-height: 1;
}
#recruit .read_text_box {
position: relative;
z-index: 2;
color: #fff;
padding: 0 3%;
}
#recruit .read_text_box h3 {
font-size: 2rem;
font-weight: 300;
margin-top: 20px;
letter-spacing: 2px;
line-height: 1.3;
}
#recruit .read_text_box .text {
font-size: 1rem;
margin-top: 20px;
font-weight: 700;
}
#recruit .read_text_box .strong {
font-size: 1.3rem;
font-weight: 700;
margin-top: 30px;
}
#recruit .wave_01 {
position: absolute;
top: -5%;
width: 100%;
z-index: 1;
left: 0;
}
#recruit .wave_02 {
position: absolute;
bottom: 0;
width: 110%;
z-index: 1;
}
#recruit .cont_box {
position: relative;
margin-top: 50px;
}
#recruit .cont_box .job_text_box .read {
font-size: .9rem;
line-height: 2.4;
padding: 0;
font-weight: 400;
margin: 0 0 30px;
}
#recruit .cont_box .job_text_box .read span {
background: #01a6da;
padding: 3px 5px;
color: #FFF;
}

#recruit .cont_box .job_text_box h3 {
font-weight: 800;
font-size: 2rem;
letter-spacing: 4px;
margin: 15px 0;
line-height: 1;
color: #fff;
}
#recruit .cont_box .job_text_box p {
font-size: 1rem;
color: #fff;
}
#recruit .cont_box .img_flex {
display: flex;
flex-wrap: wrap;
z-index: 2;
position: relative;
justify-content: space-between;
}
#recruit .cont_box .img01 {
width: 100%;
}
#recruit .cont_box .flex_box {
display: flex;
flex-wrap: wrap;
align-items: center;
width: 90%;
margin: 60px auto 30px;
}
#recruit .cont_box .flex_box .img_flex {
width: 60%;
}
#recruit .cont_box .flex_box .job_text_box {
width: 40%;
position: relative;
z-index: 3;
}
#recruit .cont_box .bg_font {
position: absolute;
font-weight: 800;
font-size: 10rem;
color: rgba(222, 222, 222, .8);
-webkit-text-fill-color: #FFF;
-webkit-text-stroke: 2px rgba(222, 222, 222, .8);
-webkit-writing-mode: vertical-rl;
-moz-writing-mode: vertical-rl;
-ms-writing-mode: tb-rl;
-ms-writing-mode: vertical-rl;
writing-mode: vertical-rl;
white-space: pre;
-webkit-text-orientation: upright;
right: 0;
top: -170%;
}
#recruit .cont_box .job_text_box {
margin-top: 30px;
}
#recruit .cont_flex {
margin: 30px auto 80px;
position: relative;
z-index: 1;
padding: 0 3%;
}
#recruit .center {
text-align: center;
}
#recruit .top_text {
font-size: 2.3rem;
font-weight: 700;
background: #121212;
color: #fff;
z-index: 3;
left: 30%;
margin: 0 auto;
display: inline-block;
line-height: 1;
}
#recruit .cont03 {
background: url("../images/index/recruite_bg.jpg") center;
background-size: cover;
padding: 100px;
position: relative;
padding: 70px 3%;
}
#recruit .cont03::after {
content: "";
display: block;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.6);
position: absolute;
top: 0;
left: 0;
}
#recruit .cont03 .text {
margin: 0 auto;
text-align: center;
font-size: 1.2rem;
font-weight: 700;
color: #fff;
position: relative;
z-index: 3;
letter-spacing: 2px;
line-height: 2;
}
#recruit .cont03 .btn_04 {
position: relative;
z-index: 3;
margin: 60px auto 0;
}
}