@charset "UTF-8";
/*------------------------------------- */
/* フォント
/*------------------------------------- */


/*------------------------------------- */
/* 色
/*------------------------------------- */
.white {
  color: #FFF !important;
}

.white a {
  color: #FFF !important;
}

.black {
  color: #222222 !important;
}

.red {
  color: #DE4341 !important;
}

.yellow {
  color: #F8B600 !important;
}

.red {
  color: #DE4341 !important;
}

.green {
  color: #0AB48D !important;
}

.dark_green {
  color: #009FBB !important;
}

.light_green {
  color: #E0F4F3 !important;
}

.blue {
  color: #144A7A !important;
}

.blue a {
  color: #144A7A !important;
}

.light_blue {
  color: #5E8CA8 !important;
}

.light_gray {
  color: #F5F5F5 !important;
}

.beige {
  color: #F3EBCF !important;
}

.light_beige {
  color: #FBF8EF !important;
}

.brown {
  color: #C1A342 !important;
}

.orange {
  color: #FA902C !important;
}

.yellow {
  color: #E7C73D !important;
}

.bg-none {
  background-image: none !important;
  background-color: #ffffff;
}


/*------------------------------------- */
/* 背景色 */
/*------------------------------------- */
.bg_black {
  background-color: #222222 !important;
}

.bg_white {
  background-color: #FFFFFF !important;
}

.bg_green {
  background-color: #0AB48D !important;
}

.bg_dark_green {
  background-color: #009FBB !important;
}

.bg-yellow {
  background-color: #F8B600 !important;
}

.bg_light_yellow {
  background-color: #FEF4D9 !important;
}

.bg_light_green {
  background-color: #E0F4F3 !important;
}

.bg_red {
  background-color: #DE4341 !important;
}

/* .bg_light_red {
  background-color: #C42222 !important;
} */
.bg_orange {
  background-color: #FC633D !important;
}

/* .bg_dark-orange {
  background-color: #E58853 !important;
} */
/* .bg_yellow{
  background-color: #FFFF02 !important;
} */
/* .bg_light_yellow{
  background-color: #DFD8CA !important;
} */
.bg_blue {
  background-color: #164B93 !important;
}

.bg_gray_blue {
  background-color: #5E8CA8 !important;
}

.bg_gray {
  background-color: #999999 !important;
}

.bg_light-gray {
  background-color: #F5F5F5 !important;
}

/* .bg_dark-gray {
  background-color: #666666 !important;
} */
.bg_beige {
  background-color: #F3EBCF !important;
}

.bg_light_beige {
  background-color: #FBF8EF !important;
}

.brown {
  background-color: #C1A342 !important;
}

/* .bg_gradation-red {
  background-image: linear-gradient(180deg, #BA0008, #F90236) !important;
} */


/* ----------------------------------------
  文字装飾
---------------------------------------- */
.strong {
  font-weight: bold;
}

.normal {
  font-weight: normal;
}

.italic {
  font-style: italic;
}

.triangle:after {
  content: "?";
  color: #1c1c1c;
  margin-left: 10px;
  font-size: 12px;
}

.indent {
  text-indent: 1em;
}

.inline01 {
  display: inline-block;
}

.inline02 {
  display: block;
}

.inline03 {
  display: inline;
}

.justify {
  text-align: justify;
  text-justify: inter-ideograph;
}

.underline {
  text-decoration: underline;
}

.w-break {
  word-wrap: break-word;
  width: 100%;
  padding: 5px;
}

.text-tate {
  writing-mode: vertical-rl;
  text-orientation: sideways;
}

.text-tate02 {
  writing-mode: vertical-rl;
  text-orientation: upright;
}

/* ----------------------------------------
  文字サイズ
---------------------------------------- */
.f50 {
  font-size: 50%;
}

.f62 {
  font-size: 62% !important;
}

.f80 {
  font-size: 80%;
}

.f90 {
  font-size: 90%;
}

.f110 {
  font-size: 110%;
}

.f120 {
  font-size: 120%;
}

.f130 {
  font-size: 130%;
}

.f9px {
  font-size: 9px;
}

.f10px {
  font-size: 10px;
}

.f11px {
  font-size: 11px;
}

.f12px {
  font-size: 12px;
}

.f13px {
  font-size: 13px;
}

.f14px {
  font-size: 14px;
}

.f15px {
  font-size: 15px;
}

.f16px {
  font-size: 16px;
}

.f17px {
  font-size: 17px;
}

.f18px {
  font-size: 18px;
}

.f19px {
  font-size: 19px;
}

.f20px {
  font-size: 20px;
}

.f25px {
  font-size: 25px;
}

.f30px {
  font-size: 30px;
}

.f40px {
  font-size: 40px;
}

.f45px {
  font-size: 45px;
}

.f50px {
  font-size: 50px;
}

.f80px {
  font-size: 80px;
}

.f16px-12px {
  font-size: 16px;
}

@media screen and (max-width: 991.5px) {
  .f16px-12px {
    font-size: 12px;
  }
}

.f12px-10px {
  font-size: 12px;
}

@media screen and (max-width: 1420px) {
  .f12px-10px {
    font-size: 10px;
  }
}

.f150p-120p {
  font-size: 150%
}

