@charset "UTF-8";

/*
 * Site Name: connetta WEB Smart5
 * File Name page.css
 * Description: Common Page Style  for Responsive
 * Version: 1.0
 * Author: DIS_ART_WORKS
 */


/*=========================================================================================
for PC 1700以上
=========================================================================================*/
@media only screen and (min-width: 1700px){

    .message #eye_catch {
        height: 50vw;
    }

}



/*=========================================================================================
for PC 1250以下
=========================================================================================*/
@media only screen and (max-width: 1250px){

    #recruit_bottom .button_link  {
        max-width: calc(100% - 120px);
    }

    .message #eye_catch {
        height: 50vw; 
    }

    .message #eye_catch .sub {
        font-size: 4vw;
    }

    .message #eye_catch .midashi {
        font-size: 3vw;
    }

    .staff_interview #eye_catch {
        height: 50vw; 
    }

    .staff_interview #eye_catch .sub {
        font-size: 4vw;
    }

    .staff_interview #eye_catch .midashi {
        font-size: 3vw;
    }
    .interview .panel_list .box {
        width: calc((100% - 50px) / 3);
    }

    .interview #main_column > h2.ttl {
        max-width: calc(100% - 120px);
    }

    .job_interview .id_pic {
        width: 40vw;
        right: 0;
        bottom: -3vw;
    }
}

/*=========================================================================================
for PC 980以下
=========================================================================================*/

@media only screen and (max-width: 980px){

    #recruit_top #main_visual #catch_pic img {
        max-width: 70vw;
    }

    #recruit_top #main_visual #catch_pic .lead {
        max-width: 70vw;
        font-size: 0.9rem;
    }

    #recruit_top .banner_list {
        max-width: calc(100% - 80px);
    }

    #recruit_top .cont_box {
        width: 56%;
    }

    #recruit_top .cont_box .ttl {
        font-size: 1.5rem;
    }

    #recruit_top .cont_box .ttl span {
        font-size: 1rem;
    }

    #recruit_top .cont_box .button {
        padding: 0.25rem 1.5rem;
        border: solid #fff 1px;
        font-size: 0.85rem;
    }

    #recruit_bottom .button_link  {
        max-width: calc(100% - 80px);
    }

    .work #main_column .text_banner {
        max-width: calc(100% - 80px);
        height: 30vw;
    }

    .work #main_column .text_banner .ttl {
        font-size: 1.75rem;
    }

    .work #main_column .text_banner .subttl {
        font-size: 1rem;
    }

    .work #main_column .text_banner .link {
        margin-top: 10px;
    }

    .work #main_column .text_banner .link a span {
        font-size: 0.85rem;
    }

    .job_interview #eye_catch {
        height: 500px;
    }

    .job_interview .profile {
        width: 100%;
        bottom: -20px;
    }

    .job_interview .id_pic {
        bottom: auto;
        top: 90px;
        right: 20px;
        width: 46vw;
        height: 28vw;
        object-fit: cover;
    }



}


/*=========================================================================================
for PC 768以下
=========================================================================================*/

