@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/

/**********************
* 全体
**********************/
* {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 16px;
    line-height: 1.7;
}
.font-serif,
.font-serif span{
    font-family: 'Noto Serif JP', serif;
}
body{
    background: none;
    min-width: 1350px;
}
a {
    color: #000;
    text-decoration: none;
    transition: all 0.5s ease;
}
a:hover {
    color: #000;
    opacity: 0.4;
}
ol, ul, li {
    list-style: none;
    padding-left: 0;
    margin: 0;
}
.article ol,
.article ul,
.article ul li {
    list-style: none;
    padding: 0;
    margin: 0;
}
em, pre, i, address {
    font-style: normal;
}
img{
    vertical-align: top;
}
.inner{
    width: 1300px;
    margin: 0 auto;
    position: relative;
}
.wrap{
    width: 1300px;
}
#content{
    padding: 160px 0 100px;
    margin: 0;
}
.content p{
    font-size: 16px;
    line-height: 2;
    margin: 0 0 20px;
}

/* 画像 フィット */
img.img-fit{
    width: 100%;
    height: 100%;
    object-fit: cover;
    overflow: hidden;
}

/* pc、sp */
.pc {
    display: block!important;
}
.sp {
    display: none!important;
}

/**********************
* 固定ページ
**********************/
/* content */
body.page .article,
body.page .entry-content,
body.page .content .main{
    padding: 0;
    margin: 0;
    border: 0;
}
body.page .article p{
    margin: 0;
}
body.page .date-tags {
    display: none;
}

/* パンくず */
.breadcrumbs{
    margin: 0 auto 20px;
    color: #CE4B01;
    font-size: 23px;
    display: flex;
    align-items: center;
    line-height: 1.3;
}
.breadcrumbs span{
    color: #00143a;
    font-size: 13px;
}

/* デフォルトのパンくず非表示 */
#breadcrumb{
    display: none;
}

/* 各固定ページの先頭画像 */
.header-ttl-img{
    margin-bottom: 60px;
}
.header-ttl-img p img{
    width: 100%;
    height: 530px;
    object-fit: cover;
    border-radius: 60px 60px 270px 60px;
}

/**********************
* TOPのみ
**********************/
body.home .wrap{
    width: 100%;
}
body.home #content,
body.home .article,
body.home .entry-content,
body.home .main{
    margin: 0;
    padding: 0;
    border: 0;
}

/**********************
* 1カラム(フルワイド)
**********************/
body.column-full-wide .article-header{
    width: 1300px;
    margin-right: auto;
    margin-left: auto;
}
body.column-full-wide .breadcrumbs{
    width: 1300px;
    margin-right: auto;
    margin-left: auto;
}

/**********************
* サイドバー
**********************/
.sidebar {
    width: 320px;
}

/**********************
* 見出し
**********************/
.article h2, .article h3, .article h4, .article h5, .article h6 {
    margin-bottom: 20px;
}

/* page h1 */
body.page .article-header{
    margin-bottom: 70px;
}
body.page .article-header h1.entry-title{
    margin: 0;
    font-size: 70px;
    font-weight: 500;
}

/* h2-simple */
.h2-simple{
    text-align: center;
    font-size: 30px;
    margin: 0 0 40px;
}
.page .h2-simple{
    background-color: transparent;
    color: #170e03;
    font-size: 30px;
    padding: 0;
}

/* h3-simple */
.h3-simple{
    font-size: 27px;
    margin: 0 0 20px;
}

/**********************
* p、span
**********************/
p.p-center{
    text-align: center;
}
p.p-last{
    margin: 0;
}
.bold{
    font-weight: 700;
}
.small{
    font-size: 13px;
}

/**********************
* ボタン
**********************/
.btn01 a{
    background-color: #CE4B01;
    color: #fff;
    padding: 10px 40px;
    border-radius: 10px;
    display: inline-block;
}