@media screen and (max-width: 570px) {
  .f150p-120p {
    font-size: 120%
  }
}

.f18px-22px {
  font-size: 18px;
}

@media screen and (min-width: 992px) {
  .f18px-22px {
    font-size: 22px;
  }
}

.f24px-30px {
  font-size: 24px;
}

@media screen and (min-width: 992px) {
  .f24px-30px {
    font-size: 30px;
  }
}

.f30px-44px {
  font-size: 30px;
}

@media screen and (min-width: 992px) {
  .f30px-44px {
    font-size: 44px;
  }
}

.f36px-54px {
  font-size: 36px;
  font-weight: 600;
}

@media screen and (min-width: 992px) {
  .f36px-54px {
    font-size: 54px;
    font-weight: 900;
  }
}

/* ----------------------------------------
  行間
---------------------------------------- */
.lh0 {
  line-height: 0%;
}

.lh100 {
  line-height: 100%;
}

.lh110 {
  line-height: 110%;
}

.lh120 {
  line-height: 120%;
}

.lh130 {
  line-height: 130%;
}

.lh140 {
  line-height: 140%;
}

.lh150 {
  line-height: 150%;
}

.lh160 {
  line-height: 160%;
}

.lh170 {
  line-height: 170%;
}

.lh180 {
  line-height: 180%;
}

.lh190 {
  line-height: 190%;
}

.lh200 {
  line-height: 200%;
}

.ls1 {
  letter-spacing: 1px;
}

.ls2 {
  letter-spacing: 2px;
}

.ls3 {
  letter-spacing: 3px;
}

.ls15 {
  letter-spacing: 15px;
}

/*------------------------------------- */
/* 位置合わせ */
/*------------------------------------- */
.fl_r {
  float: right;
  display: block;
}

.fl_l {
  float: left;
  display: block;
}

.clear {
  clear: both;
}

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

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

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

.al_m {
  vertical-align: middle;
}

.al_c {
  margin: 0 auto;
}

@media screen and (max-width: 570px) {
  .spclear {
    clear: both;
  }
}

.ta_l-r {
  text-align: left;
}

@media screen and (min-width: 992px) {
  .ta_l-r {
    text-align: right;
  }
}

/*------------------------------------- */
/* margin */
/*------------------------------------- */
/*all*/
.m00 {
  margin: 0;
}

.m03 {
  margin: 3px;
}

.m05 {
  margin: 5px;
}

.m10 {
  margin: 10px;
}

.m15 {
  margin: 15px;
}

.m20 {
  margin: 20px;
}

.m25 {
  margin: 25px;
}

.m30 {
  margin: 30px;
}

.m35 {
  margin: 35px;
}

.m40 {
  margin: 40px;
}

/*top*/
.mt-100 {
  margin-top: -100px;
}

.mt-10 {
  margin-top: -10px;
}

.mt-15 {
  margin-top: -15px;
}

.mt00 {
  margin-top: 0;
}

.mt03 {
  margin-top: 3px;
}

.mt05 {
  margin-top: 5px;
}

.mt10 {
  margin-top: 10px;
}

.mt15 {
  margin-top: 15px;
}

.mt20 {
  margin-top: 20px;
}

.mt25 {
  margin-top: 25px;
}

.mt30 {
  margin-top: 30px;
}

.mt35 {
  margin-top: 35px;
}

.mt40 {
  margin-top: 40px;
}

.mt50 {
  margin-top: 50px;
}

.mt60 {
  margin-top: 60px;
}

.mt70 {
  margin-top: 70px;
}

.mt80 {
  margin-top: 80px;
}

.mt100 {
  margin-top: 100px;
}

.mt150 {
  margin-top: 150px;
}

.mt200 {
  margin-top: 200px;
}

/*bottom*/
.mb-30 {
  margin-bottom: -20px;
}

.mb00 {
  margin-bottom: 0;
}

.mb03 {
  margin-bottom: 3px;
}

.mb05 {
  margin-bottom: 5px;
}

.mb10 {
  margin-bottom: 10px;
}

.mb15 {
  margin-bottom: 15px;
}

.mb20 {
  margin-bottom: 20px;
}

.mb25 {
  margin-bottom: 25px;
}

.mb30 {
  margin-bottom: 30px;
}

.mb35 {
  margin-bottom: 35px;
}

.mb40 {
  margin-bottom: 40px;
}

.mb50 {
  margin-bottom: 50px;
}

.mb60 {
  margin-bottom: 60px;
}

.mb100 {
  margin-bottom: 100px;
}

/*left*/
.ml-20 {
  margin-left: -20px;
}

.ml-30 {
  margin-left: -30px;
}

.ml00 {
  margin-left: 0;
}

.ml03 {
  margin-left: 3px;
}

.ml05 {
  margin-left: 5px;
}

.ml10 {
  margin-left: 10px;
}

.ml15 {
  margin-left: 15px;
}

.ml20 {
  margin-left: 20px;
}

.ml25 {
  margin-left: 25px;
}

.ml30 {
  margin-left: 30px;
}

.ml35 {
  margin-left: 35px;
}

.ml40 {
  margin-left: 40px;
}

.ml50 {
  margin-left: 50px;
}

