@charset "UTF-8";
/* CSS Document */



@import url('https://fonts.googleapis.com/css2?family=Ubuntu:ital,wght@1,300&display=swap');

/*------------共通------------*/



a{
transition: .5s;
}

a:hover{
    opacity: .5;
    transition: .5s;
}

.cta__flex__wp a:hover{
    transition: .5s;
    opacity: .5;
}

.office__flex__wp2 a:hover{
 transition: .5s;
    opacity: .5;
}

.pc__none{
    display: none;
}

.p_none{
    visibility: hidden;
}

.beige{
    color: #AF8C7B;
}

.bold{
    font-weight: bold;
}

.ft__big2{
    font-size: 1.7rem;
}

.red{
    color: #af4146;
}

.contents__ttl{
    font-size: 2.4vw;
    color: #f4f4f3;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    padding:  10vw 8vw 5vw 8vw;
}

.contents__ttl span::after{
   content: "";
   border: 0.5px solid #fff;
   margin: 0 20px;
}

.pd__2vw{
    padding:1vw;
}
.pd__4vw{
    padding:4vw;
}
.pd__8vw{
    padding:8vw;
}
.cont_small{
    font-size: 1.2vw;
}


/*------------header------------*/

    #header.m_fixed {
	position: fixed;
	top: 0;
    transition: .5s;
    background:rgba(51,51,51,0.54);
}


.logo__txt br{
    display: none;
}

.logo__txt{
    font-size: 1.3rem;
    color: #fff;
}

.hd_pr{
    background: #333;
    color: #fff;
    width: 100%;
    text-align: center;
    height: 30px;
    font-size: 1vw;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: 600;
}

.logo__wp{
    display: flex;
    flex-direction: column;
    padding: 0 0px 0 20px;
}

#header .logo{
    width: 50%;
    position: relative;
    top: 12px;
}

.logo__wp span{
    color: #fff;  
   padding-top: 1.5em;
    padding-left: 40px;
}

.cta_ico{
    width: 1.5vw;
    margin: 0 auto;
    margin-bottom: 5px;
    min-width: 20px;
    
}



/*------------mainvisual------------*/
.mv_wrap{
    overflow: hidden;
    position: relative;
    height: 100vh;
    background:#f4f4f3;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    flex-direction: column; 
}


.mv__main{
    display: flex;
    justify-content: flex-end;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    width: 100%;
    height: 100%;
    margin: auto;
}

.mv__main__ttl__wp{
    display: flex;
    justify-content: center;
    flex-direction: column;
    height: 100%;
    will-change: transform;
    margin-top: 28vh;
    margin-right: 10vw;
}




.mv-img__left{
    padding-right: 20%;
    height: 88%;
}



.mv-img__inner{
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    will-change: transform;
    
}

.mv-img__outer{
    overflow: hidden;
    box-sizing: border-box;
    position: relative;
    height: 87.1%;
    will-change: transform;
}


.mv-img__bgwp{   
    position: absolute;
    top: 0;
    right: 0;
    width: 80%;
    height: 100%;
  background-image: linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, .3)), url("../img/mv__bg.jpg");
  background-position: center center;
    will-change: transform, width;
    z-index: -1;
    
}


.mv-img{
    background-image:linear-gradient(to bottom, rgba(0, 0, 0, 0.6), transparent 40%), /* 下を暗く */
  linear-gradient(to right, rgba(0, 0, 0, 0.6), transparent 40%), /* 左を暗く */ url("../img/mv-img1.jpg");
    background-repeat: no-repeat; /* 背景画像の繰り返しを無効にする */
    background-position: center center; 
    width: 100%; /* 要素の横幅を100%に設定 */
    height: 100%; /* 要素の高さを100%に設定 */
    background-size: cover;
    
}



.mv__main__ttl{
/*    width: 1000px;*/
    color: #fff;
    font-size:3.36vw;
    line-height: 1.5;
    letter-spacing: 2px;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}

.mv__main__txt{
    margin-top: 20px;
    color: #fff;
    font-size: 1.3vw;
    line-height: 2.2;
    letter-spacing: 1px;
    font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    }
    
    @keyframes loop {
      0% {
        transform: translateX(100%);
      }
      to {
        transform: translateX(-100%);
      }
    }

@keyframes loop2 {
      0% {
        transform: translateX(0);
      }
      to {
        transform: translateX(-200%);
      }
    }
    
    
    
    
    /*スクロールダウン全体の場所*/
.scrolldown2{
    /*描画位置※位置は適宜調整してください*/
  position:absolute;
  bottom:140px;
  left:10%;
}

