@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@500;600;700&family=Noto+Sans+JP:wght@400;500;700;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500;700;900&display=swap');


html {
    font-size: 62.5%;
     overflow-x: hidden;
}


body {
    font-size: 1.6rem;
    line-height: 2;
  font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
    color: #2c2c2c;
}


p {
    font-size: 20px;
    letter-spacing: 0.15em
}

.body-wrapper {
    position: relative;
    overflow-x: hidden;
}

.pb2em {
    padding-bottom: 2em;
}

.mt10 {
    margin-top: 10px;
}

.mt20 {
    margin-top: 20px;
}

.mt30 {
    margin-top: 30px;
}

.mb20 {
    margin-bottom: 20px;
}

.red {
    color: #FC0047;
}

.yel {
    color: #FFD200;
}

.bold {
    font-weight: bold;
    background:linear-gradient(transparent 70%, #FFD200 0%);
}

.bold-n {
    font-weight: bold;
}

.sec-wrap {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
  }

  .sec-wrap img{
    width: 100%;
  }

.sec-wrap2 {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
    background: white;
}

.yokohaba {
    max-width: 640px;
    margin: -1px auto;
}

figure {
    line-height: 0;
}


.w94 {
    width: 94%;
    margin: 0 auto;
}

.w90 {
    width: 94%;
    margin: 0 auto;
}



.sank {
    background: white;
    font-size: 16px !important;
}
.sank-img {
    width: 30%;
}

/*レスポンシブ
.sp,
.tb {
    display: none;
}
*/

@media screen and (max-width: 768px) {
    .tb {
        display: block;
    }
    .pc {
        display: none;
    }

    p {
        font-size: 16px;
    }
}

@media screen and (max-width: 480px) {
    .sp {
        display: block;
    }
    .sp-hide {
        display: none;
    }
}

.container {
    width: 94%;
    max-width: 800px;
    margin: 0 auto;
}

.d-block {
    display: block !important;
}

.d-flex {
    display: flex !important;
}

.flex-wrap {
    flex-wrap: wrap !important;
}

.flex-row-reverse {
    flex-direction: row-reverse;
}

.justify-content-center {
    justify-content: center !important;
}

.justify-content-between {
    justify-content: space-between !important;
}

.justify-content-end {
    justify-content: flex-end !important;
}

.align-items-center {
    align-items: center !important;
}

.align-items-start {
    align-items: flex-start !important;
}

.align-items-end {
    align-items: flex-end !important;
}

.text-left {
    text-align: left !important;
}

.text-center {
    text-align: center !important;
}

.text-right {
    text-align: right !important;
}

.position-relative {
    position: relative !important;
}

.flex-1 {
    flex: 1;
}

.en {
    font-family: "ヒラギノ角ゴ ProN W3", HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;;
}

.font-weight-bold {
    font-weight: 700 !important;
}

.font-weight-black {
    font-weight: 900 !important;
}

.letter30 {
    letter-spacing: .03em;
}

.f-18 {
    font-size: 1.8rem !important;
}

.f-20 {
    font-size: 2rem !important;
}

.f-22 {
    font-size: 2.2rem !important;
}

.f-28 {
    font-size: 2.8rem !important;
}

.f-30 {
    font-size: 3rem !important;
}

.f-33 {
    font-size: 3.3rem !important;
}

.f-35 {
    font-size: 3.5rem !important;
}

.f-40 {
    font-size: 4rem !important;
}

@media screen and (max-width: 768px) {
    body {
        font-size: 1.4rem !important;
    }
    .f-18 {
        font-size: 1.6rem !important;
    }
    .f-20 {
        font-size: 1.7rem !important;
    }
    .f-22 {
        font-size: 1.8rem !important;
    }
    .f-28 {
        font-size: 2.1rem !important;
    }
    .f-30 {
        font-size: 2.2rem !important;
    }
    .f-33 {
        font-size: 2.3rem !important;
    }
    .f-35 {
        font-size: 2.4rem !important;
    }
    .f-40 {
        font-size: 2.6rem !important;
    }
}

@media screen and (max-width: 480px) {
    .f-14 {
        font-size: 1.2rem !important;
    }
    body {
        font-size: 1.3rem !important;
    }
    .f-18 {
        font-size: 1.4rem !important;
    }
    .f-20 {
        font-size: 1.5rem !important;
    }
    .f-22 {
        font-size: 1.6rem !important;
    }
    .f-28 {
        font-size: 1.9rem !important;
    }
    .f-30 {
        font-size: 2rem !important;
    }
    .f-33 {
        font-size: 2.1rem !important;
    }
    .f-35 {
        font-size: 2.2rem !important;
    }
    .f-40 {
        font-size: 2.4rem !important;
    }
}

.col-white {
    color: #fff !important;
}

.col-yel {
    color: #FFD200 !important;
}

.bg-white {
    background: #fff !important;
}


/********************************************************
************************ Header *************************
********************************************************/



header {
    padding: 15px 5px 10px 5px;
    display: flex;
    max-width: 640px;
    margin: 0 auto;
}

.hea1 {
    margin-right: 550px;
}


.pc-h {
    display: block;
}


.sp-h {
    display: none;
}



.w_100 {
    width: 100%;
}





@media screen and (max-width: 768px) {
    .pc-h {
        display: none;
    }


    .sp-h {
        display: block;
    }

    .hea1 {
        margin-right: 50px;
    }

    .mozi img {
        width: 95%;
    }

    .sp-w {
        width: 95%;
        margin: 0 auto;
    }
}



/********************************************************
************************ ボタンエリア *************************
********************************************************/


.btn-ue {
    padding-bottom: 1em;
}


.btn a:hover img{
    opacity: 0.7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
  }

.btn-flex {
    display: flex;
    margin-bottom: 1em;
}


.btn-eria {
    padding-bottom: 3em;
    background-color: #212b65;
}

.btn-box {
    width: 94%;
    margin: 0 auto;
}

.btn {
    margin: 0 auto;
}

.btnp {
    text-align: center;
}

.bla {
    color: white;
    font-weight: normal;
}

.btnue {
    margin-bottom: 1em;
    text-align: center;
}

.tokuten {
    background-color: #212B65;
}

.btn2{
    width: 75%;
    margin-left: 2em;
}

.btn-sp {
    padding-top: 5px;
}

 .btnsp {
    width: 100%;
    margin: 0 auto;
    padding: 1em 2px 0 2px;
 }

 .btn-p{
    color: white;
    text-align: center;
    padding: 1em 0;
 }


 .font-btn{
    font-size: 12px !important;
 }


 .font-btn2{
    font-size: 15px !important;
 }

 .tap-haikei {
    background: #0c78b7;
    border-radius: 10px;
 }



/*******************ふわふわするボタン*******************/
.fuwafuwa{
    margin: auto;
    display: block;
    animation-name: fuwafuwa;
    animation-duration: 2s;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
  }

  @keyframes fuwafuwa {
    0%{
      transform: translateY(0);/*Yは縦軸を表す*/
    }

    50%{
      transform: translateY(-15px);/*15px分動く*/
    }

    100%{
      transform: translateY(0);
    }

  }
  /*ふわふわするボタン*/




/*******************ボタンエリア下*******************/
.sokuzitutaiou {
    background: #0c78b7;
    padding: 2em 0;
}

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

    .btn-sita {
        width: 95%;
        margin: 0 auto;
    }
}