.ml60 {
  margin-left: 60px;
}

.ml105 {
  margin-left: 105px;
}

.ml106 {
  margin-left: 106px;
}

.ml140 {
  margin-left: 140px;
}

.ml200 {
  margin-left: 200px;
}

.ml250 {
  margin-left: 250px;
}

.ml275 {
  margin-left: 275px;
}

/*right*/
.mr00 {
  margin-right: 0;
}

.mr03 {
  margin-right: 3px;
}

.mr05 {
  margin-right: 5px;
}

.mr10 {
  margin-right: 10px;
}

.mr15 {
  margin-right: 15px;
}

.mr20 {
  margin-right: 20px;
}

.mr25 {
  margin-right: 25px;
}

.mr30 {
  margin-right: 30px;
}

.mr35 {
  margin-right: 35px;
}

.mr40 {
  margin-right: 40px;
}

.mr50 {
  margin-right: 50px;
}

.mr60 {
  margin-right: 60px;
}

.mb70-50 {
  margin-bottom: 70px;
}

@media screen and (max-width: 991.5px) {
  .mb70-50 {
    margin-bottom: 50px;
  }
}

.mb100-50 {
  margin-bottom: 100px;
}

@media screen and (max-width: 991.5px) {
  .mb100-50 {
    margin-bottom: 50px;
  }
}

.mb15-5 {
  margin-bottom: 15px;
}

@media screen and (max-width: 1000px) {
  .mb15-5 {
    margin-bottom: 5px;
  }
}

.mb20-00 {
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .mb20-00 {
    margin-bottom: 0px;
  }
}

.mb30-10 {
  margin-bottom: 30px !important;
}

@media screen and (max-width: 767px) {
  .mb30-10 {
    margin-bottom: 10px !important;
  }
}

.mb40-20 {
  margin-bottom: 40px !important;
}

@media screen and (max-width: 767px) {
  .mb40-20 {
    margin-bottom: 20px !important;
  }
}

.mb50-20 {
  margin-bottom: 50px !important;
}

@media screen and (max-width: 767px) {
  .mb50-20 {
    margin-bottom: 20px !important;
  }
}

.mb80-20 {
  margin-bottom: 80px;
}

@media screen and (max-width: 767px) {
  .mb80-20 {
    margin-bottom: 20px;
  }
}

.mb80-40 {
  margin-bottom: 80px !important;
}

.mb90-50 {
  margin-bottom: 90px !important;
}

@media screen and (max-width: 991.5px) {
  .mb80-40 {
    margin-bottom: 40px !important;
  }

  .mb90-50 {
    margin-bottom: 50px !important;
  }
}

.mt50-20 {
  margin-top: 50px !important;
}

@media screen and (max-width: 1200px) {
  .mt50-20 {
    margin-top: 20px !important;
  }
}

.mt70-120 {
  margin-top: 70px !important;
}

@media screen and (min-width: 768px) {
  .mt70-120 {
    margin-top: 120px !important;
  }
}

.mt100-30 {
  margin-top: 100px;
}

@media screen and (max-width: 1200px) {
  .mt100-30 {
    margin-top: 30px;
  }
}

.mt100-50 {
  margin-top: 100px;
}

@media screen and (max-width: 768px) {
  .mt100-50 {
    margin-top: 50px;
  }
}

.mt80-30 {
  margin-top: 80px;
}

@media screen and (max-width: 1200px) {
  .mt80-30 {
    margin-top: 30px;
  }
}

.mr10-3 {
  margin-right: 10px;
}

@media screen and (max-width: 500px) {
  .mr10-3 {
    margin-right: 3px;
  }
}

.ml20-5 {
  margin-left: 20px;
}

@media screen and (max-width: 500px) {
  .ml20-5 {
    margin-left: 5px;
  }
}

.mt40-10 {
  margin-top: 40px;
}

@media screen and (max-width: 1000px) {
  .mt40-10 {
    margin-top: 10px;
  }
}

.mr20-00 {
  margin-right: 20px;
}

@media screen and (max-width: 768px) {
  .mr20-00 {
    margin-right: 0px;
  }
}

.mr30-00 {
  margin-right: 30px;
}

@media screen and (max-width: 768px) {
  .mr30-00 {
    margin-right: 10px;
  }
}

/*------------------------------------- */
/* padding */
/*------------------------------------- */
/*all*/
.p00 {
  padding: 0;
}

.p03 {
  padding: 3px;
}

.p05 {
  padding: 5px;
}

.p10 {
  padding: 10px;
}

.p15 {
  padding: 15px;
}

.p20 {
  padding: 20px;
}

.p25 {
  padding: 25px;
}

.p30 {
  padding: 30px;
}

.p35 {
  padding: 35px;
}

.p40 {
  padding: 40px;
}

/*top*/
.pt00 {
  padding-top: 0;
}

.pt03 {
  padding-top: 3px;
}

.pt05 {
  padding-top: 5px;
}

.pt10 {
  padding-top: 10px;
}

.pt15 {
  padding-top: 15px;
}

.pt20 {
  padding-top: 20px;
}

.pt25 {
  padding-top: 25px;
}

.pt30 {
  padding-top: 30px;
}

.pt35 {
  padding-top: 35px;
}