/*Scrollテキストの描写*/
.scrolldown2 span{
    /*描画位置*/
  position: absolute;
  color: #333;
  left:-9px;
  bottom:0px;
  top: 90px;
    /*テキストの形状*/
  font-size: 1vw;;
  letter-spacing: 2px;
  font-family: 'Ubuntu' ;
  font-style: italic;
  transform: scalex(-1) scaleY(-1);
  /*縦書き設定*/
  -ms-writing-mode: tb-rl;
    -webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
}

/* 丸の描写 */
.scrolldown2:before {
    content: "";
    /*描画位置*/
    position: absolute;
    bottom:0;
    left:0px;
    /*丸の形状*/
  width:1px;
  height:90px;
  background:#eee;
    /*丸の動き1.6秒かけて透過し、永遠にループ*/
  animation:
    circlemove 1.6s ease-in-out infinite,
    cirlemovehide 1.6s ease-out infinite;
    z-index: 1;
}

/*下からの距離が変化して丸の全体が上から下に動く*/
@keyframes circlemove{
      0%{bottom:100px;}
     100%{bottom:-5px;}
 }

/*上から下にかけて丸が透過→不透明→透過する*/
@keyframes cirlemovehide{
      0%{opacity:0}
     50%{opacity:1;}
    90%{opacity:0.9;}
  100%{opacity:0;}
 }

/* 線の描写 */
.scrolldown2:after{
  content:"";
    /*描画位置*/
  position: absolute;
  bottom:0;
  left:0;
    /*線の形状*/
  width:1px;
  height: 190px;
  background:#000;
}


/*------------紹介------------*/


.intr__wp{
    width: 100%;
    height: 89vh;
    position: relative;
    display: flex;
    align-items: flex-end;
}

.intr__img__wp{
    width: 62.5vw;
    position: absolute;
    right: 0;
    height:89vh;
}

.intr__img{
    background-image:linear-gradient(rgba(0, 0, 0, 0),  rgba(0, 0, 0, .3)),  url("../img/introduction-img.jpg");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    height: 100%; 
}

.intr__desc{
    width: 40vw;
    position: absolute;
    margin-top:20vh;    
}

.intr__desc p{
    background: #333;
    height: auto;
    display: inline-block;
    color: #FFFFFF;
    padding: 6.5vw 5vw;
    width: 100%;
    font-size: 1.4rem;
    letter-spacing: 1px;
    line-height: 2.4;
}
    
    
 .intr-img__bgwp{   
    position: absolute;
    right: 0;
    width: 80%;
    height: 100%;
    background-image:linear-gradient(rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 3)),  url("../img/mv__bg2.jpg");
    background-position:top;
    background-repeat: no-repeat;
    will-change: transform;
    z-index: -1;
}   


/*------------キャンペーン------------*/


.cam__wp{
    background-image: url("../img/campaign__bg.jpg");
    width: 100vw;
    background-position: center center;
    background-size: cover;
    height:40vh;   
    position: relative;
    z-index: -1;
}


.cam__inner__wp{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
/*
.cam__flex__wp{
    display: flex;
    justify-content: space-around;
    width: 80vw;
    margin: 0 auto;
    align-items: stretch;
    
}
*/
.cam__flex__wp {
    display: flex;
    justify-content:center;
    width: 80vw;
    margin: 0 auto;
    align-items: center; /* 中央揃えに変更 */
}


.cam__items{
    position: relative;
    height: 100%;
    padding: 3% 4%;
    background-color: #f4f4f3;
    display: flex;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    font-size: 2vw;
    text-align: center;
    font-weight: 600;
    align-items: center;
    color: #333;

}



.cam_small{
    font-size: 1.2vw;
}

.cam_items_1{
    position: relative;
    top: -5px;
    padding:0px 5px 0px 4px;
}

.cam_items_1 br{
    display: block;
    content: "";
    margin: -7px 0;
}

.cam_items_3{
    padding: 0 32px;
}

.check__img {
    padding-right: 5px;
    display: flex; /* flexコンテナにすることで中身を縦に並べる */
    flex-direction: column; /* 縦並びにする */
    align-items: center; /* 中央揃え */
}

.check__img img {
    width: 2.5vw;
}

#Notes::after{
    content: "※12月末までの内覧予約限定";
    font-size: .85vw;
    position: absolute;
    text-align: right;
    bottom: 10px;
    right: 20px;
}


.ft__big{
    font-size: 2.5vw;
}

.check__img{
    padding-right: 5px;
}

.check__img img{
width: 2.5vw;
}