/*******************悩み*******************/

.nayami-haikei {
        /* 方眼紙模様に必須のスタイル */
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px)),
  linear-gradient(90deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px));
background-size: 16px 16px;
background-repeat: repeat;
background-position: center center;
}






/*******************解決/理由*******************/




/*******************理由*******************/

.riyuu {
background: #212b65;
}

.ri-haikei {
            /* 方眼紙模様に必須のスタイル */
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px)),
  linear-gradient(90deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px));
background-size: 16px 16px;
background-repeat: repeat;
background-position: center center;
padding: 3em 0;
}
.iryu {
    padding: 2em 1em;
    background: #fffde6;
    border: 3px #212b65 solid;
    margin-top: 2em;
}


.pp {
    padding: 1em;
    font-size: 15px !important;
}



/*******************求人*******************/

.kyu-box {
    margin-bottom: 2em;
}

/* 求人カード内の「勤務地/時給/月収例」だけ詰めて読みやすくする */
.kyu-card .kyu-meta__row{
  margin: 6px 0;           /* 10px→6px */
  row-gap: 4px;
}

.kyu-card .kyu-meta__label{
  height: 28px;            /* 30px→28px（少しだけ） */
}

.kyu-card .kyu-meta__value{
  line-height: 1.35;       /* bodyのline-height:2 の影響を切る */
  margin: 0;
}

/* 月収例が2行のときの行間をさらに詰めたい場合 */
.kyu-card .kyu-meta__value br{
  content: "";
}



/* mirai内：カード */
.mirai{
  padding: 3em 0;
}

.kyu-card{
  width: min(640px, 94%);
  margin: 0 auto;
  background: #fff;
  border: 3px solid #1e2b63;   /* 濃紺の枠 */
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 0 rgba(0,0,0,.03);
}

.kyu-card__img{
  background: #fff;
}
.kyu-card__img img{
  display:block;
  width:100%;
  height:auto;
}

.kyu-card__body{
  padding: 18px 16px 20px;
}

.kyu-card__title{
  margin: 6px 0 16px;
  text-align: center;
  font-weight: 900;
  letter-spacing: .08em;
  font-size: clamp(22px, 5.5vw, 34px);
  color: #ff6a00; /* オレンジ */
}

/* 3行メタ情報 */
.kyu-meta{
  margin: 0 0 14px;
}
.kyu-meta__row{
  display: grid;
  grid-template-columns: 84px 1fr;
  align-items: center;
  column-gap: 12px;
  margin: 10px 0;
}
.kyu-meta__label{
  display: inline-flex;
  align-items:center;
  justify-content:center;
  height: 30px;
  border-radius: 999px;
  background: #1e2b63;
  color: #fff;
  font-weight: 800;
  font-size: 14px;
  letter-spacing: .1em;
}
.kyu-meta__value{
  margin: 0;
  font-weight: 800;
  color: #1e2b63;
  font-size: 20px;
  letter-spacing: .04em;
}

/* 補足ボックス */
.kyu-notes{
  display: grid;
  gap: 14px;
  margin-top: 8px;
}
.kyu-note{
  border: 2px solid #1e2b63;
  border-radius: 10px;
  padding: 10px 12px;
}
.kyu-note__head{
  font-weight: 900;
  color:#1e2b63;
  margin-bottom: 6px;
}
.kyu-note__text{
  color:#1e2b63;
  font-weight: 700;
  line-height: 1.6;
}

/* 特典 */
.kyu-benefit{
  display: flex;
  gap: 10px;
  align-items: center;
  margin-top: 18px;
}
.kyu-benefit__tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 6px 14px;
  border-radius: 10px;
  background: #ff6a00;
  color: #fff;
  font-weight: 900;
  letter-spacing: .1em;
}
.kyu-benefit__text{
  flex: 1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 8px 14px;
  border-radius: 10px;
  background: #ff6a00;
  color: #fff;
  font-weight: 900;
  letter-spacing: .06em;
  font-size: 18px;
}

/* 特典エリアを“ボタン”に見せない（小さめ・帯） */
.kyu-benefit{
  justify-content: flex-start !important; /* 左寄せ */
  gap: 10px;
  margin-top: 14px;
}

.kyu-benefit__tag{
  padding: 6px 12px;
  border-radius: 10px;
  font-size: 14px;
  line-height: 1;
}

.kyu-benefit__text{
  flex: 0 0 auto;          /* 横いっぱいに伸ばさない */
  width: auto;
  padding: 8px 18px;       /* 高さ/横幅を縮める */
  border-radius: 12px;
  font-size: 16px;         /* 18px→16px */
  line-height: 1.2;
  letter-spacing: .04em;
}





.kyu-cta{
  margin-top: 14px;
}

.kyu-cta__btn{
  display: block;
  width: 100%;
  text-align: center;
  padding: 12px 14px;
  border-radius: 12px;
  font-weight: 900;
  letter-spacing: .06em;
  background: #212b65;   /* 紺 */
  color: #fff;
  border: none;
  cursor: pointer;
  text-decoration: none; /* a用 */
}

