@charset "UTF-8";
/*-----------------------------------------------------------------
  目次
  --------------------------------------------------------------
//tool:外部読み込み
Setting：変数及びmixin
//reset：基本外部cssを読み込む
Base：このサイト用の基本css
Layout:サイト共通で使われるもの。ヘッダ、フッタ等。
	1:header
	2:footer
page:ページ別
	1:top
module:汎用モジュールcss
utility：ユーティリティ
*/
/* ==========================================================================
   Base
   ======================================================================= */
* {
  box-sizing: border-box;
}

body {
  line-height: 1.8;
  font-size: 14px;
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "Lucida Grande", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", Meiryo, "メイリオ", sans-serif;
  color: #333;
  background: #faf5f0;
}
@media screen and (min-width: 767px) {
  body {
    font-size: 18px;
  }
}

img {
  max-width: 100%;
  border: 0;
  vertical-align: bottom;
}

a {
  text-decoration: none;
  color: #00f;
}

a, li {
  margin: 0;
  padding: 0;
}

/* ==========================================================================
   Layout
   ======================================================================= */
/*1:header
-------------------------------------------*/
/*2:footer
-------------------------------------------*/
@media screen and (min-width: 767px) {
  #wrap {
    width: 762px;
    margin: 0 auto 40px;
  }
}

/*---------------------------------------------
footer
 -----------------------------------------------*/
#footer {
  background: #29468c;
  text-align: center;
  color: #fff;
  padding: 2vw 0;
}
@media screen and (min-width: 767px) {
  #footer {
    font-size: 14px;
    padding: 6px 0;
  }
}
#footer a {
  color: #fff;
}

/* ==========================================================================
   page
   ======================================================================= */
/*---------------------------------------------
fv
 -----------------------------------------------*/
#fv {
  padding: 4vw 0 2vw;
  background: url("../images/fv_bg.png") no-repeat;
  background-size: cover;
}
@media screen and (min-width: 767px) {
  #fv {
    padding: 20px 20px;
  }
}

.fv__tit {
  margin: 3.5%;
}
@media screen and (min-width: 767px) {
  .fv__tit {
    width: 490px;
    margin: 0;
  }
}

/*---------------------------------------------
main_nav
 -----------------------------------------------*/
.main_nav {
  margin: 0 3.2%;
  padding: 8vw 0 8vw;
}
@media screen and (min-width: 767px) {
  .main_nav {
    width: 752px;
    margin: 0 auto;
    padding: 20px 0;
  }
}

.main_nav__list {
  display: -webkit-box;
  /*--- Androidブラウザ用 ---*/
  display: -ms-flexbox;
  /*--- IE10 ---*/
  display: -webkit-flex;
  /*--- safari（PC）用 ---*/
  display: flex;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  /* Safari */
  justify-content: space-between;
}
.main_nav__list li {
  width: 48%;
  margin-bottom: 3vw;
  background: #e5e5e5;
  box-shadow: 0 1px 2px #ccc;
}
.main_nav__list li:hover {
  background: #cadef6;
}
@media screen and (min-width: 767px) {
  .main_nav__list li {
    width: 32%;
    margin-bottom: 8px;
  }
}

/*---------------------------------------------
sec01
 -----------------------------------------------*/
.sec01_01 {
  margin-bottom: 6vw;
}
@media screen and (min-width: 767px) {
  .sec01_01 {
    margin-bottom: 40px;
  }
}

@media screen and (min-width: 767px) {
  .sec01_txt {
    max-width: 590px;
    margin: 0 auto;
  }
}

/*---------------------------------------------
 sec02
 -----------------------------------------------*/
.sec02__tit01 {
  margin: 0 6% 0;
}
@media screen and (min-width: 767px) {
  .sec02__tit01 {
    margin: 0;
  }
}

.sec02_img04 {
  display: block;
  width: 80%;
  margin: 0 auto 4vw;
}
@media screen and (min-width: 767px) {
  .sec02_img04 {
    width: 44%;
    float: left;
    margin: 0 20px 40px 0;
  }
}

@media screen and (min-width: 767px) {
  .kyoupro {
    width: 52%;
    float: right;
  }
}

.sec02_img04_02 {
  display: block;
  width: 60%;
  margin: 0 auto 4vw;
}
@media screen and (min-width: 767px) {
  .sec02_img04_02 {
    display: inline-block;
    width: 82%;
    margin: 0 0 20px;
  }
}