/*------------特徴------------*/

.fea__bg{
    background: #333;
}

.fea__flex__wp {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 auto;
    row-gap: 1vw;
    text-align: center;
    width: 80vw;
}

.fea__items {
    background: #f4f4f3;
    display: flex;
    flex-direction: column;
    font-size: 1.5vw;
    font-weight: bold;
    padding: 2vw;
    width: calc((100% - 2vw) / 3);
}
.fea__items p{
    font-weight:600;
}
.fea__items span{
    height: 50%;
}
.fea__items div{
    height: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.fea__items__img img{
    width: 3vw;
}

.fea__items__img_re img{
    width: 4vw;
}

.fea__items__img_rex img{
    width: 4.3vw;
}

.fea__items2 {
    background: #f4f4f3;
    font-size: 1.2vw;
    padding: 1vw;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    width: calc((100% - 2vw) / 3);
}
.fea__items2 span {
    display: flex;
    justify-content: flex-start;
    margin: 0 1vw;
}


.event__p{
    letter-spacing: -2px;
    font-size: 1.4vw;
}



.fea__flex__all{
    padding-bottom: 5vw;
}



.fea__contents__flex1,.fea__contents__flex2{
    display: flex;
}
.fea__contents__flex2{
        padding-top: 7vw;
}

.fea__contents__items{
    background: #f4f4f3;
    min-width: calc(33.33% - 36.66px);
    max-width: 430px;
    margin-right: 3vw;
    position: relative;
}

.fea__contents__items:nth-child(3),
.fea__contents__items:nth-child(6){
    margin-right:inherit;
}


.fea__contents__items p{
    font-size:0.95vw;
    padding:10px 20px 20px 20px;
    line-height: 1.7;
    text-align: left;
}
.fea__contents__items p .comment {
    display: inline-block;
    font-size: .8vw;
}
@media (max-width: 768px) {
    .fea__contents__items p .comment {
        font-size: 1.2rem;
    }
}

.cont__number{
    position: absolute;
    font-size: 6vw;
    color: #af8c7b;
    z-index: 1;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    top: -4vw;
    left: 10px;
}

.fea__contents__items h3.cont__06__h3{
    padding:1.4vw 0px 0px 0px;
    font-size:1.8vw;
}



.fea__contents__items h3{
    font-size: 1.9vw;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    padding: 1.6vw 20px 0px 20px;
    text-align: center;
}


.fea_contents_img_wrap{
    position: relative;
    overflow: hidden;
    }
    




.fea_contents_img_wrap{
    object-fit: cover;
    aspect-ratio: 3 / 2;
}

.fea__contents__wp{
    position: relative;
    padding-bottom: 17vw;
}

.fea__contents__bg{
    background-image: url("../img/mv__bg.jpg");
    z-index: -2;
    position: absolute;
    top: 0;
    right: 0;
    width: 80%;
    height: 100%;
    background-position: top;
    background-repeat: repeat;
}

.fea__contents__bg_black{
    background: #333;
    z-index: -1;
    position: absolute;
    top: 0;
    left: 0;
    width: 80vw;
    height: 100%;
    background-repeat: no-repeat;
}

.fea__contents__items_dw{
    top: 100px;
}

.fea_contents_img_wrap {
    position: relative;
    overflow: hidden;
    aspect-ratio: 3 / 2; /* 画像のアスペクト比を指定 */
}

.fea_contents_img_wrap img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(102, 102, 102, 0.2);
  pointer-events: none;
}

.fea__contents__items {
    background: #f4f4f3;
    flex: 1;
    margin-right: 3vw;
    max-width: 33.33%; /* 画面幅の1/3 */
}


.fea__contents__flex1, .fea__contents__flex2 {
    display: flex;
    justify-content: space-between;
    text-align: center;
    width: 80vw;
    margin: 0 auto;
}



/*------------cta------------*/

.cta__wp{
    background-image: url("../img/campaign__bg.jpg");
    width: 100vw;
    background-position: center center;
    background-size: cover;
    height:55vh;   
    position: relative;
    z-index: 1;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}
.cta__wp.cta__wp02{
    background-image: linear-gradient(rgba(0, 0, 0, 0.2),  rgba(0, 0, 0, .6)),url("../img/campaign__bg02.jpg");
    width: 100vw;
    background-position: center center;
    background-size: cover;
    height:55vh;   
    position: relative;
    z-index: 1;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}


.cta__flex__wp{
    display: flex;
    margin: 0 auto;
    justify-content: center;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
}

