@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: 1.6;
    font-family: "ヒラギノ角ゴ ProN W4", HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;
    font-weight: 500;
    color: #2c2c2c;
}


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

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

.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-top: 1em;
    background-color: #26228A;
    padding-bottom: 1em;
}

.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: #26228A;
}

.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 {
    padding: 2em 0 0 0;
}

.nayami-haikei {
    background: #262833;
    
}

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



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

.kai-co {
    width: 100%;
    margin: 0 auto;
    padding: 2em 0;
}

.kai-haikei{
    background-color: #26228A;
}


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


.mb-1 {
        margin-top: -1px;
}

.riyu-p{
    width: 93%;
    margin: 0 auto;
}

.riyu-p p {
    margin-top: 1em;
}



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

/* CSS */
.zisseki-hai {
  background: #ffb9b9;
  padding: 3em 0;
}

.zisseki h2 {
  text-align: center;
  font-size: 22px;
  margin-bottom: 20px;
}

.zisseki-title {
  color: #2b2b2b;
  display: inline-block;
  padding: 0.2em 0.4em;
  font-weight: bold;
  font-size: 20px;
  position: relative;
  z-index: 1;
  background: linear-gradient(transparent 60%, #FFD200 0%);
}


.zisseki-gazou img.ninka-image {
  max-width: 100%;
  height: auto;
  margin: 15px 0;
  border: 1px solid #ccc;
  box-shadow: 0 4px 8px rgba(0,0,0,0.15);
}

.ninka-box {
  background: #fff;
  border-left: 5px solid #e60033;
  padding: 1em;
  margin-top: 15px;
  border-radius: 4px;
}

.ninka-box p {
  margin: 5px 0;
  font-size: 16px;
}

.ninka-number {
  font-weight: bold;
  font-size: 18px;
  color: #e60033;
}

.ninka-number span {
  background: #ffe4e1;
  padding: 2px 6px;
  border-radius: 4px;
}

.ninka-message {
  margin-top: 20px;
  font-weight: bold;
  text-align: center;
  font-size: 17px;
}



h2.zisseki-heading {
  position: relative;
  padding: 0.4em 1em;
  border-top: solid 2px #333;
  border-bottom: solid 2px #333;
  color: #333;
  font-size: 22px;
  font-weight: bold;
  text-align: center;
  margin: 20px auto;
}

/* 左右の縦線 */
h2.zisseki-heading::before,
h2.zisseki-heading::after {
  content: '';
  position: absolute;
  top: -7px;
  width: 2px;
  height: calc(100% + 14px);
  background-color: #333;
}

h2.zisseki-heading::before {
  left: 7px;
}

h2.zisseki-heading::after {
  right: 7px;
}


/*******************未来/支援*******************/
.mirai-oya{
    margin-top: 2em;
}

.mirai-sapo-to {
    margin-top: 1em;
}

.sien {
    padding: 2em 0;
}

.sien-box {
    padding: 1em 0;
}

.sien-p {
    width: 93%;
    margin: 0 auto;
    color: white;
}


.sien p {
    margin-top: 1em;
}


.sien-box2 {
    margin-top: 1em;
}



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

.sec2-p {
text-align: center;

  }

.sec2{
    margin-bottom: 4em;
}

.sec2-box{
    margin-top: 1em;
}

.sec2-tit {
    margin-bottom: 1em
}

.w100 {
    width: 100%;
    margin: 0 auto;
}

/******************スライダー*******************/

.slick-next:before, .slick-prev:before {
    color:#FC0047;
    font-size: 40px;
}

.slick-next {
    right: 6px;
    top: 35%;
}

.slick-prev {
    left: -14px;
    top: 35%;
    z-index: 1000 !important;
}

 /******************寮・生活環境*******************/

 .kyu-co {
    margin-top: 2em;
    margin-bottom: 2em;
}

.ryou-b{
    margin-top: 2em;
    padding-bottom: 2em;

}

.ryou-m{
    margin-bottom: 2em;
}

.ryou-m2{
    margin-bottom: 1em;
}

.kyu-p{
    width: 93%;
    margin: 0 auto;
}

.kyu-p p {
    margin: 1em 0;
}

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


/*レオパレス画像*/

/******************画像スライダー*******************/
.sli{
    text-align: center;
    margin-top: 1em;
}

.sli p {
    font-size: 14px;
}



/* カルーセル全体 */
.carousel {
    /* 水平方向中央寄せ */
    display: flex;
    justify-content: center;
  }
  /* カルーセル内容 */
  .contains {
    /* サイズは自由に変更してください。*/
    /* 下の.slideも同じサイズにしてください。 */
    width: 350px;
    height: 220px;
    overflow: hidden;
    position: relative;
    padding: 0;
    list-style: none;
  }
  /* スライド切り換え用ラジオボタンは常に非表示 */
  .slide_select {
    display: none;
  }
  /* 各スライド */
  .slide {
    /* サイズは自由に変更してください。*/
    /* 上の.containsも同じサイズにしてください。 */
    width: 350px;
    height: 220px;
    position: absolute;
    /* スライドの初期値は選択されていないので透明にしておく */
    opacity: 0;
  }
  /* 前へ次へボタン */
  .scroll_button {
    position: absolute;
    display: block;
    height: 30px;
    width: 30px;
    /* 縦中央から20px上の位置 */
    top: 50%;
    margin-top: -20px;
    /* 上辺と右辺のみ幅5pxの枠線 */
    border-width: 5px 5px 0 0;
    border-style: solid;
    border-color: #2c2c2c;
    cursor: pointer;
    /* 普段はボタンはやや薄くする */
    opacity: 0.5;
    /* スライドよりも前面にする */
    z-index: 3;
  }
  /* ホバー時にボタンを強調 */
  .scroll_button:hover {
    opacity: 1;
  }
  /* 前へボタン */
  .scroll_prev {
    left: 15px;
    /* 上辺と右辺の枠線を回転して"＜"にする */
    transform: rotate(-135deg);
  }
  /* 次へボタン */
  .scroll_next {
    right: 15px;
    /* 上辺と右辺の枠線を回転して"＞"にする */
    transform: rotate(45deg);
  }
  /* スライド移動ボタンエリア */
  .move_controler {
    position: absolute;
    bottom: 20px;
    width: 100%;
    text-align: center;
  }
  /* スライド移動の各ボタン */
  .button_move {
    display: inline-block;
    height: 15px;
    width: 15px;
    margin: 0 2px;
    border-radius: 100%;
    cursor: pointer;
    /* 普段はやや薄くする */
    opacity: 0.5;
    /* スライドより前面にする */
    z-index: 2;
  }
  /* ホバー時はやや明るくする */
  .button_move:hover {
    opacity: 0.75;
  }
  /* スライド移動ボタンの色 */
  .button_move {
    background-color: #fdfdfd;
  }
  /* 1番目のスライド選択時 */
  /* 1番目のスライドの透明度を0にして表示する */
  .slide_select:nth-of-type(1):checked ~ .slide:nth-of-type(1) {
    opacity: 1;
  }
  /* スライド移動ボタンの1個目を明るくする */
  /* （今選択されていることが分かるように） */
  .slide_select:nth-of-type(1):checked ~ .move_controler .button_move:nth-of-type(1) {
    opacity: 1;
  }
  .slide_select:nth-of-type(2):checked ~ .slide:nth-of-type(2) {
    opacity: 1;
  }
  /* 2番目のスライド選択時（1番目のスライドと同じことをする） */
  .slide_select:nth-of-type(2):checked ~ .move_controler .button_move:nth-of-type(2) {
    opacity: 1;
  }
  /* 3番目のスライド選択時 */
  .slide_select:nth-of-type(3):checked ~ .slide:nth-of-type(3) {
    opacity: 1;
  }
  .slide_select:nth-of-type(3):checked ~ .move_controler
    .button_move:nth-of-type(3) {
    opacity: 1;
  }
  /* 4番目のスライド選択時 */
  .slide_select:nth-of-type(4):checked ~ .slide:nth-of-type(4) {
    opacity: 1;
  }
  .slide_select:nth-of-type(4):checked
    ~ .move_controler
    .button_move:nth-of-type(4) {
    opacity: 1;
  }
    /* 4番目のスライド選択時 */
  .slide_select:nth-of-type(5):checked ~ .slide:nth-of-type(5) {
    opacity: 1;
  }
  .slide_select:nth-of-type(5):checked
    ~ .move_controler
    .button_move:nth-of-type(5) {
    opacity: 1;
  }
  /* 4番目のスライド選択時 */
  .slide_select:nth-of-type(6):checked ~ .slide:nth-of-type(6) {
    opacity: 1;
  }
  .slide_select:nth-of-type(6):checked
    ~ .move_controler
    .button_move:nth-of-type(6) {
    opacity: 1;
  }
  /* 4番目のスライド選択時 */
  .slide_select:nth-of-type(7):checked ~ .slide:nth-of-type(7) {
    opacity: 1;
  }
  .slide_select:nth-of-type(7):checked
    ~ .move_controler
    .button_move:nth-of-type(7) {
    opacity: 1;
  }

  .p-tiisa {
    text-align: right;
    font-size: 8px;
}

/******************給料*******************/
.kyuuryou{
        /* 方眼紙模様に必須のスタイル */
  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: 5em;
padding-top: 3em;
}

.k-box {
    margin-top: 2em ;
}

.kyuryou-p {
    text-align: center;
}



/******************利用者のお声*******************/
.gugle {
    margin-bottom: 2em;
}

.riyouokoe {
    padding-bottom: 3em;
    padding-top: 3em;
}

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

.slider li {
    padding: 0 2em;
}


/******************就業までの流れ*******************/


.nagare {
background: #DAD8EB;
padding-bottom: 3em;
}

.naga-haikei {
    padding: 1em 0;
}

.nagare-main {
    padding: 2em 0;
}


.nagare-tit {
    margin: 0 auto;
}


.nagare-box {
    margin-top: 2em;
}



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

.situmon {
            /* 方眼紙模様に必須のスタイル */
  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: 0em;
padding-top: 3em;
}


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


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


.qa-007 {
    margin-bottom: 20px;
    border: 1px #26228A solid;
    border-radius: 25px;
    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: #2c2c2c;
    font-weight: 600;
    cursor: pointer;
}

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

.qa-007 summary::before {
    color: #26228A;
    content: "Q";
}

.qa-007 summary::after {
    transform: translateY(-25%) rotate(45deg);
    width: 7px;
    height: 7px;
    margin-left: 10px;
    border-bottom: 3px solid #333333b3;
    border-right: 3px solid #333333b3;
    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: .3em 3em 1.5em;
    color: #2c2c2c;
    transition: transform .5s, opacity .5s;
}

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

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

.q-tit {
    width: 40%;
    background: #26228A;
    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;
    }
}


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

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



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

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

