/*
contact
------------------------------------------------*/
.contact{
  padding: 75px 0 130px;
  color: #0068b7;
}
.contact-headline:before{
  content: "";
  display: block;
  width: 37px;
  height: 2px;
  background: #0068b7;
  margin: 0 auto 16px;
}
.contact-list{
  max-width: 715px;
  margin: 60px auto 0;
}
.contact-list a{
  color: #0068b7;
}
.contact-item{
  margin-bottom: 40px;
}
.contact-item:last-child{
  margin-bottom: 0;
}
.contact-about{
  font-size: 13px;
  font-size: 1.3rem;
  letter-spacing: .02em;
  font-weight: bold;
  margin-bottom: 10px;
}
.contact-title{
  font-family: "a-otf-midashi-go-mb31-pr6n",sans-serif;
  font-style: normal;
  font-weight: 600;
  box-sizing: border-box;
  border: 1px solid #0068b7;
  font-size: 18px;
  font-size: 1.8rem;
  letter-spacing: .04em;
}
.contact-number{
  font-family: "futura-pt",sans-serif;
  font-style: normal;
  font-weight: 600;
  font-size: 43px;
  font-size: 4.3rem;
  letter-spacing: .08em;
}
.contact-number img{
  margin-right: 5px;
  position: relative;
  top: 3px;
}
.contact-time{
  font-size: 14px;
  font-size: 1.4rem;
  letter-spacing: .04em;
  font-weight: bold;
  margin-top: 6px;
}
.contact-time span{
  font-weight: normal;
}
.contact-att{
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.2;
}
.contact-bnr{
  max-width: 910px;
  margin: 145px auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  text-align: center;
}
.contact-bnr-item{
  max-width: 298px;
  width: 32.7%;
  height: 102px;
  font-size: 18px;
  font-size: 1.8rem;
  letter-spacing: .05em;
  line-height: 1.4;
  font-weight: bold;
}
.contact-bnr-item a{
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 1025px){
  .contact-bnr-item a:hover span:before{
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  }
  .contact-bnr-item a:hover span:after{
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  }
}
.contact-bnr-item span{
  padding-right: 30px;
}
.contact-bnr-item span:before , .contact-bnr-item span:after{
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 30px;
  bottom: 0;
  margin: auto 0;
  width: 35px;
  height: 35px;
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 35px auto;
  transition: opacity .3s cubic-bezier(.23, 1, .32, 1);
}
.contact-bnr-item span:before{
  background-image: url("../images/top/contact_arrow_off.png");
}
.contact-bnr-item span:after{
  background-image: url("../images/top/contact_arrow_on.png");
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
}

@media screen and (max-width: 965px) and (min-width: 769px){
  .contact-bnr-item span:before , .contact-bnr-item span:after{
    right: 5%;
  }
  .contact-number img{
    max-width: 15%;
  }
}