.cta__items{
    background:#cdcdcd;
    font-size: 2vw;
    padding: 1% 9% 4%;
    margin-right: 7vw;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
}

.cta__items__inner{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}


.cta__items__img img{
    width: 2vw;
}

.cta__items:nth-child(2){
    margin-right:0px;
}


.cta__items p{
    margin-top: 10px;
}




.cta__flex__wp .viewing{
    color: #fff;
    background: #af4146;
}

.cta__flex__wp .contact::after{
    content: "contact";
    color: #fff;
    font-size: 12px;
    position: absolute;
    bottom:20%;
    font-family: 'Ubuntu';
    letter-spacing: 0.7px;
}

.cta__flex__wp .contact::before{
    content: "";
    position: absolute;
    border: 0.5px solid #fff;
    width: 5vw;
    right: 0;
    bottom: 30%;
   
}



.cta__flex__wp .viewing::after{
    content: "viewing";
    color: #FFFFFF;
    font-size: 12px;
    position: absolute;
    bottom: 20%;
    font-family: 'Ubuntu';
    letter-spacing: 0.7px;
}


.cta__flex__wp .viewing::before{
    content: "";
    position: absolute;
    border: 0.5px solid #fff;
    width: 5vw;
    right: 0;
    bottom: 30%;
   
}


/*------------casee------------*/

.case__wp{
    background: #464544;
    padding-bottom: 10vh;
}

.slider_01{
    width: 35vw;
    background: #333;
    position: absolute;
    bottom: 0px;
    right: -50px;
    padding: 5vw;
}


.case__sub__title,
.case__title,
.case__txt{
display: block;
}



.case__sub__title{
    color: #AF8C7B;
    font-size: 1.8vw;
    position: relative;
    width: 100%;
    text-align: center;
    font-family: 'Ubuntu' ;
    font-weight: 100;
    
}

.case__sub__title::after{
    content: "";
    border: #AF8C7B solid 0.5px;
    width:3vw;
    position: absolute;
    left: 0;
    top:50%;
}

.case__title{
    color: #fff;
    font-size: 2vw;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    padding: 2vw 0;
}

.case__txt::before{    
    content: "";
    border: #F4F4F3 solid 0.5px;
    position: absolute;
    width: 30vw;
    right: -5vw;
    margin-bottom: 20px;
    top: 0;
}

.case__txt{
    color: #fff;
    font-size: 0.95vw;
    padding-top: 3vw;
    line-height: 2;
    position: relative;
}



/*------------Access------------*/

.access__wp{
    width: 100%;
    position: relative;
    color: #fff;
    font-size: 1vw;
}

.access__txt{
    padding:  0vw 0vw 20vh 8vw ;
    
}

.access__txtitems1 span{
    font-size: 3.5vw;
}

.access__txtitems1 br{
    display: none;
}


.access__txtitems1{
    font-size: 2.6vw;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    
}

.access__txtitems2{
    padding-top: 5vh;
    line-height: 2;
}

    .access__wp__bg{
    background: #333;
    z-index: -1;
    position: absolute;
    top: 0;
    left: 0;
    width: 80vw;
    height: 100%;
    background-repeat: no-repeat;
    }
    
    
    .access__map{
    background:#f4f4f3;
    width: 40vw;
    position: absolute;
    right: 0;
    margin: 10vh 0;
    top: 0;
    
    }
    

    .access__map img{
    padding: 60px;
    }
    
    
    .access__contents__bg{
    background-image: url("../img/mv__bg.jpg");
    z-index: -2;
    position: absolute;
    top: 0;
    right: 0;
    width: 80%;
    height: 100%;
    background-position: center center;
    background-repeat: no-repeat;
    }


/*------------concept------------*/

.concept__txt__wp h2{
    padding: 5vw 0vw 5vw 0vw;
}

.concept__wp{
    background-image: url("../img/concept__bg.jpg");
    width: 100%;
    background-position: center center;
    background-size: cover;
    height:100vh;   
    position: relative;
    z-index: -1;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
     padding-bottom: 59.89583;
     min-height: calc(100vw / 1.6737);


}

.concept__wp img{
    object-fit: cover;
}


.concept__txt__wp{
    color: #fff;
    font-size: 1vw;
    text-align: left;
    width: 50%;
    position: absolute;
    left: 50%;
    font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    line-height: 2.8;
    padding-bottom: 5vw;
    min-height: calc(100vw / 3.3474);
    transform: translateY(-50%);
    top: 50%;
    padding-right: 2.5vw;
}

.concept__txt__wp .concept__ttl{
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    line-height: 1;
}

