@charset "utf-8";
/*common
-----------------------------------------------------------------------------------------*/
section{
	padding: 200px 0 0;
}

.contents-wrapper{
	width: calc(100% - 100px);
	max-width: 1500px;
	margin: 0 auto;
}

p{
    text-align: left;
}

.section-bottom{
    padding-bottom: 200px;
}



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

    .contents-wrapper{
        width: calc(100% - 50px);
    }

    .section-bottom{
    padding-bottom: 40px;
}

}


/*home
-----------------------------------------------------------------------------------------*/
.front-fv-en{
    width: 120px;
    writing-mode: vertical-rl; 
    color: rgba(247, 146, 54, 1);
    padding: 0 50px 100px;
    letter-spacing: 5px;
    position: relative;
    height: fit-content;
    margin: auto;

}

.front-fv-en::after{
    position: absolute;
    content: '';
    height: 150px;
    width: 1px;
    bottom: -100px;
    left: 50%;
    background-color: rgba(247, 146, 54, 1);
}

.mySwiper-top{
    width: calc(100% - 120px);
    position: relative;
}

.swiper-logo{
    position: absolute;
    width: 170PX;
    top: 50%;
    left: 50%;
    z-index: 1;
    transform: translate(-50%,-50%);
}

.front-delight-flex{
    justify-content: space-between;
    position: relative;
}

.front-delight-box{
    text-align: left;
    width: 50%;
    position: relative;
}

.front-delight-box::after{
    position: absolute;
    content: '';
    width: 190%;
    height: 120%;
    background-color: rgba(67, 66, 71, 1);
    top: -300px;
    left: 0;
    z-index: -1;
    margin-left: calc(50% - 50vw);
}

.front-title{
    font-size: 4.5rem;
    color: rgba(247, 146, 54, 1);
    margin-bottom: 50px;
}

.front-delight-text{
    margin-left: 50px;
    width: 85%;
    color: rgba(255, 255, 255, 1);
}

.front-delight-title{
    font-size: 2.5rem;
    padding: 20px 30px;
    margin-bottom: 30px;
    border-left: 1px solid rgba(247, 146, 54, 1);
}

.front-delight-1{
    object-fit: cover;
    z-index: 1;
    position: relative;
}

.front-delight-img{
    width: 45%;
    margin: 150px 50px 0 0;
    position: relative;
}

.front-delight-img::after{
    position: absolute;
    content: '';
    border: 1px solid rgba(247, 146, 54, 1);
    width: 100%;
    height: 120%;
    top: -50px;
    right: -50px;
}

.front-delight-2{
    position: absolute;
    width: 35%;
    bottom: -150px;
    left: 20%;
    z-index: 2;
}

.front-service-flex{
    justify-content: space-between;
    align-items: flex-end;
    text-align: left;
    margin-bottom: 90px;
}

.front-service-top{
    position: relative;
    padding-top: 350px;
}

.front-service-top::after{
    position: absolute;
    content: '';
    background-color: rgba(67, 66, 71, 1);
    height: 55%;
    width: 100%;
    top: 300px;
    left: 0;
    z-index: -1;
}

.front-service-box{
    width: 70%;
}

.front-delight-text span{
    display: inline-block;
    margin-bottom: 20px;
}

.front-service-link{
    position: relative;
    color: rgba(255, 255, 255, 1);
    display: inline-block;
}

.front-service-link::after{
	position: absolute;
	content: '';
	height: 1px;
	width: 80px;
	left: -100px;
	top: 50%;
	background-color: rgba(247, 146, 54, 1);
}

.front-service-link:hover{
    color: rgba(247, 146, 54, 1);
}

.front-service-img-flex{
    gap: 70px;
    justify-content: flex-end;

}

.front-service-img{
    width: 25%;
    margin: 0;
}

.front-news-top{
    padding: 300px 0 250px;
    overflow: hidden;
}

.front-news-flex{
    justify-content: space-between;
    position: relative;
    align-items: center;
}

.front-news-img{
    width: 40%;
    position: relative;
}

.front-news-img::after{
    position: absolute;
    content: '';
    width: 70%;
    height: 70%;
    border: 1px solid rgba(247, 146, 54, 1);
    z-index: -1;
    bottom: -100px;
    right: -100px;
}

