@charset "UTF-8";

:root {
	--color-white: #ffffff;
	--color-black: #000000;
	--color-main: #14688F;
    --color-main2: #2F2D2C;
	--color-bgc: #F2F2F2;
  }

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

body {
	color: #2F2D2C;
	font-family: "Noto Sans JP", sans-serif;
	line-height: 2rem;
}

.is-pc {
    display: block;
}
@media screen and (max-width: 767px) {
  .is-pc {
    display: none;
  }
}
.is-sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .is-sp {
    display: block;
  }
}

/* -------------------------
    	    ロゴ
------------------------- */
header div {
    position: absolute;
    width: 10em;
    top: 1.5rem;
    left: 2rem;
}

.main_visual {
    background-image: url(../img/mainvisual.jpg);
    width: 100%;
    height: 680px;
	background-position: center top;
	background-repeat: no-repeat;
	background-size: cover;
	display: block;
	content: "";
	white-space: nowrap;
}

.main_visual h1 {
	width: 593px;
	background-image: url(../img/main_title.png);
	height: 650px;
	background-position: left  top 145px;
	background-repeat: no-repeat;
	background-size: contain;
	display: block;
	content: "";
	overflow: hidden;
	text-indent: 150vw;
	white-space: nowrap;
	margin-left: 155px;
}

@media screen and (min-width: 1680px) {
    .main_visual {
        background-position: center;
        height: 750px;
    }
    .main_visual h1 {
        height: 700px;
        background-position: left  top 180px;
        margin-left: 355px;
    }
}

@media screen and (max-width: 1200px) {
	.main_visual h1 {
        background-position: left top 145px;
        margin-left: 100px;
	}
}

@media screen and (max-width: 1024px) {
	.main_visual h1 {
        width: 550px;
        background-position: left top 165px;
        margin-left: 40px;
	}
}

@media screen and (max-width: 750px) {
    .main_visual {
        background-image: url(../img/mainvisual_sp.png);
        height: 900px;
        background-position: center;
    }
    .main_visual h1 {
        width: 480px;
        background-image: url(../img/main_title_sp.png);
        height: 900px;
        background-position: left  top 150px;
        margin-left: 20px;
    }
}

@media screen and (max-width: 500px) {
    .main_visual {
        height: 700px;
        background-position: bottom right;
    }
    .main_visual h1 {
        width: 350px;
        height: 700px;
        background-position: left  top 120px;
    }
}

@media screen and (max-width: 450px) {
    header div {
        top: 1rem;
        left: 1rem;
    }
    .main_visual {
        height: 600px;
    }
    .main_visual h1 {
        width: 312px;
        height: 600px;
        background-position: left  top 92px;
    }
}

@media screen and (max-width: 400px) {
    .main_visual {
        height: 540px;
    }
    .main_visual h1 {
        width: 290px;
        height: 540px;
        background-position: left  top 80px;
        margin-left: 14px;
    }
}

/* -------------------------
    	   フォーム
------------------------- */
.p-contact {
    background: var(--color-bgc);
}

h2 {
    font-size: 35px;
    color: var(--color-main);
    font-weight: bold;
    line-height: 3rem;
    text-align: center;
    margin: 0 auto 40px;
    padding-top: 70px;
}

@media screen and (max-width: 650px) {
    h2 {
        font-size: 25px;
        line-height: 2.4rem;
        margin: 0 auto 20px;
        padding-top: 40px;
    }
    .form__title h2 {
        font-size: 22px;
        line-height: 2rem;
    }
}

/* -------------------------
    	　紹介求人例
------------------------- */
.company_icons h2 {
    margin: 0 auto 15px;
}

#slider {
    margin-bottom: 5px;
}

.company_slider_box {
    width: 1109px;
    margin: 40px auto 0;
    padding-bottom: 70px;
}

.company_slidebox {
    width: 330px;
    height: 302px;
    box-shadow: 1px 1px 15px rgba(96, 95, 95, 0.142);
    margin: 0 20px 20px;
}

.company_name_box{
    height: 90px;
    font-size: 13px;
    font-weight: 500;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background: var(--color-main);
    color: var(--color-white);
}

.company_name {
    font-size: 20px;
    font-weight: bold;
    margin: 5px 0 -7px 0;
}

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