@media screen and (min-width: 769px){
  .contact-item{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .contact-title{
    position: relative;
    line-height: 1.4;
    width: 276px;
    margin-right: 55px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .contact-title:before , .contact-title:after{
    position: absolute;
    top: 0;
    right: -21px;
    border: solid transparent;
    content: "";
    height: 0;
    width: 0;
    border-right: 0 solid transparent;
    border-left-width: 20px;
    border-bottom-color: transparent;
    border-bottom-style: solid;
    border-top-color: transparent;
    border-top-style: solid;
  }
  .contact-title:before{
    border-left-color: #0068b7;
  }
  .contact-title:after{
    border-left-color: #fff;
    margin: 0 1px 0 0;
  }
  .contact-title_large{
    height: 78px;
  }
  .contact-title_large:before , .contact-title_large:after{
    border-bottom-width: 38px;
    border-top-width: 38px;
  }
  .contact-title_small{
    height: 46px;
  }
  .contact-title_small:before , .contact-title_small:after{
    border-bottom-width: 22px;
    border-top-width: 22px;
  }
  .contact-time_center{
    text-align: center;
  }
  .contact-time span{
    font-size: 1.3rem;
    letter-spacing: .02em;
    margin-left: 12px;
  }
  .contact-att{
    margin-top: 55px;
    text-align: center;
  }
}

@media screen and (max-width: 768px){
  .contact{
    padding: 65px 0 95px;
  }
  .contact-list{
    max-width: 520px;
    margin-top: 44px;
    padding: 0 12px;
    box-sizing: border-box;
  }
  .contact-item{
    margin-bottom: 25px;
  }
  .contact-title{
    text-align: center;
    padding: 10px 0;
    line-height: 1.2;
    margin-bottom: 7px;
  }
  .contact-bnr{
    display: none;
  }
  .contact-number{
    font-size: 3.5rem;
    letter-spacing: 0;
    white-space: nowrap;
  }
  .contact-number_center{
    text-align: center;
  }
  .contact-number img{
    max-width: 51px;
    width: 17%;
  }
  .contact-time{
    line-height: 1.8em;
    margin-top: -1px;
  }
  .contact-time span{
    display: block;
    font-size: 1.2rem;
    letter-spacing: -.04em;
    line-height: 1.2;
  }
  .contact-att{
    font-size: 1.2rem;
    max-width: 520px;
    margin: 30px auto 0;
    padding: 0 12px;
    box-sizing: border-box;
  }
}

@supports (-ms-ime-align: auto){
  body .contact-number{
    letter-spacing: 0;
  }
}

/*
layout
------------------------------------------------*/
.headline{
  color: #0068b7;
  text-align: center;
}
.headline span{
  display: block;
}
.headline-en{
  font-family: "futura-pt",sans-serif;
  font-style: normal;
  font-weight: 600;
  font-size: 28px;
  font-size: 2.8rem;
  letter-spacing: .28em;
}
.headline-jp{
  font-family: "a-otf-midashi-go-mb31-pr6n",sans-serif;
  font-style: normal;
  font-weight: 600;
  font-size: 12px;
  font-size: 1.2rem;
  letter-spacing: .14em;
  margin-top: 10px;
}

/*
news
------------------------------------------------*/
.news{
  padding: 50px 0;
}
.news-inner{
  max-width: 520px;
}
.news-headline-en{
  font-size: 22px;
  font-size: 2.2rem;
}
.news-list{
  margin: 25px 0 0;
}
.news-item{
  margin-bottom: 25px;
}
.news-item a{
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.news-item:last-child{
  margin-bottom: 0;
}
.news-item a:hover .news-title{
  text-decoration: underline;
}
.news-date{
  font-size: 14px;
  font-size: 1.4rem;
  min-width: 90px;
  white-space: nowrap;
  padding-right: 20px;
  box-sizing: border-box;
}
.news-block{
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.news-title{
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.17;
}
.news-cat{
  width: 112px;
  height: 18px;
  line-height: 17px;
  text-align: center;
  font-size: 12px;
  font-size: 1.2rem;
}
.news-cat_notice{
  background: #dceaf5;
  color: #0068b7;
}
.news-cat_newsrelease{
  background: #0068b7;
  color: #fff;
}
.news-more{
  font-family: "futura-pt",sans-serif;
  font-style: normal;
  font-weight: 600;
  width: 105px;
  height: 25px;
  line-height: 22px;
  margin: 30px auto 0;
  text-align: center;
  font-size: 13px;
  font-size: 1.3rem;
  letter-spacing: .27em;
}
.news-more a{
  display: block;
  width: 100%;
  height: 100%;
  padding-right: 10px;
  border: 1px solid #818181;
  box-sizing: border-box;
  position: relative;
  color: #818181;
}
.news-more a:after{
  content: "";
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  margin: auto 0;
  vertical-align: middle;
  width: 5px;
  height: 5px;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  border-top: 2px solid #818181;
  border-right: 2px solid #818181;
}

@media screen and (min-width: 769px){
  .news-block{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .news-cat{
    margin-right: 10px;
  }
  .news-title{
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    line-height: 1.4;
  }
}

@media screen and (max-width: 768px){
  .news{
    padding: 22px 0 42px;
  }
  .news-headline{
    text-align: left;
  }
  .news-headline-en{
    font-size: 1.5rem;
  }
  .news-list{
    margin-top: 20px;
  }
  .news-item{
    margin-bottom: 14px;
  }
  .news-title{
    text-decoration: underline;
  }
  .news-cat{
    width: 98px;
    letter-spacing: -.08em;
    margin-bottom: 5px;
  }
  .news-more{
    font-size: 1.1rem;
    width: 140px;
    height: 21px;
    line-height: 19px;
  }
  .news-more a:after{
    width: 4px;
    height: 4px;
    border-width: 1px;
    right: 42px;
  }
}

/*
service
------------------------------------------------*/
.service{
  padding: 50px 0 80px;
  background: #cce1f1;
}
.service-list{
  max-width: 990px;
  margin: 30px auto 0;
}
.service-item{
  background: #fff;
}
.service-item a{
  display: block;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
}
.service-item_blue a{
  color: #0068b7;
}
.service-item_orange a{
  color: #ea8502;
}
.service-item_green a{
  color: #1eaaa5;
}
.service-title{
  font-family: "a-otf-midashi-go-mb31-pr6n",sans-serif;
  font-style: normal;
  font-weight: 600;
  font-size: 25px;
  font-size: 2.5rem;
  letter-spacing: .05em;
  line-height: 1.2;
  margin-bottom: 20px;
}
.service-more{
  font-size: 12px;
  font-size: 1.2rem;
  letter-spacing: .07em;
  text-align: center;
  padding: 10px 0;
  box-sizing: border-box;
}

@media screen and (min-width: 769px){
  .service-list{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .service-item{
    max-width: 320px;
    width: 32.3%;
    transition: background .3s cubic-bezier(.23, 1, .32, 1);
  }
  .service-item a{
    padding: 25px;
    transition: color .3s cubic-bezier(.23, 1, .32, 1);
  }
  .service-item_blue .service-img{
    border-color: #0068b7;
  }
  .service-item_blue .service-more{
    border-color: #0068b7;
  }
  .service-item_orange .service-img{
    border-color: #ea8502;
  }
  .service-item_orange .service-more{
    border-color: #ea8502;
  }
  .service-item_green .service-img{
    border-color: #1eaaa5;
  }
  .service-item_green .service-more{
    border-color: #1eaaa5;
  }
  .service-item:hover a{
    color: #fff;
  }
  .service-item:hover .service-more{
    border-color: #fff;
  }
  .service-item_blue:hover{
    background: #0068b7;
  }
  .service-item_orange:hover{
    background: #ea8502;
  }
  .service-item_green:hover{
    background: #1eaaa5;
  }
  .service-img{
    border-style: solid;
    border-width: 2px;
    margin-bottom: 12px;
  }
  .service-more{
    border-style: solid;
    border-width: 1px;
    transition: border-color .3s cubic-bezier(.23, 1, .32, 1);
  }
}

@media screen and (max-width: 1045px) and (min-width: 769px){
  .service-title{
    font-size: 2rem;
  }
  .service-title br{
    display: none;
  }
}

@media screen and (max-width: 768px){
  .service{
    padding: 53px 0 65px;
  }
  .service-list{
    max-width: 520px;
    margin-top: 28px;
  }
  .service-item{
    border-width: 2px;
    border-style: solid;
    margin-bottom: 14px;
  }
  .service-item:last-child{
    margin-bottom: 0;
  }
  .service-item_blue{
    border-color: #0068b7;
  }
  .service-item_blue .service-more{
    background: #0068b7;
  }
  .service-item_orange{
    border-color: #ea8502;
  }
  .service-item_orange .service-more{
    background: #ea8502;
  }
  .service-item_green{
    border-color: #1eaaa5;
  }
  .service-item_green .service-more{
    background: #1eaaa5;
  }
  .service-item a{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 0;
  }
  .service-img{
    width: 52%;
  }
  .service-img img{
    margin: 0 auto;
  }
  .service-block{
    width: 47.5%;
    margin: 0 0 0 auto;
    padding: 27px 18px 23px 0;
  }
  .service-title{
    font-size: 2rem;
    line-height: 1.25;
    letter-spacing: 0;
    margin-bottom: 8px;
    white-space: nowrap;
  }
  .service-more{
    color: #fff;
    max-width: 133px;
    font-weight: bold;
  }
  .service-more span:after{
    content: "";
    display: inline-block;
    vertical-align: middle;
    width: 4px;
    height: 4px;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    margin-left: 4px;
    position: relative;
    top: -1px;
  }
}