.sec02__box01 {
  border: 2px solid #29468c;
  background: #fafaf0;
  margin: 0 6% 10vw;
  padding: 4vw 4vw;
}
@media screen and (min-width: 767px) {
  .sec02__box01 {
    margin: 0 0px 40px;
    padding: 30px 36px;
  }
}

.sec02_img01 {
  display: block;
  width: 44%;
  margin: 2vw auto 6vw;
}
@media screen and (min-width: 767px) {
  .sec02_img01 {
    display: inline-block;
    float: right;
    width: 200px;
    margin: 20px auto 0 20px;
  }
}

.sec02_tit01 {
  color: #29468c;
  text-align: center;
  font-weight: bold;
}
@media screen and (min-width: 767px) {
  .sec02_tit01 {
    margin-bottom: 26px;
  }
}
.sec02_tit01 dt {
  display: inline-block;
  padding: 6px 12px;
  background: #29468c;
  color: #fff;
  margin-bottom: 4vw;
}
@media screen and (min-width: 767px) {
  .sec02_tit01 dt {
    float: left;
    height: 44px;
    margin-bottom: 0;
  }
}
.sec02_tit01 dd {
  font-size: 18px;
  border-bottom: 1px solid #29468c;
  text-align: center;
  margin-bottom: 4vw;
}
@media screen and (min-width: 767px) {
  .sec02_tit01 dd {
    font-size: 22px;
    height: 44px;
    text-align: left;
    padding-left: 84px;
    margin-bottom: 0;
  }
}

.sec02_05 {
  margin-bottom: 6vw;
}
@media screen and (min-width: 767px) {
  .sec02_05 {
    margin-bottom: 30px;
  }
}

.sec02_06 {
  display: block;
  margin: 0 auto;
  width: 80%;
}
@media screen and (min-width: 767px) {
  .sec02_06 {
    width: 270px;
  }
}

.sec02_hataraki {
  width: 74vw;
  margin: 0 auto 12vw;
}
@media screen and (min-width: 767px) {
  .sec02_hataraki {
    width: auto;
    margin: 0 auto 80px;
  }
}
.sec02_hataraki:last-child {
  margin: 0 auto 0;
}

.sec02_img02_sp img {
  display: block;
  width: 400px;
  margin: 0 auto;
}

@media screen and (min-width: 767px) {
  .u_sec02_box02 {
    max-width: 620px;
    margin: 0 auto;
  }
}

/*---------------------------------------------
 sec02ex
 -----------------------------------------------*/
#sec02ex {
  text-align: center;
  border: 2px #f00 solid;
  background: #fff;
  padding: 4vw 4vw;
  width: 84%;
  margin: 0 auto 8vw;
}
@media screen and (min-width: 767px) {
  #sec02ex {
    text-align: left;
    padding: 12px 18px;
    width: 654px;
    margin: 0 auto 50px;
  }
}
#sec02ex .sec02ex_01 {
  display: block;
  margin: 0 auto 3vw auto;
  width: 12%;
}
@media screen and (min-width: 767px) {
  #sec02ex .sec02ex_01 {
    float: left;
    margin: 20px 16px 0 0;
  }
}
#sec02ex .chui {
  font-size: 18px;
  display: inline-block;
  background: #f00;
  color: #fff;
  font-weight: bold;
  margin-bottom: 3vw;
  padding: 4px 20px 2px;
  line-height: 1.4;
}
@media screen and (min-width: 767px) {
  #sec02ex .chui {
    margin-bottom: 8px;
  }
}
#sec02ex .txt01 {
  font-size: 17px;
  margin-bottom: 2vw;
  line-height: 1.4;
}
@media screen and (min-width: 767px) {
  #sec02ex .txt01 {
    margin-bottom: 0px;
  }
}
@media screen and (min-width: 767px) {
  #sec02ex .txt01 br {
    display: none;
  }
}
#sec02ex .txt02 {
  line-height: 1.1;
}
@media screen and (min-width: 767px) {
  #sec02ex .txt02 br {
    display: none;
  }
}
#sec02ex .txt02 img {
  height: 8vw;
}
@media screen and (min-width: 767px) {
  #sec02ex .txt02 img {
    height: 36px;
  }
}

