@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: bold; }

ul { list-style: none; }

strong { font-weight: bold; }





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

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

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



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





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

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

/* テキスト関係
----------------------- */


/* #全ページ共通ヘッダー
   ----------------------------------------------------------------- */
.header-logo {
  float: left;
  width: 50.9333333333%;
  padding: 0 7.7333333333% 0 4%;
}

.header-logo-link {
  display: block;
  margin-top: 7.4829931973%;
  font-size: 0;
}

.header-logo-link img { height: auto; }

.header-info {
  position: relative;
  float: left;
  width: 49.0666666667%;
  padding: 1.3333333333% 1.3333333333% 1.3333333333% 0;
}

.header-info-txt {
  position: absolute;
  top: 15px;
  right: 14px;
  top: 3.99999999vw;
  right: 3.733333324vw;
  font-size: 10px;
  font-size: 2.6666666vw;
  font-weight: bold;
  font-family: "Hiragino Sans", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  line-height: 1;
  color: #333;
}

.header-info-tel {
  position: absolute;
  bottom: 12px;
  right: 14px;
  bottom: 3.199999992vw;
  right: 3.733333324vw;
  font-size: 23px;
  font-size: 6.133333318vw;
  font-weight: bold;
  line-height: 0.8;
  color: #1f9f97;
  text-shadow: 0px 2px 1px #fff, 0px 2px 1px #fff, 2px 2px 1px #fff, 2px 0px 1px #fff, 2px 0px 1px #fff, 2px -2px 1px #fff, 2px -2px 1px #fff, 0px -2px 1px #fff, -2px -2px 1px #fff, -2px -2px 1px #fff, -2px -2px 1px #fff, -2px 0px 1px #fff, -2px 2px 1px #fff, -2px 2px 1px #fff
}

.header-link { display: block; }

.header-link img { height: auto; }


/* 全ページ共通フッター
   ----------------------------------------------------------------- */
.l-footer { background: #fff; }

.footer-txt {
  float: left;
  margin: 3.2142857143% 0 0 8.0357142857%;
  width: 50%;
  font-size: 0;
}

.footer-tel {
  padding: 0 4.6875% 6.25%;
}

.footer-tel-btn {
  position: relative;
  display: block;
}

.footer-tel-txt {
  position: absolute;
  bottom: 14px;
  bottom: 3.733333324vw;
  right: 20px;
  right: 5.33333332vw;
  font-size: 36px;
  font-size: 9.599999976vw;
  font-weight: bold;
  line-height: 1;
  color: #222;
  text-shadow:0px 2px 1px #fff,
              0px 2px 1px #fff,
              2px 2px 1px #fff,
              2px 0px 1px #fff,
              2px 0px 1px #fff,
              2px -2px 1px #fff,
              2px -2px 1px #fff,
              0px -2px 1px #fff,
              -2px -2px 1px #fff,
              -2px -2px 1px #fff,
              -2px -2px 1px #fff,
              -2px 0px 1px #fff,
              -2px 2px 1px #fff,
              -2px 2px 1px #fff;
}

.footer-tel-time {
  position: absolute;
  top: 13px;
  left: 182px;
  top: 4.0625vw;
  left: 56.875vw;
  font-size: 10px;
  font-size: 3.125vw;
  font-weight: bold;
  line-height: 1;
  color: #222;
}

.footer-more-link {
  display: block;
  width: 40vw;
  margin: 0 auto 10.6666666667vw;
  padding: 4.8vw 0;
  font-size: 3.7333333333vw;
  line-height: 1;
  text-align: center;
  color: #333;
  text-decoration: none;
  background: #fafafa;
  background: linear-gradient(to bottom,  #fafafa 0%,#fafafa 0%,#f0f0f0 100%);
  border: 1px solid #b9c5d6;
  border-radius: 6.6666666667vw;
}

.footer-nav {
  margin-bottom: 6.25%; 
  padding: 0 4.6875%;
}

.footer-nav-ttl {
  padding: 4.1379310345% 4.4827586207%;
  background: #e8edf4;
  font-size: 13px;
  font-size: 4.0625vw;
  font-weight: bold;
  line-height: 1;
  border-radius: 5px;
}

.footer-nav-item {
  position: relative;
  display: block;
  padding: 6.5625% 15% 6.5625% 4.6875%;
  font-size: 13px;
  font-size: 4.0625vw;
  color: #366dc0;
  line-height: 1.25;
  text-decoration: none;
}

.footer-nav-item:after{
  content: "";
  position: absolute;
  top: 0;
  right: 18px;
  bottom: 0;
  margin: auto 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 5px;
  border-color: transparent transparent transparent #366dc0;
}

.footer-nav-item+.footer-nav-item{ border-top: 1px solid #e8edf4; }


.copy {
  padding: 4.6875% 0;
  text-align: center;
  font-size: 10px;
  font-size: 3.125vw;
  line-height: 1;
  color: #fff;
  background-color: #25bbb2;
}

.footer-copyright {
  padding: 4.6875% 0;
  text-align: center;
  font-size: 10px;
  font-size: 3.125vw;
  line-height: 1;
  color: #fff;
  background-color: #25bbb2;
}


/* ==========================================================================
   #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: bold; }





/* #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 */