.concept__txt__wp h3{
    letter-spacing: 4px;
    font-size: 5vw;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    line-height: 2.1;
    
}

/*------------vacancy------------*/

.vacancy__wp {
    background: #464544;
    padding-bottom: 10vw;
}
.vacancy__flex__wp {
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
    padding: 3vw 8vw 3vw 8vw;
    align-items: end;
}
.vacancy__img {
    width: 60%;
}
.vacancy__cam__wp {
    width: 40%;
}
.table-area .cam__items {
    height: auto;
    justify-content: center;
    outline-offset: -1vw;
    outline: 1vw solid #af4146;
    padding: 7% 5%;
}
.table-area .cam__items #Notes::after {
    content: "※9月末までの内覧予約限定";
    font-size: .35vw;
    position: absolute;
    text-align: right;
    bottom: 0.3vw;
    right: 20px;
}
.vacancy__cam__wp .cam_txtwp{
    display:inherit!important;
    margin: 0 2vw;
}
.vacancy__cam__wp .check__img{
    padding: 1.5vw 0vw;
    display: block;
}.vacancy__cam__wp .cam_txt02{
    padding: 2vw 2vw 3vw 2vw;
}
@media screen and (min-width: 768px) {
    .table-area .cam__items .check__img img {
        width: 3vw;
    }
    .table-area .cam__items .check__img img {
        margin-right:  0px;
    }
}
@media screen and (max-width: 768px) {
    .vacancy__cam__wp .cam_txtwp {
        display:inherit;
        margin: 0 10vw;
    }
    .table-area .cam__items {
        outline-offset: -3vw;
        outline: 3vw solid #af4146;
    }

}



.table-area {
    display: flex;
    row-gap: 2vw;
    width: 100%;
    justify-content:center;
}
.price-area {
    align-items: center;
    background-image: url("../img/table_bg.jpg");
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 2.5rem;
    text-align: center;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    background-position: center;
}
.price-area p {
    font-size: 1.8rem;
    line-height: 1.8;
    margin-bottom: 3rem;
}
@media (max-width: 768px) {
    .table-area,
    .price-area {
        width: 100%;
    }
    .table-area {
        margin: 0;
        row-gap: 0;
    }
    .price-area{
        padding: 4rem 2rem;
    }
}



table.table01 {
	width:100%;
	border-right:#e9e1dc solid 1px;
	border-collapse: collapse;
    border-spacing: 10px;
    table-layout: fixed;
}
table.table01 thead th {
	background:#333;
	color:#FFF;
	padding:10px 15px;
	border-right:#FFF solid 1px;
	border-bottom:#FFF solid 1px;
    text-align: center;
    font-size: 1.4vw; 
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    font-weight: 600;
}


.table__wp{
    padding: 0vw 5% 0vh;
}

table.table01 .table__vacant{
    width: 8vw;
}



table.table01 thead th:last-child {
	border-right:#333 solid 1px;
}
table.table01 tbody th {
	background:#333;
	color:#FFF;
	padding:10px 15px;
	border-bottom:#FFF solid 1px;
	vertical-align:center;
    text-align: center;
    font-weight: 600;
    font-size: 1.5vw;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}
table.table01 tbody tr:last-child th {
	border-bottom:#e9e1dc solid 1px;
}
table.table01 tbody td {
    color: #333;
	background:#FFF;
	padding:10px 15px;
	border-left:#e9e1dc solid 1px;
	border-bottom:#e9e1dc solid 1px;
	vertical-align:center;
    font-size: 1.2vw;
    text-align: center;
}
 
@media screen and (max-width:768px) {
table.table01 thead {
	display:none;
}
table.table01 tbody th {
	display:block;
}
table.table01 tbody td {
	display:block;
}
table.table01 tbody td::before {
	content: attr(label);
	float: left;
	clear:both;
}
/*
table .table__Pd__left {
 padding-left: 20em;
}
*/
}




table.table01 tbody .gray{
    background: #ededed;
    color: #ADADAD;
}













/*------------office------------*/

.office__wp{
    background: #333;
    padding-bottom: 10vh;
}

.office__wp-title {
    align-items: center;
    display: flex;
    justify-content: space-between;
    padding: 10vw 10vw 5vw 8vw;
}
.office__wp-title h2 {
    padding: 0;
}
.office__wp-title_sub {
    color: #f4f4f3;
    font-size: 1vw;
    letter-spacing: -.2px;
    line-height: 2;
}
@media (max-width: 768px) {
    .office__wp-title {
        align-items: flex-start;
        flex-direction: column;
        row-gap: 1.5vw;
    }
    .office__wp-title_sub {
        font-size: 1.45rem;
        padding-top: 5vw;
    }
        .table-area {
        display: block;
    }
}