#src00ex {
  text-align: center;
  border: 3px #4980ff solid;
  background: #fff;
  padding: 2vw 2vw;
  width: 80%;
  margin: 0 auto 6vw;
}


/*---------------------------------------------
sec03
 -----------------------------------------------*/
.sec03_01 {
  margin-bottom: 8vw;
}
@media screen and (min-width: 767px) {
  .sec03_01 {
    margin-bottom: 50px;
  }
}

.sec03_reason__box {
  width: 72vw;
  margin: 0 auto 10vw;
  font-size: 18px;
}
@media screen and (min-width: 767px) {
  .sec03_reason__box {
    width: auto;
    margin: 0 auto 40px;
    font-size: 20px;
  }
}
.sec03_reason__box .img {
  width: 60vw;
  margin: 0 auto 6vw;
}
@media screen and (min-width: 767px) {
  .sec03_reason__box .img {
    width: 190px;
    float: left;
    margin: 0 auto 0;
  }
}
.sec03_reason__box .txt {
  line-height: 1.6;
}
@media screen and (min-width: 767px) {
  .sec03_reason__box .txt {
    float: left;
    padding-left: 22px;
    text-align: left;
    width: 70%;
  }
}
.sec03_reason__box .txt br {
  display: none;
}
@media screen and (min-width: 767px) {
  .sec03_reason__box .txt br {
    display: block;
  }
}
.sec03_reason__box .reason {
  display: block;
  width: 17vw;
  margin: 0 auto 4vw;
}
@media screen and (min-width: 767px) {
  .sec03_reason__box .reason {
    width: 66px;
    margin: 0 0 20px;
  }
}

.sec03_03 {
  display: block;
  width: 92%;
  margin: 0 auto 6vw;
}
@media screen and (min-width: 767px) {
  .sec03_03 {
    float: left;
    width: 240px;
    margin: 0 30px 20px 0;
  }
}

.sec03_04 {
  display: block;
  width: 90%;
  margin: 0 auto 6vw;
}
@media screen and (min-width: 767px) {
  .sec03_04 {
    float: right;
    width: 254px;
    margin: 0 0px 20px 20px;
  }
}

/*---------------------------------------------
sec04
 -----------------------------------------------*/
.sec04_01 {
  margin: 0 4vw 4vw;
}
@media screen and (min-width: 767px) {
  .sec04_01 {
    margin: 0 0 20px;
  }
}

.sec04__box01 {
  padding: 4vw 4vw;
}
@media screen and (min-width: 767px) {
  .sec04__box01 {
    padding: 20px;
  }
}
.sec04__box01:after {
  content: "";
  display: block;
  clear: both;
}
.sec04__box01 .sec04_03 {
  display: block;
  width: 49%;
  margin: 0 auto 4vw;
}
@media screen and (min-width: 767px) {
  .sec04__box01 .sec04_03 {
    float: right;
    width: 136px;
    margin: 0 0 0 10px;
  }
}
.sec04__box01 .txt {
  text-align: left;
}
@media screen and (min-width: 767px) {
  .sec04__box01 .txt {
    width: 70%;
    float: left;
  }
}

.sec04__box {
  background: #fff;
  margin-bottom: 20px;
  text-align: center;
}
@media screen and (min-width: 767px) {
  .sec04__box {
    width: 100%;
  }
}

/*---------------------------------------------
sec05
 -----------------------------------------------*/
#sec05 {
  background: url("../images/sec05_bg02.jpg");
  background-size: 100% auto;
  margin: 0 8% 8vw;
}
@media screen and (min-width: 767px) {
  #sec05 {
    width: 660px;
    margin: 0 auto 50px;
    font-size: 18px;
  }
}
#sec05:before {
  content: "";
  width: 100%;
  height: 20px;
  display: block;
  background: url("../images/sec05_bg01.jpg") no-repeat;
  background-size: 100% auto;
  vertical-align: top;
}

.sec05__in {
  padding: 4vw;
}
@media screen and (min-width: 767px) {
  .sec05__in {
    padding: 4px 40px;
  }
}

.sec05_01 {
  margin-bottom: 4vw;
}
@media screen and (min-width: 767px) {
  .sec05_01 {
    width: 420px;
    margin-bottom: 18px;
  }
}