.kyu-cta__btn:active{
  transform: translateY(1px);
}



/*******************未来*******************/

.mirai{
    padding: 3em 0;
}








/*******************特典*******************/

.toku {
    padding: 1em 0 0.5em 0;
}

.toku-p {
    text-align: right;
    padding: 1em 0 2em 0;
}
.toku-p  p{

    font-size: 10px !important;
}



/*******************他社比較*******************/

.hikaku-g {
padding: 2em 0;

}



.tasya{
    padding: 3em 0;
}



/* =========================
   他社比較（添付っぽい見た目 + 横スクロール）
   ========================= */



.cmp-section{
  margin: 0 auto;
    padding: 0em 0 3em 0;
}

/* 横スクロール領域（スマホ向け） */
.cmp-scroll{
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding: 0;                 /* 余白は不要なら0 */
}

/* iOSで“横スクロールできる”ことを示したい場合は影も可（任意）
.cmp-scroll{
  mask-image: linear-gradient(to right, transparent, #000 24px, #000 calc(100% - 24px), transparent);
}
*/

/* 表本体：縮まない幅を持たせる（ここが横スクロールの肝） */
.cmp-table{
  display: grid;
  grid-template-columns: 100px 260px 230px 230px;
  min-width: 820px; /* 合計に合わせて調整（必須ではないけど推奨） */
  background: #fff;
}

/* セル共通 */
.cmp-cell{
  border: 1px solid #cfcfcf;
  padding: 26px 14px;        /* 添付みたいに縦が大きめ */
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;

  font-size: 20px;
  font-weight: 800;
  line-height: 1.25;
  letter-spacing: .06em;
  box-sizing: border-box;
}

/* ヘッダー行 */
.cmp-head{
  color: #fff;
  padding: 22px 12px;
}
.cmp-head--blank{
  background: #6a6a6a; /* 左上（濃グレー） */
}
.cmp-head--ts{
  background: #ff6a00; /* オレンジ */
}
.cmp-head--other{
  background: #212b65; /* 紺 */
}

/* 左の項目列 */
.cmp-rowhead{
  background: #6a6a6a;
  color: #fff;
font-size: 15px;   /* 左列だけ少し小さく */
  letter-spacing: .04em;
  padding: 26px 8px; /* 横paddingも少し削る */
}

/* テクノ列（薄オレンジ + 文字オレンジ） */
.cmp-ts{
  background: #ffe3d5;
  color: #ff6a00;
}

/* 他社列 */
.cmp-other{
  background: #fff;
  color: #2c2c2c;
}

/* 罫線の見た目を“添付のしっかり感”に寄せる（任意で濃く） */
.cmp-cell{
  border-color: #c9c9c9;
}

/* スマホで文字を少しだけ調整 */
@media (max-width: 480px){
  .cmp-cell{
    font-size: 18px;
    padding: 22px 12px;
  }
  /* 左の項目列 */
.cmp-rowhead{
  background: #6a6a6a;
  color: #fff;
font-size: 15px;   /* 左列だけ少し小さく */
  letter-spacing: .04em;
  padding: 26px 8px; /* 横paddingも少し削る */
}


  /* 横スクロール開始時に“次の列”が見えるように列幅を縮める */
  .cmp-table{
    grid-template-columns: 88px 200px 200px 200px; /* ←ここ調整ポイント */
    min-width: 688px; /* 合計に合わせる（88+200*3=688） */
  }

  .cmp-cell{
    font-size: 16px;
    padding: 18px 10px;
  }

  .cmp-rowhead{
    font-size: 13px;
    padding: 18px 8px;
  }



}




/* ===== 比較表：スクロールヒント（完成版） ===== */
.cmp-hint{
  display: flex;
  align-items: center;
  justify-content: center; /* ← 追加：全体を中央寄せ */
  gap: 10px;

  width: 100%;
  box-sizing: border-box;

  padding: 5px 16px;
  margin: 0px 0 12px;

  border-radius: 999px;
  background: #212b65;
  color: #fff;

  font-size: 16px;
  font-weight: 800;
  letter-spacing: .06em;

  /* ふわっと */
  transition: opacity .25s ease, transform .25s ease;
}


/* 消える状態 */
.cmp-hint.is-hide{
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
}

/* アイコン：←→（CSSだけ） */
.cmp-hint__icon{
  width: 22px;
  height: 22px;
  flex: 0 0 22px;
  position: relative;
}

/* 簡易「左右矢印」 */
.cmp-hint__icon::before{
  content: "⇆";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 18px;
  line-height: 1;
  color: #fff;
  opacity: .95;
}

/* 文字：少しだけ動く（うるさければ消してOK） */
@keyframes cmpHintNudge {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(8px); }
}
.cmp-hint__text{
  display: inline-block;
  animation: cmpHintNudge 1.2s ease-in-out infinite;
    font-size: 12px;
}


/* 左の項目列を横スクロールでも固定 */
.cmp-scroll{ position: relative; } /* 念のため */

.cmp-rowhead{
  position: sticky;
  left: 0;
  z-index: 5;              /* 他セルの上に出す */
}

/* 左上の空セルも固定（ヘッダー行の左端） */
.cmp-head--blank{
  position: sticky;
  left: 0;
  z-index: 6;              /* rowheadより上 */
}


.kyu-meta__row{ align-items: flex-start; }



.pad-hikaku {
    padding: 2em 0;
}


/******************声*******************/





/* =========================
   お客様の声（koe）
========================= */

.koe-syousi {
    margin-bottom: -3em;
}

.ko-ue {
    margin-bottom: 5em;
}

.ko-ue2 {
    margin-bottom: 2em;
}


.koe{
  padding: 3em 0;
}

/* 枠（添付の金枠っぽく） */
.koe-card{
  width: min(640px, 90%);
  margin: 0 auto;
  background: #fff;
  border: 2px solid #caa75d;
  overflow: visible; /* 人物写真をはみ出させる */
}