.pt40 {
  padding-top: 40px;
}

.pt50 {
  padding-top: 50px;
}

.pt70 {
  padding-top: 70px;
}

.pt100 {
  padding-top: 100px;
}

.pt50-100 {
  padding-top: 50px;
}

@media screen and (min-width: 992px) {
  .pt50-100 {
    padding-top: 100px;
  }
}

.pt0-70 {
  padding-top: 0px;
}

@media screen and (min-width: 992px) {
  .pt0-70 {
    padding-top: 70px;
  }
}

.pt30-70 {
  padding-top: 30px;
}

@media screen and (min-width: 992px) {
  .pt30-70 {
    padding-top: 70px;
  }
}

/*bottom*/
.pb00 {
  padding-bottom: 0;
}

.pb03 {
  padding-bottom: 3px;
}

.pb05 {
  padding-bottom: 5px;
}

.pb10 {
  padding-bottom: 10px;
}

.pb15 {
  padding-bottom: 15px;
}

.pb20 {
  padding-bottom: 20px;
}

.pb25 {
  padding-bottom: 25px;
}

.pb30 {
  padding-bottom: 30px;
}

.pb35 {
  padding-bottom: 35px;
}

.pb40 {
  padding-bottom: 40px;
}

.pb50 {
  padding-bottom: 50px;
}

.pb70 {
  padding-bottom: 70px;
}

.pb50-100 {
  padding-bottom: 50px;
}

@media screen and (min-width: 992px) {
  .pb50-100 {
    padding-bottom: 140px;
  }
}

@media screen and (min-width: 1700px) {
  .pb50-100 {
    padding-bottom: 315px;
  }
}


/*left*/
.pl00 {
  padding-left: 0;
}

.pl03 {
  padding-left: 3px;
}

.pl05 {
  padding-left: 5px;
}

.pl10 {
  padding-left: 10px;
}

.pl15 {
  padding-left: 15px;
}

.pl20 {
  padding-left: 20px;
}

.pl25 {
  padding-left: 25px;
}

.pl30 {
  padding-left: 30px;
}

.pl35 {
  padding-left: 35px;
}

.pl40 {
  padding-left: 40px;
}

.pl60-70 {
  padding-left: 60px !important;
}

@media screen and (min-width: 992px) {
  .pl60-70 {
    padding-left: 70px !important;
  }
}

/*right*/
.pr00 {
  padding-right: 0;
}

.pr03 {
  padding-right: 3px;
}

.pr05 {
  padding-right: 5px;
}

.pr10 {
  padding-right: 10px;
}

.pr15 {
  padding-right: 15px;
}

.pr20 {
  padding-right: 20px;
}

.pr25 {
  padding-right: 25px;
}

.pr30 {
  padding-right: 30px;
}

.pr35 {
  padding-right: 35px;
}

.pr40 {
  padding-right: 40px;
}

/*------------------------------------- */
/* 角丸 */
/*------------------------------------- */
/*all*/
.br5 {
  border-radius: 5px;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
}

.br10 {
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
}

.br20 {
  border-radius: 20px;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
}

.br30 {
  border-radius: 30px;
  -webkit-border-radius: 30px;
  -moz-border-radius: 30px;
}

.br50 {
  border-radius: 50px;
  -webkit-border-radius: 50px;
  -moz-border-radius: 50px;
}

.br100 {
  border-radius: 100px;
  -webkit-border-radius: 100px;
  -moz-border-radius: 100px;
}

.br-tl0 {
  -webkit-border-top-left-radius: 10px;
  -moz-border-radius-topleft: 10px;
}

.br-tr10 {
  -webkit-border-top-right-radius: 10px;
  -moz-border-radius-topright: 10px;
}

.br-bl10 {
  -webkit-border-bottom-left-radius: 10px;
  -moz-border-radius-bottomleft: 10px;
}

.br-br10 {
  -webkit-border-bottom-right-radius: 10px;
  -moz-border-radius-bottomright: 10px;
}

.br-tl30 {
  -webkit-border-top-left-radius: 30px;
  -moz-border-radius-topleft: 30px;
}

.br-tr30 {
  -webkit-border-top-right-radius: 30px;
  -moz-border-radius-topright: 30px;
}

.br-bl30 {
  -webkit-border-bottom-left-radius: 30px;
  -moz-border-radius-bottomleft: 30px;
}

.br-br30 {
  -webkit-border-bottom-right-radius: 30px;
  -moz-border-radius-bottomright: 30px;
}

@media screen and (max-width: 992px) {
  .br-none-sp {
    border-radius: 0px !important;
    -webkit-border-radius: 0px !important;
    -moz-border-radius: 0px !important;
  }
}



/*------------------------------------- */
/* border */
/*------------------------------------- */
.border-none {
  border: none;
}

.border-blue-solid {
  border: solid 1px #164b93;
}

/*------------------------------------- */
/* 高さ */
/*------------------------------------- */
.hei_auto {
  height: auto !important;
}

.height100 {
  height: 100%;
}

.height54p {
  height: 54px;
}

.height100p {
  height: 100px;
}

.height120p {
  height: 120px;
}

.height130p {
  height: 130px;
}

.height140p {
  height: 140px;
}

