*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: "source-han-sans-japanese", sans-serif;
    font-weight: 700;
    font-style: normal;
    scroll-behavior: smooth;
    color: #000000;
    line-height: 1.4;
}

html {
    background-color: #f8f8f8;
}

img {
    width: 100%;
    vertical-align: bottom;
}

body {
    margin: 0 auto;
    background-color: #c2c2c2;
}

section {
    text-align: center;
}

#fv {
    position: relative;
}

.fv_btn {
    position: absolute;
    width: 90%;
    bottom: 4%;
    left: 5%;
}

@media screen and (min-width: 767px){
    .header {
        background-color: #000;
        width: 100%;
        text-align: center;
    }
    .header img {
        width: 20%;
        max-width: 300px;
        padding: 1% 0;
    }

    #fv {
    background-image: url(../img/fv_bg_pc02.jpg);
    background-position: top center;
    background-size: cover;
    background-repeat: no-repeat;
    position: relative;
  }

  #fv h1 {
    margin: 0;
  }

  .fv_main {
    width: 100%;
    display: block;
    margin: 0 auto;
    padding-bottom: 0;
  }

  .fv_green {
    width: 100%;
    display: block;
  }

  .fv_contents {
    width: 96%;
    max-width: 1000px;
    margin-top: 50%;
  }

  .fv_btn {
    position: static;
    width: 86%;
    max-width: 800px;
    margin: 0 auto;
    padding-bottom: 2%;
  }
}

@media screen and (min-width: 1140px){
    #fv {
        background-image: url(../img/fv_bg_pc.jpg);
    }
    .fv_contents {
        margin-top: 40%;
    }
}

@media screen and (min-width: 1500px){
    .fv_contents {
        margin-top: 35%;
    }
}

@media screen and (min-width: 1640px){
    .fv_contents {
        margin-top: 27%;
    }
}

/*お悩み*/
#worries {
    position: relative;
}

.worries_wrapper {
    position: absolute;
    bottom: 5%
}

.worries_wrapper img {
    padding-bottom: 3%;
}

@media screen and (min-width: 767px){
    #worries {
        background-image: url(../img/worries_bg_pc.jpg);
        background-position: top;
        background-size: cover;
        background-repeat: no-repeat;
    }

    .worries_ttl {
        width: 100%;
        max-width: 700px;
        margin: 0 auto;
        padding: 2% 0;
    }

    .worries_contents {
        width: 96%;
        max-width: 900px;
        margin: 0 auto;
        padding: 10% 0 0 5%;
    }

    .worries_wrapper {
        width: 96%;
        max-width: 1000px;
        margin: 0 auto;
        position: static;
        padding: 2% 0 3%;
    }
}

@media screen and (min-width: 1300px){ 
    .worries_contents {
        padding: 5% 0 0 5%;
    }
}


/*求人倍率*/
#raito {
    background-color: #2d2d2d;
}

.raito_ttl {
    width: 52%;
    margin: 0 auto;
    padding: 5% 0;
}

.raito_contents {
    width: 96%;
    padding: 0 0 5% 3%;
}

@media screen and (min-width: 767px){
    .raito_ttl {
        width: 75%;
        max-width: 350px;
        padding-bottom: 2%;
    }
    .raito_contents {
        width: 70%;
        max-width: 650px;
        margin: 0 auto;
        padding: 0 0 2% 1%;
    }
}

/*SNS*/
#sns {
    position: relative;
}

.sns_ttl {
    position: absolute;
    top: 5%;
    left: 5%;
    width: 92%;
    padding-left: 1%;
}

.sns_contents_wrapper {
    position: absolute;
    top: 31%;
    left: 5%;
    width: 90%;
    padding-top: 6%;
}

.sns_content {
    width: 50%;
}

.sns_flex {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: -2%;
}

.sns_btn {
    width: 90%;
    position: absolute;
    bottom: 10%;
    left: 5%;
}

@media screen and (min-width: 767px){
    #sns {
        background-image: url(../img/sns_bg_pc.jpg);
        background-position: top center;
        background-size: cover;
        background-repeat: no-repeat;
    }
    .sns_ttl {
        position: static;
        width: 98%;
        max-width: 1100px;
        margin: 0 auto;
        padding-top: 1%;
    }
    .sns_contents {
        width: 96%;
        max-width: 920px;
        margin: 0 auto;
        padding: 0 0 3% 2%;
    }

    .sns_btn {
        margin: 0 auto;
        position: static;
        width: 80%;
        max-width: 750px;
        padding-bottom: 8%;
    }
}