.front-news-flex::before{
    position: absolute;
    content: '';
    width: 30%;
    height: 90%;
    left: 0px;
    top: -100px;
    background-color: rgba(166, 169, 175, 1);
    z-index: -1;
    margin-left: calc(50% - 50vw);
}

.front-news-right{
    text-align: left;
    width: 50%;
    margin-top: -100px;
}

.front-news-text{
    margin: 0 0 70px 50px;
}

.front-news-link-box{
    text-align: right;
}

.front-news-link{
    color: rgba(67, 66, 71, 1);
}

div.front-home-title{
    margin-left: 10px;
}

@media screen and (max-width:1300px) {
    .front-fv-en {
        padding: 0 50px 50px;
    }

    .front-delight-box::after {
        height: 150%;
        top: -250px;
    }

    .front-delight-text {
        margin-left: 0px;
        width: 100%;
    }

    .front-delight-box {
        width: 55%;
    }

    .front-delight-img {
        width: 40%;
        margin-right: 0;
    }

    .front-delight-img::after {
        height: 130%;
        right: 40px;
    }
    .front-delight-2 {
        bottom: -200px;
        left: 30%;
    }

    .front-news-img::after{
        bottom: -80px;
        right: -20px;
        width: 90%;
    }

    .front-news-right {
        width: 60%;
    }
}

@media screen and (max-width:1023px) {
    .swiper-logo {
        width: 120PX;
    }

    .front-fv-en::after {
        height: 100px;
        bottom: -60px;
    }

    .swiper-wrapper-fv img{
        height: 400px;
        object-fit: cover;
    }

    .front-delight-box::after {
        height: 180%;
        top: -230px;
        width: 110%;
    }

    .front-delight-box{
        width: 100%;
    }

    .front-delight-text {
        width: 95%;
    }

    .front-delight-img{
        width: 50%;
        margin: 40px 50px 0 auto;
    }

    .front-delight-img::after {
        height: 130%;
        right: -50px;
    }

    .front-delight-1{
        z-index: 3;
    }

    .front-delight-2 {
        bottom: 60px;
        left: 0%;
        width: 45%;
    }

    .front-service-top{
        padding-top: 150px;
    }

    .front-service-top::after {
        height: 70%;
        top: 110px;
    }

    .front-service-img-flex {
        gap: 30px;
    }

    .front-news-top {
        padding: 200px 0 150px;
    }
}

@media screen and (max-width:767px) {
    .mySwiper-top{
        width: 100%;
    }

    .front-fv-en{
        position: absolute;
        background-color: rgba(255, 255, 255, 1);
        left: 0;
        top: 0;
        width: 35px;
        height: 350px;
        z-index: 3;
        padding: 10px;
    }

    .swiper-wrapper-fv img{
        height: 350px;
    }

    .front-fv-en::after {
        display: none;
    }

    .front-title {
        font-size: 3rem;
        margin-bottom: 20px;
    }

    .front-delight-title {
        font-size: 1.8rem;
        padding: 0px 10px;
        margin-bottom: 20px;
    }
    .front-delight-box::after{
        height: 130%;
        top: -40px;
        width: 115%;
    }

    .front-delight-img {
        width: 60%;
        margin: 30px 10px 0 auto;
    }

    .front-delight-img::after {
        right: -20px;
        top: -30px;
    }

    .front-delight-2 {
        bottom: 75px;
        width: 40%;
    }

    .front-service-top{
        padding-top: 40px;
    }

    .front-service-top::after {
        height: 70%;
        top: 10px;
    }

    .front-service-box{
        width: 100%;
    }

    .front-delight-text{
        width: 100%;
    }

    .front-delight-text span {
        margin-bottom: 10px;
    }

    .front-service-link{
        margin: 20px 0 0 auto;
    }

    .front-service-img-flex {
        gap: 10px;
    }

    .front-service-flex{
        margin-bottom: 20px;
    }

    .front-service-img{
        width: calc((100% - 10px*2)/3);
    }

    .front-news-img {
        width: 90%;
    }

    .front-news-top {
        padding: 30px 0 40px;
    }

    .front-news-flex::before {
        width: 90%;
        height: 30%;
        top: -30px;
    }

    .front-news-img::after {
        bottom: -20px;
        right: -40px;
        width: 100%;
        height: 90%;
    }

    .front-news-right{
        width: 100%;
        margin-top: 30px;
    }
    .front-news-text{
        margin: 0 0 20px 0;
    }

}