.height240p {
  height: 240px;
}

.height_237px-500p {
  height: 237px;
}

@media screen and (min-width: 992px) {
  .height_auto-500p {
    height: 500px;
  }
}

.height80p-240p {
  height: 80px;
}

@media screen and (min-width: 992px) {
  .height80p-240p {
    height: 240px;
  }
}

.height100p-140p {
  height: 100px;
}

@media screen and (min-width: 992px) {
  .height100p-140p {
    height: 140px;
  }
}

.heightauto-420p {
  height: auto !important;
}

@media screen and (min-width: 992px) {
  .heightauto-420p {
    height: 420px !important;
  }
}

.heightauto-560p {
  height: auto;
}

@media screen and (min-width: 992px) {
  .heightauto-560p {
    height: 560px;
  }
}

.height90-200p {
  height: 90px;
}

@media screen and (min-width: 992px) {
  .height90-200p {
    height: 200px;
  }
}


/*------------------------------------- */
/* 幅 */
/*------------------------------------- */
.w6per {
  width: 6%;
}

.w10per {
  width: 10%;
}

.w14per {
  width: 14%;
}

.w15per {
  width: 15%;
}

.w18per {
  width: 18%;
}

.w20per {
  width: 20%;
}

.w24per {
  width: 24%;
}

.w30per {
  width: 30%;
}

.w40per {
  width: 30%;
}

.w50per {
  width: 50%;
}

.w60per {
  width: 50%;
}

.w70per {
  width: 70%;
}

.w80per {
  width: 80%;
}

.w90per {
  width: 90%;
}

.w100per {
  width: 100%;
}

.w40 {
  width: 40px;
}

.w50 {
  width: 50px;
}

.w60 {
  width: 60px;
}

.w80 {
  width: 80px;
}

.w100 {
  width: 100px;
}

.w120 {
  width: 120px;
}

.w140 {
  width: 140px;
}

.w180 {
  width: 180px;
}

.w200 {
  width: 200px;
}

.w240 {
  width: 236px;
}

.w350 {
  width: 350px;
}

.w80 {
  width: 80px;
}

.w20per-100per {
  width: 20%;
}

@media screen and (max-width: 640px) {
  .w20per-100per {
    width: 100%;
  }
}

.w50per-100per {
  width: 100%;
}

@media screen and (min-width: 992px) {
  .w50per-100per {
    width: 50%;
  }
}

.w60per-100per {
  width: 100%;
}

@media screen and (min-width: 992px) {
  .w60per-100per {
    width: 60%;
  }
}

.w60per-90per {
  width: 90%;
}

@media screen and (min-width: 992px) {
  .w60per-90per {
    width: 60%;
  }
}

.w90per-100per {
  width: 100%;
}

@media screen and (min-width: 768px) {
  .w90per-100per {
    width: 90%;
  }
}

.w80per-100per {
  width: 100%;
}

@media screen and (min-width: 768px) {
  .w80per-100per {
    width: 80%;
  }
}

.w70per-90per {
  width: 70%;
}

@media screen and (max-width: 991.5px) {
  .w70per-90per {
    width: 90%;
  }
}

.w100-140 {
  width: 100px;
}

@media screen and (min-width: 992px) {
  .w100-140 {
    width: 140px;
  }
}

.w200-400 {
  width: 200px;
}

@media screen and (min-width: 992px) {
  .w200-400 {
    width: 400px;
  }
}


.sp-w80-200 {
  width: 80px;
  height: auto;
}

@media screen and (min-width: 992px) {
  .sp-w80-200 {
    width: 200px;
  }
}

.sp-w100-180 {
  width: 100px;
  height: auto;
}

@media screen and (min-width: 992px) {
  .sp-w100-180 {
    width: 180px;
  }
}


/*------------------------------------- */
/* ライン */
/*------------------------------------- */
.hr01 {
  border-top: solid 8px #186bb3;
  margin: 0;
  opacity: 1;
}

.hr02 {
  border-top: solid 2px #111;
  width: 100%;
}

.hr03 {
  border-bottom: solid 1px #144A7A;
  padding-bottom: 10px;
  margin: 0;
  opacity: 1;
}

@media screen and (min-width: 992px) {
  .hr03 {
    border: none;
  }
}
body {
  -webkit-font-smoothing: antialiased;
  -webkit-overflow-scrolling: touch;
  background: #FFF5EB;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif !important;
  font-weight: 400 !important;
  color: #484A4D !important;
  font-size: 15px;
}

table {
  width: 100% !important;
}

th {
  background-color: #f5f5f5 !important;
}

th,
td {
  padding: 8px 12px !important;
  border: 1px solid darkgray !important;
}

.header-nav {
  width: 100%;
  top: 15px;
  left: 0;
  right: 0;
  z-index: 1000;
}

.header-nav.change-color {
  top: 0px;
  background-color: #FFF5EB;
}

.navbar-collapse.show {
  background-color: #fff;
  padding: 10px 20px 30px;
  position: relative;
  text-align: center;
}

.btn-hamburger {
  z-index: 1100;
  background-color: #164b93 !important;
}

.btn-hamburger:focus {
  box-shadow: inherit;
}