/*実績*/
#achievement {
    position: relative;
}

.achievements_ttl {
    position: absolute;
    top: 1%;
    left: 7%;
    width: 86%;
}

.achievements_contents {
    position: absolute;
    top: 22%;
    left: 10%;
    width: 80%;
}

@media screen and (min-width: 767px){
    #achievement {
        background-image: url(../img/achievements_bg_pc.jpg);
        background-position: top;
        background-size: cover;
        background-repeat: no-repeat;
    }
    .achievements_ttl {
        position: static;
        width: 80%;
        max-width: 750px;
        padding-top: 2%;
        margin: 0 auto;
    }
    .achievements_contents{
        position: static;
        width: 98%;
        max-width: 1000px;
        margin: 0 auto;
        padding: 2% 5% 6% 0;
    }
}

/*採用実績*/
#recruit {
    background-image: url(../img/recruit_bg.jpg);
    background-position: top;
    background-size: cover;
    background-repeat: no-repeat;
}

.recruit_ttl {
    width: 80%;
    padding-top: 9%;
}

/*スライダー全体*/
.recruit_cases_slider {
    position: relative;
    width: 100%;
    max-width: 700px;
    margin: 0 auto;
    overflow: hidden;
    padding-top: 5%;
}

.recruit_cases_slider .swiper-wrapper {
    display: flex;
  }

  .recruit_cases_slider .swiper-slide {
    flex-shrink: 0;
    display: flex;
    justify-content: center;
  }
  
  .recruit_cases_slider .swiper-slide img {
    width: 88%;
    display: block;
    margin: 0 auto;
  }


.recruit_cases_prev,
.recruit_cases_next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 8%;
    cursor: pointer;
}

.recruit_cases_prev {
    left: 3%;
}

.recruit_cases_next {
    right: 3%;
}

.recruit_cases_prev img,
.recruit_cases_next img {
    width: 100%;
}

.recruit_cases_pagination {
    margin-top: 1%;
    text-align: center;
}

.recruit_contents {
    width: 90%;
    padding: 5% 0;
}

@media screen and (min-width: 767px){
    #recruit {
        background-image: url(../img/recruit_bg_pc.jpg);
        background-position: top;
        background-size: cover;
        background-repeat: no-repeat; 
    }
    .recruit_ttl {
        width: 72%;
        max-width: 750px;
        padding: 5% 0 0;
        margin: 0 auto;
    }
    .recruit_cases_slider {
        max-width: 1200px;
        padding-top: 2%;
      }
    
      .recruit_cases_slider .swiper-slide img {
        width: 100%;
        max-width: 750px;
      }
    
      .recruit_cases_prev,
      .recruit_cases_next {
        width: 5%;
      }
    
      .recruit_cases_prev {
        left: 6%;
      }
    
      .recruit_cases_next {
        right: 6%;
      }
    
      .recruit_cases_pagination {
        margin-top: 1.5%;
      }
    
      .recruit_contents {
        width: 98%;
        max-width: 650px;
        padding: 4% 0 3%;
      }
}

/*比較*/
#comparison {
    background-image: url(../img/comparison_bg.jpg);
    background-position: top;
    background-size: cover;
    background-repeat: no-repeat;
}

.comparison_ttl {
    width: 90%;
    padding: 10% 0 3%;
}

.comparison_table {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch; 
    padding: 0 5%;

     /* Firefox用 */
     scrollbar-color: #0b5d2a #eee; /* 親指 / 背景 */
     scrollbar-width: thin;
}

/* ===== Chrome / Safari ===== */
.comparison_table::-webkit-scrollbar {
    height: 8px; 
}

.comparison_table::-webkit-scrollbar-track {
    background: #eee; 
    border-radius: 10px;
}

.comparison_table::-webkit-scrollbar-thumb {
    background: #0b5d2a;
    border-radius: 10px;
}

.comparison_table::-webkit-scrollbar-thumb:hover {
    background: #08441f;
}

.swiper-pagination-bullet-active {
    opacity: var(--swiper-pagination-bullet-opacity, 1);
    background: #d5a745;
}

.comparison_table img {
    max-width: none;
    width: 550px;
}

.comparison_bottom {
    width: 90%;
    padding: 5% 0 13%;
}

@media screen and (min-width: 600px){
    .comparison_table img {
        width: 100%;
    }
}

