@charset "UTF-8";

*{
	margin:0;
	padding:0;
}

body {
	color: #2D2D2D;
	margin:0;
	padding:0;
	font-family: "Noto Sans JP", sans-serif;
	width:100%;
	webkit-text-size-adjust: 100%;
	text-size-adjust: 100%;
}

img{
	border:0;
	margin:0;
	vertical-align: bottom;
}

table,tr,td {
	border-collapse: collapse;
}

ul{
	list-style-type: none;
}

a{
	text-decoration: none;
}

input,
textarea,
select,
button{
	font-family: "Noto Sans JP", sans-serif;
}

a,a img,button {
	transition: 0.3s ease-in-out;
}

a:hover img {
	opacity: 0.7;
	filter: alpha(opacity=70);
}

.clear{
	clear:both;
}

.clearfix:after{
	content: "";
	display: block;
	clear: both;
}

@media print, screen and (min-width: 768px){

    body {
        min-width: 1200px;
        background: #F6F6F6;
    }

    .pc_none{
        display: none;
    }

    #style01{
        width:100%;
    }





    /*　■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■　ヘッダー　■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■　*/

    .header{
        position: sticky;
        top: 0;
        z-index: 10000;
        box-sizing: border-box;
        width: 100%;
        height: 120px;
        background: #fff;
        box-shadow: 0 0 6px rgba(0, 0, 0, 0.25);
    }
    .header0x{
        font-size:6px;
        padding: 0 25px 0 35px;
    }

    .header01{
        display: flex;
        justify-content: space-between;
        padding: 10px 25px 19px 35px;
    }

    .header_logo{
        font-size: 20px;
    }

    .header01_menu{
        display: flex;
        gap: 64px;
    }

    .header01_form{
        position: relative;
        display: flex;
        gap: 8px;
    }

    .header01_form:before{
        position: absolute;
        top: 50%;
        left: 6px;
        transform: translateY(-50%);
        content: "";
        width: 31px;
        height: 31px;
        background: url("/img/header01_form_icon.svg") center/cover no-repeat;
    }

    .header01_form input{
        box-sizing: border-box;
        width: 447px;
        height: 41px;
        padding: 9px 10px 8px 45px;
        border: none;
        border-radius: 2px;
        background: #F6F6F6;
        box-shadow: inset 0 0 3px rgba(0, 0, 0, .16);
    }

    .header01_form button{
        display: flex;
        justify-content: center;
        align-items: center;
        width: 66px;
        height: 41px;
        border: none;
        border-radius: 2px;
        background: #EC1C16;
        color: #fff;
        font-size: 15px;
        cursor: pointer;
    }

    .header01_rl{
        display: flex;
        gap: 16px;
    }

    .header01_reg a,
    .header01_login a{
        display: flex;
        justify-content: center;
        align-items: center;
        height: 41px;
        border-radius: 2px;
        color: #fff;
        font-size: 15px;
        font-weight: 700;
    }

    .header01_reg a{
        gap: 5px;
        /*width: 144px;*/
        width: 130px;
        background: linear-gradient(to right, #23A87B 0%, #36A5A1 100%);
    }

    .header01_reg a img{
        width: 32px;
    }

    .header01_login a{
        gap: 6px;
        width: 112px;
        background: #2D2D2D;
    }

    .header01_login a img{
        width: 31px;
    }

    .header01_form button:hover,
    .header01_reg a:hover,
    .header01_login a:hover{
        opacity: 0.7;
    }

    .header01_reg a:hover img,
    .header01_login a:hover img{
        opacity: 1;
    }

    @media screen and (max-width: 1380px){
        .header01{
            padding-left: 25px;
            padding-right: 15px;
        }

        .header01_form input{
            width: 300px;
        }
    }

    @media screen and (max-width: 1270px){
        .header01_menu{
            gap: 40px;
        }
    }



    .header02_menu01{
        display: flex;
        gap: 48px;
        width: 1200px;
        margin: 0 auto;
        font-size: 15px;
        font-weight: 700;
    }

    .header02_menu02_wrap{
        position: relative;
    }

    .header02_menu01 > li{
        height: 40px;
    }

    .header02_menu01 > li > a{
        color: #2D2D2D;
    }

    .header02_menu01 > li > a:hover{
        color: #EC1C16;
    }

    .header02_arrow{
        position: relative;
        display: inline-block;
        padding-right: 14px;
    }

    .header02_arrow:after{
        position: absolute;
        top: 50%;
        right: 0;
        transform: translateY(-50%);
        content: "";
        width: 10.7px;
        height: 6.61px;
        background: url("/img/header02_arrow.svg") center/contain no-repeat;
    }

    .header02_menu02{
        position: absolute;
        top: 60%;
        left: 50%;
        transform: translateX(-50%);
        z-index: 10010;
        white-space: nowrap;
        background: #fff;
        opacity: 0;
        visibility: hidden;
        transition: .3s ease-in-out;
    }

    .header02_menu02_wrap:hover .header02_menu02{
        top: 80%;
        opacity: 1;
        visibility: visible;
    }

    .header02_menu02 a{
        display: block;
        padding: 10px;
        background: #EC1C16;
        color: #fff;
        line-height: 1;
    }

    .header02_menu02 a:hover{
        opacity: 0.7;
    }





    /*　■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■　フッター　■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■　*/

    .footer{
        position: relative;
        border-top: 1px #9E9E9E solid;
    }

    #page-top{
        position: absolute;
        right: 20px;
        bottom: calc(100% + 20px);
        width: 74px;
        height: 74px;
        background: url("/img/page-top.svg") center/contain no-repeat;
        cursor: pointer;
    }

    .footer01{
        padding: 33px 0 30px;
    }

    .footer01_box{
        display: flex;
        justify-content: space-between;
        width: 1200px;
        margin: 0 auto;
    }

    .footer01_l{
        width: 287px;
        padding-top: 16px;
    }

    .footer_logo{
        margin-bottom: 30px;
    }

    .footer_logo img{
        width: 100%;
    }

    .footer_contact{
        margin-bottom: 12px;
    }

    .footer_contact a{
        display: flex;
        justify-content: center;
        align-items: center;
        box-sizing: border-box;
        width: 242px;
        height: 48px;
        border: 1px #EC1C16 solid;
        border-radius: 3px;
        color: #fff;
        font-weight: 700;
        background: #EC1C16;
    }

    .footer_contact a:hover{
        color: #EC1C16;
        background: #fff;
    }


    .footer01_c{
        display: flex;
        gap: 80px;
        padding-top: 17px;
        font-size: 14px;
    }

    .footer01_c ul{
        display: grid;
        gap: 10px;
    }

    .footer01_c ul a{
        position: relative;
        display: inline-block;
        padding-right: 16px;
        color: #2D2D2D;
    }

    .footer01_c ul a:hover{
        color: #EC1C16;
    }

    .footer01_c ul a:after{
        position: absolute;
        top: 50%;
        right: 0;
        transform: translateY(-50%) rotateZ(-90deg);
        content: "";
        width: 10.7px;
        height: 6.61px;
        background: url("/img/header02_arrow.svg") center/contain no-repeat;
    }


    .footer01_r{
        width: 306px;
    }

    .footer_banner{
        display: grid;
        gap: 16px;
    }

    .footer_banner img{
        width: 100%;
    }



    .footer02{
        padding: 1em 0;
        background: #2B2B2B;
        color: #fff;
        font-size: 12px;
        text-align: center;
        line-height: 1;
    }






    /*　■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■　index　■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■　*/

    .mv{
        height: auto;
        position: relative;
    }

    .mv-slider {
        width: 100%;
    }

    .mv-slider .slick-list {
        height: auto;
    }

    .mv-slider .slick-track {
        height: auto;
        display: flex;
        align-items: flex-start;
    }

    .mv-slider .slick-slide {
        height: auto;
    }

    .mv-slider .slick-slide > div {
        height: 100%;
    }

    .mv-slider img {
        width: 100%;
        height: auto;
    }

    .mv-slider .slick-dots {
        position: relative;
        bottom: auto;
        margin-top: 0;
    }

    .mv-slider .slick-dots li {
        margin: 0 6px;
    }

    .mv-slider .slick-dots li button {
        width: 12px;
        height: 12px;
        border-radius: 50%;
    }

    .mv-slider .slick-dots li button:before {
        font-size: 12px;
        width: 12px;
        height: 12px;
        line-height: 12px;
    }

    .mv-slider .slick-prev,
    .mv-slider .slick-next {
        z-index: 2;
        width: 60px;
        height: 60px;
        top: 50%;
        transform: translateY(-50%);
    }

    .mv-slider .slick-prev {
        left: 30px;
    }

    .mv-slider .slick-prev:before {
        font-size: 40px;
        color: #fff;
        opacity: 0.9;
    }

    .mv-slider .slick-next {
        right: 30px;
    }

    .mv-slider .slick-next:before {
        font-size: 40px;
        color: #fff;
        opacity: 0.9;
    }




    .is01{
        padding-top: 50px;
        margin-bottom: 85px;
    }

    .is01_box{
        position: relative;
        width: 1200px;
        padding-top: 64px;
        margin: 0 auto;
    }

    /* PC版ではアコーディオンを非表示 */
    .is01_accordion_header{
        display: none;
    }

    .is01_accordion_content{
        display: block !important;
    }

    #tab1_radio01,
    #tab1_radio02,
    #tab1_radio03{
        display: none;
    }

    .tab1_label{
        position: absolute;
        top: 0;
        display: flex;
        justify-content: center;
        align-items: center;
        width: 380px;
        height: 64px;
        border-radius: 3px 3px 0 0;
        background: #2D2D2D;
        color: #fff;
        font-size: 20px;
        font-weight: 700;
    }

    #tab1_radio01 + .tab1_label{
        left: 0;
    }

    #tab1_radio02 + .tab1_label{
        left: 50%;
        transform: translateX(-50%);
    }

    #tab1_radio03 + .tab1_label{
        right: 0;
    }

    .tab1_label:hover,
    #tab1_radio01:checked + .tab1_label,
    #tab1_radio02:checked + .tab1_label,
    #tab1_radio03:checked + .tab1_label{
        background: #EC1C16;
    }

    .is01_area{
        display: none;
        padding: 56px 56px 26px;
        background: #fff;
        box-shadow: 0 0 6px rgba(0, 0, 0, 0.25);
    }

    #tab1_radio01:checked ~ #tab1_area01,
    #tab1_radio02:checked ~ #tab1_area02,
    #tab1_radio03:checked ~ #tab1_area03{
        display: block;
    }

    .form_dl{
        display: grid;
        grid-template-columns: 6em 1fr;
        align-items: center;
        gap: 32px 55px;
    }

    .form_dl dt:nth-of-type(n+5),
    .form_dl dd:nth-of-type(n+5){
        display: none;
    }

    .form_dl.active dt,
    .form_dl.active dd{
        display: block;
    }

    .form_dl dt{
        font-weight: 700;
    }

    .form_check_list{
        display: flex;
        flex-wrap: wrap;
        gap: 16px 40px;
    }

    .form_check_list.grid01{
        display: grid;
        gap: 16px 20px;
        grid-template-columns: repeat(6, 1fr);
    }

    .form_check-label{
        display: flex;
        gap: 10px;
    }

    .form_check-label input{
        display: none;
    }

    .form_checkbox{
        position: relative;
        box-sizing: border-box;
        width: 23px;
        height: 23px;
        border: 1px #9E9E9E solid;
        border-radius: 2px;
        box-shadow: inset 0 3px 6px rgba(0, 0, 0, .16);
    }

    .form_check-label input:checked + .form_checkbox{
        border-color: #EC1C16;
        background-color: #EC1C16;
        box-shadow: none;
    }

    .form_check-label input:checked + .form_checkbox:before{
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        content: "";
        width: 12.02px;
        height: 10.22px;
        background: url("/img/check_white.svg") center/contain no-repeat;
    }

    .form_select_wrap{
        display: flex;
        gap: 40px;
    }

    .form_select_box{
        position: relative;
    }

    .form_select_box:after{
        position: absolute;
        top: 50%;
        right: 10px;
        transform: translateY(-50%);
        content: "";
        width: 13.4px;
        height: 7.32px;
        background: url("/img/header02_arrow.svg") center/contain no-repeat;
        pointer-evenst: none;
    }

    .form_select_box select{
        box-sizing: border-box;
        width: 294px;
        height: 54px;
        padding: 14px;
        border: 1px #9E9E9E solid;
        border-radius: 2px;
        background: #fff;
        box-shadow: inset 0 3px 6px rgba(0, 0, 0, .16);
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
    }

    .form_more{
        padding: 5px;
        border: 1px #8E8E8E solid;
        margin-top: 30px;
        background: #F6F6F6;
        text-align: center;
        cursor: pointer;
    }

    .form_more span{
        position: relative;
        display: inline-block;
        padding: 0 17px;
    }

    .form_more .form_more_close,
    .form_more.active .form_more_open{
        display: none;
    }

    .form_more.active .form_more_close{
        display: inline-block;
    }

    .form_more span:before{
        position: absolute;
        top: 50%;
        right: 0;
        transform: translateY(-50%);
        content: "";
        width: 10px;
        height: 10px;
    }

    .form_more .form_more_open:before{
        background: url("/img/icon_plus.svg") center/10px no-repeat;
    }

    .form_more .form_more_close:before{
        background: url("/img/icon_minus.svg") center/10px no-repeat;
    }

    .form_button{
        display: flex;
        justify-content: center;
        margin-top: 30px;
    }

    .form_button button{
        cursor: pointer;
    }

    .form_button button:hover{
        opacity: 0.7;
    }

    .form_button01{
        width: 265px;
        height: 70px;
        border: none;
        border-radius: 3px;
        background: #EC1C16;
        color: #fff;
        font-size: 23px;
        font-weight: 700;
    }

    .form_button01 span{
        position: relative;
        padding-left: 37px;
    }

    .form_button01 span:before{
        position: absolute;
        top: 50%;
        left: 0;
        transform: translateY(-50%);
        content: "";
        width: 31px;
        height: 31px;
        background: url("/img/form_button01_icon.svg")center/contain no-repeat;
    }




    .is02{
        margin-bottom: 85px;
    }

    .is_title{
        margin-bottom: 30px;
        font-size: 35px;
        font-weight: 700;
        text-align: center;
    }

    .is_title span{
        color: #EC1C16;
    }

    .is_box{
        width: 1200px;
        margin: 0 auto;
    }

    .is02_box{
        position: relative;
    }

    .is02_box input{
        display: none;
    }

    .tab2_label_wrap{
        display: flex;
        justify-content: space-between;
    }

    .tab2_label{
        display: flex;
        justify-content: center;
        align-items: center;
        width: 120px;
        height: 42px;
        border: 1px #EC1C16 solid;
        border-radius: 3px 3px 0 0;
        background: #fff;
        font-size: 16px;
        font-weight: 700;
    }

    .tab2_label:hover,
    #tab2_radio01:checked ~ .tab2_label_wrap .tab2_label01,
    #tab2_radio02:checked ~ .tab2_label_wrap .tab2_label02,
    #tab2_radio03:checked ~ .tab2_label_wrap .tab2_label03,
    #tab2_radio04:checked ~ .tab2_label_wrap .tab2_label04,
    #tab2_radio05:checked ~ .tab2_label_wrap .tab2_label05,
    #tab2_radio06:checked ~ .tab2_label_wrap .tab2_label06,
    #tab2_radio07:checked ~ .tab2_label_wrap .tab2_label07,
    #tab2_radio08:checked ~ .tab2_label_wrap .tab2_label08,
    #tab2_radio09:checked ~ .tab2_label_wrap .tab2_label09{
        background: #EC1C16;
        color: #fff;
    }

    .is02_area{
        display: none;
        padding: 32px;
        background: #fff;
    }
    .is02_area_open{
        padding: 32px;
        background: #fff;
    }

    #tab2_radio01:checked ~ #tab2_area01,
    #tab2_radio02:checked ~ #tab2_area02,
    #tab2_radio03:checked ~ #tab2_area03,
    #tab2_radio04:checked ~ #tab2_area04,
    #tab2_radio05:checked ~ #tab2_area05,
    #tab2_radio06:checked ~ #tab2_area06,
    #tab2_radio07:checked ~ #tab2_area07,
    #tab2_radio08:checked ~ #tab2_area08,
    #tab2_radio09:checked ~ #tab2_area09{
        display: block;
    }

    .is02_list_item{
        display: grid;
        grid-template-columns: auto 1fr;
        grid-template-rows: auto auto;
        column-gap: 16px;
        row-gap: 8px;
        align-items: center;
        padding: 16px 0;
    }
    .is02_list > li:not(:last-child) .is02_list_item {
        border-bottom: 1px #9E9E9E solid;
    }

    .is02_list_row {
        display: flex;
        justify-content: center;
    }

    .is02_list_img img {
        display: block;
        margin-left: auto;
        margin-right: auto;
    }

    .is02_list_category{
        grid-row: 1;
        grid-column: 1;
    }

    .is02_list_category span{
        display: inline-block;
        padding: 3px 5px;
        border: 1px #EC1C16 solid;
        border-radius: 3px;
        background: #fff;
        color: #EC1C16;
        font-size: 14px;
        white-space: nowrap;
    }

    .is02_list_title{
        grid-row: 2;
        grid-column: 1 / -1;
        color: #0075CF;
        font-weight: 700;
        font-size: 16px;
        line-height: 1.5;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis;
        -webkit-line-clamp: 2;
    }

    .is02_list_salary{
        grid-row: 1;
        grid-column: 2;
        padding-left: 30px;
        background: url("/img/icon_salary.svg") center left/22px no-repeat;
        color: #2D2D2D;
        line-height: 22px;
        vertical-align: bottom;
    }

    .is02_list_more{
        margin-top: 30px;
        text-align: right;
    }

    .is02_list_more a{
        display: inline-block;
        padding-right: 30px;
        background: url("/img/is02_list_more_icon.svg") center right/21px no-repeat;
        color: #2D2D2D;
        font-size: 16px;
        font-weight: 700;
        line-height: 21px;
        vertical-align: bottom;
    }

    .is02_list_more a:hover{
        color: #EC1C16;
    }

    .is02_banner{
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 58px;
        margin-top: 40px;
    }

    .is02_banner img{
        width: 360px;
    }




    .is03{
        margin-bottom: 85px;
    }

    .is03_box{

    }

    .is03_01{
        padding: 56px 56px 37px;
        background: #fff;
    }

    .is03_list{
        display: flex;
        justify-content: space-between;
    }

    .is03_list a{
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 5px;
        box-sizing: border-box;
        width: 168px;
        height: 168px;
        border: 1px #EC1C16 solid;
        border-radius: 3px;
        color: #2D2D2D;
        font-weight: 700;
        text-align: center;
    }

    .is03_list a:hover{
        color: #EC1C16;
    }

    .is03_list_icon img{
        width: 59px;
    }

    .is03_list_text{
        display: flex;
        align-items: center;
        height: 3em;
        font-size: 18px;
    }

    .is03_more{
        margin-top: 32px;
    }

    .is03_more a{
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 10px;
        /*width: 500px;*/
        width: 380px;
        height: 77px;
        margin: 0 auto;
        background: linear-gradient(to right, #23A87B 0%, #36A5A1 100%);
        color: #fff;
        font-size: 23px;
        font-weight: 700;
        text-align: center;
    }

    .is03_more a:hover{
        opacity: 0.7;
    }

    .is03_more a:hover img{
        opacity: 1;
    }



    .is03_02{
        margin-top: 40px;
    }

    .is03_02 dt{
        position: relative;
        padding: 21px 24px 20px;
        background-color: #fff;
        font-size: 23px;
        font-weight: 700;
    }

    .is03_02 dt:after{
        position: absolute;
        top: 50%;
        right: 21px;
        transform: translateY(-50%);
        content: "";
        width: 21px;
        height: 21px;
        background: url("/img/icon_plus.svg") center/contain no-repeat;
    }

    .is03_02 dt.active:after{
        background-image: url("/img/icon_minus.svg");
    }

    .is03_02 dd{
        display: none;
        padding: 0 56px;
        margin-top: 24px;
        font-size: 16px;
        line-height: 2.125;
    }




    .is04{
        margin-bottom: 64px;
    }

    .is04_box{
        display: grid;
        gap: 24px;
    }

    .is04_01{
        background: #fff;
    }

    .is04_01_01{
        position: relative;
        display: flex;
        justify-content: space-between;
        align-items: center;
        height: 82px;
        padding: 0 56px;
        border-bottom: 2px #9E9E9E solid;
    }

    .is04_01_01:before{
        position: absolute;
        top: 100%;
        left: 0;
        content: "";
        width: 71px;
        height: 2px;
        background: #EC1C16;
    }

    .is04_01_title{
        font-size: 23px;
        font-weight: 700;
    }

    .is04_01_more{
        display: inline-block;
        padding-right: 30px;
        background: url("/img/is02_list_more_icon.svg") center right/21px no-repeat;
        color: #2D2D2D;
        font-size: 16px;
        font-weight: 700;
        line-height: 21px;
        vertical-align: bottom;
    }

    .is04_01_more:hover{
        color: #EC1C16;
    }

    .is04_01_02{
        padding: 56px;
    }

    .is04_column{
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 24px;
    }

    .is04_column_img{
        width: 100%;
        height: 159px;
        margin-bottom: 15px;
    }

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

    .is04_column_title{
        display: -webkit-box;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis;
        -webkit-line-clamp: 2;
        color: #EC1C16;
        text-decoration: underline;
    }

    .is04_column a:hover .is04_column_title{
        text-decoration: none;
    }

    .is04_news{
        display: grid;
        gap: 21px;
    }

    .is04_news li{
        display: grid;
        grid-template-columns: 5em 991px;
        gap: 17px;
    }

    .is04_news_date{
        color: #8E8E8E;
    }

    .is04_news_title{
        width: 100%;
    }

    .is04_news_title a{
        display: block;
        width: 100%;
        color: #EC1C16;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .is04_news_title a:hover{
        text-decoration: underline;
    }






    /*　■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■　共通パーツ　■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■　*/

    .search_section{
        padding: 64px 0;
        border-top: 1px #9E9E9E solid;
    }

    .ss_title{
        position: relative;
        padding-top: 39px;
    }

    .ss_title:before{
        position: absolute;
        top: 0;
        left: 50%;
        transform: translateX(-50%);
        content: "";
        width: 31px;
        height: 31px;
        background: url("/img/icon_search_red.svg") center/contain no-repeat;
    }

    .ss_list01{
        display: grid;
        gap: 8px;
    }

    .ss_list01 > li{
        display: grid;
        grid-template-columns: 210px 1fr;
        gap: 40px;
    }

    .ss_list01_l{
        display: flex;
        justify-content: center;
        align-items: center;
        font-weight: 700;
    }

    .color01 .ss_list01_l,
    .color02 .ss_list01_l{
        background: #D7DCEE;
    }

    .color03 .ss_list01_l{
        background: #CFE4E8;
    }

    .color04 .ss_list01_l{
        background: #CAE3DF;
    }

    .color05 .ss_list01_l{
        background: #CFE6D6;
    }

    .color06 .ss_list01_l{
        background: #E0E5CF;
    }

    .color07 .ss_list01_l{
        background: #E3DBCE;
    }

    .color08 .ss_list01_l{
        background: #E2CADA;
    }

    .color09 .ss_list01_l{
        background: #E5CBC8;
    }

    .color10 .ss_list01_l {
        background: #C6B2D4;
    }

    .color11 .ss_list01_l{
        background: #D2BBAF
    }


    .ss_list02{
        display: grid;
        grid-template-columns: repeat(7, 1fr);
        gap: 12px 16px;
        padding: 8px 0;
    }

    .ss_list02 a,
    .ss_list02 span{
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        height: 32px;
        border-radius: 3px;
        color: #2D2D2D;
    }

    .ss_list02 a:hover{
        opacity: 0.7;
    }

    .color01 .ss_list02 a,
    .color02 .ss_list02 a,
    .color01 .ss_list02 span,
    .color02 .ss_list02 span{
        background: #AFB8DC;
    }

    .color03 .ss_list02 a,
    .color03 .ss_list02 span{
        background: #A9D0D8;
    }

    .color04 .ss_list02 a,
    .color04 .ss_list02 span{
        background: #9CCCC4;
    }

    .color05 .ss_list02 a,
    .color05 .ss_list02 span{
        background: #ACD4B9;
    }

    .color06 .ss_list02 a,
    .color06 .ss_list02 span{
        background: #CBD4AC;
    }

    .color07 .ss_list02 a,
    .color07 .ss_list02 span{
        background: #D4C4AC;
    }

    .color08 .ss_list02 a,
    .color08 .ss_list02 span{
        background: #DBB2CE;
    }

    .color09 .ss_list02 a,
    .color09 .ss_list02 span{
        background: #D4B2AE;
    }

    .color10 .ss_list02 a,
    .color10 .ss_list02 span {
        background: #C6B2D4;
    }

    .color11 .ss_list02 a,
    .color11 .ss_list02 span {
        background: #D2BBAF
    }




    .ul_title_wrap{
        width: 1200px;
        padding-top: 40px;
        margin: 0 auto 40px;
    }
    .ul_title_wrap01{
        width: 1200px;
        padding-top: 40px;
        margin: 0 auto 0 auto;
    }

    .pankuzu{
        margin-bottom: 8px;
        color: #8E8E8E;
        font-size: 12px;
    }

    .pankuzu a{
        color: #8E8E8E;
    }

    .pankuzu a:hover{
        text-decoration: underline;
    }

    .pankuzu span{
        color: #2D2D2D;
    }

    .ul_title{
        font-size: 45px;
    }






    /*　■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■　よくある質問　■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■　*/

    .faqs01{
        margin-bottom: 60px;
    }

    .faq_title{
        margin-bottom: 32px;
        font-size: 35px;
        text-align: center;
    }

    .faqs_box{
        display: grid;
        gap: 32px;
    }

    .faqs_box .is03_02{
        margin-top: 0;
    }

    .faq_q{
        display: flex;
        gap: 1em;
    }

    .faq_q01{
        color: #EC1C16;
    }






    /*　■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■　派遣までの流れ　■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■　*/

    .flos01{
        margin-bottom: 64px;
    }

    .flos01 input{
        display: none;
    }

    .flos01_label_wrap{
        display: flex;
        justify-content: center;
        gap: 30px;
    }

    .flos01_label_wrap label{
        display: flex;
        justify-content: center;
        align-items: center;
        width: 380px;
        height: 64px;
        border-radius: 3px 3px 0 0;
        background: #2D2D2D;
        color: #fff;
    }

    .flos01_label_wrap label h3{
        font-size: 20px;
        font-weight: 700;
    }

    #flos01_tab_radio01:checked ~ .flos01_box #flos01_tab_tab01,
    #flos01_tab_radio02:checked ~ .flos01_box #flos01_tab_tab02{
        background: #EC1C16;
    }

    .flos01_tab_area{
        display: none;
        padding: 56px;
        background: #fff;
    }
    #flos01_tab_radio01:checked ~ .flos01_box #flos01_tab_area01,
    #flos01_tab_radio02:checked ~ .flos01_box #flos01_tab_area02{
        display: block;
    }

    .flos01_list01{
        display: grid;
        gap: 80px;
    }

    .flos01_list01 li{
        position: relative;
        display: grid;
        align-items: center;
        grid-template-columns: 204px 1fr;
        gap: 50px;
        padding: 32px;
        background: #F6F6F6;
    }

    .flos01_list01_l{
        display: flex;
        justify-content: center;
        align-items: center;
        width: 204px;
        height: 204px;
        border-radius: 50%;
        background: #fff;
    }

    .flos01_list01_l img{
        width: 72px;
    }

    .flos01_list01_step{
        margin-bottom: 32px;
        font-size: 35px;
    }

    .flos01_list01_step span{
        color: #EC1C16;
    }

    .flos01_list01_text{
        font-size: 15px;
        line-height: 2.1;
    }

    .flos01_list01_text a{
        text-decoration: underline;
    }

    .flos01_list01_r .is03_more{
        margin-top: 15px;
    }

    .flos01_list01_r .is03_more a{
        margin-left: 0;
    }
    .anken_box01{
        margin:0 0 60px 0;
        background-color:#FFF;
    }
    .anken01{
        padding:10px 20px;
        font-size:1.2em;
        background-color:#EC1C16;
        color:#FFF;
    }
    .anken01 span{
        display:inline-block;
        background-color:#FFF;
        color:#EC1C16;
        padding:0 15px;
        border-radius:10px;
    }
    .anken02{
        margin:1em auto;
        padding:10px;
        background-color:#EFEFEF;
        border:1px #999 solid;
    }
    .anken03{
        width:100%;
    }
    .anken03 img{
        width:100%;
    }
    .anken04{
        padding:10px 20px;
    }

    .icon-tags{
        padding:0;
    }

    .anken04 span{
        display:inline-block;
        background-color:#EC1C16;
        color:#FFF;
        padding:0 15px;
        border-radius:10px;
        margin-right:10px;
    }
    .anken05{
        width:96%;
        border-top:1px #000 solid;
        margin:1em auto;
        table-layout: fixed;
    }
    .anken05 th{
        background-color:#EC1C16;
        color:#FFF;
        padding:10px 20px;
        width:15%;
        border-bottom:1px #000 solid;
        vertical-align: top;
        word-break: keep-all;
        white-space: normal;
    }
    .anken05 td{
        padding:10px 20px;
        border-bottom:1px #000 solid;
        word-break: break-word;
        overflow-wrap: break-word;
        white-space: normal;
        max-width: 100%;
    }
    .anken05 td pre,
    .anken05 td code {
        white-space: pre-wrap;
        word-break: break-word;
    }
    .anken06{
        padding:10px 0;
        width:60%;
        margin:0 auto;
    }
    .anken06_bt01{
        width:48%;
        float:left;
        text-align:center;
    }
    .anken06_bt02{
        width:48%;
        float:right;
        text-align:center;
    }

    .anken06_bt01 .anken06_like_btn {
        display: block;
        background-color: #FFF;
        color: #EC1C16;
        padding: 10px 0;
        border: 1px #EC1C16 solid;
        width: 100%;
        font: inherit;
        cursor: pointer;
        text-align: center;
        box-sizing: border-box;
    }

    .anken06_bt01 .anken06_like_btn:hover {
        background-color: #EC1C16;
        color: #FFF;
    }

    .anken06_bt02 a{
        display:block;
        background-color:#EC1C16;
        color:#FFF;
        padding:10px 0;
        border:1px #EC1C16 solid;
    }
    .anken06_bt02 a:hover{
        background-color:#FFF;
        color:#EC1C16;
    }
    .anken06_bt03{
        font-size:1em;
        width:48%;
        margin:0 auto;
        text-align:center;
        display:block;
        background-color:#FFF;
        color:#EC1C16;
        padding:10px 0;
        border:1px #EC1C16 solid;
        cursor: pointer;
    }
    .anken06_bt04{
        font-size:1em;
        width:48%;
        margin:0 auto 5px;
        text-align:center;
        display:block;
        background-color:#efefef;
        color:#000;
        padding:10px 0;
        border:1px #ccc solid;
        cursor: pointer;
    }
    .input_type01{
        width:50%;
        font-size:1em;
        font-family: "Noto Sans JP", sans-serif;
        margin:0 0 5px 0;
        padding:5px;
    }
    .input_type02{
        font-size:1em;
        font-family: "Noto Sans JP", sans-serif;
        margin:0 0 5px 0;
        padding:5px;
    }
    .input_type03{
        margin:0 25px 0 0;
    }
    .input_type04{
        width:20%;
        font-size:1em;
        font-family: "Noto Sans JP", sans-serif;
        margin:0 0 5px 0;
        padding:5px;
    }
    .input_type05{
        width:90%;
        font-size:1em;
        font-family: "Noto Sans JP", sans-serif;
        margin:0 0 5px 0;
        padding:5px;
    }
    .input_type06{
        width:90%;
        height:150px;
        font-size:1em;
        font-family: "Noto Sans JP", sans-serif;
        margin:0 0 5px 0;
        padding:5px;
    }
    .input_type07{
        width:98%;
        font-size:1em;
        font-family: "Noto Sans JP", sans-serif;
        margin:0 0 5px 0;
        padding:5px;
    }
    .entry01{
        padding:10px;
        width:96%;
        margin:10px auto;
    }
    .login_box01{
        background-color:#FFF;
        padding:50px 0;
        margin:0 auto 50px auto;
    }
    .login_box02{
        width:50%;
        margin:0 auto 2em auto;
    }

    .login_box04{
        width:50%;
        margin:0 auto 1em auto;

    }
    .paging01{
        width:90%;
        margin:0 auto 30px auto;
    }
    .paging02{
        width:15%;
        float:left;
    }
    .paging03{
        width:15%;
        float:right;
        text-align:right;
    }
    .paging01 a{
        color:#EC1C16;
    }
    .editor_area01{
        width:100%;
    }
    .editor_area01 img{
        max-width:100%;
    }
    .editor_area01 iframe{
        max-width:100%;
    }


    #tab li {
      float: left;
      padding: 10px 25px;
      list-style: none;
      cursor: pointer;
      background: #000;
      color:#FFF;
      border-right:1px #fff solid;
    }

    #tab li.select {
      background: #EC1C16;
    }

    .disnon {
      display: none;
    }

    .content_wrap {
      clear: left;
      background: #fff;
      color: #000;
      padding:25px;
    }
    .yogo_title01{
      background: #EC1C16;
      color:#FFF;
      padding:10px 15px;
      margin:0 0 20px 0;
    }
    .yogo_area01{
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
    }
    .yogo01 {
        background: #E8E8E8;
        color: #2d2d2d;
        padding:5px 10px;
        border-radius:4px;
        display: inline-block;
        width:max-content;
        text-decoration: none;
        transition: background-color 0.3s ease;
        letter-spacing: 0.05em;
    }
    .yogo01:hover {
        background: #D0D0D0;
        color: #2d2d2d;
    }
    /*.my_bt_area{*/
    /*    width: 1200px;*/
    /*    margin: 0 auto 30px;*/
    /*    }*/
    /* TODO: ↓メッセージ機能が必要になったら切り替え↑ */
    .my_bt_area {
        display: flex;
        justify-content: center; /* 横方向中央寄せ */
        align-items: center;     /* 縦方向中央揃え（必要に応じて） */
        gap: 16px;               /* ボタン間の間隔 */
        flex-wrap: wrap;         /* 画面幅が狭いときに折り返す */
    }
    .my_bt01{
        float:left;
        /*width:32%;*/
        /* TODO: ↓メッセージ機能が必要になったら切り替え↑ */
        width:25%;
        margin:0 0.5%;
        text-align:center;
    }
    .my_bt01 a{
        display:block;
        background: #EC1C16;
        color:#FFF;
        padding:15px 10px;
    }
    .my_bt01 a:hover{
        background: #000;
        color:#FFF;
    }
    .my_bt02{
        display:inline-block;
        background: #fff;
        color:#EC1C16;
        padding:0 20px;
        margin:0 0 0 10px;
        border-radius:20px;
    }
    .mail-link-right {
        font-size: 12px;
        float: right;
        margin: 8px 0;
    }
    .message01{
        width:100%;
    }
    .message01 th{
        background: #ccc;
        padding:5px 10px;
        text-align:left;
        border:1px #999 solid;
    }
    .message01 td{
        width:10%;
        background: #fff;
        padding:5px 10px;
        border:1px #ccc solid;
    }
    .message02{
        width:70%;
    }
    .message03{
        width:10%;
    }
    .message04{
        width:250px;
        margin:0 0 10px 0;
        text-align:center;
    }
    .message04 a{
        display:block;
        background: #EC1C16;
        color:#FFF;
        padding:10px 10px;
    }
    .message04 a:hover{
        background: #000;
    }
    .message05{
        background: #EC1C16;
        color:#FFF;
        padding:0 10px;
        border-radius:10px;
    }



    .column-post-date {
        margin: 0 0 20px 0;
        text-align:right;
    }
    .column-post-img{
        width:100%;
        margin: 0 0 20px 0;
    }
    .column-post-img img{
        width:100%;
    }
    .column-post-contents{

    }
    .column-post-contents p{
        margin: 0 0 10px 0;
    }
    .column-index{
        border: 1px solid #3F3D3B;
        box-sizing: border-box;
        padding: 20px;
        width: 100%;
        margin:0 0 40px 0;
    }
    .column-index-title {
        color: #3F3D3B;
        font-size: 15px;
        font-weight: normal;
        margin: 0 0 6px;
    }
    .column-index-ul {
        list-style: none;
        margin: 0;
        padding: 0;
    }
    .column-index-ul li {
        font-size: 15px;
        line-height: 1.6;
        list-style: none;
        margin: 0;
        padding: 0;
    }
    .column-index-ul li a {
        color: inherit;
        cursor: pointer;
    }
    .column-index-ul li a::before {
        content: '■';
    }
    .column-post-contents h4{
            color: #EC1C16;
            font-weight: bold;
            margin: 0 0 15px 0;
            font-size: 1.5em;
    }
    .column-post-contents h5{
            font-weight: bold;
            margin: 0 0 15px 0;
            font-size: 1.2em;
    }
    .column-post-contents h6{
            font-weight: bold;
            margin: 0 0 15px 0;
            font-size: 1.0em;
    }
    .column-post-contents p{
            margin: 0 0 25px 0;
    }

    .news_embed_pdf {
        width: 100vw;
        height: 100vh;
    }

    .search_count {
        margin: 0 0 20px 0;
        font-size: 1.2em;
        font-weight: bold;
    }

    .slider.single-item {
        width: 600px; /* スライダーの幅を調整 */
        margin: 0 auto;
    }
    .slider.single-item img {
        width: 100%;
        height: auto;
        display: block;
        object-fit: contain;
        border-radius: 0px;
    }

    .pref_message,
    .municipality_message {
        width: 294px;
    }

}/* end */

