
[v-cloak] {
    display: none;
}

.btn_entry { z-index: 3; display: block; width: 200px; bottom: 4rem; right: 3rem; transition: none; }
.btn_entry span { font-size: 1.25rem; display: block; top: 0; bottom: 0; width: 100%; margin: auto;  color: #fff; letter-spacing: 2px; height: 20px; line-height: 20px; }

/* --------------------- fv */

.fv_image { width: calc(50% - 150px); min-height: 500px; height: 80vh; max-height: 800px; background-position: center center; background-size: cover; }
.fv_text { width: 300px; height: 100%; margin: auto; top: 0; left: 0; right: 0; }
.fv_text p { font-weight: 100; font-size: 2rem; letter-spacing: 4px; }
.fv_text2 { pointer-events: none; bottom: -50px; width: 88%; margin: auto; left: 0; right: 0; }
.fv_text2 p { font-size: clamp(1rem, 7.5vw, 7.5rem); height: 120px; line-height: 120px; }

/* --------------------- about */

.about { padding: 6rem 0 4rem; }
.about h3 { max-width: 290px; margin: auto; }
.about h3 span { display: block; margin-top: 2rem; padding: 1.5rem 0 0; border-top: 1px solid #555555; font-size: 1.5rem; }
.about .txt { line-height: 260%; padding: 4rem 0; position: relative; z-index: 2; }
.about .obj { box-shadow: 5px 5px 12px -8px #787878; max-width: 260px; }
.about .obj1 { left: 5%; top: 20%; width: 260px; }
.about .obj2 { left: 15%; top: 80%; width: 193px; }
.about .obj3 { right: 2%; top: 50%; }

/* --------------------- job */

.job { padding: 4rem 0; }
.job .head_style1 { padding-bottom: 2rem; }
.job .head_style2 { padding: 2rem 0; }
.job ul li { width: 50%; position: relative; box-sizing: border-box; margin-bottom: 2rem; }
.job ul li .box { padding: 3rem 3% 0; bottom: 0; right: 0; 
    background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.2) 10%,
    rgba(255, 255, 255, 0.9) 50%,
    rgba(255, 255, 255, 1) 100%
    );
}
.job ul li .box h3 { font-size: 1.85rem; padding-bottom: 0.25rem; }
.job ul li .box .txt { font-size: 14px; line-height: 200%; min-height: 84px; }

/* --------------------- appeal */

.appeal { padding: 6rem 0; }
.appeal ul { padding: 4rem 0 0; }
.appeal ul li { padding: 2rem; margin-bottom: 30px; background-color: #fff; border-radius: 0.5rem; }
.appeal ul li .num { background-color: #fff; border: 1px solid #218c57; width: 55px; height: 55px; line-height: 54px; font-size: 1.8rem; border-radius: 50%; }
.appeal ul li .col { width: calc(100% - 90px); }
.appeal ul li .col h4 { font-size: 1.5rem; }
.appeal ul li .col .txt { font-size: 14px; padding: 1rem 0 0; }

/* --------------------- interview */

.interview { padding: 6rem 0; }
.interview .slider { width: 94%; margin: auto; padding: 4rem 0 0; max-width: 1476px; margin: auto; }
.interview .slider .slide { width: 275px; background-color: #000; color: #fff; cursor: pointer; }
.interview .slider .slide .thumb { padding-top: 162%; opacity: 0.8; position: relative; }
.interview .slider .slide .thumb img { width: 101%; height: auto; }
.interview .slider .slide:hover .thumb img { width: 108%; }
.interview .slider .slide.active .thumb { opacity: 0.6; }
.interview .slider .slide .num { z-index: 2; top: 1rem; left: 12px; writing-mode: vertical-rl; font-size: 11px; letter-spacing: 3px; }
.interview .slider .slide .info { z-index: 2; bottom: 0; left: 0; width: 100%; padding: 12px 10px; box-sizing: border-box; }
.interview .slider .slide .info .pos { font-size: 14px; }
.interview .slider .slide .info .name { font-size: 14px; line-height: 220%; padding: 5px 0 0; text-transform: lowercase; }
.interview .slider .slide .info .name span { padding-right: 8px; display: inline-block; font-size: 1.5rem; }
.interview .slider .arws { gap: 1rem; padding: 1.5rem 0 0; }
.interview .slider .arws img { width: 50px; cursor: pointer; }
.interview .slider .arws .arw_prev { transform: rotate(-180deg); }
.interview .profile { padding: 4rem 0 0; max-width: 250px; margin: auto; box-sizing: border-box; } 
.interview .profile img { width: 100%; max-width: 320px; }
.interview .profile .wbox { padding: 1rem 0; background-color: #fff; bottom: 0; left: 0; }
.interview .profile .wbox .num { padding: 0 0 5px; }
.interview .profile .wbox .pos { font-size: 14px; }
.interview .profile .wbox .name { color: #AAAAAA; font-size: 14px; line-height: 200%; padding-top: 0.5rem; }
.interview .profile .wbox .name span { font-size: 1.5rem; display: inline-block; padding-right: 5px; color: #000; }

.article_body { padding: 2rem 0 0; }
.article_body .row { padding: 1rem 0; }
.article_body .row .icon { width: 3rem; }
.article_body .head { padding: 1rem 0 2rem; border-bottom: 1px solid #d1d1d1; font-family: "Noto Serif JP", sans-serif; font-size: 1.8rem; line-height: 150%; font-weight: 300; }
.article_body .txt { font-size: 15px; line-height: 200%; word-wrap: break-word; }
.article_body figure { padding: 1.5rem 0; max-width: 580px; margin: auto; }
.article_body .holiday { padding: 1.5rem 0; }
.article_body .holiday .head { font-size: 1.5rem; padding: 0 0 0.5rem; }
.article_body .holiday .img { width: 88%; max-width: 300px; margin: auto; }
.article_body .holiday figure { padding: 66% 0 0; overflow: hidden; }
.article_body .holiday figure img { height: 100%; width: auto; left: 50%; top: 50%; transform: translate(-50%, -50%); }
.article_body .holiday .box { padding: 2rem 0 0; }
.article_body .img_txt1 { background-color: #F7F7F7; padding: 1.5rem 3% 1rem; }
.article_body .img_txt1 .left { width: 100px; }
.article_body .img_txt1 .right { width: calc(100% - 130px); box-sizing: border-box; }
.article_body .img_txt1 figure { padding: 100% 0 0; overflow: hidden; border-radius: 50%; }
.article_body .img_txt1 figure img { left: 50%; top: 50%; transform: translate(-50%, -50%); }
.article_body .img_txt1 h4 { font-size: 14px; font-weight: 600; padding: 0 0 0.5rem; }
.article_body .img_txt1 .txt { font-size: 14px; }

/* --------------------- flow */

.flow { padding: 6rem 0; }
.flow .head_style1 .lead { line-height: 120%; }
.flow ul { padding: 4rem 0 0; }
.flow ul li { background-color: #fff; padding: 2rem 1.5rem 5rem; }
.flow ul li::before { width: 20px; height: 35px; left: calc(-50% - 10px); top: 0; bottom: 0; background: url(../../img/recruit/common/icn-arw_right.png) no-repeat center center; background-size: 100% auto; }
.flow ul li:first-child::before { display: none; }
.flow ul li .num { border-radius: 50%; height: 45px; width: 45px; margin: auto; font-size: 12px; line-height: 120%; }
.flow ul li .num span { display: block; font-size: 20px; }
.flow ul li .txt { padding: 1.5rem 0 0; width: 100%; font-size: 1.5rem; }
.flow .note { font-size: 1.1rem; line-height: 200%; padding: 4rem 0 0; }

/* --------------------- details */

.details { padding: 4rem 0 12rem; }
.details dl { padding: 1rem 0 0; margin: 0; }
.details dl dt,
.details dl dd { padding: 1rem 0; line-height: 200%; box-sizing: border-box; }
.details dl dt { width: 200px; padding-left: 1rem; padding-right: 0.5rem; word-break: keep-all; }
.details dl dt::before {  width: 3px; height: 20px; background-color: #000; left: 0; top: 22px; }
.details dl dd { width: calc(100% - 200px); margin: 0; font-size: 15px; }

.details .head_style2 { padding: 4rem 0 1rem; }
.details .dropdown-button { border: 1px solid #b2b2b2; padding: 0.5rem; cursor: pointer; transition: 0.5s; }
.details .dropdown-button::before,
.details .dropdown-button::after { width: 15px; height: 1px; background-color: #b2b2b2; margin: auto; top: 0; bottom: 0; right: 1rem; }
.details .dropdown-button::after { transform: rotate(90deg); transition: 0.5s; }
.details .dropdown-button.active::after { transform: rotate(0deg); } 
.details .dropdown-button:hover { opacity: 0.7; }

.details .listing-dropdown { display: none; }

.entry-wrap { min-height: 190px; position: relative; }
.entry-wrap .box { top: -69%; width: 94%; max-width: 800px; box-sizing: border-box;  margin: auto; position: absolute; left: 0; right: 0;
    background-image: url(../../img/recruit/index/entry-bg.png);
    box-shadow: 3px 3px 12px -6px #000;
}
.entry-wrap .box a { padding: 3rem 1rem; color: #fff; display: block; }
.entry-wrap .box a p { font-size: 1.25rem; }
.entry-wrap .box a .font-cormorant { font-style: italic; font-size: 80px; padding-top: 0.5rem; }
.entry-wrap .box a::after { right: 3%; top: 0; bottom: 0; width: 60px; height: 60px; z-index: 0;
    background: url(../../img/recruit/common/icn-arw_circle.png) no-repeat center center;
    background-size: 98% auto;
}

.marquee-wrap { overflow: hidden; padding: 10px 0; }
.marquee-wrap ul { width: 5220px; animation: marquee-animation 64s linear infinite; }
.marquee-wrap ul li { width: 500px; margin-left: 10px; }
.marquee-wrap ul li:nth-child(2n) { width: 350px; }

@keyframes marquee-animation { from{ transform:translateX(0); } to{ transform:translateX(-50%); } }


/* --------------------- tablet */
@media screen and (max-width: 1100px) {
    .fv_text { width: 150px; }
    .fv_image { width: calc(50% - 75px); }
    .fv_text p { font-size: 1.5rem; }
    .fv_text p span { font-size: 2rem; }
    .fv_image { min-height: 400px; max-height: 700px; }

    .appeal { padding: 4rem 0; }

    .interview .slider .slide { width: 250px; }
    .interview .profile { width: 88%; max-width: 480px; }

    .article_body { padding: 2rem 0; }

    .flow ul { display: block; }
    .flow ul li { padding: 1rem 1.5rem; margin: 0 auto 4rem; width: 100%; max-width: 400px; box-sizing: border-box; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; }
    .flow ul li .num { margin: 0; }
    .flow ul li .txt { width: calc(100% - 70px); writing-mode: unset; text-orientation: unset; padding: 0; }
    .flow ul li::before { width: 15px; transform: rotate(90deg); left: 0; right: 0; top: -3rem; bottom: auto; }

    .btn_entry { width: 140px; right: 3%; }
    .btn_entry span { font-size: 1rem; }
}

/* --------------------- tablet */
@media screen and (max-width: 797px) {

    .btn_entry { width: 100px; bottom: 2rem; }
    .btn_entry span { font-size: 12px; }

    .fv_text { width: 100%; position: unset; }
    .fv_text p { padding: 1.5rem 0; font-size: clamp(1.5rem, 5vw, 3rem); writing-mode: unset; text-orientation: unset; letter-spacing: 2px; }
    .fv_text p span { font-size: inherit; }

    .fv_image { background-position: center center; height: 46vw; min-height: 0; max-height: 500px; width: 100%; }

    .fv_text2 { bottom: -30px; display: none; }
    .fv_text2 p { line-height: 100%; height: auto; }

    .about { padding: 4rem 0 2rem; }
    .about .inner { width: 100%; padding-bottom: 50%; }
    .about h3 { width: 160px; }
    .about h3 span { margin-top: 1.5rem; font-size: 12px; }
    .about .txt { line-height: 220%; }
    .about .obj { top: auto !important; }
    .about .obj1 { bottom: 15%; width: 40%; }
    .about .obj2 { left: 30%; width: 25%; bottom: 0%; }
    .about .obj3 { width: 40%; bottom: 10%; }
    

    .job { padding: 3rem 0 2rem; }
    .job ul li { width: 100%; padding-bottom: 0; margin-bottom: 3rem; } 
    .job ul li .box { padding: 1rem 6% 0; position: inherit; }
    .job ul li .box h3 { font-size: 20px; }
    .job ul li .box .txt { font-size: 12px; min-height: 0; }

    .appeal ul { padding-top: 2rem; }
    .appeal ul li { justify-content: center; margin-bottom: 1rem; }
    .appeal ul li .col { width: 100%; padding: 1.5rem 0 0; }
    .appeal ul li .num { font-size: 1.75rem; width: 45px; height: 45px; line-height: 45px; }
    .appeal ul li .col h4 { text-align: center; font-size: 20px; }
    
    .interview { padding: 4rem 0 1rem; }
    .interview .slider { padding: 2rem 0; }
    .interview .slider .slide { width: calc((80vw - 10px) / 2); }
    .interview .slider .slide .num { font-size: 10px;  top: 3%; left: 3%; }
    .interview .slider .slide .info .pos { font-size: 9px; font-size: clamp(9px, 2.25vw, 2rem); }
    .interview .slider .arws img { width: 40px; }
    .interview .slider .slide .info .name span { font-size: 1.5rem; padding-right: 12px; }

    .interview .profile { max-width: 200px; padding: 2rem 0 0; }
    .interview .profile .wbox { padding: 1rem 0; }
    .interview .profile .wbox .name span { font-size: 1.5rem; }

    .article_body { padding: 1rem 0; }
    .article_body .head { font-size: 1.5rem; padding: 0.75rem 0 1rem; }
    .article_body figure { padding: 0.5rem 0; }
    .article_body .txt { font-size: 1rem; }
    .article_body .holiday { padding: 1.5rem 4%; display: block; }
    .article_body .holiday .head { font-size: 1.25rem; }
    .article_body .holiday .txt { line-height: 180%; padding: 0 0 2rem; }
    .article_body .holiday .left { width: 100%; padding: 0; }
    .article_body .holiday .right { width: 70%; max-width: 420px; margin: auto; }
    .article_body .img_txt1 { padding: 1.5rem 6% 1rem; }
    .article_body .img_txt1 .txt { line-height: 180%; font-size: 12px; }
    .article_body .img_txt1 .left { max-width: 320px; margin: auto; }
    .article_body .img_txt1 .right { width: 100%; padding-top: 1.5rem; }

    .marquee-wrap ul { width: 2610px; }
    .marquee-wrap ul li { width: 250px; margin-left: 5px; }
    .marquee-wrap ul li:nth-child(2n) { width: 175px; }

    .flow { padding: 4rem 0; }
    .flow ul { padding: 2rem 0 0; }
    .flow ul li { margin-bottom: 3rem; }
    .flow ul li::before { width: 12px; }
    .flow ul li .txt { font-size: 1.25rem; }
    .flow .note { padding: 2rem 0 0; font-size: 1rem; }

    .details dl dt,
    .details dl dd { width: 100%; padding: 0.5rem 0; }
    .details dl dt { padding-left: 1rem; font-size: 16px; }
    .details dl dt::before { top: 12px; }
    .details dl dd { padding-top: 0; font-size: 1rem; }


    .entry-wrap { min-height: 110px; }
    .entry-wrap .box { top: -38%; width: 88%; }
    .entry-wrap .box a { padding: 1.5rem 0 1rem; }
    .entry-wrap .box a p { font-size: 12px; }
    .entry-wrap .box a .font-cormorant { font-size: 40px; padding: 0; }
    .entry-wrap .box a::after { width: 30px; height: 30px; }

    .details { padding: 4rem 0 6rem; }
    .details .head_style2 { padding-top: 3rem; }
}