@charset "UTF-8";

/**
 * common.css
 *
 * #base
 *  #reset.............リセット用
 *  #default...........要素用
 *
 * #layout
 *
 * #common module
 *  #全ページ共通ヘッダー
 *  #全ページ共通フッター
 *
 * #utility.........ヘルパークラス
 *  #Margin
 *  #Padding
 *  #font
 *  #position
 *  #other.............clearfix等
*/


/* ==========================================================================
   #base
   ========================================================================== */

/* #reset
   ----------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6, p, ul, li {
  margin: 0;
  padding: 0;
}

h1, h2, h3, h4, h5, h6, th { font-weight: 600; }

ul { list-style: none; }

strong { font-weight: 600; }





/* #default
   ----------------------------------------------------------------- */
body {
  color: #222;
  font-size: 16px;
  font-family: "Helvetica Neue", Helvetica, "Hiragino Sans", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
   /* font-family: "Helvetica Neue", Helvetica, "游ゴシック", YuGothic, "Hiragino Sans", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif; */
  line-height: 1.6;
  font-weight: 400;
}


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

img {
  vertical-align: bottom;
}

*, *:before, *:after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}





/* ==========================================================================
   #layout
   ========================================================================== */


body {
  margin: 0 auto;
  min-width: 1200px;
}

/* 朱色太字*/

.point-txt-01 {
  font-weight: 600;
  color: #ed5121;
}

/* 黒太字*/

.point-txt-02 {
  font-weight: 600;  
}

/* 朱色細字*/

.point-txt-03 {
  color: #ed5121;
}

/* マーカー*/
.point-txt-04 {
  font-weight: 600;
  background-color: #fcff00;
}

/*青細字*/
.point-txt-05 {
  color: #1458bf;
}

/* ==========================================================================
   #common module
   ========================================================================== */

/* #全ページ共通パーツ
   ----------------------------------------------------------------- */