@media screen and (min-width: 767px){
    #comparison {
        background-image: url(../img/comparison_bg_pc.jpg);
    }
    .comparison_ttl {
        width: 76%;
        max-width: 720px;
        padding: 5% 0 1%;
    }
    .comparison_table img{
        width: 100%;
        max-width: 950px;
        margin: 0 auto;
    }
    .comparison_bottom {
        width: 90%;
        max-width: 950px;
        margin: 0 auto;
        padding: 3% 0 5%;
    }
}

/*すぐに結果が出ます*/
#result {
    position: relative;
}

.result_bottom {
    position: absolute;
    width: 80%;
    bottom: 41%;
    left: 10%;
}

.result_sns {
    position: absolute;
    width: 96%;
    bottom: 16%;
    left: 2%;
}

.result_btn {
    position: absolute;
    width: 90%;
    bottom: 4%;
    left: 5%;
}

@media screen and (min-width: 767px){
    #result {
        background-image: url(../img/result_bg_pc.jpg);
        background-position: top;
        background-size: cover;
        background-repeat: no-repeat;
    }
    .result_top {
        width: 90%;
        max-width: 850px;
        margin: 0 auto;
        padding: 4% 0 0;
    }

    .result_contents {
        width: 96%;
        max-width: 1100px;
        margin: 0 auto;
        padding: 3% 0;
    }

    .result_bottom {
        width: 60%;
        max-width: 700px;
        bottom: 41%;
        left: 50%;
        transform: translateX(-50%);
    }

    .result_sns {
        position: static;
        width: 96%;
        max-width: 1000px;
        margin: 0 auto;
    }

    .result_btn {
        position: static;
        width: 98%;
        max-width: 750px;
        margin: 0 auto;
        padding: 1% 0 5%;
        display: block;
    }
    
}

/*強み*/
#forte {
    background-image: url(../img/forte_bg.jpg);
    background-position: top;
    background-size: cover;
    background-repeat: no-repeat;
}

.forte_ttl {
    width: 74%;
    padding: 10% 0 1%;
}

.forte_wrapper img {
    padding-bottom: 3%;
}

.forte_bottom {
    padding: 5% 13% 10% 5%;
}

@media screen and (min-width: 767px){
    #forte {
        background-image: url(../img/forte_bg_pc.jpg);
    }
    .forte_ttl {
        width: 60%;
        max-width: 580px;
        margin: 0 auto;
        padding: 5% 0 2%;
    }
    .forte_wrapper {
        width: 96%;
        max-width: 1050px;
        margin: 0 auto;
    }
    .forte_bottom {
        width: 96%;
        max-width: 900px;
        margin: 0 auto;
        padding: 1% 0 4% 3%;
    }
}

/*お客様の声*/
#review {
    background-image: url(../img/review_bg.jpg);
    background-position: top;
    background-size: cover;
    background-repeat: no-repeat;
    position: relative;
}

.review_ttl {
    width: 48%;
    padding: 10% 0 3%;
}

.review_wrapper img {
    padding-bottom: 6%;
}

.review_bottom {
    position: relative;
}

.review_btn {
    position: absolute;
    width: 90%;
    bottom: 10%;
    left: 5%;
}

@media screen and (min-width: 767px){
    #review {
        background-image: url(../img/review_bg_pc.jpg);
    }
    .review_ttl {
        width: 40%;
        max-width: 400px;
        padding: 5% 0 3%;
    }
    .review_wrapper {
        width: 96%;
        max-width: 1050px;
        margin: 0 auto;
        padding-left: 3%;
    }

    .review_wrapper img {
        padding-bottom: 4%;
    }

    .review_bottom {
        background-image: url(../img/review_bottom_bg_pc.jpg);
        background-position: top;
        background-size: cover;
        background-repeat: no-repeat;
        position: relative;
    }
    .review_bottom_contents {
        width: 100%;
        max-width: 1050px;
        margin: 0 auto;
        padding: 5% 0 0 2%;
    }
    .review_btn {
        position: static;
        width: 96%;
        max-width: 750px;
        margin: 0 auto;
        padding: 1% 0 3%;
    }
}


/*運用の流れ*/
#flow {
    background-image: url(../img/flow_bg.jpg);
    background-position: top;
    background-size: cover;
    background-repeat: no-repeat;
    position: relative;
}

.flow_ttl {
    width: 54%;
    padding: 10% 0 3%;
}

.flow_contents {
    width: 90%;
    padding-bottom: 10%;
}

