/**
* css document
* 
* 
*/
#l_main_visual {
  height: 350px;
  background: url(../img/bg_main.jpg) no-repeat 50% 20%;
  background-size: cover;
  padding: 0;
  text-align: center; }
  #l_main_visual .m_bg {
    display: none; }
  #l_main_visual .l_head {
    position: relative;
    color: #fff;
    font-weight: bold;
    margin: 97px 0 30px;
    padding: 22px 0 20px;
    text-align: center; }
  #l_main_visual .l_head p {
    margin-bottom: 3px;
    font-size: 22px; }
  #l_main_visual .l_head h1 {
    font-size: 34px; }
  #l_main_visual .l_head:before, #l_main_visual .l_head:after {
    content: "";
    position: absolute;
    display: block;
    left: 50%;
    width: 140px;
    height: 2px;
    margin-left: -70px;
    background: #fff; }
  #l_main_visual .l_head:before {
    top: 0; }
  #l_main_visual .l_head:after {
    bottom: 0; }
  #l_main_visual p {
    color: #fff;
    font-size: 25px;
    text-align: center; }

@media only screen and (max-width: 768px) {
  #l_main_visual {
    height: 187px; }
    #l_main_visual .l_head {
      margin: 43px 0 15px;
      padding: 15px 0 11px;
      line-height: 1.2; }
    #l_main_visual .l_head p {
      margin-bottom: 7px;
      font-size: 14px; }
    #l_main_visual .l_head h1 {
      font-size: 20px; }
    #l_main_visual .l_head:before, #l_main_visual .l_head:after {
      width: 88px;
      height: 1px;
      margin-left: -44px; }
    #l_main_visual p {
      font-size: 12px; } }

.ie8 #l_main_visual {
  position: relative;
  background: none;
  height: 350px;
  padding: 0;
  text-align: center;
  overflow: hidden; }
  .ie8 #l_main_visual .m_bg {
    display: block; }
    .ie8 #l_main_visual .m_bg img {
      position: absolute;
      display: block;
      text-align: center;
      left: -100%;
      top: -100%;
      bottom: -100%;
      right: -100%;
      margin: auto;
      width: 100%;
      min-width: 1600px;
      min-height: 350px; }
  .ie8 #l_main_visual .l_inner {
    position: relative;
    z-index: 2; }

#service_01 { }
#service_01 h2 {
  margin-bottom: 10px; }
@media only screen and (max-width: 768px) {
  #service_01 h2 {
    margin-bottom: 10px; }
  #service_01 h2 img {
    width: 68px; } }
#service_01 .l_sec_cont > .m_lead {
  margin-bottom: 45px;
  font-size: 15px;
  text-align: left;
  line-height: 2; }
@media only screen and (max-width: 768px) {
  #service_01 .l_sec_cont > .m_lead {
    margin-bottom: 30px;
    font-size: 12px;
    line-height: 1.67; } }

#service_01 .l_sec_body {
  overflow: hidden; }
#service_01 .l_row {
  margin-top: -41px; }
#service_01 .l_sec_body:after {
  content: "";
  clear: both;
  display: block; }
#service_01 .l_col {
  position: relative;
  width: 33%; }
#service_01 .l_col_third {
  width: 34%; }
#service_01 .l_col_inner {
  padding: 40px 30px 124px;
  text-align: center;
  border-top: 1px solid #c8c8c8;
  border-right: 1px solid #c8c8c8; }
#service_01 .l_col_third .l_col_inner {
  border-right: none; }
#service_01 dt {
  font-size: 22px;
  font-weight: bold;
  line-height: 1.5;
  margin-bottom: 10px; }
#service_01 dt img {
  display: block;
  margin: 0 auto 13px;
  width: 108px; }
#service_01 dd {
  text-align: left; }
#service_01 dd small {
  display: inline-block; }
#service_01 .l_col .m_btn {
  position: absolute;
  bottom: 40px;
  left: 0;
  right: 0;
  margin: auto; }
#service_01 .l_col .m_btn span {
  min-width: 170px; }