/* 上段（青い帯 + 写真を重ねる） */
.koe-top{
  position: relative;
  overflow: visible;
}

/* 青い帯：ピタッと幅100% */
.koe-top__bg{
  display: block;
  width: 100%;
  height: auto;
}

/* 人物写真：左上に少しズラして重ねる */
.koe-top__photo{
  position: absolute;
    left: -22px;
    top: -54px;   /* ←縦のズレ（好みで調整） */
  width: 42%;    /* ←写真の大きさ（好みで 38〜48%） */
  height: auto;
}

/* 下段テキスト */
.koe-body{
  padding: 22px 18px 26px;
}

/* 見出し */
.koe-title{
  margin: 0 0 14px;
  font-weight: 900;
  color: #1e2b63;
  letter-spacing: .06em;
  line-height: 1.35;
  font-size: clamp(24px, 5.8vw, 40px);
}

.koe-accent{
  color: #ff6a00;
}

/* 本文 */
.koe-text{
  margin: 0;
  color: #2c2c2c;
  line-height: 1.9;
  font-size: 18px;
}

/* 黄色マーカー */
.koe-mark{
  font-weight: 900;
  background: linear-gradient(transparent 55%, #ffe95a 0);
  padding: 0 .15em;
}

/* スマホ微調整（必要なら） */
@media (max-width: 480px){
  .koe-top__photo{
        left: -22px;
        top: -50px;
        width: 45%;
  }
  .koe-body{
    padding: 18px 14px 22px;
  }
  .koe-text{
    font-size: 16px;
  }
}




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

.qa {
    padding: 3em 0 1em 0;
}

.situ {
    padding: 3em 0;
}

.qe {
    letter-spacing: 0.15em;
    font-size:15px;
}



.situ-gazou{
    width: 80%;
    margin: 0 auto;
    padding: 3em 0;;
}


.que-box{
    margin: 0 auto;
    width: 94%;
    padding-bottom: 3em;
    padding-top: 2em;
}


.qa-007 {
    margin-bottom: 20px;
    border: 1px #212b65 solid;
    box-shadow: 0 4px 4px rgb(0 0 0 / 2%), 0 2px 3px -2px rgba(0 0 0 / 5%);
    background-color: #fff;
    font-size: 16px;
}

.qa-007 summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    padding: 1em 2em 1em 3em;
    color: white;
    font-weight: 600;
    cursor: pointer;
    background: #212b65;
}

.qa-007 summary::before,
.qa-007 p::before {
    position: absolute;
    left: 1em;
    font-weight: 600;
    font-size: 16px;
}

/* まず Q の見た目（共通） */
.qa-007 summary::before{
  color: #fff;
  /* content はここでは書かない（下で番号を入れる） */
}

/* Q1〜Q9（必要な数だけ増やす） */
.que-box .qa-007:nth-of-type(1) summary::before{ content: "Q1"; }
.que-box .qa-007:nth-of-type(2) summary::before{ content: "Q2"; }
.que-box .qa-007:nth-of-type(3) summary::before{ content: "Q3"; }
.que-box .qa-007:nth-of-type(4) summary::before{ content: "Q4"; }
.que-box .qa-007:nth-of-type(5) summary::before{ content: "Q5"; }
.que-box .qa-007:nth-of-type(6) summary::before{ content: "Q6"; }
.que-box .qa-007:nth-of-type(7) summary::before{ content: "Q7"; }
.que-box .qa-007:nth-of-type(8) summary::before{ content: "Q8"; }
.que-box .qa-007:nth-of-type(9) summary::before{ content: "Q9"; }


.qa-007 summary::after {
    transform: translateY(-25%) rotate(45deg);
    width: 7px;
    height: 7px;
    margin-left: 10px;
    border-bottom: 3px solid white;
    border-right: 3px solid white;
    content: '';
    transition: transform .5s;
}

.qa-007[open] summary::after {
    transform: rotate(225deg);
}

.qa-007 p {
    position: relative;
    transform: translateY(-10px);
    opacity: 0;
    margin: 0;
    padding: 1.3em 3em 1.5em;
    color: #2f2f2f;
    transition: transform .5s, opacity .5s;
}

.qa-007[open] p {
    transform: none;
    opacity: 1;
    color: #2f2f2f;
}

.qa-007 p::before {
    color: #ff5a00;
    line-height: 1.2;
    content: "A";
}

.q-tit {
    width: 40%;
    background: #212b65;
    padding: 0.2em 1em;
    margin: 1em 0;
    text-align: center;
}

.q-tit p {
    color: white;
    font-size: 18px;
}

@media screen and (max-width: 768px) {
    .q-tit p {
        font-size: 16px;
    }
}


/***************** 最後に ******************/


.saigoni {
        /* 方眼紙模様に必須のスタイル */
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px)),
  linear-gradient(90deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px));
background-size: 16px 16px;
background-repeat: repeat;
background-position: center center;
padding-bottom: 3em;

}

.sai-haikei {
    background: #f9faf5;
    padding: 3em 0 3em 0;
}

.p-box-cyousei2 {
    margin: 0 auto;
}

.k-cyou {
    margin: 0 auto;
}


.saigoni3 {
    padding: 2em 0;
}

.saigo-box {
    margin-bottom: 1.5em;
}

.sa-cyou {
    width: 94%;
    margin: 0 auto;
}




/***************** ステップ ******************/





.step-gazou {
    padding: 2em 1em;
    background: white;
    border: 3px #212b65 solid;
    margin-top: 2em;

}



.stp-haikei {
            /* 方眼紙模様に必須のスタイル */
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px)),
  linear-gradient(90deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px));
background-size: 16px 16px;
background-repeat: repeat;
background-position: center center;
padding: 2em 0;
}




.pp {
    padding: 1em;
    font-size: 15px !important;
}

.oren {
    color: #ff5a00;
    font-weight: bold;
}

/***************** 求人 ******************/

.kyu-haikei {
    background: #f2f2f5;
    padding-bottom: 5em;
}

.kyuzin-lp {
    background: #212b65;
}

.kyu-jin {
    padding: 2em 0 1em 0;
}



.kyu-jin2 {
    padding: 6em 0 2em 0;
}