/**********************
* ヘッダー
**********************/
.header{
    width: 100%;
    min-width: 1300px;
    height: 90px;
    position: fixed;
    top: 0;
    z-index: 100;
    color: #170E03;
    background-color: #fff;
    box-shadow: 0 4px 10px 0 rgba(1, 26, 44, .1);
}
#header-in-pc{
    width: 1200px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0;
}
#header-in-pc .left{
    width: auto;
}
#header-in-pc .left a{
    width: 90px;
    display: inline-block;
}
#header-in-pc .right{
    width: 820px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0 0;
}
#header-in-pc .right_in p.ttl{
    font-size: 12px;
    text-align: right;
    margin: 0 0 7px;
}
#header-in-pc .right_in ul{
    display: flex;
    flex-wrap: wrap;
    gap: 0 20px;
}
#header-in-pc .right_in ul li a{
    font-weight: 700;
}
#header-in-pc .right .contact_box{

}
#header-in-pc .right .contact_box ul{
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}
#header-in-pc .right .contact_btn{
    font-weight: 700;
    background-color: #CE4B01;
    color: #fff;
    padding: 13px 24px;
    border-radius: 10px;
}
#header-in-pc .right .contact_btn02{
    font-weight: 700;
    background-color: #CE4B01;
    color: #fff;
    padding: 13px 33px 13px 24px;
    border-radius: 10px;
    position: relative;
}
#header-in-pc .right .contact_btn02::after {
    content: "\f35d";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    position: absolute;
    right: 10px;
    top: 52%;
    transform: translateY(-50%);
    font-size: 14px;
}
#header-in-sp{
    display: none;
}
.sp-globalmenu{
    display: none;
}

/**********************
* メインイメージ
**********************/
#main_img{
    position: relative;
    background-image: url(img/main_bg.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top center;
    overflow: hidden;
    margin: 90px 0 100px;
}
.main_text_in{
    width: 1300px;
    margin: 0 auto;
    z-index: 2;
    position: relative;
    min-height: 640px;
}
.main_text_in p{
    color: #fff;
}
.main_text_in p.text{
    width: auto;
    position: absolute;
    top: 50%;
    left: 35%;
    transform: translate(-50%, -50%);
}

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

/**********************
* フッター
**********************/
#footer{
    margin: 100px 0 0;
    padding: 90px 0;
    text-align: center;
    background-color: #CE4B01;
}
#footer .footer_in p{
    margin: 0 auto 20px;
}
#footer .footer_in p:last-child{
    margin: 0 auto 0;
}
#footer .footer_in p.logo{
    width: 140px;
}
#footer .footer_in p.logo a{
    display: block;
}
#footer .footer_in .box01{
    margin: 0 0 40px;
}
#footer .footer_in .box02{
    margin: 0 0 40px;
}
#footer .footer_in .box02 ul{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    width: 630px;
    margin: 0 auto;
    gap: 30px;
}
#footer .footer_in .box02 ul li a{
    background: #04457d;
    color: #ffffff;
    font-weight: 700;
    width: 300px;
    border-radius: 17px;
    padding: 20px;
    display: block;
    position: relative;
}
#footer .footer_in .box02 ul li:nth-child(2) a{
    background: #0062b7;
}
#footer .footer_in .box02 ul li:nth-child(2) a::after {
    content: "\f35d";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    position: absolute;
    right: 25%;
    top: 52%;
    transform: translateY(-50%);
    font-size: 15px;
}

/**********************
* トップページ
**********************/
/* 企業のご担当者の方 */
#top-feature{
    margin: 160px 0 130px;
}
.top-feature_in{
    width: 1200px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.top-feature_in .img_box{
    width: 520px;
}
.top-feature_in .text_box{
    position: relative;
    width: 600px;
}
.top-feature_in .text_box::before {
    content: "";
    width: 100px;
    height: 325px;
    border-radius: 100px;
    transform: rotate(20deg);
    position: absolute;
    background-color: #ffbda8;
    z-index: -1;
    left: -230px;
    top: -60px;
}
.top-feature_in .text_box::after {
    content: "";
    width: 141px;
    height: 456px;
    border-radius: 100px;
    transform: rotate(17deg);
    position: absolute;
    background-color: #ffbda8;
    z-index: -1;
    opacity: 0.2;
    left: -64px;
    top: -52px;
}

/* サービス */
#top-service{
    margin: 0 0 100px;
}
.top-service_in{
    width: 1200px;
    margin: auto;
    display: flex;
    flex-wrap: wrap;
}
.top-service_in .child{
    position: relative;
    width: 50%;
    background-image: url(img/service_fig01_ov.jpg);
    background-repeat: no-repeat;
    background-size: 100%;
    background-position: top center;
    overflow: hidden;
    transition: background-size 0.5s ease-in-out;
}
.top-service_in .child:nth-child(2){
    background-image: url(img/service_fig02_ov.jpg);
}
.top-service_in .child:hover {
    background-size: 110%;
}
.top-service_in .child::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.3);
    pointer-events: none;
    z-index: 1;
    transition: background-color 0.5s ease-in-out;
}
.top-service_in .child:hover::before{
    background-color: transparent;
}
.top-service_in .child a{
    display: block;
    padding: 60px;
    min-height: 620px;
    z-index: 2;
    position: relative;
}
.top-service_in .child a:after {
    content: "";
    position: absolute;
    display: block;
    width: 48px;
    height: 48px;
    bottom: 40px;
    right: 40px;
    border-radius: 50%;
    background: #CE4B01 url(img/test/top_basic_arrow_001.svg) center / cover no-repeat;
    z-index: 3;
}
.top-service_in .child a:hover{
    opacity: 1;
}
.top-service_in h2{
    color: #fff;
    font-size: 27px;
    margin: 0 0 23px;
}
.top-service_in p{
    color: #fff;
}