.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: #D50B04;
}

.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:#26228A;
    -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:#26228A;
}


.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: 0px 0 0px 0;
}
@media screen and (max-width: 768px) {
    .thabox {
        width: 70%;
    }
}


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

footer {
    color: #fff;
    background: #26228A;
}

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


/*************************************/

.cmn-contact {
    background: url(../img/bg_cmn_contact.jpg) no-repeat center / cover;
}

.cmn-contact_tel {
    position: relative;
    padding-left: 20%;
    z-index: 2;
}

.cmn-contact_tel::before {
    content: '';
    position: absolute;
    left: -5px;
    bottom: 0;
    width: 27%;
    height: 350px;
    background: url(../img/character.png) no-repeat left bottom / 100% auto;
    z-index: -1;
}

.cmn-contact_tel a {
    display: inline-block;
    margin-top: 10px;
    line-height: 1.2;
}

.cmn-contact_tel a img {
    margin-right: 10px;
    vertical-align: -3px;
}

.cmn-contact_tel a span {
    margin-right: 15px;
    font-size: 6.6rem;
}

.cmn-contact__cont {
    position: relative;
    border-top: 3px solid #242423;
    border-bottom: 3px solid #242423;
}

.cmn-contact__cont::before {
    content: '';
    position: absolute;
    top: 28px;
    bottom: 28px;
    left: calc(50% - 1.5px);
    width: 3px;
    background: #242423;
}