.btn-hamburger .btn-hamburger-icon {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255,255,255,1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E");
}

.header-nav.bg-white-on {
  background-color: #fff !important;
}

@media (min-width: 992px) {
  .navbar-expand-lg {
      background: #ffffff;
  }
  .navbar-expand-xxl {
    background: #ffffff;
}  
}

.table-spacing {
  border-spacing: 3px !important;
  border-collapse: separate !important;
}

.table-th {
  display: table-cell;
  align-content: center;
}

@media screen and (min-width: 992px) {
  .container {
    max-width: 1100px;
  }

  body {
    font-size: 16px;
  }
}

#footer {
  background-color: #164b93;
  color: #fff;
  font-size: 14px;
  padding: 100px 0 80px;
  border-radius: 40px 40px 0 0;
}
@charset "UTF-8";

/*border*/

.border-bottom-white-1px {
  border-bottom: solid 1px #ffffff;
}

.border-gray-1px {
  border: solid 1px #777777;
}

.border-yellow-1px {
  border: solid 1px #E7C73D;
}

.border-lightblue-5px {
  border: solid 5px #5E8CA8;
}

.border-md-right {
  border-right: none;
}
@media screen and (min-width: 768px) {
  .border-md-right {
    border-right: solid 2px #222222;
    height:400px;
  }
}

/*width*/

.w450px {
  width: 100%;
}

@media screen and (min-width: 768px) {
  .w450px {
    width: 450px;
  }
}

.width150px-200px {
  width: 150px;
}

@media screen and (min-width: 768px) {
  .width150px-200px {
    width: 200px;
  }
}

.width150px-300px {
  width: 150px;
}

@media screen and (min-width: 768px) {
  .width150px-300px {
    width: 300px;
  }
}

/*height*/


/*位置*/
.transform-translate-n50 {
  transform: translate(-50%, -50%);
}

.top--50 {
  top: -50%;
}
.top--40 {
  top: -40%;
}

.top--33 {
  top: -33%;
}

.top--30 {
  top: -30%;
}

.top--25 {
  top: -25%;
}

.top--24 {
  top: -24%;
}

.top--20 {
  top: -20%;
}

.top--18 {
  top: -18%;
}

.top--15 {
  top: -15%;
}

.top--11 {
  top: -11%;
}

.top--2 {
  top: -2%;
}

.top-0 {
  top: 0;
}

.top-5 {
  top: 5%;
}

.top-10 {
  top: 10%;
}

.top-12 {
  top: 12%;
}

.top-15 {
  top: 15%;
}

.top-20 {
  top: 19%;
}

.top-25 {
  top: 25%;
}

.top-30 {
  top: 30%;
}

.top-35 {
  top: 35%;
}

.top-40 {
  top: 40%;
}

.top-48 {
  top: 48%;
}

.top-58 {
  top: 58%;
}

.top-70 {
  top: 70%;
}

.left--15 {
  left: -15%;
}

.left--100 {
  left:-100px;
}

.left-14 {
  left:14%;
}

.left-17 {
  left:17%;
}

.left-5 {
  left:5%;
}

.left-20 {
  left:20%;
}

.left-24 {
  left:24%;
}

.left-27 {
  left:27%;
}

.left-28 {
  left:28%;
}

.left-30 {
  left:30%;
}

.left-33 {
  left:33%;
}

.left-50 {
  left:50%;
}

.right-8 {
  right:8px;
}

.right-18 {
  right:18%;
}

.right-20 {
  right:20%;
}

.right-40 {
  right: 40%;
}

.right--100 {
  right:-100px;
}

.right--3 {
  right:-3%;
}

.right--5 {
  right:-5%;
}

.right--7 {
  right:-7%;
}

.right--10 {
  right:-10%;
}

.right--20 {
  right:-20%;
}

.right--22 {
  right:-22%;
}

.right--25 {
  right:-25px;
}

.bottom-10 {
  bottom:10%;
}

.bottom-20 {
  bottom:20%;
}

.bottom-43 {
  bottom:43%;
}

.bottom-50 {
  bottom:50%;
}

.bottom-25 {
  bottom:25%;
}

.bottom--40 {
  bottom:-40%;
}

.bottom--45 {
  bottom:-45%;
}

.bottom--130 {
  bottom:-130%;
}

.bottom--10 {
  bottom:-10%;
}

.left-0--100 {
  left:0px;
}
@media (min-width: 992px) {
  .left-0--100 {
    left:-100px;
  }
}

.top-20--25 {
  top: 20%;
}
@media (min-width: 992px) {
  .top-20--25 {
    top: -25%;
  }
}

.right--30--100 {
  right:-30px;
}
@media (min-width: 992px) {
  .right--30--100 {
    right:-100px;
  }
}

.left-auto-30 {
  left:auto;
}
@media (min-width: 1250px) {
  .left-auto-30 {
    left:30%;
  }
}

.left-auto-33 {
  left:auto;
}
@media (min-width: 1250px) {
  .left-auto-33 {
    left:33%;
  }
}

.left-30-50 {
  left:60%;
}
@media (min-width: 992px) {
  .left-30-50 {
    left:30%;
  }
}

.top--12--15 {
  top:-12%;
}
@media (min-width: 992px) {
  .top--12--15 {
    top:-15%;
  }
}

