@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');
html {
    font-size: 62.5%;
     overflow-x: hidden;
}


body {
    font-size: 1.6rem;
    line-height: 2;
    font-family: "Noto Serif JP", 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 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: 3em 0;
    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;
padding-bottom: 3em;
}

.nayami {
    margin-bottom: 2em;
}

/* 枠全体（画像＋箇条書き）を囲う */
.nayami-box{
  width: min(940px, 94%);
  margin: 0 auto;
  background: #fff;
  border: 1px solid #212b65;
  padding: 56px 56px 48px;
  box-sizing: border-box;
}

/* 画像は枠の中で中央配置。ここにborderは付けない */
.nayami-g{
  border: 0;              /* ←重要：今付けてる枠線は消す */
  padding: 0;             /* 余白は .nayami-box 側で取る */
  background: transparent;
  display: flex;
  justify-content: center;
  margin: 10px 0 36px;
}

.nayami-g img{
  width: min(680px, 100%);
  height: auto;
  display: block;
}

/* 箇条書きの見た目（添付に寄せる） */
.ul-n{
  color: #212b65;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
}

.ul-n ul{
  list-style: disc;
  margin: 0;
  padding-left: 1.2em;
  font-size: 28px;
  line-height: 1.9;
}

.ul-n li{
  margin: 14px 0;
}

/* スマホ調整 */
@media (max-width: 480px){
  .nayami-box{
    padding: 28px 18px 22px;
  }
  .ul-n ul{
    font-size: 16px;
    line-height: 1.85;
  }
  .nayami-g{
    margin: 6px 0 18px;
  }
}





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

.kaiketu-haikei{
    background: #212b65;
    padding-bottom: 4em;
}


.kaiketu-box{
    background: white;
    padding: 2em 2em 3em 2em;
    margin-top: 3em;
}

.p-tekuno{
    color: #212b65;
    font-size: 16px;
}

.kaiketu {
    padding: 0em 0;
    margin: 0 auto;
}

.kaiketu-syu {
    /* 方眼紙模様に必須のスタイル */
  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;
}



/*******************仕事*******************/

.work{
        /* 方眼紙模様に必須のスタイル */
  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;
}


.work1 {
    padding-top: 4em;
    margin-bottom: 1em;
}

.p-w {
    width: 85%;
    margin: 0 auto;
}


.work-box2 {
    margin-top: 4em;
    padding-bottom: 2em;
}



/*******************サポート*******************/



.pad {
    padding: 2em 0;
    line-height: 2;
}

.saprt-box {
    background: #212b65;
    margin-top: 2em;
    padding-bottom: 4em;
}

.saport-2 {
    background: white;
    padding: 2.5em 1.5em;
    border-radius: 10px;
    margin-top: 3em;
}

.pad-2 {
    padding: 1em;
}

.b-s {
    width: 80%;
    margin: 0 auto;
}


/* サポート用モーダル：初期は非表示 */
.support-modal{
  display: none;
}

.support-modal.is-open{
  display: block;
}

/* 背景（薄黒） */
.support-modal__backdrop{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 9999;
}

/* 中央の枠 */
.support-modal__panel{
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 10000;

  width: min(720px, 92vw);
  max-height: 80vh;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.25);

  display: flex;
  flex-direction: column;
}

/* ヘッダー */
.support-modal__header{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 18px;
  border-bottom: 1px solid #e6e6e6;
}

.support-modal__title{
  margin: 0;
  font-size: 18px;
}

.support-modal__close{
  border: 0;
  background: transparent;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
}

/* 本文：ここだけスクロール */
.support-modal__body{
  padding: 18px;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  font-size: 16px;
  line-height: 1.9;
}


:root{
  --support-main: #212b65;     /* 濃紺 */
  --support-accent: #e34b4b;   /* 強調用（赤寄り）※変えたければここ */
  --support-bg: #f6f7fb;
  --support-border: #e3e6f3;
}

.support-modal__body{
  color: #111;
  font-size: 16px;
  line-height: 1.9;
  letter-spacing: .02em;
}

/* 冒頭の結論 */
.support-lead{
  background: var(--support-bg);
  border: 1px solid var(--support-border);
  border-radius: 12px;
  padding: 14px 14px;
  margin: 0 0 16px;
}

.support-badge{
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  background: var(--support-main);
  padding: 4px 10px;
  border-radius: 999px;
  margin-bottom: 8px;
}

.support-lead__text{
  margin: 0;
  font-weight: 700;
  color: var(--support-main);
}

/* 数字を見せるカード */
.support-kpi{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 0 0 18px;
}