.kyu-a {
    padding: 2em 0em 3em 0;
}




/* ===== 求人詳細モーダル（完成版・整理済み） ===== */
.jobModal{
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: none;
}
.jobModal.is-open{ display:block; }

.jobModal__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.65);
}

/* モーダル箱（ヘッダー/本文/フッターの3段） */
.jobModal__panel{
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(94vw, 680px);
  max-height: 90vh;

  transform: translate(-50%, -46%);
  opacity: 0;
  transition: transform .22s ease, opacity .22s ease;

  background: #fff;
  border-radius: 16px;
  box-shadow: 0 24px 70px rgba(0,0,0,.35);
  overflow: hidden;

  display: flex;
  flex-direction: column;
}
.jobModal.is-open .jobModal__panel{
  opacity: 1;
  transform: translate(-50%, -50%);
}

/* ×ボタン */
.jobModal__close{
  position: absolute;
  right: 10px;
  top: 10px;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 999px;
  background: rgba(255,255,255,.18);
  color: #fff;
  font-size: 24px;
  line-height: 40px;
  cursor: pointer;
}

/* ===== ヘッダー（左ラベル＋タイトル＋タグ） ===== */
.jobModal__head{
  position: relative;
  padding: 18px 56px 14px 16px; /* ×の分だけ右に余白 */
  background: #212b65;
  color: #fff;

  display: grid;
  grid-template-columns: 92px 1fr; /* 左ラベル / 右タイトル */
  grid-template-rows: auto auto;   /* 1段目：タイトル / 2段目：タグ */
  column-gap: 16px;
  row-gap: 12px;
  align-items: start;
}

/* 左の白ラベル（求人詳細） */
.jobModal__eyebrow{
  grid-column: 1;
  grid-row: 1;
  margin: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 44px;
  padding: 0 14px;
  background: #fff;
  color: #212b65;
  border-radius: 6px;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: .08em;
  white-space: nowrap;
}

/* タイトル（PC：大きめ。日本語の変な分割を防ぐ） */
.jobModal__title{
  grid-column: 2;
  grid-row: 1;
  margin: 0;
  font-size: 44px;
  font-weight: 900;
  letter-spacing: .06em;
  line-height: 1.05;

  word-break: keep-all;
  overflow-wrap: anywhere;
}

/* タグ：2列 */
.jobChips{
  grid-column: 2;
  grid-row: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  justify-items: stretch;
}

/* タグ（チップ） */
.jobChip{
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-height: 54px;
  padding: 10px 14px;
  border-radius: 999px;

  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;

  font-size: 18px;
  font-weight: 900;
  letter-spacing: .04em;
  text-align: center;
  white-space: nowrap;
}

.jobChip--accent{
  background: #ff6a00;
  border-color: #ff6a00;
}

/* ===== 本文（ここだけ縦スクロール） ===== */
.jobModal__body{
  padding: 14px 14px 18px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  background: #f7f8fb;

  /* ↓下の固定ボタン分の余白（見切れ防止 + iPhone safe area） */
  padding-bottom: calc(18px + 78px + env(safe-area-inset-bottom));
}

/* ===== 下ボタン固定 ===== */
.jobModal__footer{
  position: sticky;
  bottom: 0;
  background: #fff;
  padding: 12px 14px calc(12px + env(safe-area-inset-bottom));
  border-top: 1px solid #e6e6e6;
  z-index: 2;
}

/* ===== カード（本文の各ブロック） ===== */
.jobBlock{
  background: #fff;
  border-radius: 14px;
  padding: 14px 14px;
  box-shadow: 0 2px 10px rgba(0,0,0,.06);
  margin: 10px 0;
}

.jobBlock--highlight{
  border: 2px solid #ff6a00;
}

.jobBlock__title{
  margin: 0 0 10px;
  font-size: 16px;
  font-weight: 900;
  color: #212b65;
  letter-spacing: .06em;
}

/* 定義リスト */
.jobDl{ margin:0; }

.jobDl__row{
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 10px;
  padding: 10px 0;
  border-top: 1px solid #e6e6e6;
}
.jobDl__row:first-child{ border-top:none; }

.jobDl dt{
  color: #666;
  font-weight: 800;
  letter-spacing: .04em;
}
.jobDl dd{
  margin:0;
  color:#222;
  font-weight: 600;
  line-height: 1.6;
}