/*COMPANY カンパニー
-----------------------------------------------------------------------------------------*/
.page-company-top{
    padding-top: 80px;
    background-image: url("../images/company-top-bg.jpg");

}

.page-title-top{
    background-color: rgba(67, 66, 71, 1);
    width: 50%;
    padding: 65px 70px 65px 120px;
}

.page-title{
    font-size: 4.5rem;
    font-weight: 500;
    color: rgba(247, 146, 54, 1);
    margin-bottom: 30px;
    text-align: left;
}

.bread ul{
    display: flex;
    align-items: center;
    border-top: 1px solid rgba(255, 255, 255, 1);
}

.bread-home a {
    color: rgba(255, 255, 255, 1);
    padding: 5px 10px 0;
}

.bread-single{
    color: rgba(255, 255, 255, 1);
    padding: 5px 10px 0;

}

.bread-page{
    color: rgba(218, 105, 44, 1);
    padding: 5px 10px 0;
    position: relative;
}

.bread-page::after{
    position: absolute;
    content: '';
    border-top: 2px solid rgba(218, 105, 44, 1);
    width: 100%;
    top: -2px;
    left: 0;
    z-index: 1;
}

.company-top-box{
    background-color: rgba(255, 255, 255, 0.9);
    padding: 70px;
    width: 66%;
    margin: 80px 0 0 auto;
    position: relative;
}

.company-top-add{
    font-size: 1.5rem;
    margin-bottom: 30px;
}

.company-top-flex{
    margin-bottom: 50px;
    gap: 30px;
    align-items: center;
    justify-content: center;
}

.company-top-text{
    font-size: 1.2rem;
}

.company-top-title{
    font-size: 2rem;
    font-weight: 700;
}

.company-top-number{
    font-size: 6rem;
    font-weight: 700;
    position: relative;
    z-index: 1;
}

.company-top-orange{
    position: absolute;
    width: 100%;
    bottom: 25px;
    left: 0;
    z-index: -1;
}

/* .company-top-number::before{
     background-color: rgba(247, 146, 54, 1);
  content: '';
  position: absolute;
  bottom: 25px;
  display: inline-block;
  opacity: 0.75;
  width: 100%;
  height: 15px;
  transform:skewX(-30deg);

} */

.company-top-number span{
    font-size: 2rem;
    font-weight: 700;
}

.company-top-span{
    margin-right: 20px;
    display: inline-block;
}

.company-top-set{
    width: 70%;
    text-align: left;
    margin: auto;
}

.company-top-mini{
    margin-top: 20px;
    display: inline-block;
}

.company-top-img{
    position: absolute;
    width: 55%;
    bottom: -50px;
    left: -380px;
}

.company-message-top{
    padding: 200px 0;
    width: 70%;
    margin: auto;
}

.company-title{
    font-size: 2.5rem;
    color: rgba(218, 105, 44, 1);
    border-left: 1px solid rgba(218, 105, 44, 1);
    border-right: 1px solid rgba(218, 105, 44, 1);
    padding: 5px 60px;
    display: inline-block;
    position: relative;
    margin-bottom: 60px;
}

.company-title::after{
    position: absolute;
    content: '';
    border-top: 1px solid rgba(218, 105, 44, 1);
    width: 100%;
    top: -15px;
    left: 0;
}

.company-title::before{
    position: absolute;
    content: '';
    border-bottom: 1px solid rgba(218, 105, 44, 1);
    width: 100%;
    bottom: -15px;
    left: 0;
}

.company-message-text{
    color: rgba(255, 255, 255, 1);
    margin-bottom: 30px;
}

.company-message-name{
    color: rgba(255, 255, 255, 1);
    font-size: 2.5rem;
    text-align: right;
}

.company-message-name span{
    font-size: 1.7rem;
    font-weight: 600;
    display: inline-block;
    margin-right: 50px;
}

.company-overview-big{
    gap: 100px;
}

.company-overview-flex{
    padding: 10px 0;
    border-bottom: 1px solid rgba(166, 169, 175, 1);
}

.company-overview-box{
    width: 45%;
}

.company-overview-title{
    width: 130px;
    text-align: left;
    font-size: 1.2rem;
    color: rgba(106, 112, 122, 1);
    font-weight: 500;
    margin: 0px 0 10px 15px ;
}