/* 無効化された要素の基本スタイル */
.is-disabled {
    opacity: 0.6;
    pointer-events: none;
    cursor: not-allowed;
}

/* 無効化された都道府県リンクのスタイル */
.municipality_link.is-disabled {
    color: #999;
    text-decoration: none;
}

.pref_message,
.municipality_message {
    width: 294px;
}

.job-tag {
    margin: 5px 0;
}


/** フラッシュメッセージ **/

.message.success {
    background: #e6ffed;
    color: #218838;
    border: 1px solid #b7ebc6;
    padding: 16px 24px;
    border-radius: 6px;
    font-size: 1.1em;
    margin: 16px 0;
    box-shadow: 0 2px 8px rgba(33,136,56,0.08);
    cursor: pointer;
    transition: opacity 0.4s, visibility 0.4s;
}

.message.success.hidden {
    opacity: 0;
    display: none;
    /*visibility: hidden;*/
    pointer-events: none;
}

.message.error {
    background: #ffeaea;
    color: #c82333;
    border: 1px solid #f5c6cb;
    padding: 16px 24px;
    border-radius: 6px;
    font-size: 1.1em;
    margin: 16px 0;
    box-shadow: 0 2px 8px rgba(200,35,51,0.08);
    cursor: pointer;
    transition: opacity 0.4s, visibility 0.4s;
}