/* お仕事紹介 */
#top-work{
    margin: 0 0 100px;
}
#top-work .top-work_in{
    width: 1000px;
    margin: 0 auto 0;
    display: flex;
    gap: 60px 0;
    flex-direction: column;
    flex-wrap: wrap;
}
#top-work .child{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
#top-work .child02{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    flex-direction: row-reverse;
}
#top-work p:last-child{
    margin: 0;
}
#top-work .img_box{
    width: 500px;
}
#top-work .text_box{
    width: 460px;
}

/* 募集中のお仕事一覧 */
#top-recruit{
    padding: 140px 0 100px;
    background-color: #FFEDE2;
    position: relative;
}
#top-recruit:before,
#top-recruit:after {
    content: "";
    display: block;
    position: absolute;
    width: 358px;
    height: 348px;
    background-color: #CE4B01;
    -webkit-mask: url(img/test/top_basic_bg_001.svg) left / contain no-repeat;
    mask: url(img/test/top_basic_bg_001.svg) left / contain no-repeat;
    z-index: 1;
}
#top-recruit:before {
    bottom: 0;
    left: 0;
}
#top-recruit:after {
    bottom: 0;
    right: 0;
    transform: rotate(-90deg);
}
#top-recruit .h2_ttl_box::before {
    content: "RECRUIT";
    font-weight: 700;
    font-size: 140px;
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: -175px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    color: #FFF7F2;
    opacity: .45;
    text-align: center;
    z-index: 1;
}
#top-recruit .h2_ttl_box h2{
    position: relative;
    z-index: 2;
}
.top-recruit_in{
    display: flex;
    flex-wrap: wrap;
    gap: 40px 0;
    width: 960px;
    margin: 70px auto 60px;
    position: relative;
    z-index: 2;
}
.top-recruit_in .child{
    display: flex;
    background-color: #fff;
    box-shadow: 0 0 15px 0 rgba(1, 26, 44, .1);
    flex-wrap: wrap;
    flex-direction: column;
    width: 100%;
    border-radius: 20px;
}
.top-recruit_in .child a{
    width: 100%;
    padding: 40px;
    display: block;
    position: relative;
}
.top-recruit_in .child a::after {
    content: "";
    position: absolute;
    display: block;
    width: 48px;
    height: 48px;
    bottom: 30px;
    right: 30px;
    border-radius: 50%;
    background: #CE4B01 url(img/test/top_basic_arrow_001.svg) center / cover no-repeat;
}
.top-recruit_in .ttl_box p.p-ttl{
    font-size: 14px;
    margin: 0;
}
.top-recruit_in .child_in{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.top-recruit_in .child_in .img_box{
    width: 200px;
}
.top-recruit_in .child_in .text_box{
    width: 640px;
}
.ul_top-recruit li{
    margin: 0 0 17px;
    padding: 0 0 0 43px;
    position: relative;
}
.ul_top-recruit li:last-child{
    margin: 0;
}
.ul_top-recruit li span{
    border: solid 1px #000;
    margin: 0 7px 0 0;
    font-size: 13px;
    padding: 0px 5px;
    display: inline-block;
}
.ul_top-recruit li::before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f290";
    color: #CE4B01;
    position: absolute;
    top: 0;
    left: 0;
    font-size: 25px;
    line-height: 1;
}
.ul_top-recruit li.li01::before{
    content: "\f290";
}
.ul_top-recruit li.li02::before{
    content: "\f0d6";
    font-size: 20px;
}
.ul_top-recruit li.li03::before{
    content: "\f3c5";
}
.ul_top-recruit li.li04::before{
    content: "\f017";
}
.top-recruit_btn{
    position: relative;
    max-width: 660px;
    margin: auto;
}
.top-recruit_btn:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    background: url(img/test/top_basic_arrow_001.png) 50% / contain no-repeat;
    width: 32px;
    height: 32px;
    right: 36px;
}
.top-recruit_btn a{
    padding: 23px 150px;
    letter-spacing: .48px;
    border-radius: 10px;
    background-color: #CE4B01;
    display: block;
    text-align: center;
    color: #fff;
    font-size: 23px;
    font-weight: 700;
    line-height: 1;
}
.top-recruit_btn a span{
    border-radius: 9999px;
    color: #CE4B01;
    font-weight: 700;
    background-color: #fff;
    font-size: 14px;
    padding: 7px 0;
    position: relative;
    width: 100%;
    text-align: center;
    display: block;
}
.top-recruit_btn a span:before {
    content: "";
    display: block;
    position: absolute;
    bottom: -5px;
    right: 0;
    left: 0;
    margin: 0 auto;
    width: 12px;
    height: 6px;
    -webkit-clip-path: polygon(0 0, 100% 0, 50% 100%);
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    background-color: #fff;
}