@media only screen and (max-width: 768px){

    #recruit_top #main_column {
        padding-top: 0;
    }

    #recruit_bottom .button_link .item a {
        padding: 0.75rem 0;
        font-size: 1rem;
    }

    #recruit_bottom .button_link .item a::after {
        top: 22px;
        right: 20px;
    }

    .message #eye_catch {
        padding-top: 0;
    }

    .message #eye_catch .cover {
        width: 48%;
    }

    .message #main_column h2 {
        margin-bottom: 10px;
        font-size: 1.25rem;
    }

    .message #main_column .section {
        flex-direction: column;
        gap: 30px;
        margin-bottom: 40px;
        max-width: calc(100% - 60px);
    }

    .message #main_column .section p {
        font-size: 0.9rem;
    }

    .message #main_column .section.divide .pic_box,
    .message #main_column .section.divide .txt_box {
        width: 100%;
    }
    
    .message #main_column .section.layout1::before {
        right: 40px;
    }

    .message #main_column .section.layout2::before {
        left: 40px;
    }

    .message #main_column .section.layout1 .pic_box::after {
        bottom: -20px;
        right: -20px;
    }

    .message #main_column .section.layout2 .pic_box::after {
        bottom: -20px;
        left: -20px;
    }

    .message #main_column .section.full::after {
        bottom: -20px;
        left: -20px;
    }

    .message .article {
        padding: 30px 20px;
    }

    .staff_interview #eye_catch {
        padding-top: 0;
    }

    .staff_interview #eye_catch .cover {
        width: 48%;
    }

    .staff_interview #main_column h2 {
        margin-bottom: 10px;
        font-size: 1.25rem;
    }

    .staff_interview #main_column .section {
        flex-direction: column;
        gap: 30px;
        margin-bottom: 40px;
        max-width: calc(100% - 60px);
    }

    .staff_interview #main_column .section p {
        font-size: 0.9rem;
    }

    .staff_interview #main_column .section.divide .pic_box,
    .staff_interview #main_column .section.divide .txt_box {
        width: 100%;
    }
    
    .staff_interview #main_column .section.layout1::before {
        right: 40px;
    }

    .staff_interview #main_column .section.layout2::before {
        left: 40px;
    }

    .staff_interview #main_column .section.layout1 .pic_box::after {
        bottom: -20px;
        right: -20px;
    }

    .staff_interview #main_column .section.layout2 .pic_box::after {
        bottom: -20px;
        left: -20px;
    }

    .staff_interview #main_column .section.full::after {
        bottom: -20px;
        left: -20px;
    }

    .staff_interview .article {
        padding: 30px 20px;
    }

    .work #main_column {
        padding-top: 0;
    }

    .work #page_header_img {
        height: 40vw;
        padding-top: 0px;
    }
    
    .work #page_header_img p{
        font-size: 6vw;
    }

    .work #main_column .section {
        padding-bottom: 30px;
    }

    .work #main_column .text_banner {
        max-width: calc(100% - 60px);
        height: 50vw;
    }

    .work #tab_buttons {
        max-width: calc(100% - 60px);
        flex-wrap: wrap;
        border-bottom: none;
        gap: 2px;
    }

    .work #tab_list {
        max-width: calc(100% - 60px);
    }

    .work .tab_label {
        width: calc((100% - 4px) / 3);
    }

    .work #main_column .item_list .midashi {
        width: 100%;
        margin-bottom: 0;
        padding: 10px;
        font-size: 0.875rem;
        gap: 14px;
    }

    .work #main_column .item_list .naiyou {
        width: 100%;
        padding: 10px 14px;
        font-size: 0.875rem;
    }

    .work #slider {
        margin: 30px auto 50px;
        max-width: calc(100% - 60px);
    }

    .work .slick-slide {
        margin: 0 0;
    }

    .work .slick-slide img {
        opacity: 1;
    }

    .interview ul#topicpath {
        margin: 0px auto 10px;
    }

    .interview #main_column {
        margin-top: 0;
        padding-top: 0;
    }

    .interview .catch_img {
        height: 50vw;
    }

    .interview .catch_img p {
        padding-left: 0;
        font-size: 5vw;
    }

    .interview #main_column > h2.ttl {
        max-width: calc(100% - 60px);
        font-size: 1.25rem;
    }

    .interview .panel_list {
        max-width: calc(100% - 60px);
        gap: 20px;
    }

    .interview .panel_list .box {
        width: calc((100% - 20px) / 2);
    }

    .interview .job_label::before {
        right: 10px;
    }

    .interview .job_label::after {
        right: 16px;
    }

    .job_interview #eye_catch {
        height: 390px;
    }

    .job_interview #eye_catch .title {
        font-size: 2.25rem;
        line-height: 1;
    }

    .job_interview #eye_catch > .inner {
        max-width: calc(100% - 80px);
        padding-top: 20px;
    }

    .job_interview .id_pic {
        top: 30px;
        right: 10px;
    }

    .job_interview #main_column h2 {
        margin-bottom: 10px;
        font-size: 1.25rem;
    }

    .job_interview #main_column .section {
        flex-direction: column;
        gap: 30px;
        margin-bottom: 40px;
        max-width: calc(100% - 60px);
    }

    .job_interview #main_column .section p {
        font-size: 0.9rem;
    }

    .job_interview #main_column .section.divide .pic_box,
    .job_interview #main_column .section.divide .txt_box {
        width: 100%;
    }
    
    .job_interview #main_column .section.layout1::before {
        right: 40px;
    }

    .job_interview #main_column .section.layout2::before {
        left: 40px;
    }

    .job_interview #main_column .section.layout1 .pic_box::after {
        bottom: -20px;
        right: -20px;
    }

    .job_interview #main_column .section.layout2 .pic_box::after {
        bottom: -20px;
        left: -20px;
    }

    .job_interview #main_column .section.full::after {
        bottom: -20px;
        left: -20px;
    }

    .job_interview .article {
        padding: 30px 20px;
    }

    .job_interview #main_column .article .sub_ttl,
    .job_interview .article .list {
        width: 70%;
    }

    /* --- recruit --- */
    #recruit #content_wrapper {
        padding-top: 0;
    }
	
}