/* テキスト関係
----------------------- */
/*ポイント 赤*/
.point-txt { color: #d24c4a; }

/*マーカー 黄色*/
.marker {
  background: linear-gradient(transparent 75%, #f4d600 0%);
  background-color: #f4d600\9;
}





/* # ヘッダー（下層）
   ----------------------------------------------------------------- */

.header-02 {
  border-top: 3px solid #1458bf;
  border-bottom: 1px solid #1458bf;
  background: #fff;
}

.l-header-menu {
  margin: 0 auto;
  width: 860px;
}

.header-logo02 {
  display: block;
  float: left;
  margin: 13px 0 15px 0;
}

.header-menu {
  float: right;
  width: 500px;
  margin: 25px 70px 0 0 ;
  font-size: 14px;
}

.header-menu-item {
  float: left;
  /* width: 164px; */
}

.header-menu-item a {
  color: #222;
  font-size: 14px;
  text-decoration: none;
}

.header-menu-item+.header-menu-item {
  margin-left: 54px;
}





/* 全ページ共通フッター
   ----------------------------------------------------------------- */


.footer {
  margin-bottom: 65px;
  background-color: #fff;
  border-top: 1px solid #1458bf;
}

.footer-inner {
  overflow: hidden;
  width: 1000px;
  margin: 0 auto;
  padding: 50px 0 20px 20px;
}

.footer-menu {
  overflow: hidden;
  float: left;
  width: 600px;
}

.footer-menu-item {
  float: left;
  margin: 0 35px 27px 0;
}

.footer-menu-item a:before {
  content: "";
  position: absolute;
  top: 2px;
  left: 0;
  border-left: 6px solid #ed5121;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
}

.footer-menu-item a {
  position: relative;
  display: block;
  padding-left: 16px;
  color: #222;
  font-size: 16px;
  line-height: 1;
  text-decoration: none;
}

.footer-copy {
  padding: 14px 0;
  color: #fff;
  font-size: 12px;
  line-height: 1;
  text-align: center;
  background-color: #1458bf;
}

.footer-copy {
  display: block;
  font-size: inherit;
}

.footer-logo {
  float: right;
  margin: -20px 120px 0 0;
}


/* #  追従フッター　----------------------------------------------------------------- */


.footer-flow.show {
  transform: translateY(0);
}

.footer-flow {
  position: fixed;
  bottom: 0;
  right: 0;
  width: 100%;
  background: #fff;
  border-top: 3px solid #1458bf;
  z-index: 1000;
  transition: 0.4s;
  transform: translateY(114px);
  box-sizing: content-box;
  height: 88px;
}

.footer-flow-inner:before {
  content: "";
  position: absolute;
  top: -1px;
  right: 100%;
  display: block;
  width: 1500px;
  height: 89px;
  background: #1458bf;
}

.footer-flow-inner {
  position: relative;
  width: 1000px;
  margin: 0 auto;
  background: #fff;
}

.footer-flow-staff {
  position: absolute;
  top: -17px;
  left: -75px;
}

.footer-flow-contact {
  position: relative;
  float: right;
  width: 696px;
}

.footer-flow-tel {
  float: left;
  margin: 15px 0 0 0 ;
}

.footer-flow-contact-time {
  margin: -18px 0 0 20px;
}

/* 0800切替用スタイル */
.footer-flow-tel .js-set-tel {
  position: absolute;
  top: 36px;
  left: 66px;
  display: block;
  /* width: 244px; */
  color: #1a2e5b;
  font-size: 38px;
  font-family: Helvetica, "Helvetica Neue";
  font-weight: 600;
  text-align: center;
  line-height: 1;
  white-space: nowrap;
}


/* ==========================================================================
   #utility
   ========================================================================== */

/* #Margin
   ----------------------------------------------------------------- */
.m0{ margin:0!important; }

.mr0 { margin-right: 0!important; }
.mr5 { margin-right: 5px!important; }
.mr10 { margin-right: 10px!important; }
.mr15 { margin-right: 15px!important; }
.mr20 { margin-right: 20px!important; }
.mr25 { margin-right: 25px!important; }
.mr30 { margin-right: 30px!important; }
.mr35 { margin-right: 35px!important; }
.mr40 { margin-right: 40px!important; }
.mr45 { margin-right: 45px!important; }
.mr50 { margin-right: 50px!important; }

.ml0 { margin-left: 0!important; }
.ml5 { margin-left: 5px!important; }
.ml10 { margin-left: 10px!important; }
.ml15 { margin-left: 15px!important; }
.ml20 { margin-left: 20px!important; }
.ml25 { margin-left: 25px!important; }
.ml30 { margin-left: 30px!important; }
.ml35 { margin-left: 35px!important; }
.ml40 { margin-left: 40px!important; }
.ml45 { margin-left: 45px!important; }
.ml50 { margin-left: 50px!important; }

.mt0 { margin-top: 0!important; }
.mt5 { margin-top: 5px!important; }
.mt10 { margin-top: 10px!important; }
.mt15 { margin-top: 15px!important; }
.mt20 { margin-top: 20px!important; }
.mt25 { margin-top: 25px!important; }
.mt30 { margin-top: 30px!important; }
.mt35 { margin-top: 35px!important; }
.mt40 { margin-top: 40px!important; }
.mt45 { margin-top: 45px!important; }
.mt50 { margin-top: 50px!important; }

.mb0 { margin-bottom: 0!important; }
.mb1 { margin-bottom: 1px!important }
.mb2 { margin-bottom: 2px!important }
.mb3 { margin-bottom: 3px!important }
.mb4 { margin-bottom: 4px!important }
.mb5 { margin-bottom: 5px!important }
.mb10 { margin-bottom: 10px!important; }
.mb15 { margin-bottom: 15px!important; }
.mb20 { margin-bottom: 20px!important; }
.mb25 { margin-bottom: 25px!important; }
.mb30 { margin-bottom: 30px!important; }
.mb35 { margin-bottom: 35px!important; }
.mb40 { margin-bottom: 40px!important; }
.mb45 { margin-bottom: 45px!important; }
.mb50 { margin-bottom: 50px!important; }


/* #Padding
   ----------------------------------------------------------------- */
.p0{ padding: 0!important; }

.pr0 { padding-right: 0!important; }
.pr5 { padding-right: 5px!important; }
.pr10 { padding-right: 10px!important; }
.pr15 { padding-right: 15px!important; }
.pr20 { padding-right: 20px!important; }
.pr25 { padding-right: 25px!important; }
.pr30 { padding-right: 30px!important; }
.pr35 { padding-right: 35px!important; }
.pr40 { padding-right: 40px!important; }
.pr45 { padding-right: 45px!important; }
.pr50 { padding-right: 50px!important; }

.pl0 { padding-left: 0!important; }
.pl5 { padding-left: 5px!important; }
.pl10 { padding-left: 10px!important; }
.pl15 { padding-left: 15px!important; }
.pl20 { padding-left: 20px!important; }
.pl25 { padding-left: 25px!important; }
.pl30 { padding-left: 30px!important; }
.pl35 { padding-left: 35px!important; }
.pl40 { padding-left: 40px!important; }
.pl45 { padding-left: 45px!important; }
.pl50 { padding-left: 50px!important; }

.pt0 { padding-top: 0!important; }
.pt1 { padding-top: 1px!important; }
.pt2 { padding-top: 2px!important; }
.pt3 { padding-top: 3px!important; }
.pt4 { padding-top: 4px!important; }
.pt5 { padding-top: 5px!important; }
.pt10 { padding-top: 10px!important; }
.pt15 { padding-top: 15px!important; }
.pt20 { padding-top: 20px!important; }
.pt25 { padding-top: 25px!important; }
.pt30 { padding-top: 30px!important; }
.pt35 { padding-top: 35px!important; }
.pt40 { padding-top: 40px!important; }
.pt45 { padding-top: 45px!important; }
.pt50 { padding-top: 50px!important; }

.pb0 { padding-bottom: 0!important; }
.pb1 { padding-bottom: 1px!important; }
.pb2 { padding-bottom: 2px!important; }
.pb3 { padding-bottom: 3px!important; }
.pb4 { padding-bottom: 4px!important; }
.pb5 { padding-bottom: 5px!important; }
.pb10 { padding-bottom: 10px!important; }
.pb15 { padding-bottom: 15px!important; }
.pb20 { padding-bottom: 20px!important; }
.pb25 { padding-bottom: 25px!important; }
.pb30 { padding-bottom: 30px!important; }
.pb35 { padding-bottom: 35px!important; }
.pb40 { padding-bottom: 40px!important; }
.pb45 { padding-bottom: 45px!important; }
.pb50 { padding-bottom: 50px!important; }





/* #font
   ----------------------------------------------------------------- */
.tc { text-align: center; }
.tl { text-align: left; }
.tr { text-align: right; }

.tdu { text-decoration: underline; }

.lh10 { line-height: 1em; }
.lh15 { line-height: 1.5em; }
.lh2 { line-height: 2em; }
.lh3 { line-height: 3em; }

.vm { vertical-align: middle; }
.vt { vertical-align: top; }

.fs08 { font-size: 0.8em; }
.fs09 { font-size: 0.9em; }
.fs1 { font-size: 1em; }
.fs11 { font-size: 1.1em; }
.fs12 { font-size: 1.2em; }
.fs13 { font-size: 1.3em; }

.bn { border:none; }
.bbn { border-bottom: none; }
.bol { font-weight: 600; }





/* #position
   ----------------------------------------------------------------- */
.relative { position: relative; }
.absolute { position: absolute; }

/* float解除 */
.cb { clear:both; }

/* float */
.fl-left { float: left; }
.fl-right { float: right; }





/* #other
   ----------------------------------------------------------------- */
.oh { overflow: hidden; }
.di { display: inline; }
.db { display: block; }

.clearfix:before, .clearfix:after {
  content:"";
  display:table;
}

.clearfix:after { clear:both; }
.clearfix { zoom: 1; } /* For IE 6/7 */