.company_salary_title {
    height: 22px;
    font-size: 12px;
    font-weight: 500;
    margin: 15px 0 10px;
    display: flex;
    align-items: center;
    background: var(--color-main);
    color: var(--color-white);
}

.company_salary_title p {
    padding: 0 10px;
}

.company_salary {
    width: 260px;
    padding-top: 10px;
    padding-bottom: 12px;
}

.company_salary_text {
    width: 300px;
    font-size: 15px;
    line-height: 26px;
    margin-bottom: 20px;
}

@media screen and (max-width: 1200px) {
    .company_slider_box {
        width: 740px;
        margin: 40px auto 0;
        padding-bottom: 70px;
    }
}

@media screen and (max-width: 650px) {
    .company_icons h2 {
        margin: 0 auto 5px;
    }
}

@media screen and (max-width: 800px) {
    .company_slider_box {
        width: 370px;
        padding-bottom: 40px;
    }
}

/*ドットナビゲーションの設定*/
button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 50px;
  height: 7px;
  padding: 0 7px;
}

.slider {
    margin: 0 auto;
    max-width: 500px;
    width: 80%;
  }
  .slider-img img {
    height: auto;
    width: 100%;
  }
  .slide-dots {
    margin: 0;
    padding: 0;
    text-align: center;
  }
  .slide-dots li {
    display: inline-block;
    margin: 0 5px;
  }
  .slide-dots li button {
    position: relative;
    text-indent: -9999px;
  }

.slide-dots li button:before {
    background-image: url(../img/dots_var.png);
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    cursor: pointer;
    height: 7px;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    top: 0;
    width: 50px;
}
.slide-dots li.slick-active button:before {
    background-image: url(../img/dots_var_2.png);
}

  /* -------------------------
    	ボタン帯
------------------------- */
.button_area {
	background: var(--color-main);
	display: flex;
	align-items: center;
	justify-content: center;
}