.sec05_02 {
  display: block;
  width: 50%;
  margin: 0 auto 6vw;
}
@media screen and (min-width: 767px) {
  .sec05_02 {
    float: right;
    width: 160px;
    margin: 0 0 20px 20px;
  }
}

.sec05_03 {
  display: block;
  width: 60%;
  margin: 0 auto 6vw;
}
@media screen and (min-width: 767px) {
  .sec05_03 {
    float: left;
    margin-right: 24px;
    margin-bottom: 16px;
    width: 200px;
  }
}

/*---------------------------------------------
sec06
 -----------------------------------------------*/
#sec06 {
  font-size: 12px;
}
@media screen and (min-width: 767px) {
  #sec06 {
    font-size: 17px;
  }
}
#sec06 .shutten {
  color: #29468c;
  font-size: 10px;
  margin-top: 1em;
  text-align: center;
}
@media screen and (min-width: 767px) {
  #sec06 .shutten {
    font-size: 12px;
  }
}
#sec06 .sec06_02 {
  width: 60%;
}
@media screen and (min-width: 767px) {
  #sec06 .sec06_02 {
    width: auto;
  }
}

/*---------------------------------------------
sec07
 -----------------------------------------------*/
.sec07__tit01 {
  background: #29468c;
}

#sec07 {
  margin: 4vw 8vw;
}
@media screen and (min-width: 767px) {
  #sec07 {
    margin: 42px 42px;
  }
}

.sec07__box {
  border: 2px solid #29468c;
  background: #fff;
  margin: 0 0 8vw;
  padding: 4vw 4vw;
}
@media screen and (min-width: 767px) {
  .sec07__box {
    margin: 0 0px 40px;
    padding: 30px 36px;
  }
}

@media screen and (min-width: 767px) {
  .sec07_01 {
    width: 380px;
  }
}

/*---------------------------------------------
about
 -----------------------------------------------*/
.about {
  width: 92%;
  margin: 2.5em auto;
}
@media screen and (min-width: 767px) {
  .about {
    width: 80%;
    font-size: 14px;
  }
}

/* ==========================================================================
   module：汎用モジュール
   ======================================================================= */
.cv {
  position: relative;
  padding: 0 0 0 10%;
  width: 86%;
  margin: 0 auto 8%;
}
.cv .a-arrow {
  position: absolute;
  top: 16%;
  left: -1%;
  -webkit-animation-duration: 1s;
  -moz-animation-duration: 1s;
  -ms-animation-duration: 1s;
  -o-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-timing-function: ease-in;
  -moz-animation-timing-function: ease-in;
  -o-animation-timing-function: ease-in;
  animation-timing-function: ease-in;
  -moz-animation-iteration-count: infinite;
  -webkit-animation-iteration-count: infinite;
  -o-animation-iteration-count: infinite;
  -ms-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -webkit-animation-name: animate2;
  -moz-animation-name: animate2;
  -o-animation-name: animate2;
  animation-name: animate2;
  z-index: 9;
  width: 14%;
  max-width: 68px;
}
.cv .cv__btm {
  border-radius: 8px;
  border: 1px solid #FFFFFF;
  width: 100%;
  background: #ff9e20;
  color: #fff;
  display: inline-block;
  font-weight: bold;
  padding: 3% 4%;
  text-decoration: none;
  text-align: center;
  box-sizing: border-box;
  box-shadow: 0 0 6px #af6300;
}

.cv:hover {
  opacity: 0.8;
}

@-webkit-keyframes animate2 {
  0% {
    -webkit-transform: translateX(0px);
  }
  45% {
    -webkit-transform: translateX(20px);
  }
  50% {
    -webkit-transform: translateX(25px);
  }
  55% {
    -webkit-transform: translateX(20px);
  }
  95% {
    -webkit-transform: translateX(0px);
  }
  100% {
    -webkit-transform: translateX(0px);
  }
}
/* ==========================================================================
   utility：汎用クラス
   ======================================================================= */
.utl {
  text-align: left;
}

.utc {
  text-align: center;
}

.utr {
  text-align: right;
}

.ustrong {
  font-weight: bold;
}

/*独自*/
.uspbr {
  display: none;
}
@media screen and (max-width: 768px) {
  .uspbr {
    display: block;
  }
}

.dsp {
  display: block !important;
}
@media screen and (min-width: 767px) {
  .dsp {
    display: none !important;
  }
}