.message.error.hidden {
    opacity: 0;
    display: none;
    pointer-events: none;
}

.message.warning {
    background: #fffbe6;
    color: #856404;
    border: 1px solid #ffe58f;
    padding: 16px 24px;
    border-radius: 6px;
    font-size: 1.1em;
    margin: 16px 0;
    box-shadow: 0 2px 8px rgba(133,100,4,0.08);
    cursor: pointer;
    transition: opacity 0.4s, visibility 0.4s;
}
.message.warning.hidden {
    opacity: 0;
    display: none;
    pointer-events: none;
}

.message.info {
    background: #e6f7ff;
    color: #0c5460;
    border: 1px solid #91d5ff;
    padding: 16px 24px;
    border-radius: 6px;
    font-size: 1.1em;
    margin: 16px 0;
    box-shadow: 0 2px 8px rgba(12,84,96,0.08);
    cursor: pointer;
    transition: opacity 0.4s, visibility 0.4s;
}
.message.info.hidden {
    opacity: 0;
    display: none;
    pointer-events: none;
}

.message.set,
.message.default {
    background: #f0f0f0;
    color: #333;
    border: 1px solid #d9d9d9;
    padding: 16px 24px;
    border-radius: 6px;
    font-size: 1.1em;
    margin: 16px 0;
    box-shadow: 0 2px 8px rgba(51,51,51,0.08);
    cursor: pointer;
    transition: opacity 0.4s, visibility 0.4s;
}
.message.set.hidden,
.message.default.hidden {
    opacity: 0;
    display: none;
    pointer-events: none;
}