@media screen and (min-width: 767px){
    #flow {
        background-image: url(../img/flow_bg_pc.jpg);
    }
    .flow_ttl {
        width: 46%;
        max-width: 420px;
        padding: 5% 0 3%;
    }

    .flow_contents {
        width: 96%;
        max-width: 1050px;
        margin: 0 auto;
        padding-bottom: 4%;
    }
}


/*よくあるご質問*/
#faq {
    background-image: url(../img/faq_bg.jpg);
    background-position: top;
    background-size: cover;
    background-repeat: no-repeat;
    position: relative;
}

.faq_ttl {
    width: 60%;
    padding: 10% 0 6%;
}

.faq_list {
    padding: 0 5% 6%;
}

.faq_item {
    padding-bottom: 5%;
}

.faq_q {
    width: 100%;
    padding: 3%;
    border: none;
    background: url("../img/q_bg.png") center / cover no-repeat;
    display: flex;
    align-items: center;
    position: relative;
    cursor: pointer;
    text-align: left;
}

.faq_q_icon {
    width: 12%;
    flex-shrink: 0;
    margin-right: 2%;
}

.faq_q_text {
    color: #fff;
    font-size: 16px;
    font-weight: 900;
    line-height: 1.3;
}

.faq_arrow {
    position: absolute;
    right: 5%;
    top: 50%;
    transform: translateY(-50%);
    color: #fff;
    font-size: 14px;
    font-weight: bold;
}

.faq_a {
    display: none;
    background: #fff;
    padding: 3%;
    display: none;
    align-items: center;
    text-align: left;
}

/* Aアイコン */
.faq_a_icon {
    width: 12%;
    flex-shrink: 0;
    margin-right: 2%;
}

.faq_a p {
    margin: 0;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.5;
    color: #333;
}

/* 開いた状態 */
.faq_item.is-open .faq_a {
    display: flex;
}

@media screen and (min-width: 767px){
    #faq {
        background-image: url(../img/faq_bg_pc.jpg);
    }
    .faq_ttl {
        width: 50%;
        max-width: 500px;
        padding: 5% 0 3%;
    }
    .faq_list {
        width: 80%;
        max-width: 700px;
        margin: 0 auto;
        padding: 0 0 4%;
    }
    .faq_q,
    .faq_a {
        padding: 2%;
    }

    .faq_q_icon,
    .faq_a_icon {
        width: 10%;
    }

    .faq_q_text{
        font-size: 26px;
    }

    .faq_a p{
        font-size: 24px;
    }
}


/*お問い合わせフォーム*/
#contact {
    background-image: url(../img/contact_bg.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    padding: 5% 5% 10%;
}

#contact form {
    background-color: #fff;
    text-align: left;
    padding: 5% 5% 3%;
}

.contact_ttl {
    width: 80%;
    padding: 5% 0;
}

.form_item {
    margin-bottom: 5%;
}

.form_item label {
    color: #000;
    font-weight: bold;
    font-size: 0.9rem;
}

.req {
    background: #e60012;
    color: #fff;
    padding: 1% 2%;
    font-size: 0.7rem;
    margin-left: 2%;
    border-radius: 3px;
}

.any {
    background: #999;
    color: #fff;
    padding: 1% 2%;
    font-size: 0.7rem;
    margin-left: 2%;
    border-radius: 3px;
}

/* ===== 入力欄 ===== */
input[type="text"],
input[type="tel"],
input[type="email"],
select,
textarea {
    width: 100%;
    padding: 3% 3%;
    margin-top: 2%;
    border: none;
    border-radius: 8px;
    background: #dcdcdc;
    font-size: 18px;
    color: #333;
}

/* textarea高さ（px固定） */
textarea {
    height: 120px;
}

/* placeholder */
input::placeholder,
textarea::placeholder {
    color: #9c9c9c;
}

/* ===== select矢印 ===== */
select {
    appearance: none;
    background: #dcdcdc url("data:image/svg+xml;utf8,<svg fill='%23666' height='20' viewBox='0 0 20 20' width='20' xmlns='http://www.w3.org/2000/svg'><polygon points='0,0 20,0 10,10'/></svg>") no-repeat right 3% center;
    background-size: 12px;
}

/* ===== フォーカス ===== */
input:focus,
textarea:focus {
    background-color: #dcdcdc;
    color: #000;
    outline: none;
}

/* ===== ボタン ===== */
.submit-btn {
    width: 100%;
    margin: 0 auto 5%;
    display: block;
    border: none;
    background: none;
}