.jobEm{ color:#ff6a00; font-size: 18px; }

.jobList{
  margin: 0;
  padding-left: 1.2em;
}
.jobList li{
  padding: 4px 0;
  line-height: 1.6;
}

.jobNote{
  margin: 10px 0 0;
  font-size: 12px;
  color: #666;
  letter-spacing: .04em;
}

.jobBig{
  text-align:center;
  padding: 10px 0 2px;
}
.jobBig__label{
  margin:0;
  font-size: 12px;
  color:#666;
  letter-spacing: .12em;
}
.jobBig__value{
  margin: 4px 0 2px;
  font-size: 34px;
  font-weight: 900;
  color: #ff6a00;
  letter-spacing: .06em;
}
.jobBig__sub{
  margin:0;
  font-size: 12px;
  color:#666;
}

/* 下のボタン */
.jobActions{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.jobBtn{
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-height: 52px;
  padding: 12px 10px;
  border-radius: 12px;
  text-decoration: none;
  font-weight: 900;
  letter-spacing: .06em;
  white-space: nowrap; /* ボタン内文字は折り返し禁止 */
}

.jobBtn--primary{
  background: #ff6a00;
  color: #fff;
}

.jobBtn--ghost{
  background: #fff;
  color: #212b65;
  border: 2px solid #212b65;
}

/* ===== スマホ最適化（ここ1個だけ） ===== */
@media (max-width: 480px){

  .jobModal__head{
    padding: 14px 52px 12px 14px;
    grid-template-columns: 86px 1fr;
    column-gap: 12px;
    row-gap: 10px;
  }

  .jobModal__eyebrow{
    height: 36px;
    padding: 0 10px;
    font-size: 14px;
    border-radius: 6px;
  }

  /* タイトルは2行まで（見切れ防止＆コンパクト） */
  .jobModal__title{
    font-size: 28px;
    line-height: 1.08;
    white-space: normal;
    overflow: hidden;

    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }

  /* タグは2列のまま、横の隙間を詰めて幅を稼ぐ */
    .jobChip{
        min-height: 50px;
        padding: 10px 9px;
        font-size: 13px;
        line-height: 1.2;
        white-space: normal;
        text-align: center;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        overflow: hidden;
}

    .jobChips {
        grid-template-columns: 1fr 1fr;
        gap: 10px 9px;
        width: 17em;
        width: 17em;
}


}



.jobModal__body{ overscroll-behavior: contain; }


/* ===== 求人詳細モーダル：右上×を常に表示 ===== */
.jobModal__panel{
  position: relative; /* ×の基準 */
}

.jobModal__close{
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 10000;

  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 999px;

  background: rgba(255,255,255,.92);
  color: #212b65;
  font-size: 28px;
  line-height: 44px;
  text-align: center;
  cursor: pointer;

  /* スマホでのタップが気持ち悪くならないように */
  -webkit-tap-highlight-color: transparent;
}

/* ×の分だけヘッダー右側を空ける（被り防止） */
.jobModal__head{
  padding-right: 64px;
}


/* タイトルが長い時に×と被らないように、ヘッダー右側を確保 */
.jobModal__head{
  position: relative;
  padding-right: 84px; /* ←×の幅(44)+余白(10)+安全マージン */
}

/* タイトルは右端まで突っ込まないようにする */
.jobModal__title{
  margin-right: 0;
  padding-right: 0;
  overflow-wrap: anywhere; /* 長い文字でもはみ出さず折れる */
}

/* ×は右上に固定（すでにあるならそのままでもOK） */
.jobModal__close{
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 10000;
}


.jobModal__close{
  top: 10px;
  right: 10px;
  transform: translate(20%, -20%); /* 右上に逃がす */
}



/* ===== 求人詳細ボタン（画像だけ）を常時ぷかぷか：スマホ向け ===== */
.jobDetailOpen{
  display: inline-block;
  -webkit-tap-highlight-color: transparent;
      padding-top: 0.5em;
}

.jobDetailOpen > img{
  display: block;
  will-change: transform, filter;
  animation: jobBtnFloat 1.9s ease-in-out infinite;
}

/* 浮く量：-4px（強めにしたいなら -6px） */
@keyframes jobBtnFloat{
  0%,100% { transform: translateY(0) scale(1); filter: brightness(1); }
  50%     { transform: translateY(-4px) scale(1.03); filter: brightness(1.06); }
}


/* ===== 求人詳細ボタン：マイクロコピー（HTML変更なし） ===== */
.jobDetailOpen{
  position: relative;          /* ::before の基準 */
  display: inline-block;
}

/* 上に出す文言 */
.jobDetailOpen::before{
  content: "タップで求人詳細を開く";
  position: absolute;
  left: 50%;
  bottom: calc(100% + 6px);    /* ボタンの上に6px離す */
  transform: translateX(-50%);

  /* 見た目 */
  font-size: 11px;
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: .04em;
  color: #fff;
  background: rgba(0,0,0,.55);
  padding: 4px 8px;
  border-radius: 999px;
  white-space: nowrap;

  /* クリックを邪魔しない */
  pointer-events: none;
  z-index: 2;
}

/* ちょい吹き出しの三角（任意） */
.jobDetailOpen::after{
  content: "";
  position: absolute;
  left: 50%;
  bottom: calc(100% + 2px);
  transform: translateX(-50%);
  width: 0; height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 5px solid rgba(0,0,0,.55);
  pointer-events: none;
  z-index: 2;
}

/* スマホ用微調整 */
@media (max-width: 480px){
  .jobDetailOpen::before{
    font-size: 10px;
    padding: 4px 7px;
  }
}




/***************** 最後に ******************/

.saigoni {
    padding-bottom: 3em;
}

.saigo-b  {
width: 90%;
margin: 0 auto;

}


.saigo-b p {
    font-family: "Noto Serif JP", serif;
}


.sai-gao {
    padding: 2em 0;
}

/***************** お問い合わせ ******************/


.for-ga {
    padding-top: 2em;
}

.gender-box {
  display: flex;
  align-items: center;
  gap: 24px;
}

.gender-box label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 16px;
  cursor: pointer;
}

.gender-box input[type="radio"] {
  accent-color: #212b65;
}


 .fo-tit {
    width: 90%;
    margin: 0 auto;
 }

 .p-tekuno5 {
    color: white;
    font-size: 18px;
}

.s-color {
    width: 100%;
    height: 62px;
    padding: 0 15px;
    background: #EBECF0;
    border: none;
    box-sizing: border-box;
    font-size: 1.8rem;
    font-weight: 500;
    font-family: "ヒラギノ角ゴ ProN W3", HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;
    border-radius: 0;
}

.s-flex {
    display: flex;
    color: black;
}

.s-box1 {
    width: 50% !important;
    padding-left: 5px;
}

.s-box2 {
    width: 25% !important;
    padding-left: 5px;
}

.s-box3 {
    width: 25% !important;
    padding-left: 5px;
}

.tex {
    text-align:center;
    padding:20px 0;
}

.year {
    padding-left: 5px;
}

.adress {
    margin-top: 15px;
}



#contact {
    position: relative;
    /* 方眼紙模様に必須のスタイル */
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px)),
  linear-gradient(90deg, transparent calc(100% - 1px), #f0f0f0 calc(100% - 1px));
background-size: 16px 16px;
background-repeat: repeat;
background-position: center center;
}


#contact form {
    padding: 0 3%;
    background: #fff;
}

.contact_box dl {
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 15px 0;
}

.contact_box dl dt {
    position: relative;
    width: 55%;
    padding: 5px 0 0 85px;
}

.required,
.optioned {
    position: absolute;
    left: 0;
    top: 14px;
    width: 70px;
    text-align: center;
    font-size: 90%;
    color: #fff;
    background: #b81c23;
}

.optioned {
    background: #F7F4F4;
    color: #AFACAC;
}

.contact_box dl dd {
    flex: 1;
}