.company-overview-text{
    margin-left: 130px;
}

@media screen and (max-width:1300px) {
    .page-title-top{
        padding-left: 80px;
    }

    .company-top-box {
        padding: 50px;
        width: 75%;
    }

    .company-top-set {
        width: 80%;
        margin: 0 0 0 auto;
    }

    .company-top-img{
        left: -280px;
        width: 52%;
    }
}

    @media screen and (max-width:1150px) {
    .company-top-img{
        left: -250px;
    }

    .company-message-top{
        width: 80%;
    }

    .company-overview-text {
        margin-left: 100px;
    }

    .company-overview-box{
        width: 50%;
    }

    .company-overview-box2{
        width: 43%;
    }

    .company-overview-big {
        gap: 50px;
    }

}

@media screen and (max-width:1023px) {
    .page-title-top{
        padding: 30px;
    }

    .page-title{
        font-size: 4rem;
        margin-bottom: 15px;
    }

    .company-top-box{
        width: 100%;
        padding: 45px 45px 100px;
    }

    .company-top-set{
        width: 100%;
    }

    .company-top-flex{
        margin-bottom: 0px;
    }

    .company-top-add{
        margin-bottom: 0px;
    }

    .company-top-img{
        left: 100px;
        width: 70%;
        height: 200px;
        object-fit: cover;
        object-position: top;
        bottom: -120px;
    }

    .company-message-top{
        width: 100%;
    }

    .company-message-text{
        text-align: left;
    }

    .company-overview-box{
        width: 100%;
    }

    .company-overview-text {
        margin-left: 130px;
    }

    .company-overview-big{
        gap: 0;
    }
}


@media screen and (max-width:767px) {
    .page-company-top{
        padding-top: 60px;
    }

    .page-title {
        font-size: 3rem;
        margin-bottom: 5px;
    }

    .page-title-top {
        padding: 10px 20px;
        width: 80%;
    }

    .company-top-box {
        padding: 15px 16px 100px;
        margin-top: 30px;
    }

    .company-top-flex{
        gap: 0;
        margin: 15px 0;
    }

    .company-top-number{
        line-height: 1;
    }

    .company-top-orange{
        bottom: 5px;
    }

    .company-top-mini{
        margin-top: 10px;
    }

    .company-top-img{
        width: 100%;
        left: 0;
    }

    .company-message-top {
        padding: 180px 0 40px;
    }

    .company-title{
        margin-bottom: 30px;
    }

    .company-message-text{
        margin-bottom: 10px;
    }

    .company-message-name span{
        margin-right: 20px;
    }
.company-overview-title,
    .company-overview-text {
        margin-left: 10px;
    }
}


/*SERVICE 事業内容
-----------------------------------------------------------------------------------------*/
.page-top{
    position: relative;
    margin-top: 84px;
}

.page-top::after{
    position: absolute;
    content: '';
    width: 90%;
    height: 400px;
    top: 0;
    right: 0;
    z-index: -1;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}

.page-services-top::after{
    background-image: url("../images/services-top-bg.jpg");
}

.services-top{
    padding-top: 350px;
}

.services-flex{
    gap: 50px;
    justify-content: space-between;
    margin-bottom: 100px;
    text-align: left;
    align-items: center;
}

.services-text{
    width: 57%;
}

.services-number{
    color: rgba(247, 146, 54, 0.4);
    font-size: 7.5rem;
    line-height: 0.5;
    opacity: 0.6;
}

.services-title{
    font-size: 2.5rem;
    font-weight: 600;
    padding-bottom: 25px;
    border-bottom: 1px solid rgba(67, 66, 71, 1);
    margin-bottom: 60px;
    margin-left: 30px;
    
}

.services-text-mini{
    margin-bottom: 20px;
    display: inline-block;
}

.services-img{
    width: 33%;
    margin-right: 50px;
    position: relative;
}

.services-img::after{
    position: absolute;
    content: '';
    border: 1px solid rgba(218, 105, 44, 1);
    width: 100%;
    height: 100%;
    bottom: -50px;
    right: -50px;
    z-index: -1;
}

@media screen and (max-width:1200px) {
    .services-flex{
        gap: 30px;
    }

    .services-title{
        margin-left: 0;
    }
}