@media screen and (min-width: 767px){
    #contact {
        padding: 5% 0;
    }
    .contact_ttl {
        width: 60%;
        max-width: 600px;
        padding: 0 0 2%;
        margin: 0 auto;
    }
    #contact form {
        width: 96%;
        max-width: 1000px;
        margin: 0 auto;
        padding: 3% 4% 1%;
    }
    .submit-btn {
        width: 50%;
        max-width: 600px;
    }
    .form_item label {
        font-size: 24px;
    }

    input[type="text"],
    input[type="tel"],
    input[type="email"],
    select,
    textarea,
    select option {
        padding: 1%;
        margin-top: 1%;
        border-radius: 8px;
        font-size: 20px;
    }

    .form_item {
        margin-bottom: 4%;
    }

    .req,
    .any {
        font-size: 18px;
        padding: 0 1%;
    }

    textarea {
        height: 180px;
    }

    .submit-btn {
        width: 100%;
        padding: 2% 0;
        max-width: 650px;
    }
}

/*フッター*/
.footer {
    background: #000;
    text-align: center;
    padding: 6% 4%;
    font-size: 0.5rem;
    color: #fff;
}

.footer_links {
    margin-bottom: 4%;
}

.footer_links a,
footer p {
    display: inline-block;
    color: #fff;
    text-decoration: none;
    margin: 0 3%;
}

@media screen and (min-width: 767px){
    .footer {
        font-size: 14px;
        padding: 3% 0;
    }
    .footer_links {
        margin-bottom: 1%;
    }
}

/*追従*/
.floating {
    position: fixed;
    bottom: 0;
    width: 100%;
    margin: 0 auto;
    padding: 4% 2% 2%;
    background-color: #5c5c5c93;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: opacity 0.3s ease, visibility 0.3s ease;
    z-index: 9999;
}

.floating.hidden {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }

  @media screen and (min-width: 767px){
    .floating{
        right: 0;
        bottom: 2%;
        background: none;
        width: 24%;
        padding: 0;
    }
  }

  /*サンクスページ*/
  /* 送信完了ページ（thanks.html） */
.thanks-body {
	background: linear-gradient(180deg, #f4f7f9 0%, #ffffff 45%);
	min-height: 100vh;
}

.thanks-body header{
    background-color: #000;
    width: 100%;
    text-align: center;
}

.thanks-body header img {
    width: 30%;
    padding: 2% 0;
}

.thanks-body .wrapper {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}
.thanks-main {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 4rem 1.6rem 5rem;
	box-sizing: border-box;
}
.thanks-inner {
	width: 100%;
	max-width: 56rem;
	margin: 0 auto;
	text-align: center;
	background: #fff;
	border-radius: 1.2rem;
	padding: 4rem 2.4rem;
	box-shadow: 0 0.4rem 2.4rem rgba(0, 0, 0, 0.06);
	box-sizing: border-box;
}
.thanks-label {
	font-size: 1.2rem;
	letter-spacing: 0.2em;
	color: #0f9721;
	font-weight: 700;
	margin: 0 0 1.2rem;
}
.thanks-title {
	font-size: 2.2rem;
	font-weight: 700;
	line-height: 1.45;
	margin: 0 0 2rem;
	color: #111;
}
.thanks-lead {
	font-size: 20px;
	line-height: 1.75;
	margin: 0 0 2.4rem;
	color: #333;
}
.thanks-note {
	font-size: 1.3rem;
	line-height: 1.65;
	margin: 0;
	color: #666;
	text-align: left;
}
.thanks-body .footer {
	margin-top: auto;
}
@media only screen and (max-width: 768px) {
	.thanks-inner {
		padding: 3rem 1.6rem;
		border-radius: 0.8rem;
	}
	.thanks-title {
		font-size: 1.8rem;
	}
	.thanks-lead {
		font-size: 18px;
		text-align: left;
	}
	.thanks-note {
		font-size: 1.2rem;
	}
}

/*レスポンシブ*/
.pc {
    display: none;
}

@media screen and (min-width: 767px){
    .sp {
        display: none!important;
    }
    .pc {
        display: block;
    }
}

/* ─── フォームバリデーション ─── */
.form .form_item {
    position: relative;
}
.form .form-error {
    display: none;
    margin-top: 6px;
    color: #d60000;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.4;
}
.form .form_item input.is-invalid,
.form .form_item select.is-invalid,
.form .form_item textarea.is-invalid {
    background: #fff0f0;
    box-shadow: inset 0 0 0 2px #d60000;
}
.form .submit-btn:disabled,
.form .submit-btn.is-disabled {
    opacity: 0.45;
    cursor: not-allowed;
}