.button_box {
	margin: 50px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.button_area p {
	text-align: center;
	font-size: 25px;
	font-weight: bold;
	line-height: 2.5rem;
	color: var(--color-white);
}

.button_subtitle {
	width: 210px;
	height: 65px 0;
	margin-top: 15px;
}

.button_free {
	width: 370px;
	margin-top: -23px;
}

.button_free:hover {
	opacity: 0.7;
}


@media screen and (max-width: 500px) {
	.button_box {
		margin: 30px 0;
	}
	.button_area p {
		font-size: 20px;
	}
	.button_free {
		width: 330px;
	}
}

/* -------------------------
    	選ばれる理由
------------------------- */
.reason {
    background: var(--color-bgc);
    padding-bottom: 30px;
}

h2 span {
    font-size: 56px;
    font-weight: 600;
    vertical-align: -3px;
}

@media screen and (max-width: 650px) {
    h2 span {
        font-size: 46px;
    }
    .reason_box {
        padding-bottom: 40px;
    }
}

.reason_box {
    display: flex;
    margin: 0 auto;
    width: 1050px;
    padding-bottom: 40px;
}

.reason_img {
    width: 480px;
    height: 280px;
}

.reason_text {
    width: 570px;
    height: 280px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    background: var(--color-white);
}

.reason_titletext {
    width: 490px;
    font-size: 22px;
    font-weight: bold;
    color: var(--color-main);
}

.reason_detail {
    width: 490px;
    letter-spacing: 0.2px;
    margin-top: 10px;
}


@media screen and (max-width: 1100px) {
    .reason_box {
        width: 480px;
        flex-direction: column;
    }
    .reason_text {
        width: 480px;
        height: 240px;
    }
    .reason_text_3 {
        height: 270px;
    }
    .reason_titletext {
        width: 444px;
        font-size: 20px;
        font-weight: bold;
        color: var(--color-main);
    }
    .reason_detail {
        width: 444px;
        margin-top: 3px;
    }
}

@media screen and (max-width: 500px) {
    .reason {
        padding-bottom: 10px;
    }
    .reason_box {
        width: 330px;
        flex-direction: column;
        padding-bottom: 30px;
    }
    .reason_img {
        width: 330px;
        height: auto;
    }
    .reason_text {
        width: 330px;
        height: 290px;
    }
    .reason_text_2 {
        height: 240px;
    }
    .reason_text_3 {
        height: 300px;
    }
    .reason_titletext {
        width: 300px;
        line-height: 26px;
        font-size: 17px;
        font-weight: bold;
        color: var(--color-main);
    }
    .reason_detail {
        width: 300px;
        line-height: 30px;
    }
}

/* -------------------------
    	　　成功例
------------------------- */
.success {
    background: rgb(20,104,143,0.1);
}

.success_slider_box {
    width: 1080px;
    margin: 0 auto;
    padding-bottom: 70px;
}

.success_box {
    height: 660px;
    background: var(--color-white);
    display: flex !important;
    align-items: center;
    justify-content: center;
    margin: 0 15px;
}

.success_detail_box {
    width: 300px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.success_human_box {
    display: flex;
    font-size: 12px;
    align-items: center;
    justify-content: center;
}

.success_icon {
    width: 70px;
}

.success_human_detail {
    margin-left: 20px;
}

.success_title {
    font-weight: bold;
    line-height: 21px;
}

.success_salary {
    width: 296px;
    margin: 20px 0 15px;
}

.success_text {
    font-size: 16px;
    line-height: 30px;
}

.success .slick-dots {
    margin-top: 30px;
}

.success .slick-dotted {
    padding-bottom: 40px;
    margin: 0;
}

@media screen and (max-width: 1200px) {
    .success_slider_box {
        width: 720px;
        padding-bottom: 0;
    }
    .success_box {
        margin-bottom: 20px;
    }
}

@media screen and (max-width: 700px) {
    .success_slider_box {
        width: 360px;
    }
}

@media screen and (max-width: 650px) {
    .success .slick-dotted {
        padding-bottom: 40px;
    }
    
}

/*=================================
スライダーのためのcss
===================================*/
/*矢印の設定*/
/*戻る、次へ矢印の位置*/
.slick-prev, 
.slick-next {
    position: absolute;
    display: block;
    z-index: 10000;
    top: 12%;
}

.voice_slider .slick-prev, 
.voice_slider .slick-next {
    position: absolute;
    display: block;
    z-index: 10000;
    top: 12%;
}

.slick-prev {/*戻る矢印の位置と形状*/
    left: 25px;;
}

.slick-prev:before {
    content: '＜';
}

.slick-prev:before,
.slick-next:before {
    font-family: '';
    font-weight: bold;
    color: var(--color-main2);
    font-size: 20px;
    line-height: 0;
}

.slick-next {/*次へ矢印の位置と形状*/
    right: 25px;
}

.slick-next:before {
    content: '＞';
}

/* -------------------------
    	　　流れ
------------------------- */
.flow {
    background: var(--color-bgc);
}

.flow_container {
    width: 1050px;
    margin: 0 auto;
    padding-bottom: 70px;
    display: flex;
    justify-content: space-between;
}

.flow_stepbox {
    width: 300px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

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

.flow_notitle_box p {
    font-size: 22px;
    font-weight: bold;
    color: var(--color-main);
    margin: 22px 0 33px;
}

.flow_nobox {
    width: 45px;
}

.flow_img_box {
    width: 145px;
    margin-bottom: 33px;
}

.flow_text {
    font-size: 16px;
    line-height: 28px;
    letter-spacing: 0.2px;
}

@media screen and (max-width: 1100px) {
    .flow_container {
        width: 300px;
        margin: 0 auto;
        padding-bottom: 35px;
        flex-direction: column;
        justify-content: center;
    }
    .flow_stepbox {
        margin-bottom: 35px;
    }
    .flow_notitle_box {
        width: 300px;
        flex-direction: row;
        justify-content: start;
        align-items: center;
    }
    .flow_nobox_1 {
        margin-right: 36px;
    }
    .flow_nobox_2 {
        margin-right: 10px;
    }
    .flow_nobox_3 {
        margin-right: 57px;
    }
}

@media screen and (max-width: 650px) {
    .flow_container {
        padding-bottom: 5px;
    }
    
}

/* -------------------------
    	　　ca
------------------------- */
.ca {
    background: rgb(20,104,143,0.1);
}

.ca_slider_box {
    width: 1080px;
    margin: 0 auto;
    padding-bottom: 70px;
}

.ca_box {
    width: 330px;
    height: 540px;
    background: var(--color-white);
    margin: 0 15px 20px;
}

.ca_name {
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    margin: 20px auto 15px;
}

.ca_text {
    font-size: 16px;
    line-height: 28px;
    width: 290px;
    margin: 0 auto;
}

.slick-dotted.slick-slider {
    margin-bottom: 0;
}

@media screen and (max-width: 1200px) {
    .ca_slider_box {
        width: 720px;
    }
}

@media screen and (max-width: 700px) {
    .ca_slider_box {
        width: 360px;
        padding-bottom: 40px;
    }
    .ca_title {
        font-size: 24px;
    }
}

/*=================================
スライダーのためのcss
===================================*/
/*矢印の設定*/
/*戻る、次へ矢印の位置*/
.slick-prev_2, 
.slick-next_2 {
    position: absolute;
    display: block;
    z-index: 10000;
    top: 18%;
}

.voice_slider .slick-prev_2, 
.voice_slider .slick-next_2 {
    position: absolute;
    display: block;
    z-index: 10000;
    top: 18%;
}

.slick-prev_2 {/*戻る矢印の位置と形状*/
    left: 25px;;
}

.slick-prev_2:before {
    content: '＜';
}

.slick-prev_2:before,
.slick-next_2:before {
    font-family: '';
    font-weight: bold;
    color: var(--color-main2);
    font-size: 20px;
    line-height: 0;
}

.slick-next_2 {/*次へ矢印の位置と形状*/
    right: 25px;
}

.slick-next_2:before {
    content: '＞';
}

/* -------------------------
    	　　質問
------------------------- */
.question {
    background: var(--color-bgc);
}

.question_container {
    width: 650px;
    margin: 0 auto;
    padding-bottom: 70px;
}

.question_Qtext_box {
    margin-bottom: 35px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
    border-radius: 8px;
    overflow: hidden;
}

.question_box {
    height: 78px;
    border-radius: 8px 8px 0 0 ;
    background: var(--color-main);
    display: flex;
}

.question_box_2,
.question_box_3 {
    height: 105px;
}

.question_box_2 p {
    width: 430px;
}

.question_text_sp {
    display: none;
}

.Q_box {
    display: flex;
    align-items: center;
}

.Q_img {
    width: 56px;
    margin: 0 15px 0 35px;
}

.Q_box p {
    font-size: 22px;
    font-weight: bold;
    color: white;
}

.question_text_box {
    background: var(--color-white);
    border-radius: 0 0 8px 8px ;
}

.question_text_box p {
    font-size: 16px;
    line-height: 28px;
    padding: 23px 43px;
}

.question_Qtext_box_3 {
    margin-bottom: 0;
}

@media screen and (max-width: 700px) {
    .question_container {
        width: 450px;
        padding-bottom: 40px;
    }
    .question_text_pc {
        display: none;
    }
    .question_text_sp {
        display: block;
    }
    .question_box_2 p,
    .question_box_3 p {
        width: 300px;
        font-size: 17px;
        line-height: 25px;
    }
}

@media screen and (max-width: 500px) {
    .question_container {
        padding-bottom: 20px;
    }
    .question_container {
        width: 330px;
    }
    .question_Qtext_box {
        margin-bottom: 20px;
    }
    .Q_box p {
        font-size: 16px;
    }
    .Q_img {
        margin: 0 10px 0 15px;
    }
    .question_text_box p {
        font-size: 15px;
        line-height: 26px;
        padding: 13px 23px;
    }
    .question_box_2 p,
    .question_box_3 p {
        width: 250px;
        font-size: 17px;
        line-height: 25px;
    }
}

/* -------------------------
    	　　フォーム
------------------------- */
#contact-2 {
    background: rgb(20,104,143,0.1);
}

/* -------------------------
    	    フッター
------------------------- */
footer {
    background: var(--color-main2);
    color: var(--color-white);
    text-align: center;
}

.footer_container {
    padding: 15px 0;
}

.footer_link {
    display: flex;
    width: 236px;
    margin: 0 auto; 
    font-size: 14px;
    text-decoration: underline;
}

.footer_link a {
    margin: 0 10px;
}

@media screen and (max-width: 500px) {
    .footer_container {
        padding: 5px 0;
    }
    .footer_link {
        width: 208px;
        font-size: 12px;
        margin-bottom: -15px;
    }
    small {
        font-size: 10px;
    }
}