.cmn-contact__cont a {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    width: 48%;
    max-width: 464px;
    height: 108px;
    margin: 9px auto;
    padding: 10px;
    border-radius: 15px;
}

.cmn-contact_mail {
    background: linear-gradient(to bottom, #FEE20E, #FBAC35);
    border: 2px solid #FEE20E;
}

.cmn-contact_mail img {
    margin-right: 25px;
}

.cmn-contact_line {
    background: linear-gradient(to bottom, #05D205, #05A105);
    border: 2px solid #02CC02;
}

.cmn-contact_line img {
    margin-right: 7px;
}

@media screen and (max-width: 768px) {
    .cmn-contact_tel a img {
        width: 25px;
        margin-right: 10px;
        vertical-align: -3px;
    }
    .cmn-contact_tel a span {
        font-size: 3.3rem;
    }
    .cmn-contact__cont::before {
        display: none;
    }
    .cmn-contact__cont a {
        width: 100%;
    }
}

@media screen and (max-width: 480px) {
    .cmn-contact_tel {
        padding-left: 0;
    }
    .cmn-contact_tel a {
        padding-left: 10vw;
    }
    .cmn-contact_tel a img {
        margin-right: 5px;
    }
    .cmn-contact__cont a {
        height: 90px;
    }
}

.sec_ttl {
    text-align: center;
    line-height: 1;
}

.sec_ttl .en {
    font-size: 7.9rem;
    font-weight: 600;
    color: #D50B04;
    line-height: 1.35;
}

.sec_ttl .en::before,
.sec_ttl .en::after {
    content: url(../img/illu_ttl.png);
    display: inline-block;
    vertical-align: middle;
}

.sec_ttl .en::before {
    margin-right: 18px;
}

.sec_ttl .en::after {
    transform: rotateY(180deg);
    margin-left: 18px;
}

@media screen and (max-width: 768px) {
    .sec_ttl .en {
        font-size: 4rem;
    }
}

.mv_login {
    padding: 28px 0;
    background: #3A3A3A;
}

.mv_login .container {
    max-width: 1580px;
}

.mv_login_ttl {

    font-weight: 400;
}

.mv_login_ttl img {
    margin-right: 5px;
    vertical-align: -5px;
}

.mv_login_form {
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    font-weight: 400;
}

/*
.mv_login_form p {

}
*/

.mv_login_form p label {
    margin-right: 10px;
}

.mv_login_form p input {
    height: 34px;
    padding: 0 10px;
    font-size: 1.4rem;
    box-sizing: border-box;
    border-radius: 5px;
}

.mv_login_form input[type="submit"] {
    height: 34px;
    margin: 20px 0;
    padding: 0;
    font-size: 1.6rem;
    font-weight: 500;
    font-family: "ヒラギノ角ゴ ProN W3", HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;;
    color: #fff;
    background: #D50B04;
    border-radius: 10px;
}

@media screen and (max-width: 1024px) {
    .mv_login_ttl {
        margin: 0 0 10px;
        padding-right: 0;
        border-right: none;
    }
}

@media screen and (max-width: 768px) {
    .mv_login_ttl {
        text-align: center;
    }
    .mv_login_form p {
        margin-bottom: 10px;
    }
    .mv_login_form p label {
        display: inline-block;
        width: 80px;
    }
}



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

.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: #D50B04;
    color: #fff;
}

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




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

.f-flex {
    display: flex;
   
}


.fro-haikei{
    background-color: rgba(38, 34, 138, 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;
}
}




/* =====================
   診断ボックス
   ===================== */

.sindan-haikei {
    background: #26228A;
    padding: 3em 0;
}

.diagnosis-container {
  max-width: 500px;
  margin: auto;
  text-align: center;
  font-family: "Hiragino Sans", sans-serif;
  background: #fff;
  padding: 20px;
  border-radius: 10px;
}

/* ヘッダー */
.diagnosis-header .catch-copy {
  margin-bottom: 5px;
}
.diagnosis-header .highlight {
  color: orange;
  font-weight: bold;
}
.main-title {
  font-size: 26px;
  color: #FC0047;
  margin: 5px 0;
  font-weight: bold;
}
.sub-title {
  font-size: 1rem;
  color: #555;
}

/* =====================
   プログレスバー（細切れ型）
   ===================== */
.progress-wrapper {
  margin: 15px 0;
}
.progress-steps {
  display: flex;
  justify-content: space-between;
  margin-bottom: 6px;
}
.step-block {
  flex: 1;
  height: 12px;
  background: #eee;
  margin: 0 4px;
  border-radius: 4px;
  transition: background 0.3s ease;
}
.step-block.active {
  background: linear-gradient(90deg, orange, red);
}
.progress-text {
  font-size: 1.2rem;
  color: #333;
}

/* =====================
   ステップ・質問ボックス
   ===================== */
.step {
  display: none;
}
.step.active {
  display: block;
}
.question-box {
  background: #f5f5f5;
  padding: 15px;
  border-radius: 8px;
  text-align: left;
  margin-bottom: 15px;
}
.question-title {
  font-size: 1.6rem;
  margin-bottom: 12px;
  font-weight: bold;
  color: #2c1580;
}

label {
  display: block;
  margin: 8px 0;
  text-align: left;
  font-size: 15px;
}

/* =====================
   ボタン
   ===================== */
.next-btn {
  margin-top: 10px;
  padding: 12px 25px;
  background: linear-gradient(to right, #FFB05E, #F06A44);
  border: none;
  border-radius: 6px;
  color: #fff;
  font-weight: bold;
  cursor: pointer;
  font-size: 1.5rem;
  width: 100%;
}



/* =====================
   結果表示
   ===================== */
.result-num {
  font-size: 3rem;
  font-weight: bold;
  color: #FC0047;
}
.result-text {
  font-size: 1.1rem;
  margin-bottom: 20px;
}

/* CTA ボタン */
.cta-buttons a {
  display: block;
  margin: 10px 0;
  padding: 12px;
  font-weight: bold;
  border-radius: 5px;
  text-decoration: none;
  color: #fff;
  font-size: 16px;
}
.line-btn { background: #06c755; }
.mail-btn { background: #ff5a5a; }
.tel-btn { background: #f1c40f; color: #000; }


/* CTA ボタン 画像よう*/

.btn-eria2 {
    padding-top: 1.5em;
    padding-bottom: 1em;
}

.cta-buttons2 a {
    display: block;
    /* margin: 10px 0; */
    /* padding: 12px; */
    font-weight: bold;
    border-radius: 5px;
    text-decoration: none;
    color: #fff;
    font-size: 16px;
}