.top--50--30 {
  top:-60%;
}
@media (min-width: 992px) {
  .top--50--30 {
    top:-30%;
  }
}

.top-54-40 {
  top:54%;
}
@media (min-width: 1250px) {
  .top-54-40 {
    top:40%;
  }
}

.bottom--10--190 {
  bottom:-190%;
}
@media (min-width: 992px) {
  .bottom--10--190 {
    bottom:-10%;
  }
}

.bottom-50--100 {
  bottom:-100%;
}
@media (min-width: 992px) {
  .bottom-50--100 {
    bottom:50%;
  }
}

.z-99 {
  z-index: 99 !important;
}

.z-999 {
  z-index: 999 !important;
}

.z-9999 {
  z-index: 9999 !important;
}

.nav-item.text-center {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
}


/* TOPページのみメニュー間の「|」を消す */
.top-page .navbar-nav .nav-item + .nav-item::before {
  display: none;
}

/* または、単純に区切り線として指定されているクラスを消す場合 */
.top-page .navbar-nav li {
  border: none !important;
}

/* TOPページ（.top-page）の時だけ、メニュー展開時の背景を青にする */
.top-page .navbar-collapse {
  background-color: #164B93 !important; /* 丸商建設様の青色（任意の色コードに変えてね） */
}

/* 背景を青にしたら文字が見えなくなるので、文字を白にする */
.top-page .navbar-collapse .nav-link {
  color: #ffffff !important;
}

/* スマホ時のみ適用したい場合（PC版のナビゲーションに影響させない） */
@media (max-width: 991px) {
  .top-page .navbar-collapse {
      background-color: #164B93 !important;
      padding: 20px;
  }
}

.overflow-x-auto {
  -webkit-overflow-scrolling: touch;
  /* iOSの慣性スクロール対応 */
  scrollbar-width: none;
  /* Firefoxでスクロールバー非表示 */
}

.overflow-x-auto::-webkit-scrollbar {
  display: none;
  /* Chrome/Safariでスクロールバー非表示 */
}

/* 下層ナビ横の線 */
@media (min-width: 992px) {
  .navbar-nav .nav-item {
    position: relative;
    display: flex;
    align-items: center;
  }

  .navbar-nav .nav-item:not(:last-child)::after {
    content: "";
    display: inline-block;
    width: 1px;
    height: 15px;
    background-color: #111;
    margin: 0 5px;
  }
}

/* 下層パンくず */
.breadcrumb {
  --bs-breadcrumb-divider: ">";
}

.breadcrumb li a {
  color:#777777 !important;
  text-decoration: none;
}

/* フォントサイズ */
@media screen and (min-width: 768px) {
  .fs-lg-12 {
      font-size: 3.5rem !important;
  }
}

@media screen and (min-width: 768px) {
  .fs-lg-10 {
      font-size: 3rem !important;
  }
}

.fs15px-20px {
  font-size: 15px;
}
@media screen and (min-width: 768px) {
  .fs15px-20px {
      font-size: 20px;
  }
}

.fs12px-14px {
  font-size: 12px;
}
@media screen and (min-width: 768px) {
  .fs12px-14px {
    font-size: 14px;
  }
}

.fs36px-60px {
  font-size: 36px;
}
@media screen and (min-width: 768px) {
  .fs36px-60px {
    font-size: 60px;
  }
}

.fs16px-24px {
  font-size: 16px;
}
@media screen and (min-width: 768px) {
  .fs16px-24px {
    font-size: 24px;
  }
}

/* テキスト飾り */
.text-border-bottom-blue {text-align:center;padding-bottom:10px;}
.text-border-bottom-blue::after {
    content:'';
    display:block;
    width:65px;
    height:3px;
    background:#1247ba;
    margin:8px auto 0;
}

/* ボタン */
.btn-blue {
  position: relative;
  display: inline-block;
  padding: 20px 0;
  background-color: #164b93;
  border-radius: 50px;
  color: #fff;
  text-decoration: none;
  text-align: center;
  border:none;
}

.btn-blue:hover {
  opacity: 0.8;
}

.btn-gray {
  position: relative;
  display: inline-block;
  padding: 20px 0;
  background-color: #555555;
  border-radius: 50px;
  color: #fff;
  text-decoration: none;
  text-align: center;
  border:none;
}

.btn-gray:hover {
  opacity: 0.8;
}

.btn-orange {
  padding: 10px 0;
  background-color:#C20909;
  border-radius: 50px;
  color: #fff;
  text-decoration: none;
  text-align: center;
  border:none;
}

.btn-orange:hover {
  opacity: 0.8;
}

.btn-circle-right::before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 20px;
  width: 22px;
  height: 22px;
  margin: auto;
  border-radius: 20px;
  background-color: #fff;
}
.btn-circle-right::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 25px;
  width: 0;
  height: 0;
  margin: auto;
  border-top: 6px solid transparent;
  border-right: 0 solid transparent;
  border-left: 9px solid #164b93;
  border-bottom: 6px solid transparent;
  box-sizing: border-box;
}