.header02_menu02 li.header_area {
    min-width: 150px;
}

.job-comment {
    margin-top: 8px;
}

.other-option {
    margin-top: 10px;
}

/* 個人情報に同意 */

.box_padding {
    padding: 10px;
    background-color: #f9f9f9;
}

.error-area {
    margin: 10px;
}

.post-entry h4{
    font-size:150%;
    text-align:left;
    margin:10px 0;
    padding:5px 0 5px 10px;
    color:#B30908;
    border-bottom:5px dotted #B30908;
}

.personal_information-content {
    height:350px;
    overflow-y: scroll;
}

.td-noline {
    font-size: 15px;
}
.td-noline p {
    margin: 5px;
    padding: 5px;
}

/* 郵便番号検索 */
.zipcode_search {
    background-color: #f0f0f0;
    margin-left: 10px;
    border: 1px solid #ccc;
    padding: 5px 10px;
    cursor: pointer;
}
.zipcode_search:hover {
    background-color: #e0e0e0;
}

.video_area {
    text-align: center;
}

li {
    list-style:none;
}

/* キャンペーン2025 */
    .campaign-page {
        max-width: 1200px;
        margin: 0 auto;
    }

    .campaign-post-img {
        width: 100%;
        margin: 0 0 30px 0;
    }

    .campaign-post-img img {
        width: 100%;
        height: auto;
    }

    .campaign-btns {
        display: flex;
        justify-content: center;
        gap: 20px;
        margin: 30px 0;
    }

    .campaign-btns .btn {
        display: inline-block;
        width: 300px;
        padding: 15px 40px;
        font-size: 18px;
        font-weight: 700;
        text-align: center;
        text-decoration: none;
        border-radius: 5px;
        transition: opacity 0.3s;
        box-sizing: border-box;
    }

    .campaign-btns .btn:hover {
        opacity: 0.8;
    }

    .campaign-btns .btn-red {
        background: #C8151D;
        color: #fff;
    }

    .campaign-btns .btn-blue {
        background: #0E50CA;
        color: #fff;
    }

    .campaign-post-contents {
        margin: 40px 0;
    }

    .campaign-post-contents h3 {
        font-size: 35px;
        font-weight: 700;
        margin: 40px 0 20px 0;
        color: #2D2D2D;
        border-bottom: 4px solid #C8151D;
        display: inline-block;
    }

    .campaign-post-contents h3:first-child {
        margin-top: 0;
    }

    .campaign-post-contents p {
        font-size: 15px;
        line-height: 2.1;
        margin: 0 0 20px 0;
        color: #2D2D2D;
    }

    .campaign-post-contents a {
        color: #0066CC;
        text-decoration: underline;
    }

    .campaign-post-contents a:hover {
        opacity: 0.7;
    }

    .campaign-flow {
        display: grid;
        gap: 80px;
        margin: 40px 0;
    }

    .campaign-flow-item {
        display: grid;
        align-items: center;
        grid-template-columns: 160px 1fr;
        gap: 50px;
        padding: 32px;
        background: #fff;
    }

    .campaign-flow-item figure {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 160px;
        height: 160px;
        border-radius: 50%;
    }

    .campaign-flow-item figure img {
        width: 100%;
        height: 100%;
    }


    .campaign-flow-item-ttl {
        margin: 0 0 32px 0;
        font-size: 35px;
        font-weight: 700;
        color: #2D2D2D;
    }

    .campaign-flow-item-ttl span {
        color: #EC1C16;
    }

    .campaign-flow-item-txt {
        font-size: 15px;
        line-height: 2.1;
        color: #2D2D2D;
    }

    .campaign-flow-item-txt p {
        margin: 0;
    }


