/*==============================
  Base Layout
  ==============================*/
.container {
  margin: 0 auto;
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-shadow: 0 1rem 2rem -2rem hsl(200 50% 20% / 40%);
}
@media screen and (max-width: 991px) {
.container {
  margin: 0 auto;
  width: 100%;
  }
}

/*==============================
  Breadcrumb
  ==============================*/
.breadcrumb .inner{
  padding: 2em 0;
}
.breadcrumb-list{
  display: flex;
  justify-content: left;
}
.breadcrumb-list li{
  list-style-type: none;
  font-size: .8em;
  padding: 0 1.6em 0 0;
  margin: 0 1em 0 0;
  position: relative;
  display: inline-block;
  vertical-align: middle;
  color: #8698ad;
}
.breadcrumb-list li a{
  color: #8698ad;
}
.breadcrumb-list li::before{
  content: "";
  vertical-align: middle;
  position: absolute;
  right: 0;
  top: 40%;
  width: 4px;
  height: 4px;
  border-top: 2px solid #3366bb;
  border-right: 2px solid #3366bb;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.breadcrumb-list li:last-child::before{
  border: 0;
}

@media screen and (max-width: 768px) {
#page-top a{
  width: 50px;
  height: 50px;
  line-height: 50px;
}
#page-top a img {
  width: 15px;
  height: 15px;
  margin-top: 12px;
}
.breadcrumb-list li{
  font-size: 10px;
}

}

/*==============================
  Main Contents
  ==============================*/
main {
  text-align: center;
  padding: 70px 0 0;
}
#main .inner{
  width: 85%;
  max-width: 1240px;
  margin: 0 auto;
}

#top-service{
  background: #fff;
  padding: 5em 4vw;
}
#top-service h2 p,#top-recruit h2 p{
  font-size: max(3vw, 1.4em);
  line-height: 1.2;
  position: relative;
  margin: 1em 0 0;
}
#top-service h2 p:before,#top-recruit h2 p:before{
  position: absolute;
  content: '';
  top: -20px;
  width: 20px;
  height: 5px;
  background: url("../img/common/line.svg");
}
#top-service h2 span,#top-recruit h2 span{
  display: block;
  font-size: 13px;
  margin: 10px 0 0 4px;
  color: #3366bb;
  letter-spacing: .1em;
}
.top-service-items ul{
  display: flex;
}
#top-recruit{
  background: #e9ecf3;
  padding: 5em 4vw;
}
#top-service .top-service-ttl .txt,#top-recruit .top-recruit-ttl .txt{
  padding: 3em 0 0;
}
#top-service .top-service-items img,#top-recruit .top-recruit-items img{
  border-radius: 8px;
}
#top-service .btn,#top-recruit .btn,#top-news .btn{
  text-align: right;
}
#top-service .btn a,#top-recruit .btn a,#top-news .btn a{
  position: relative;
  display: inline-block;
  padding: 0 36px 0 0;
  vertical-align: middle;
  text-decoration: none;
  font-size: .9em;
  font-weight: 600;
}
#top-service .btn a::before,#top-recruit .btn a::before,#top-news .btn a::before{
  width: 30px;
  height: 30px;
  -webkit-border-radius: 50%;
  border-radius: 50%;
  background: #3366bb;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
}
#top-service .btn a::after,#top-recruit .btn a::after,#top-news .btn a::after{
  width: 6px;
  height: 6px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  bottom: 0;
  right: 12px;
  margin: auto;
  content: "";
  vertical-align: middle;
}
#top-service .btn a span,#top-recruit .btn a span,#top-news .btn a span{
  position: relative;
}
#top-service .btn a span:before,#top-recruit .btn a span:before,#top-news .btn a span:before{
 content: "";
 display: block;
 width: 100%;
 height: 1px;
 background-color: #3366bb;
 position: absolute;
 bottom: -5px;
}