@media only screen and (max-width: 768px) {
  #service_01 .l_row {
    margin-top: -21px;
    margin-right: -1px; }
  #service_01 .l_col, #service_01 .l_col_third {
    position: relative;
    float: left;
    width: 50%; }
  #service_01 .l_col_inner {
    padding: 20px 15px 92px; }
  #service_01 .l_col_third .l_col_inner {
    border-right: 1px solid #c8c8c8; }
  #service_01 dt {
    font-size: 12px; }
  #service_01 dt img {
    width: 74px; }
  #service_01 .l_col .m_btn {
    position: absolute;
    bottom: 20px;
    left: 0;
    right: 0;
    margin: auto; }
  #service_01 .l_col .m_btn span {
    min-width: 0; } }

.l_sec_cont .m_notice {
  position: relative;
  margin-top: -40px;
  padding-top: 25px;
  background: #ededed; }
@media only screen and (max-width: 768px) {
.l_sec_cont .m_notice {
  min-height: 20px;
  margin-top: -20px;
  padding-top: 10px; } }

#internal {
  padding-top: 40px; }
  #internal .l_sec_head {
    font-weight: bold;
    margin-bottom: 15px; }
  #internal .l_sec_head:after {
    width: 50px;
    margin-left: -25px; }
  #internal .l_sec_head h1 {
    margin-bottom: 0;
    font-size: 22px; }
  #internal .m_lead {
    margin-bottom: 25px;
    font-size: 15px; }
  #internal .m_btn a {
    background: transparent;
    border: 1px solid #fff; }
  #internal .m_btn span {
    min-width: 170px;
    padding: 10px 15px 10px 35px;
    font-size: 14px; }
@media only screen and (max-width: 768px) {
  #internal .l_sec_head {
    margin-bottom: 10px;
    padding-bottom: 12px;;
    line-height: 1.2; }
  #internal .l_sec_head:after {
    width: 36px;
    margin-left: -18px; }
  #internal .l_sec_head h1 {
    font-size: 12px; }
  #internal .m_lead {
    margin: 0 15px 10px;
    font-size: 12px;
    line-height: 1.4 }
  #internal .m_btn span {
    min-width: 80%;
    padding: 5px 10px 5px 25px;
    font-size: 12px; }
  #internal .m_ico_ar_white a:before {
    left: 10px; } }

#internal_mechanism {
  position: relative;
  width: 490px;
  height: 300px;
  padding-right: 490px;
  margin: 0 auto;
  background: url(../img/bg_mechanism.jpg) no-repeat; }
  #internal_mechanism .l_inner {
    display: table-cell;
    width: 490px;
    min-width: 490px;
    height: 300px;
    margin: 0;
    text-align: center;
    vertical-align: middle;
    background: url(../img/bg_black_transparent.png); }
@media only screen and (max-width: 768px) {
  #internal_mechanism {
    width: 50%;
    height: 199px;
    padding-right: 50%;
    background: url(../img/bg_mechanism_sp.jpg) no-repeat center center;
    background-size: cover;
    overflow: hidden; }
    #internal_mechanism .l_inner {
      width: 50%;
      min-width: 50%;
      height: 199px; } }

#card_apply li {
  width: 50%;
  float: left;
  box-sizing: border-box;
  -ms-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box; }
  @media only screen and (max-width: 768px) {
    #card_apply li {
      width: 100%;
      float: none; } }
#card_apply li + li {
  padding-left: 1px; }
  @media only screen and (max-width: 768px) {
    #card_apply li + li {
      padding-left: 0;
      margin-top: 1px; } }
#card_apply .m_btn a {
  width: 100%; }
#card_apply .m_btn a span {
  padding: 20px 15px 20px 35px; }
  @media only screen and (max-width: 768px) {
    #card_apply .m_btn a span {
      padding: 15px 15px 15px 35px; } }
#card_apply .m_btn a img {
  vertical-align: middle;
  padding-right: 10px; }

/*# sourceMappingURL=../../service/css/style.css.map */