.office__inner__wp{
    display: flex;
    padding: 0vw 10vw 5vw 10vw;
}



.office__inner__wp2{
   width: 50%;
}

.office__img{
    width: 60%;
    padding-right: 2vw;
}



.office__txt{
    width: 40%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    line-height: 2;
    padding: 2vw;
}

.office__flex__wp2{
    display: flex;
    padding: 0 10vw 5vw 10vw;
}

.office__inner__wp2:nth-child(1){
     margin-right: 12vw;
}



.office__inner__wp h3{
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    color: #fff;
    font-size: 3vw;
}

.office__inner__wp2 h3{
    font-size: 2vw;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    color: #fff;
    padding: 2vw;
}



.office__inner__wp p,
.office__inner__wp2 p{
    color: #fff;
    font-size: 1vw;
    
}

.office__inner__wp2 p{    
    padding: 0vw  2vw 2vw;
    line-height: 2;
    position: relative;
}



/*READMORE*/

/*
.office__inner__wp2 span::after{
   content: "";
    border: 0.5px solid #AF8C7B;
    position: absolute;
    width: 35px;
    right: 5.5vw;
    bottom: 10px;
} 


.office__inner__wp2 span{
   content: "READ MORE";
   color: #AF8C7B;
   font-family: 'Ubuntu' ;
   font-size: 1.2rem;
   font-weight: 100;
   } 
*/







/*------------footer------------*/

.office_list_item_wp{
    width: auto;
    display: flex;
    justify-content: center
    }
    
.office-list__item{
    margin-right: 2vw;
}


#footer{
background: #0f0f0f;
}

#footer .footer-logo{
width: 25%;
}
#footer .office-list {
  display: flex;
  gap: 90px 60px;
  color:#A7A7A7;
  align-items:end;
  padding: 5vh;
  line-height: 1.5;
  justify-content: space-between;
}
#footer .office-list .en {
  display: block;
  margin-bottom: 0.2em;
  font-size: 1.3vw;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}

#footer .office-list .jp {
  font-size: 0.7vw;
}

#footer .cta__flex__wp{
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    position: inherit;
    top: 0%; 
    left: 0%; 
    transform: translate(0%, 0%);
    padding: 10vh 0 5vh 0;
}

.office-list a{
    width: 25%;
}

.copyright{
    color: #A7A7A7;
    bottom: 5px;
    position: absolute;
    right: 20px;
}






/*==================================================
スライダーcss
===================================*/
.slider {/*横幅94%で左右に余白を持たせて中央寄せ*/
    width:100%;
    margin:0 auto;
}

.slider img {
    width:60vw;/*スライダー内の画像を60vwにしてレスポンシブ化*/
    height:auto;
    border: none;
    
}



.slider .slick-slide,
.slider2 .slick-slide{
  transform: scale(0.8);/*左右の画像のサイズを80%に*/
  transition: all .5s;/*拡大や透過のアニメーションを0.5秒で行う*/
  opacity: 0.5;/*透過50%*/
}

.slider .slick-slide.slick-center,
.slider2 .slick-slide.slick-center{
  transform: scale(1);/*中央の画像のサイズだけ等倍に*/
  opacity: 1;/*透過なし*/
}


/*矢印の設定*/

/*戻る、次へ矢印の位置*/
.slick-prev, 
.slick-next {
    position: absolute;/*絶対配置にする*/
    top: 42%;
    cursor: pointer;/*マウスカーソルを指マークに*/
    outline: none;/*クリックをしたら出てくる枠線を消す*/
    border-top: 2px solid #fff;/*矢印の色*/
    border-right: 2px solid #fff;/*矢印の色*/
    height: 30px;
    width: 30px;
}

.slick-prev {/*戻る矢印の位置と形状*/
    left: 5%;
    transform: rotate(-135deg);
    z-index: 1;
}

.slick-next {/*次へ矢印の位置と形状*/
    right:5%;
    transform: rotate(45deg);
}

/*ドットナビゲーションの設定*/

.slick-dots {
    text-align:center;
    margin-top: 50px;
}

.slick-dots li {
    display:inline-block;
  margin:0 5px;
}

.slick-dots button {
    color: transparent;
    outline: none;
    width:8px;/*ドットボタンのサイズ*/
    height:8px;/*ドットボタンのサイズ*/
    display:block;
    border-radius:50%;
    background:#AF8C7B;/*ドットボタンの色*/
    opacity: 0.1;
    border-bottom-style: none;
}