/*=========================================================================================
for PC 600以下
=========================================================================================*/

@media only screen and (max-width: 600px){

    #recruit_top #top_slider {
        display: block;
    }

    #recruit_top #top_slider .slick-slide img {
        width: 100%;
        height: calc(100vh - 70px);
        object-fit: cover;
    }

    #recruit_top #main_column {
        margin-top: 30px;
    }

    #recruit_top .banner_list {
        max-width: calc(100% - 60px);
    }

    #recruit_top .banner_list .item {
        height: 50vw;
    }

    #recruit_top .banner_list .item img {
        height: 100%;
        object-fit: cover;
        object-position: 80%;
    }
    
    #recruit_top .cont_box {
        width: 60%;
    }

    #recruit_top .color01.layout02 .cont_box {
        background: linear-gradient(84deg, #115FAE 90%, transparent 90.5%, transparent 0);
    }

    #recruit_top .cont_box .ttl {
        font-size: 1.125rem;
        line-height: 1.25;
    }

    #recruit_top .cont_box .ttl span {
        margin-top: 6px;
        font-size: 0.85rem;
    }

    #recruit_top .cont_box .button {
        padding: 0.125rem 1rem;
        font-size: 0.75rem;
    }

    #recruit_bottom .button_link {
        flex-direction: column;
        gap: 20px;
    }
	
    #recruit_bottom .button_link .item {
        width: 100%;
    }

    #recruit_bottom .button_link .item a {
        padding: 0.75rem 0;
        font-size: 0.9rem;
    }

    #recruit_bottom .button_link .item a::after {
        top: 19px;
    }

    .message #main_column {
        margin-top: 0;
    }

    .message #main_column .section.lead::before {
        width: calc(54px * 0.5);
        height: calc(54px * 0.5);
        top: -30px;
        right: 0;
    }

    .message #main_column .section.lead::after {
        width: calc(304px * 0.5);
        height: calc(304px * 0.5);
        top: auto;
        bottom: 0;
    }

    .message #main_column .section .pic_box::after {
        width: calc(304px * 0.5);
        height: calc(304px * 0.5);
    }

    .message #main_column .section.layout2 .pic_box::after {
        width: calc(304px * 0.5);
        height: calc(304px * 0.5);
    }

    .message #main_column .section.full::after {
        width: calc(304px * 0.5);
        height: calc(304px * 0.5);
    }

    .staff_interview #main_column {
        margin-top: 0;
    }

    .staff_interview #main_column .section.lead::before {
        width: calc(54px * 0.5);
        height: calc(54px * 0.5);
        top: -30px;
        right: 0;
    }

    .staff_interview #main_column .section.lead::after {
        width: calc(304px * 0.5);
        height: calc(304px * 0.5);
        top: auto;
        bottom: 0;
    }

    .staff_interview #main_column .section .pic_box::after {
        width: calc(304px * 0.5);
        height: calc(304px * 0.5);
    }

    .staff_interview #main_column .section.layout2 .pic_box::after {
        width: calc(304px * 0.5);
        height: calc(304px * 0.5);
    }

    .staff_interview #main_column .section.full::after {
        width: calc(304px * 0.5);
        height: calc(304px * 0.5);
    }

    .work .tab_label {
        width: calc((100% - 2px) / 2);
        font-size: 1rem;
    }

    .interview .panel_list {
        gap: 10px;
    }

    .interview .panel_list .box {
        width: calc((100% - 10px) / 2);
    }

    .interview .job_type .job_label {
        padding: 25px 0.75rem;
    }

    .interview .job_type .title {
        font-size: 0.95rem;
    }

    .interview .job_type .sub_title {
        font-size: 0.85rem;
    }

    .job_interview #eye_catch {
        height: 520px;
        margin-bottom: 60px;
    }

    .job_interview .id_pic {
        top: 100px;
        left: 0;
        right: 0;
        margin: auto;
        width: calc(500px * 0.7);
        height: calc(355px * 0.7);
    }

    .job_interview .profile {
        width: 100%;
        padding: 20px 20px 20px;
        height: auto;
        bottom: auto;
        top: 340px;
    }

    .job_interview .profile h3 {
        font-size: 1.05rem;
        line-height: 1.5;
    }

    .job_interview .profile p {
        font-size: 0.75rem;
        line-height: 1.5;
    }

    .job_interview #main_column {
        margin-top: 0;
    }

    .job_interview #main_column .section.lead::before {
        width: calc(54px * 0.5);
        height: calc(54px * 0.5);
        top: -30px;
        right: 0;
    }

    .job_interview #main_column .section.lead::after {
        width: calc(304px * 0.5);
        height: calc(304px * 0.5);
        top: auto;
        bottom: 0;
    }

    .job_interview #main_column .section .pic_box::after {
        width: calc(304px * 0.5);
        height: calc(304px * 0.5);
    }

    .job_interview #main_column .section.layout2 .pic_box::after {
        width: calc(304px * 0.5);
        height: calc(304px * 0.5);
    }

    .job_interview #main_column .section.full::after {
        width: calc(304px * 0.5);
        height: calc(304px * 0.5);
    }

    .job_interview .article {
        padding: 20px 30px 40px;
    }

    .job_interview #main_column .article .ttl {
        font-size: 1.75rem;
    }

    .job_interview #main_column .article .sub_ttl {
        width: 100%;
        font-size: 0.8rem;
        padding: 6px 10px;
    }

    .job_interview .article .list .item {
        gap: 5px;
    }

    .job_interview .article .list {
        width: 90%;
    }

    .job_interview .article .list .time,
    .job_interview .article .list .txt {
        font-size: 0.8rem;
    }

    .job_interview .article .list .time {
        width: 60px;
    }

    .job_interview .article .list .txt {
        width: calc(100% - 60px - 5px);
        padding: 6px 0px 6px 10px;
        border-left: solid 9px rgba(23,98,171,0.3);
    }


}




/*=========================================================================================
for Smart Phone 480以下
=========================================================================================*/

@media only screen and (max-width: 480px){



    .interview .job_type .job_cont {
        width: calc(200% + 10px);
        top: 0px;
    }

    /*-- 偶数番目の場合 --*/
    .interview .job_type li:nth-child(even) .job_cont {
        left: calc(-100% - 10px);
    }

    /*-- 奇数かつ最後の場合 --*/
    .interview .job_type li:nth-child(odd):last-child .job_cont {
        left: calc(-50% - 5px);
    }


}