select,
input[type="text"],
input[type="tel"],
input[type="email"],
input[type="password"],
input[type="age"] {
    width: 100%;
    height: 62px;
    padding: 0 15px;
    background: #EBECF0;
    border: none;
    box-sizing: border-box;
    font-size: 1.8rem;
    font-weight: 500;
    font-family: "ヒラギノ角ゴ ProN W3", HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;;
    border-radius: 0;
}


.contact_box select.year {
    max-width: 150px;
    margin-right: 10px;
}

.contact_box select.month {
    max-width: 110px;
    margin-right: 10px;
}

.contact_box select.day {
    max-width: 110px;
    margin-right: 10px;
}

textarea {
    font-size: 16px !important;
    width: 100%;
    padding: 15px;
    background: #EBECF0;
    border: none;
    box-sizing: border-box;
    font-family: "ヒラギノ角ゴ ProN W3", HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif !important;

}

input[type="submit"] {
    display: block;
    width: 100%;
    max-width: 545px;
    height: 105px;
    margin: 0 auto;
    padding-right: 4%;
    text-align: center;
    font-size: 3.5rem;
    font-weight: 700;
    font-family: "ヒラギノ角ゴ ProN W3", HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;;
    letter-spacing: .05em;
    color: #fff;
    border: none;
    background:#212B65;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
}

input[type="submit"]::after {
    content: url(../img/icn_right.png);
    display: inline-block;
}

.privacy_cont {
    height: 260px;
    padding: 30px 4%;
    overflow-y: scroll;
    border: 1px solid #C9C8C8;
}

@media screen and (max-width: 768px) {
    .contact_box dl dt {
        padding-left: 75px;
    }
    .required,
    .optioned {
        width: 60px;
    }
}

@media screen and (max-width: 600px) {
    .contact_box dl {
        padding: 10px 0;
    }
    .contact_box dl dt {
        width: 100%;
    }
    .contact_box dl dd {
        width: 100% !important;
        margin-top: 10px;
    }
    input[type="submit"] {
        font-size: 2rem;
        height: 55px;
    }
}



/*プライバシーポリシー*/

.prb {
    font-size: 18px;
}






/*サンクスページ*/


/*文字動かす*/


.anim-box.slidein.is-animated {
    animation: slideIn 1s cubic-bezier(0.25, 1, 0.5, 1) 1 forwards;
  }

  @keyframes slideIn {
    0% {
      transform: translateX(180px);
      opacity: 0;
    }
    100% {
      transform: translateX(0);
    }
    40%,100% {
      opacity: 1;
    }
  }




/*文字動かす*/



.thanks-main {
    background-size: auto auto;
    background-color: rgba(249, 241, 212, 1);
}

.thanks-main_top {
    background:#212B65;
}


.tel-t {
    color: #0c78b7;
}

.cmn_btn a {
    position: relative;
    display: inline-block;
    width: 100%;
    max-width: 460px;
    text-align: center;
    padding: 15px;
    background: linear-gradient(to bottom, #FEE20E, #FBAC35);
    border: 2px solid #FEE20E;
    border-radius: 15px;
}


.thabox {
    width: 70%;
    margin: 0 auto;
}

.white {
    color: white;
}

.hazimemasita{
    color: #ff0000;
    display: inline;
    font-weight: bold;
}

.tokuten-sen  {
        border-bottom: solid 3px #32A709;
        position: relative;
        font-weight: bold;
        font-size: 20px;
}

.tokuten-sen:after {
    position: absolute;
    content: " ";
    display: block;
    border-bottom: solid 3px #ffc778;
    bottom: -3px;
    width: 30%;
  }

ol {
    background: #f3fbff;
    border: 2px skyblue dashed;
    padding-left: 2em;
    list-style: disc;
  }

  .kazyou {
    padding: 1em;
  }


.copyright-t {
    font-size: 1.3rem;
    padding: 1em 0;
}
@media screen and (max-width: 768px) {
    .thabox {
        width: 70%;
    }
}


/********************************************************
************************ Footer *************************
********************************************************/

.co {
    padding-top: 1em;
    font-size: 14px;
}


footer {
    color: #fff;
    background: #212B65;
}

.f-gaiyou {
    text-align: center;
    flex: 1;
}
.f-gaiyou1 {
    text-align: center;
    flex: 1;
}

.f-gaiyou p {
    font-size: 14px;
}
.f-gaiyou1 p {
    font-size: 14px;
}

.flex {
    display: flex;
    margin: 0 auto;
    padding-top: 1.5em;
}

.f-gaiyou2 {
    text-align: center;
    margin-top: 0.5em;
}
.f-gaiyou2 p {
    font-size: 14px;
}

.copyright {
    font-size: 1.3rem;
    padding: 0px 0 5px 0;
    margin-top: 0.8em;
}

.t-ft {
    padding: 0em 0 !important;
}

#topBtn {
    z-index: 90;
    position: fixed;
    right: 0;
    bottom: 15em;
    width: 65px;
    height: 65px;
    background: url(../img/pagetop.png) no-repeat center / 100% 100%;
    cursor: pointer;
    -webkit-transition: opacity .3s 0s, visibility 0s .3s;
    transition: opacity .3s 0s, visibility 0s .3s;
}

#topBtn2 {
    opacity: 80%;
    z-index: 90;
    position: fixed;
    right: 0;
    bottom: 20em;
    width: 65px;
    height: 65px;
    background: url(../img/s-btn.png) no-repeat center / 100% 100%;
    cursor: pointer;
    -webkit-transition: opacity .3s 0s, visibility 0s .3s;
    transition: opacity .3s 0s, visibility 0s .3s;
}

.float_btn {
    position: fixed;
    right: 0;
    top: 150px;
    width: 78px;
    text-align: center;
    z-index: 10;
}