.slick-dots .slick-active button{
    background:#AF8C7B;/*ドットボタンの現在地表示の色*/
    opacity: 1;
}




ul{
  margin:0;
  padding: 0;
  list-style: none;
}



/* アニメーション*/

   
      .swiper-container {
    position: relative;
  }

@-webkit-keyframes zoomUp {
  0% {
      -webkit-transform: scale(1);
      transform: scale(1);
  }
  100% {
      -webkit-transform: scale(1.15);
      transform: scale(1.15);
  }
}

@keyframes zoomUp { /* 1.15倍させる指定 */
  0% {
      -webkit-transform: scale(1);
      transform: scale(1);
  }
  100% {
      -webkit-transform: scale(1.15);
      transform: scale(1.15);
  }
}
swiper-container{
  position: relative;
}
    .swiper-slide {
  overflow: hidden;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  z-index: -1;
}




.scroll_up {
  transition: 0.2s ease-in-out;
  transform: translateY(30px);
  opacity: 0;
    transition-duration: .4s;
}
.scroll_up.on {
  transform: translateY(0);
  opacity: 1.0;
}


.timing02 {transition-delay: .2s;}
.timing03 {transition-delay: .4s;}
.timing04 {transition-delay: .6s;}
.timing05 {transition-delay: .8s;}
.timing06 {transition-delay: 1s;}




/*1122修正_追加css*/




.cam_txt01{
      padding: 0 1.5vw 0 2vw;
}

.cam__items{
  padding:5% 8% 5% 4%;
  outline-offset: -1.25vw;
  outline: 1.25vw solid #af4146;
}

.red{
  color: #af4146
}

.cam_items_3 {
    padding: 0px!important;
}

.cam__items .check__img img {
    width:5vw;
}


.cam__items .ft__big {
    font-size: 8vw;
        border-bottom: 5px solid #af41465e;
}

.cam__items .check__img {
     padding-right: 0px; 
}

.cam_txt02{
  font-size: 1.3rem;
  }

.hd_pr{
  font-size: 1.4rem;
}

.cam__wp02{
  background: #333;
}

.black{
  color: #333;
  font-size: 1.5rem;
}

.zero{
  font-weight: bold;
  font-size:2vw;
  color: #af4146;
}
.light{
  font-size: 1.5rem;
  padding-left: .05em;
}
.forever{
  padding-right: .05em;
}




@media screen and (min-width: 768px) {
.vacancy__wp .table-area .cam__items .ft__big{
        font-size: 3vw;
    }
.vacancy__wp .table-area .cam__items:nth-of-type(1){
    margin-right: 2.5vw;
}

    .vacancy__wp .cam_txt01 {
        font-size: 1.6vw;
    }
.vacancy__wp .table-area .cam__items{
        padding: 2.5% 5%;
        margin-bottom: 2.5vw;
}
.vacancy__wp .table-area .cam__items .cam_txt02{
        font-size: 1rem;
}
.cam__items .cam_txt02 {
    font-size: 1.3rem;
    padding-top: 1vw;
    display: block;
    }
  
.cam__wp {
    height: 55vh;
   
}
.cam_txtwp{
 
   
  /* border-bottom: 5px solid #af41465e; */
}
  
  
  
  
.Mglast{
  margin-right: 0px!important;
}
  


table.table01 tbody th {
    padding: .5vw .5vw;
   
  }
table.table01 .table__vacant {
    width: 15vw;
}
  
  
}

@media screen and (max-width: 768px){
  .slick-dots {
        margin-top: 0px!important;
    }
  
  .case__wp {
    padding-bottom: 5vh;
}  
  .sp__none{
    display: none;
}
  
  .cam__items {
    padding: 5% 3% 5% 3%;
    display: block;
    outline-offset: -6vw;
    outline: 6vw solid #af4146;
}
  
  

  .cam__items .check__img{
    padding: 2.5vw 0;
  }
  
 
  
  .cam__items .ft__big {
    font-size:8.5vw;

}
  
  .cam__items .cam_txt02 {
        font-size: 1.3rem;
        padding: 2.5vw 10vw;
        display: block;
    }
  
      .ft__big2 {
        font-size: 5.5vw;
    }
  
  .cam__items .check__img img {
    width: 10vw;
}
  
  .cam__wp {
        height: 55vh;
        width: 100%;
    }

  .cam__items{
    display: block;
  }
  
  
  .scroll_up {
    transition: 0.2s ease-in-out;
    transform: translateY(30px);
    opacity: 0;
    transition-duration: .4s;
}
.vacancy__img {
    width: 45%;
}
  .zero{
  font-size:2.5rem;
}
}