/* お仕事のポイント */
#top-point{
    margin: 100px 0 0;
}
.top-point_in{
    width: 960px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 40px 0;
}
.top-point_in .child{
    width: 30%;
}
.top-point_in p{
    margin: 0;
}
.top-point_in p.img{
    width: 130px;
    margin: 0 auto 20px;
    min-height: 150px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.top-point_in .h3-simple{
    text-align: center;
}
.top-point_in svg {
    width: 60%;
    height: 100%;
}
.top-point_in svg .color02 {
    fill: #ffffff;
}
.top-point_in svg .color01 {
    fill: #FFEDE2;
}
.top-point_in svg .line {
    fill: #ce4b01;
}

/* 応募の流れ */
#top-step{
    margin: 100px 0 0;
}
.top-step_in{
    width: 960px;
    margin: 0 auto 60px;
    display: flex;
    flex-wrap: wrap;
    gap: 40px 0;
}
.top-step_in p{
    margin: 0;
}
.top-step_in .h3-simple{
    margin: 0;
}
.top-step_in .child{
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    border: solid 2px #000;
    border-radius: 10px;
}
.top-step_in .num_box{
    background-color: #000;
    width: 160px;
    color: #fff;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
}
.top-step_in .num_box p{
    font-size: 25px;
    font-weight: 700;
}
.top-step_in .num_box p span{
    font-size: 30px;
}
.top-step_in .text_box{
    padding: 30px 50px;
    max-width: 795px;
}