.float_btn-ctn {
    display: block;
    padding: 20px 10px;
    background: linear-gradient(to bottom, #42C8CC, #129498);
    border: 2px solid #3DC2C6;
    border-right: none;
    border-radius: 10px 0 0 10px;
    line-height: 1.3;
}

.float_btn-ctn .pc {
    margin-top: 10px;
}

.float_btn-group {
    margin-top: 10px;
    padding: 0 5px;
    color: #242423;
    background: #FEE20E;
    border: 2px solid #fff;
    border-right: none;
    border-radius: 10px 0 0 10px;
}

.float_btn-group a {
    display: block;
    padding: 13px 0;
    font-weight: 700;
    line-height: 1.35;
}


.float_btn-group--tel {
    border-bottom: 2px solid #fff;
}



.float_btn-group--tel img {
    width: 24px;
}

.float_btn-group--line img {
    width: 36px;
}

@media screen and (max-width: 768px) {
    footer {
        padding-bottom: 5.5em;
        }
    .float_btn {
        display: flex;
        top: auto;
        right: 0;
        bottom: 0;
        width: 100%;
    }
    .float_btn-ctn {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        padding: 12px 0;
        background: #fee20e;

        border-left: none;
        border-bottom: none;
        border-radius: 0;
        line-height: 0;
    }
    .float_btn-ctn img {
        width: 34px;
    }
    .float_btn-group {
        display: flex;
        width: 67%;
        margin-top: 0;
        padding: 0;
        border: none;
        border-radius: 0;
    }
    .float_btn-group a {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 50%;

        border-bottom: none;
    }
    .float_btn-group a:last-of-type {
        border-right: none;
    }
    #topBtn {
        width: 50px;
        height: 50px;
        bottom: 90px;
    }

    #topBtn2 {
        width: 50px;
        height: 50px;
        bottom: 150px;
    }
}




/***************** 会社概要 ******************/

.company {
    background: #EBECF0;
}

.company-cont table {
    width: 100%;
}

.company-cont table tr th,
.company-cont table tr td {
    padding: 30px 5%;
    border: 1px solid #C9C8C8;
    vertical-align: middle;
}

.company-cont table tr th {
    width: 25%;
    padding: 27px 10px;
    background: #b81c23;
    color: #fff;
}

.company-cont table tr td {
    font-weight: 400;
    background: #fff;
}




/***************** 追尾ボタン ******************/

.f-flex {
    display: flex;

}


.fro-haikei{
    background-color: rgba(33, 43, 101, 0.7);
    padding: 5px 0px;
}

.f-1 {
    margin-right: 5px;
}
.f-2 {
    margin-right: 5px;
}


.floating-banner {
    position: fixed;/* 追従 */
    z-index: 99999;/* 他の要素の下に隠れないように */
    bottom: 0;/* バナーの上下の位置 */
    right: 0;/* バナーの左右の位置 */
  }
  .pc {
    width: 345px;/* バナーの横幅を指定 */
  }
  .floating-banner:hover {
    opacity: .9;/* ホバーで少し透過 */
  }
  .sp {
    display: none;/* PCではスマホ用のバナーは非表示に */
  }
  @media screen and (max-width: 990px) {/* タブレット用のブレイクポイントを指定 */
    .pc {
        display: none;/* タブレットサイズ以下でPC用のバナーを非表示に */
    }
  }
  @media screen and (max-width: 560px) {/* スマホ用のブレイクポイントを指定 */
    .sp {
        display: inline-block;/* 消していたスマホ用のバナーを表示させる */
        width: 100vw;/* スマホの画面幅いっぱいにバナーを表示 */
    }
  }


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

    .fro-haikei {
        background-color: transparent;
        padding: 5px 0px;

}
    .f-flex {
         flex-wrap: wrap;
         justify-content:flex-end;
    }

    .f-1 {
    margin-bottom: 10px;
    margin-right: 0px;
}
}






/* FAQボタンの見た目 */
.faq-card {
  position: relative;
  background: #fff;
  border-radius: 40px;
  padding: 10px 20px 10px 15px;
  cursor: pointer;
  transition: all .2s;
  box-shadow: 0 3px 0 #000;
  margin-bottom: 14px;
}
.faq-card:hover {
  background: #f9f9f9;
  transform: translateY(1px);
  box-shadow: 0 2px 0 #000;
}

.faq-label {
  color: #4bbdff;   /* Q1の色（青系） */
  font-size: 15px;
  font-weight: bold;
  margin-right: 6px;
}

.faq-title {
  font-size: 16px;
  color: #111;
  font-weight: 600;
}

/* Q1 とタイトルを1行に並べたい場合 */
.faq-card .faq-label,
.faq-card .faq-title {
  display: inline-block;
  vertical-align: middle;
}

/* 右矢印 */
.faq-arrow {
  position: absolute;
  right: 7px;
  top: 50%;
  transform: translateY(-50%);
  color: #4bbdff;
  font-size: 15px;
  font-weight: bold;
}

/* モーダル全体 */
#faqModal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(0,0,0,.7);
  justify-content: center;
  align-items: center;
}

/* モーダル中身 */
#faqModal .modal-content {
  position: relative;
  background: #fff;
  width: 80%;
  max-width: 420px;
  border-radius: 8px;
  padding: 24px 20px 28px;
  box-shadow: 0 4px 10px rgba(0,0,0,.4);
}

#faqModal h3 {
  text-align: center;
  font-size: 17px;
  font-weight: 800;
  margin-bottom: 14px;
  color: #222;
}

/* 閉じるボタン */
.faq-close {
  position: absolute;
  top: -35px;
  right: 20px;
  font-size: 26px;
  font-weight: bold;
  cursor: pointer;
  color: #000;
  border: 2px solid #ccc;
  border-radius: 50%;
  width: 30px;
  height: 30px;
  line-height: 22px;
  text-align: center;
  background: #fff;
}
.faq-close:hover { background:#eee; }

/* Aの帯 */
.faq-block {
  background:#ff7070;
  font-weight: bold;
  padding: 10px 12px;
  border-radius: 4px;
  margin-bottom: 10px;
  font-size: 15px;
  color: white;
}

/* 回答文リスト */
.faq-list {
  list-style: none;
  padding-left: 0;
  margin: 10px 0 0;
  font-size: 16px;
  line-height: 1.7;
}
.faq-list li {
  position: relative;
  padding-left: 18px;
  line-height: 1.6;
}
.faq-list li::before {
  content: "•";
  color: #ff7070;
  position: absolute;
  left: 0;
}