img.dsp {
  display: inline-block !important;
}
@media screen and (min-width: 767px) {
  img.dsp {
    display: none !important;
  }
}

.dpc {
  display: none !important;
}
@media screen and (min-width: 767px) {
  .dpc {
    display: block !important;
  }
}

img.dpc {
  display: none !important;
}
@media screen and (min-width: 767px) {
  img.dpc {
    display: inline-block !important;
  }
}

.clearfix:after, .sec03_reason__box:after {
  content: "";
  clear: both;
  display: block;
}

.u_sec {
  padding: 6vw 3.5%;
  background: #fff;
  margin-bottom: 8vw;
  border-top: 2px solid #eeeeee;
  border-bottom: 2px solid #eeeeee;
}
@media screen and (min-width: 767px) {
  .u_sec {
    padding: 40px  50px;
    background: #fff;
    margin-bottom: 50px;
    border: 2px solid #eeeeee;
  }
}

.u_title01 {
  position: relative;
  border: 2px solid #29468c;
  border-radius: 24px;
  background: #cadef6;
  padding: 10px 0 10px 30px;
  color: #29468c;
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 20px;
  line-height: 1.4;
}
@media screen and (min-width: 767px) {
  .u_title01 {
    border-radius: 32px;
    padding: 10px 0 10px 60px;
    font-size: 28px;
    margin-bottom: 32px;
    line-height: 1.4;
  }
}
.u_title01:before {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  background: #fff;
  border-radius: 10px;
  border: 2px solid #29468c;
  top: 15px;
  left: 12px;
}
@media screen and (min-width: 767px) {
  .u_title01:before {
    width: 16px;
    height: 16px;
    top: 18px;
    left: 20px;
  }
}

.u_title02 {
  position: relative;
  color: #29468c;
  font-size: 18px;
  padding-left: 20px;
  font-weight: bold;
}
@media screen and (min-width: 767px) {
  .u_title02 {
    font-size: 22px;
    margin-bottom: 6px;
  }
}
.u_title02:before {
  position: absolute;
  display: inline-block;
  content: "";
  width: 6px;
  height: 6px;
  transform: rotate(-45deg);
  background: #29468c;
  left: 7px;
  top: 10px;
}
@media screen and (min-width: 767px) {
  .u_title02:before {
    width: 8px;
    height: 8px;
    left: 4px;
    top: 16px;
  }
}

.u_txtbox01 {
  margin-bottom: 6vw;
}
.u_txtbox01:last-child {
  margin-bottom: 0;
}
@media screen and (min-width: 767px) {
  .u_txtbox01 {
    margin-bottom: 40px;
  }
}

.u_txtbox01inbox {
  padding: 0 4vw;
}
@media screen and (min-width: 767px) {
  .u_txtbox01inbox {
    max-width: 590px;
    margin: 0 auto;
    padding: 0;
  }
}

.u_strong {
  color: #cc6633;
  text-decoration: underline;
  font-weight: bold;
}

.u_strong02 {
  font-weight: bold;
}

.u_box01 {
  padding: 3vw 3vw;
  background: #eff5fc;
  margin-bottom: 4vw;
}
@media screen and (min-width: 767px) {
  .u_box01 {
    padding: 30px 30px;
    margin-bottom: 20px;
  }
}
.u_box01 .u_txtbox01 {
  padding: 0;
}

.u_box02 {
  border: 2px solid #29468c;
  background: #fafaf0;
  margin: 0 6% 8vw;
  padding: 6vw 4vw;
}
@media screen and (min-width: 767px) {
  .u_box02 {
    margin: 0 0 80px;
    padding: 40px 40px;
  }
}

.u_box02tit {
  margin: 0 6% 0;
}

.u_list01 {
  margin-bottom: 6vw;
  font-size: 12px;
}
@media screen and (min-width: 767px) {
  .u_list01 {
    margin-bottom: 0px;
    font-size: 14px;
  }
}
.u_list01 li {
  position: relative;
  padding-left: 20px;
}
.u_list01 li:before {
  position: absolute;
  display: inline-block;
  content: "";
  width: 6px;
  height: 6px;
  transform: rotate(-45deg);
  background: #29468c;
  left: 7px;
  top: 10px;
}

.umb0 {
  margin-bottom: 0px !important;
}