.support-kpi__item{
  border: 1px solid var(--support-border);
  border-radius: 12px;
  padding: 12px 12px;
  background: #fff;
}

.support-kpi__label{
  margin: 0 0 6px;
  font-size: 12px;
  color: #666;
  font-weight: 700;
}

.support-kpi__value{
  margin: 0;
  font-size: 18px;
  font-weight: 800;
  color: var(--support-main);
}

.support-kpi__note{
  margin: 6px 0 0;
  font-size: 12px;
  color: #666;
}

/* 強調 */
.support-em{
  color: var(--support-main);
}

.support-strong{
  color: var(--support-accent);
  font-weight: 800;
}

/* 見出し */
.support-h{
  margin: 18px 0 8px;
  font-size: 16px;
  font-weight: 800;
  color: var(--support-main);
}

/* 箇条書き（読みやすく） */
.support-list{
  margin: 0 0 16px;
  padding-left: 1.2em;
}

.support-list li{
  margin: 8px 0;
}

/* ハイライト */
.support-highlight{
  background: #fff;
  border: 1px solid var(--support-border);
  border-left: 6px solid var(--support-accent);
  border-radius: 12px;
  padding: 12px 12px;
  margin: 0 0 18px;
}

.support-highlight__title{
  margin: 0 0 6px;
  font-size: 13px;
  font-weight: 800;
  color: var(--support-main);
}

.support-highlight__text{
  margin: 0;
}

/* 段落 */
.support-p{
  margin: 0 0 10px;
}

/* 最後の引用っぽい締め */
.support-quote{
  margin: 16px 0 0;
  padding: 12px 12px;
  background: var(--support-bg);
  border: 1px solid var(--support-border);
  border-radius: 12px;
  font-weight: 700;
  color: var(--support-main);
}

/* スマホ */
@media (max-width: 480px){
  .support-kpi{
    grid-template-columns: 1fr;
  }
}



.sap-3 {
    margin-top: 3em;
}



/******************キャリア*******************/

.p-w3 {
    width: 80%;
    margin: 0 auto;
}

.pad2 {
    padding: 2em 0 1em 0;
    line-height: 2;
}


.kyaria-box {
    margin-top: 3em;
}


.kyaria-box2 {
    padding: 2em 0;
}


.kyariapasu {
    margin-top: 2em;
}

.kyariapasu2 {
    margin-top: 3em;
    padding-bottom: 3em;
}




/******************実績*******************/


.p-tekuno2{
    color: #212b65;
    font-size: 16px;
    text-align: center;
}

.ziseki-2 {
    background: #212b65;
    padding: 3em 0;
    margin-top: 3em;
}

.p-tekuno3{
    color: white;
    font-size: 16px;
}

.ye {
    color: #fcee48;
}



/******************インタビュー*******************/

.intavu {
    padding: 5em 0;
}

.p-w {
    width: 90%;
    margin: 0 auto;
}

.int-box {
    margin-top: 5em;
}

.koe-b {
    padding: 2em 0;
}
/******************ステップ*******************/


.flow {
    background: #212b65;
    padding-bottom: 3em;

}

.flow-b {
    padding-bottom: 2em;
}

.fo-b {
    padding-bottom: 1em;
}

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


.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;
}

.qa-007 summary::before {
    color: white;
    content: "Q";
}

.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: #212b65;
    transition: transform .5s, opacity .5s;
}

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

.qa-007 p::before {
    color: #b81c23;
    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;
}




/***************** 求人内容 ******************/


.kyuuzinnnaiyou{
background: #212b65;
padding: 2em 0.3em;
}

.kyu-box {
    background: white;
    margin: 0.5em;
    padding: 2em 0;
}

.pad3 {
    padding: 2em 0 0 0;
    line-height: 2;
}


.bosyuu-bar {
    background: #212b65;
    text-align: center;
}

.p-tekuno4 {
    color: white;
    font-size: 16px;
}

.bos {
    background: #eeeff3;
    width: 95%;
    margin: 0 auto;
    padding-bottom: 2em;
}


.bos-b {
    padding: 2em 0;
    width: 80%;
    margin: 0 auto;
}

.kyu-sen{
  width: 90%;
  margin: 40px auto;
  border-top: 1px solid #212b65;
}

.pad4 {
    padding: 1em 0 0 0;
    line-height: 2;
}


.kakoi{
    border: 1px solid #212b65;
    padding: 1em;
    margin-top: 1em;
}



.bos-b2{
    padding: 2em 0;
    width: 90%;
    margin: 0 auto;
}



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

.saigoni {
    padding: 2em 0;
}

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

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

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



.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;
}