@media screen and (max-width:1023px) {
    .services-img {
        width: 37%;
        margin-right: 10px;
    }

    .services-img::after {
        right: -30px;
    }

    .services-img2{
        width: 35%;
    }
}

@media screen and (max-width:767px) {
    .page-top {
        margin-top: 50px;
    }

    .page-top::after {
        height: 250px;
    }

    .services-top {
        padding-top: 180px;
    }

    .services-text{
        width: 100%;
    }

    .services-number{
        font-size: 5rem;
    }

    .services-title{
        font-size: 2rem;
        padding-bottom: 10px;
        margin-bottom: 20px;
    }

    .services-text-mini{
        margin-bottom: 10px;
    }

    .services-img{
        width: 90%;
    }

    .services-img img{
        height: 200px;
        object-fit: cover;
    }

    .services-img::after{
        bottom: -30px;
    }

    .services-img2{
        order: 2;
    }

    .services-flex{
        margin-bottom: 70px;
    }
}



/*CONTACTお問い合わせ
-----------------------------------------------------------------------------------------*/
.page-contact-top::after{
    background-image: url("../images/contact-top-bg.jpg");
}

.contact-top{
    padding: 300px 0 200px;
}

.contact-box{
    margin: 100px auto;
    width: 80%;
    border-bottom: 1px solid rgba(166, 169, 175, 1);
}

.contact-title{
    width: 35%;
}

.contact-title p{
    font-weight: 500;
}

.contact-flex{
    padding: 30px 0 30px 40px;
    border-top: 1px solid rgba(166, 169, 175, 1);
}

.text-common{
    border: none;
    background: aliceblue;
    height: 45px;
    padding-left: 40px;
    width: 100%;
    background-color: rgba(242, 243, 243, 1);
}

.contact-common{
    border: none;
    background: aliceblue;
    height: 200px;
    padding: 20px 40px;
    background-color: rgba(242, 243, 243, 1);
    width: 100%;
}

.contact-text{
    width: 65%;
}

.required{
    padding: 2px 20px;
    margin-right: 10px;
    color: rgba(218, 105, 44, 1);
    border: 1px solid rgba(218, 105, 44, 1);
}

.contact-sub{
    margin-top: 20px;
}

.contact-privacy{
    color: rgba(67, 66, 71, 1);
    border-bottom: 1px solid rgba(67, 66, 71, 1);
}

.button-submit{
    font-size: 1.5rem;
    background-color: rgba(247, 146, 54, 1);
    color: rgba(255, 255, 255, 1);
    width: 250px;
    padding: 25px;
    border: none;
    opacity: 0.5;
}

.button-submit.active{
	opacity: 1;
}

.contact-button{
    margin: auto;
    width: 250px;
}

@media screen and (max-width:1300px) {
    .contact-box{
        width: 100%;
    }

    .contact-flex{
        padding-left: 0;
    }
}

@media screen and (max-width:1023px) {
    .contact-text {
        width: 100%;
        margin-top: 20px;
    }

    .contact-title{
        width: 100%;
    }
}

@media screen and (max-width:767px) {
    .contact-top {
        padding: 190px 0 50px;
    }

    .contact-box{
        margin: 30px 0;
    }
    .contact-flex{
        padding: 10px 0 20px;
    }
}



/*PRIVACYPOLICYプライバシーポリシー
-----------------------------------------------------------------------------------------*/
.privacy-policy-top{
    font-family: "Noto Sans JP", sans-serif;
    width: 70%;
    margin: auto;
}

.privacy-text{
    margin-bottom: 100px;
}

.privacy-title{
    font-size: 1.2rem;
    margin: 40px 0 25px;
    background-color: rgba(247, 146, 54, 1);
    color: rgba(255, 255, 255, 1);
    padding: 10px 15px;
    text-align: left;
}

.privacy-span{
    margin-bottom: 30px;
    display: inline-block;
}

@media screen and (max-width:1200px) {
    .privacy-policy-top{
        width: 100%;
    }

    .privacy-text{
        text-align: left;
    }
}

@media screen and (max-width:767px) {
    .privacy-policy-top{
        padding-top: 130px;
    }

    .privacy-text{
        margin-bottom: 0;
    }

    .privacy-title {
        margin: 20px 0 10px;
    }

    .privacy-span{
        margin-bottom: 15px;
    }
}