@media screen and (max-width: 768px) {
    .cam__items {
        padding: 8% 0% !important;
        display: block;
        outline-offset: -3vw;
        outline:3vw solid #af4146;
    }
}

@media screen and (max-width: 768px) {
    .cam__flex__wp {
        width: 100vw;
        margin: 0 auto;
        flex-direction: column;
      padding: 0 8vw;
    }
}

@media screen and (max-width: 768px) {
    .cam__wp {
        height:100vh!important;
        width: 100%;
    }
  
      .cam__items {
    padding: 3% 12% 3% 10%;
    outline-offset: -3vw;
    outline: 3vw solid #af4146;
}
}

@media screen and (min-width: 768px) {
    .cam__wp {
        height: 55vh!important;
    }
  
  .vacancy__img {
    width: 58%;
}
  
  .cam__items .check__img img {
      width: 4.5vw;
      margin-right: 1.5vw;
    }
  
   .cam__items .ft__big {
    font-size: 4vw;
    border-bottom: 5px solid #af41465e;
    }
     .cam__wp .cam__items .ft__big {
       /* margin-right: 4vw; */
  }
  
   .cam_txt01 {
    font-size: 2vw;
}

  
}
  
  
  .cam_txt01 {
    font-weight:normal; 
}

  .cam_items_3 {
    padding: 0 1vw;
}


  .vacancy__flex__wp {
    display: flex;
    justify-content:space-between;
    margin: 0 auto;
    padding: 0vw 8vw 2.5vw 8vw;
    align-items:center;
}

  .cam_txt01-pd{
  padding-right: 1vw;
}






.type{
  width: 10vw;
}

.capacity{
  width: 18vw;
}

.commonexpenses{
  width: 11vw;
}
span.campaign{
 font-size: 1.2rem;
padding-left: .25rem;
}

.remarks{
  width: 17vw;
}

.ftbig{
  font-size: 2.5rem;
}

.arrow{
  padding: 0 .5vw;
}






@media screen and (max-width: 768px){
  .arrow{
  font-size: 1.5rem;
}
  
  .ft__big2 s{
  font-size: 1.5rem;
  }
}


.cta_ico img{
height:2rem
}

#footer .logo{
  width: 20%;
}

.cam_txtwp_02{
/* margin-top: 2vw!important; */
display: block;;
}

.fea__items p{
margin-top: .5vw;
}

.office_slider_wp{
    display: flex;
    padding: 2vw;
}


.office__wp .office_slider_wp img{
    width: 50vw;
}

.office__wp .slider_01 {
    width: 25vw;
    background: #333;
    position:relative;
    padding: 2vw 2vw 2vw 4vw;
}

.office__wp .case__txt::before {
    content: "";
    border: #F4F4F3 solid 0.5px;
    position: absolute;
    width: 100%;
    left: 0;
    margin-bottom: 20px;
    top: 0;
}

.office__wp .slider_01{
    right: 0px;
}
.table_wp {
      /* max-width: 1100px; */
      margin: 0 auto;
      border-radius: 12px;
      margin:0vw 8vw 3vw 8vw;
    }


    table.table01 {
      width: 100%;
      border-collapse: collapse;
    }

    thead {
      background-color: #2b2b2b;
      color: #fff;
    }

    th, td {
      padding: 1rem;
      border-bottom: 1px solid #ddd;
      text-align: left;
      white-space: nowrap;
    }

    th.type, th.capacity, th.table__vacant {
      font-weight: bold;
    }

    tbody tr:last-child td {
      border-bottom: none;
    }

    .table__Pd__left p {
      margin: 0;
    }


    .vacancy__wp .cta__items{
      display: block;
      background-color: #af4146;
      color: #fff;
      font-size: 2vw;
      padding: 1% 20% 4%;
      text-decoration: none;
      transition:.3s;
    }
    .vacancy__wp .cta__items span{
        display: block;
        font-size: 2vw;
        font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
        }
    
        .vacancy__wp .cta__items__img img{
            width: 1.7vw;
        }

    .vacancy__wp .cta__items:hover {
      background-color: #af4146;
      opacity: .5;
      transition: .3s;
    }
    .cam__wp .cam__items:first-child,
    .cta__wp  .cam__items:first-child{
        margin-right: 3vw;;
    }

    @media (max-width: 768px) {
      .wrapper {
        flex-direction: column;
      }

    }

@media screen and (min-width: 1600px) {
.intr__desc p {
    padding: 3vw 3vw;
}
}