#top-news{
  padding: 6em 0 4em;
  border-top: 1px solid #f4f4f4;
}
#top-news .top-news-ttl-sec{
  font-size: max(1.6vw, 1.2em);
  line-height: 1.2;
}
#top-news .top-news-ttl-sec .pop{
  font-size: 14px;
  display: block;
  color: #3366bb;
  margin: 0 0 10px 4px;
  font-weight: 600;
}
#top-news .top-news__category {
  display: inline-block;
  border: 1px #6aa3c8 solid;
  border-radius: 500px;
  min-width: 100px;
  margin-right: 10px;
  padding: 2px 10px;
  text-align: center;
  line-height: 23px;
  font-size: .75em;
  color: #6aa3c8;
}
#top-news .top-news__date{
  font-size: .9em;
  color: #8698ad;
}
#top-news li{
  padding: 1.2em 0;
}
#top-news li:first-child{
  padding-top: 0;
}
#top-news li:nth-child(n+2) {
  border-top: 1px solid #f4f4f4;
}
.top-new-list-text{
  font-weight: 600;
}
.top-nintei{
  border-top: 1px solid #d9dfe8;
  padding: 4em 0;
}
.top-nintei p{
  padding: 0 0 1em;
  font-size: max(2vw, .9em);
  font-weight: 600;
}

footer{
  border-top: 1px solid #fff;
  padding: 5em 0 2em;
  background: #e9ecf3;
  position: relative;
}
footer a{
  color: #26282f;
}
footer .inner{
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
footer .copyright{
  font-size: 10px;
  color: #8698ad;
  text-align: center;
  padding-top: 6em;
}
.footer-wrap{
  text-align: center;
}
.footer-logo{
  margin-bottom: 1em;
}
.foot-call-wrap{
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 1em 0 5em;
}
.foot-call{
  display: flex;
  flex-wrap: wrap;
  margin: 10px 0 0;
}
.foot-call li{
  width: calc(20% - 10px);
  margin: 10px 5px 10px;
  padding: 10px;
  background: #fff;
  border-radius: 4px;
  position: relative;
}
.foot-call li .txt{
  font-size: .8em;
  padding: 20px 0 0;
}
.foot-call li .tel{
  font-size: 1.4em;
  line-height: 1;
  padding-bottom: 10px;
  letter-spacing: 0;
}
.foot-call li span{
  position: absolute;
  background: #003399;
  font-size: 11px;
  text-align: center;
  padding: 3px 0;
  display: block;
  line-height: 1.2;
  color: #fff;
  width: 80px;
  border-radius: 500px;
}
.foot-call.s2 li span{
  position: absolute;
  background: #3366bb;
  font-size: 11px;
  text-align: center;
  padding: 3px 0;
  display: block;
  line-height: 1.2;
  color: #fff;
  width: 80px;
  border-radius: 500px;
}

.footer-nav-list li a{
  position: relative;
}

.footer-nav-list dt a{
  position: relative;
  padding-left: 14px;
}
.footer-nav-list dt a:after{
  width: 4px;
  height: 4px;
  border-top: 2px solid #3366bb;
  border-right: 2px solid #3366bb;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 2px;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
}
footer h2{
  display: flex;
  align-items: center;
  margin-bottom: .7em;
}
footer h2 span{
  display: block;
}
footer h2 span:last-child{
  border: 1px solid #fff;
  font-size: 12px;
  padding: 4px 10px;
  margin-left: 6px;
}
.footer-takuma{
  position: absolute;
  right: 110px;
  bottom: 10px;
}
.footer-takuma img{
  width: 130px;
}
.footer-logo img{
  width: 320px;
}
.footer-logo .area{
  background: #da6f5f;
  font-size: 13px;
  color: #fff;
  padding: 2px 6px;
  border-radius: 2px;
}

@media screen and (max-width: 991px) {
main{
  padding: 57px 0 0;
  }
}
@media screen and (min-width: 768px) {
#top-service .wrap,#top-recruit .wrap{
  display: flex;
  justify-content: space-between;
}
.top-service-ttl,.top-recruit-ttl{
  width: 25%;
  text-align: left;
}
.top-service-items,.top-recruit-items{
  width: 70%;
}
#top-service .btn,#top-recruit .btn{
  padding: 3em 0 0;
}
#top-news .inner{
  display: flex;
  text-align: left;
}
#top-news .top-news-ttl-sec{
  width: 30%;
}
#top-news .top-news-list-sec{
  width: 70%;
}
#top-news .btn{
  padding: 3em 0 0;
}
.footer-nav-list{
  display: flex;
  justify-content: center;
}
.footer-nav-list li{
  padding: .5em .4vw;
  font-size: max(.9vw, 12px);
  letter-spacing: .04em;
}
footer .f-sub{
  padding-right: 0;
}
.footer-nav-list li:last-child{
  padding-right: 0;
}
.footer-nav-list dl{
  padding-top: .6em;
}
.footer-nav-list dt{
  font-size: .8em;
  font-weight: 500;
  padding: .2em 0;
  letter-spacing: 0;
}
.footer-nav-list li a::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -8px;
  width: 100%;
  height: 1px;
  background: #3366bb;
  transform: scale(0, 1);
  transition: 0.4s;
}
.footer-nav-list li a:hover:before {
  transform: scale(1);
}
.top-news-list li{
  display: flex;
}
.top-news-list-head{
  padding: 4px;
  width: 100px;
}
.top-new-list-text{
  padding: 4px;
}

}
@media screen and (max-width: 768px) {
#top-service .top-service-ttl .txt, #top-recruit .top-recruit-ttl .txt{
  text-align: left;
  padding: 1em 0 0;
}
#top-service h2 p::before, #top-recruit h2 p::before{
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
}
#top-service .btn, #top-recruit .btn, #top-news .btn{
  padding: .5em 0 2em;
}
#top-service,#top-recruit{
  padding: 2em 20px;
}
#top-news{
  padding: 2em 0;
}
.top-news-list-sec{
  width: 100%;
  padding: 1em 0 0;
}
#top-news li{
  text-align: left;
}
.top-nintei{
  padding: 3em 0;
}