/* よくある質問 */
#top-qa{
    margin: 100px 0 0;
    padding: 120px 0 100px;
    background-color: #FFEDE2;
    position: relative;
}
#top-qa .h2_ttl_box::before {
    content: "Q&A";
    font-weight: 700;
    font-size: 130px;
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: -200px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    color: #FFF7F2;
    opacity: .45;
    text-align: center;
    z-index: 1;
}
#top-qa .h2_ttl_box h2{
    position: relative;
    z-index: 2;
    background: none;
    color: #170e03;
    font-size: 30px;
}
#top-qa .top-qa_in{
    width: 960px;
    margin: 70px auto 60px;
    position: relative;
    z-index: 2;
}
.qa-item {
    width: 100%;
    margin-bottom: 30px;
    border-radius: 10px;
    overflow: hidden;
    position: relative;
}
.qa-item:last-child{
    margin-bottom: 0;
}
.qa-item::before {
    width: 40px;
    height: 31px;
    content: "";
    position: absolute;
    left: 20px;
    top: 27px;
    background-color: #CE4B01;
    padding: 0;
    mask: url(img/test/Q_basic.svg) center / contain no-repeat;
}
.qa-item::after {
    width: 40px;
    height: 40px;
    content: "";
    position: absolute;
    right: 20px;
    top: 27px;
    mask: url(img/test/top_basic_arrow_002.png) center / contain no-repeat;
    background-color: #170E03;
}
.qa-item.active::after {
    transform: rotate(180deg);
}
.qa-question {
    width: 100%;
    padding: 30px 70px;
    background-color: #ffffff;
    color: #000000;
    border: none;
    font-size: 17px;
    font-weight: 700;
    cursor: pointer;
    text-align: left;
    transition: all 0.3s ease;
}
.qa-question.active {
    background-color: #0056b3;
}
.qa-answer {
    max-height: 0;
    overflow: hidden;
    transition: all 0.3s ease;
    background-color: #f9f9f9;
    padding: 0px 70px;
    position: relative;
}
.qa-item.active .qa-answer {
    max-height: 100px;
    padding: 30px 70px;
}
.qa-answer::before {
    width: 40px;
    height: 27px;
    content: "";
    position: absolute;
    left: 20px;
    top: 0;
    background-color: #CE4B01;
    padding: 0;
    mask: url(img/test/A_basic.svg) center / contain no-repeat;
    background-color: #FFEDE2;
    transition: all 0.3s ease;
}
.qa-item.active .qa-answer::before{
    top: 27px;
}

/* 会社概要 */
#top-company{
    margin: 100px 0 0;
}
table.table_top-company{
    width: 960px;
    margin: 40px auto 0;
}
table.table_top-company tr{
    background: none;
}
table.table_top-company th{
    border: 0;
    color: #CE4B01;
    background: no-repeat;
    width: 30%;
}
table.table_top-company td{
    background: none;
    border: 0;
}
table.table_top-company th,
table.table_top-company td{
    padding: 20px 10px;
}

/**********************
* 代表挨拶
**********************/
.message-box{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.message-box .left{
    width: 500px;
}
.message-box .right{
    width: 720px;
}
body.page .article .message-box p{
    margin-bottom: 30px;
    font-weight: 500;
}
body.page .article .message-box p:last-child{
    margin-bottom: 0;
}
.message-profile{
    margin: 30px 0 0;
}
body.page .article .message-profile p{
    text-align: right;
    margin-bottom: 0;
}
body.page .article .message-profile p.ttl{
    font-size: 30px;
    font-weight: 600;
}

/**********************
* コンタクトフォーム問い合わせページ
**********************/
/* 全体のフォームスタイル */
.wpcf7-form {
    max-width: 600px;
    margin: 0 auto;
    padding: 20px;
    border: 1px solid #ddd;
    border-radius: 8px;
    background-color: #f9f9f9;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

/* 入力フィールド */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form textarea {
    width: 100%;
    padding: 12px;
    margin-bottom: 15px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 16px;
    box-sizing: border-box;
    transition: border-color 0.3s, box-shadow 0.3s;
}

.wpcf7-form input[type="text"]:focus,
.wpcf7-form input[type="email"]:focus,
.wpcf7-form input[type="tel"]:focus,
.wpcf7-form textarea:focus {
    border-color: #CE4B01;
    box-shadow: 0 0 8px rgba(58, 160, 234, 0.5);
    outline: none;
}

/* テキストエリア */
.wpcf7-form textarea {
    height: 120px;
    resize: vertical;
}

/* 送信ボタン */
.wpcf7-form input[type="submit"] {
    background-color: #CE4B01;
    color: #fff;
    border: none;
    padding: 12px 20px;
    border-radius: 4px;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
    text-align: center;
    transition: background-color 0.3s, transform 0.2s;
}

.wpcf7-form input[type="submit"]:hover {
    background-color: #ff7324;
    transform: scale(1.05);
}

/* エラーメッセージ */
.wpcf7-not-valid-tip {
    color: #d9534f;
    font-size: 14px;
    margin-top: -10px;
    margin-bottom: 10px;
}

/* 成功メッセージ */
.wpcf7-mail-sent-ok {
    color: #CE4B01;
    background-color: #e7f4fc;
    border: 1px solid #CE4B01;
    padding: 10px;
    border-radius: 4px;
    font-size: 14px;
    text-align: center;
}

/* ラベル */
.wpcf7-form label {
    font-size: 14px;
    font-weight: bold;
    margin-bottom: 5px;
    display: block;
    color: #333;
}