.btn-circle-right-gray::before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 20px;
  width: 22px;
  height: 22px;
  margin: auto;
  border-radius: 20px;
  background-color: #fff;
}
.btn-circle-right-gray::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 25px;
  width: 0;
  height: 0;
  margin: auto;
  border-top: 6px solid transparent;
  border-right: 0 solid transparent;
  border-left: 9px solid #555555;
  border-bottom: 6px solid transparent;
  box-sizing: border-box;
}

/* top */

#section02 {
  background-image: none;
  position:relative;
  height:330px;
}

@media screen and (min-width: 1250px) {
  #section02 {
    background-size: cover,cover;
    background-position: 0 20%,100% -50px;
    background-repeat: no-repeat,no-repeat;
    background-size: 400px, 400px;
    height:540px;
    background-image: url(../../assets/img/section02-illust01.png), url("../../assets/img/section02-illust02.png");
  }
}

@media screen and (min-width: 1500px) {
  #section02 {
    background-size: cover,cover;
    background-position: 0 20%,100% -50px;
    background-repeat: no-repeat,no-repeat;
    background-size: 550px, 550px;
    background-image: url(../../assets/img/section02-illust01.png), url("../../assets/img/section02-illust02.png");
  }
}


  .section06-bg {
    background-size: 100% 100%;
    background-position: top;
    background-repeat: no-repeat;
    background-image: url(../../assets/img/bg-section06.png);
  }

  .section06-waku:hover .btn-orange {
    background-color: #ff9900; /* 背景色を変更 */
    color: #fff; /* 文字色を変更 */
    transition: background-color 0.3s ease, color 0.3s ease; /* スムーズな変化 */
  }


.section11-bg {
  background-image: none;
}

@media screen and (min-width: 992px) {
  .section11-bg {
    background-size: 100%;
    background-position: bottom center;
    background-repeat: no-repeat;
    background-image: url(../../assets/img/bg-company.png);
  }
}

/* slider */
.slick-dots li button:before {
  font-size: 11px;
  color: #164B93;
  opacity: 0.25;
}

.slick-dots li.slick-active button:before {
  color: #164B93;
  opacity: 1;
}

.slider01 {
  width: 100%;
}
.slider-img img {
  height: auto;
  width: 100%;
}

.slider02 .slider-img {
  margin: 0 10px; /* 上下0、左右10px */
}

.slider02 {
  margin: 0 -10px;
}

.slider02 .slider-img img {
  width: 100%;
  height: auto;
  display: block;
}

.slick-dots {
  bottom: -40px !important; 
}

.slider01, .slider02, .slider03 {
  margin-bottom: 60px !important; 
}

.slider03 .slider-img {
  margin: 0 10px; /* 上下0、左右10px */
}

.slider04 .slider-img {
  margin: 0 10px; /* 上下0、左右10px */
  max-width:100%;
  overflow:hidden;
}

.slider04 {
  margin-bottom: 100px !important; 
}

.slick-prev:before, .slick-next:before {
  color: #164b93 !important;
  font-size: 30px; /* サイズも少し大きくすると分かりやすい */
}

.slick-prev {
  left: -30px;
}

/* サイト全体で横へのはみ出しを禁止する */
body, .top-page {
  overflow-x: hidden;
}

/* スライダー自体のはみ出しを防止 */
.slick-list {
  margin: 0 !important;
}


/* 見学会・イベント情報 */
.bg-modelhouse {
  background-position: -460px 250px;
  background-repeat: no-repeat;
  background-size: 130%;
  background-image: url(../../assets/img/bg-modelhouse.png);
}

/* 物件情報 */
.pr-img img {
  max-width: 100%;
  margin:30px 0;
}

/* 施工事例 */
.sec-works {
  font-size: 16px !important;
}
.sec-works h2 {
  font-size: 18px !important;
}

/* お客様の声 */
.sec-voice p {
  font-size: 16px !important;
}
.sec-voice h3 {
  font-size: 18px !important;
}


/* 画像比率 */
.img-3_2 {
  width: 100%; /* 横幅を親要素に合わせる */
  aspect-ratio: 3 / 2; /* アスペクト比を3:2に設定 */
  object-fit: cover; /* 画像を枠内に収める */
}
@charset "UTF-8";

.li-stylenone{
    list-style:none;
}

.custom-list {
    list-style: none; 
    counter-reset: my-ct;
    padding-left: 1.5em; 
  }
  
  .custom-list li {
    counter-increment: my-ct; 
    position: relative;
    margin-bottom: 0.5em;
  }
  
  .custom-list li::before {
    content: counter(my-ct) "）"; 
    position: absolute;
    left: -1.5em;
    color: #333;
  }

  .circle-list-naka {
    list-style: none;
    counter-reset: circle-ct; 
    padding-left: 2em;
    margin-top:10px;
  }
  
  .circle-list-naka li {
    counter-increment: circle-ct;
    position: relative;
  }
  
  .circle-list-naka li::before {
    content: counter(circle-ct); 
    position: absolute;
    left: -2.2em;
    top: 0.1em;
    width: 1.6em;
    height: 1.6em;
    border:solid 1px #111;
    border-radius: 50%; 
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75em;
  }

.word-break {
    word-break: break-all;
}

.form-control,
.form-select,
textarea.form-control {
  font-size: 1rem !important;
}