/* Footer SP */
footer{
  padding: 3em 0 2em;
}
footer .inner{
  width: 90%;
}
footer h2{
  font-size: 1.3em;
}
.footer-nav-area{
  padding: 3em 0 2em;
}
.footer-nav-list{
  border-top: 1px solid #a9b7c8;
  box-shadow: 0 1px 0 rgba(255,255,255,1);
}
.footer-nav-list li{
  border-bottom: 1px solid #a9b7c8;
  box-shadow: 0 1px 0 rgba(255,255,255,1);
  padding: 6px 0;
  font-size: 14px;
}
.foot-list-item a{
  display: block;
  position: relative;
  margin-left: 10px;
}
.foot-list-item a::before{
  content: "-";
  position: absolute;
  left: -10px;
  color: #3366bb;
}
.foot-list-item dt a::before{
  content: " ";
}
.footer-nav-list dl{
  font-size: 12px;
  padding: 2px 0;
  display: none;
}
.footer-takuma{
  right: 80px;
}
.footer-takuma img{
  width: 110px;
}
footer .copyright{
  padding-top: 9em;
  font-size: 9px;
  width: 45%;
  text-align: left;
}
.footer-logo{
  text-align: center;
  justify-content: center;
}
.footer-logo img{
  width: 260px;
}
.foot-call-wrap{
  padding: 0;
  margin-bottom: -1em;
}
.foot-call li{
  width: calc(100% - 20px);
}
.footer-nav-list li{
  text-align: left;
}
.foot-call li span{
  position: relative;
    margin: 2px auto -18px auto;
  }
}


#intro-content{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 500px;
  background-size: cover!important;
  color: #fff;
}
.intro-content-inner h1{
  letter-spacing: .12em;
  font-size: max(2.8vw, 1.2em);
  text-shadow: 0 2px 4px rgba(0,0,0,.5);
  position: relative;
}
.intro-content-inner h1:before{
  content: '';
  position: absolute;
  left: 0;
  top: -40px;
  right: 0;
  width: 2px;
  height: 30px;
  margin: auto;
  background-color: #3366bb;
}
.intro-content-inner span{
  text-shadow: 0 1px 4px rgba(0,0,0,.5);
  font-size: max(2.2vw, 1em);
  font-weight: 600;
}
.intro-content-inner p{
  font-size: max(1.2vw, .6em);
  letter-spacing: .1em;
  text-shadow: 0 1px 4px rgba(0,0,0,.5);
  padding: .6em 0 0;
}

#main .hd-service{
  background: url(../service/img/title-img.jpg) no-repeat center center fixed;
}
#main .hd-contact{
  background: url(../contact/img/title-img.jpg) no-repeat center center fixed;
}
#main .hd-shimonoseki{
  background: url(../sightseeing/img/title-img.jpg) no-repeat center center fixed;
}
#main .hd-taxi{
  background: url(../taxi/img/title-img.jpg) no-repeat center center fixed;
}
#main .hd-office{
  background: url(../office/img/title-img.jpg) no-repeat center center fixed;
}

#is-content{
  padding: 5em 0;
}

@media screen and (max-width: 768px) {
#intro-content{
  height: 200px;
}
#is-content{
  padding: 2em 0;
}

}