@charset "UTF-8";
/* CSS Document */
/*----------------------------------------
変数
----------------------------------------*/
/* ファーストビュー
---------------------------------------------- */
#fv {
  position: relative;
  background: url(/images/top/fv.jpg) no-repeat center center/cover;
  width: 100%;
  height: 60rem;
}
@media screen and (max-width: 768px) {
  #fv {
    background-image: url(/images/top/fv_sp.jpg);
    height: 49rem;
  }
}
@media screen and (min-width: 540px) and (max-width: 1023px) {
  #fv {
    height: 66rem;
  }
}
#fv .titleImage {
  position: absolute;
  left: calc(50% - 21.8rem);
  top: 11.7rem;
}
@media screen and (max-width: 768px) {
  #fv .titleImage {
    max-width: 320px;
    width: 100%;
    left: calc(50% - 16rem);
    top: 10.5em;
  }
}
@media screen and (min-width: 540px) and (max-width: 1023px) {
  #fv .titleImage {
    top: calc(50% - 13rem);
  }
}

/* 先頭
---------------------------------------------- */
#lead {
  color: #222856;
  font-weight: 700;
  font-size: 2rem;
  line-height: 1.8;
  letter-spacing: 0.06rem;
  padding: 5rem 0;
}
@media screen and (min-width: 769px) {
  #lead {
    text-align: center;
  }
}
@media screen and (max-width: 768px) {
  #lead {
    font-size: 1.6rem;
    letter-spacing: 0;
    line-height: 1.62;
    padding: 3rem 0;
  }
}
#lead span {
  display: block;
  margin-bottom: 4rem;
}
@media screen and (max-width: 768px) {
  #lead span {
    margin-bottom: 2.5rem;
  }
}

/* 企業さまが旅ベースをご利用いただくメリット
---------------------------------------------- */
#meritBox {
  padding-bottom: 5.5rem;
}
@media screen and (max-width: 768px) {
  #meritBox {
    padding-bottom: 2.7rem;
  }
}
#meritBox #meritList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 901px;
  margin: 1.2rem auto 0;
}
@media screen and (max-width: 768px) {
  #meritBox #meritList {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    max-width: 500px;
  }
}
#meritBox #meritList li {
  border: 1px solid #A49A8D;
  background-color: #F1EEEA;
  max-width: 211px;
  width: 24%;
  color: #2B3588;
  font-size: clamp(1.6rem, 2vw, 1.8rem);
  line-height: 1.33;
  letter-spacing: 0.018rem;
  font-weight: 700;
  text-align: center;
  padding: 2rem 1rem;
}
@media screen and (min-width: 769px) {
  #meritBox #meritList li:not(:last-of-type) {
    margin-right: 2%;
  }
}
@media screen and (max-width: 768px) {
  #meritBox #meritList li {
    width: 48%;
    margin-bottom: 4%;
    font-size: 1.5rem;
    letter-spacing: 0.015rem;
    line-height: 1.26;
    padding: 1.5rem 1rem 1.4rem;
  }
  #meritBox #meritList li:not(:nth-of-type(even)) {
    margin-right: 4%;
  }
}
@media screen and (max-width: 320px) {
  #meritBox #meritList li {
    padding: 1rem 0.2rem;
    width: 49%;
    font-size: 1.4rem;
    margin-bottom: 2%;
  }
  #meritBox #meritList li:not(:nth-of-type(even)) {
    margin-right: 2%;
  }
}
#meritBox #meritList li span {
  color: #E87B0D;
}

/* 予約のお問合せについて
---------------------------------------------- */
#reserveBox .inner {
  padding: 6rem 0 7rem;
  border-bottom: 1px solid #A49A8D;
}
@media screen and (max-width: 768px) {
  #reserveBox .inner {
    padding: 4rem 0 5rem;
  }
}
#reserveBox p {
  font-size: 1.6rem;
  letter-spacing: 0.015rem;
  line-height: 1.56;
}
@media screen and (max-width: 768px) {
  #reserveBox p {
    letter-spacing: 0;
  }
}
#reserveBox p span {
  display: block;
  margin-top: 2rem;
}
#reserveBox .caution {
  font-size: 1.4rem;
  letter-spacing: 0.011rem;
  line-height: 1.4;
  margin: 0.6rem 0 4rem;
}

/* 福利厚生代行サービスにはお金がかかる？
---------------------------------------------- */
#priceBox {
  padding: 7rem 2rem 10rem;
}
@media screen and (max-width: 768px) {
  #priceBox {
    padding: 4rem 2rem 7rem;
  }
}
#priceBox h3 {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.13;
  letter-spacing: 0.022rem;
  margin: 2rem 0 0.4rem;
}
@media screen and (max-width: 768px) {
  #priceBox h3 {
    font-size: 1.8rem;
    letter-spacing: 0.018rem;
    line-height: 1.33;
    margin-top: 1.55rem;
  }
}
#priceBox h3 span {
  color: #E87B0D;
  font-size: 3.3rem;
  line-height: 0.75;
  letter-spacing: 0.033rem;
}
@media screen and (max-width: 768px) {
  #priceBox h3 span {
    font-size: 2.8rem;
    line-height: 0.85;
    letter-spacing: 0.028rem;
  }
}
#priceBox p {
  font-size: 1.6rem;
  letter-spacing: 0.015rem;
  line-height: 1.56;
  padding: 0.4rem 0 2rem;
}
#priceBox .imageBox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  margin-bottom: 4.1rem;
}
@media screen and (min-width: 769px) {
  #priceBox .imageBox {
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
}
@media screen and (max-width: 768px) {
  #priceBox .imageBox {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media screen and (min-width: 769px) {
  #priceBox .imageBox #priceImage {
    max-width: 342px;
    width: 35%;
  }
}
@media screen and (max-width: 768px) {
  #priceBox .imageBox #priceImage {
    margin-bottom: 3rem;
  }
}
@media screen and (min-width: 769px) {
  #priceBox .imageBox #priceList {
    max-width: 630px;
    width: 63%;
  }
}
#priceBox .imageBox #priceList h4 {
  color: #2B3588;
  font-weight: 700;
  font-size: 2rem;
  line-height: 1.35;
  letter-spacing: 0.02rem;
  text-align: center;
  margin-bottom: 0.4rem;
}
@media screen and (max-width: 768px) {
  #priceBox .imageBox img {
    max-width: 100%;
    width: 100%;
  }
}

/* サービス内容
---------------------------------------------- */
#service {
  padding: 7rem 0;
}
@media screen and (max-width: 768px) {
  #service {
    padding: 5rem 0 4rem;
  }
}
#service #serviceContent {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 4rem;
}
@media screen and (max-width: 768px) {
  #service #serviceContent {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media screen and (min-width: 769px) {
  #service #serviceContent .serviceBox {
    max-width: 320px;
    width: 32%;
  }
}
@media screen and (min-width: 769px) {
  #service #serviceContent .serviceBox:not(:nth-of-type(3n)) {
    margin-right: 1%;
  }
}
@media screen and (max-width: 768px) {
  #service #serviceContent .serviceBox:not(:last-of-type) {
    margin-bottom: 5rem;
  }
}
#service #serviceContent .serviceBox h3 {
  font-size: 2.1rem;
  font-weight: 700;
  line-height: 1.28;
  letter-spacing: 0.021rem;
  color: #2B3588;
  text-align: center;
}
@media screen and (max-width: 768px) {
  #service #serviceContent .serviceBox h3 {
    font-size: 1.9rem;
    letter-spacing: 0.019rem;
  }
}
@media screen and (max-width: 320px) {
  #service #serviceContent .serviceBox h3 span {
    display: block;
  }
}
#service #serviceContent .serviceBox .image {
  margin: 1.7rem auto 3rem;
  max-width: 206px;
}
#service #serviceContent .serviceBox p {
  font-size: 1.6rem;
  letter-spacing: 0.015rem;
  line-height: 1.5;
}

/* 会社概要
---------------------------------------------- */
#company #companyList {
  margin: 1.7rem auto 5rem;
}
@media screen and (max-width: 768px) {
  #company #companyList {
    margin: 1rem auto 2.5rem;
  }
}
#company #companyList > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 2rem 0;
}
@media screen and (min-width: 769px) {
  #company #companyList > div {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media screen and (max-width: 768px) {
  #company #companyList > div {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 1.5rem 0 1rem;
  }
}
#company #companyList > div:not(:last-of-type) {
  border-bottom: 1px solid #A49A8D;
}
#company #companyList dt {
  font-size: 1.7rem;
  font-weight: 700;
  letter-spacing: 0.017rem;
  line-height: 1.2;
}
@media screen and (min-width: 769px) {
  #company #companyList dt {
    width: 22%;
    margin-right: 1%;
    min-width: 180px;
  }
}
@media screen and (max-width: 768px) {
  #company #companyList dt {
    margin-bottom: 0.2rem;
  }
}
#company #companyList dd {
  font-size: 1.6rem;
  letter-spacing: 0.015rem;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #company #companyList dd {
    width: 77%;
  }
}
@media screen and (min-width: 769px) {
  #company #companyList #companyAdress {
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
  }
}
@media screen and (max-width: 320px) {
  #company #companyList #companyAdress address span {
    display: block;
  }
}
#company #companyList #companyAdress .flexBox {
  margin-top: 1rem;
}
@media screen and (max-width: 768px) {
  #company #companyList #companyAdress .flexBox {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media screen and (min-width: 769px) {
  #company #companyList #companyAdress #map {
    margin-right: 2.5%;
    max-width: 387px;
    width: 70%;
  }
}
#company #companyList #companyAdress #map iframe {
  width: 100%;
  max-width: 387px;
}
@media screen and (max-width: 768px) {
  #company #companyList #companyAdress #map iframe {
    max-width: 100%;
    height: 29rem;
  }
}
#company #companyList #companyAdress .accessBox h3 {
  font-size: 1.6rem;
  letter-spacing: 0.015rem;
  line-height: 1.5;
  margin: 0 0 0.4rem -1rem;
}
@media screen and (max-width: 768px) {
  #company #companyList #companyAdress .accessBox h3 {
    margin: 1.4rem 0 0.3rem -1rem;
  }
}
#company #companyList #companyAdress .accessBox ul li {
  font-size: 1.5rem;
  line-height: 1.6;
  padding-left: 1.3rem;
  position: relative;
}
#company #companyList #companyAdress .accessBox ul li:before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  background-color: #A49A8D;
  border-radius: 50%;
  position: absolute;
  top: 0.8rem;
  left: 0;
}

/* お問い合わせ
---------------------------------------------- */
#contact .inner {
  margin: 4rem auto 2.5rem;
}
@media screen and (max-width: 768px) {
  #contact .inner {
    margin: 2.4rem auto 2rem;
  }
}
#contact p,
#contact address,
#contact .privacyLink {
  font-size: 1.6rem;
  letter-spacing: 0.015rem;
  line-height: 1.5;
}
#contact p {
  margin-bottom: 2.2rem;
}
#contact address .telLink {
  display: inline-block;
  font-size: 4.8rem;
  line-height: 0.83;
  font-weight: 700;
  color: #E87B0D;
  margin: 0 0.6rem;
  vertical-align: -0.5rem;
}
@media screen and (max-width: 768px) {
  #contact address .telLink {
    font-size: 3.3rem;
    letter-spacing: 0.033rem;
    line-height: 1;
    margin: 0.3rem 0.4rem 0.5rem 0;
  }
}
@media screen and (max-width: 320px) {
  #contact address .telLink {
    font-size: 2.7rem;
    letter-spacing: -0.05rem;
  }
}
#contact address .companyNumber {
  font-size: 1.3rem;
  letter-spacing: 0.013rem;
}
#contact address .faxText {
  display: inline-block;
  font-size: 2rem;
  letter-spacing: 0.02rem;
  line-height: 1.2;
}
@media screen and (min-width: 769px) {
  #contact address .faxText {
    margin-left: 2.8%;
  }
}
#contact address .borderBox {
  display: inline-block;
  border: 1px solid #13141C;
  font-size: 1.4rem;
  line-height: 1.28;
  letter-spacing: 0.014rem;
  padding: 1.1rem 1.2rem 0.9rem 1.3rem;
  margin: 1.2rem 0 2rem;
}
@media screen and (max-width: 768px) {
  #contact address .borderBox {
    display: block;
    max-width: 380px;
    padding: 0.7rem 1.2rem 0.5rem;
    margin: 0.5rem 0 2rem;
  }
}
@media screen and (max-width: 768px) {
  #contact address .mailLink {
    display: inline-block;
    line-height: 1.25;
    margin-bottom: 0.3rem;
  }
}
@media screen and (min-width: 769px) {
  #contact address .mailLink a:hover {
    opacity: 0.8;
  }
}
#contact address .caution {
  display: block;
  font-size: 1.4rem;
  letter-spacing: 0.014rem;
  line-height: 1.3;
}
#contact .privacyLink {
  margin: 3rem 0 2rem;
}
@media screen and (max-width: 768px) {
  #contact .privacyLink {
    margin: 2rem 0;
  }
}
#contact .privacyLink a {
  text-decoration: underline;
}
@media screen and (min-width: 769px) {
  #contact .privacyLink a:hover {
    opacity: 0.8;
    text-decoration: none;
  }
}
#contact .pdfList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  #contact .pdfList {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
#contact .pdfList li {
  margin-bottom: 2rem;
}
@media screen and (min-width: 769px) {
  #contact .pdfList li {
    margin-bottom: 1.5rem;
  }
  #contact .pdfList li:not(:nth-of-type(3n)) {
    margin-right: 1%;
  }
}
@media screen and (min-width: 769px) {
  #contact .pdfList li.item01 {
    max-width: 298px;
    width: 30%;
  }
  #contact .pdfList li.item02 {
    max-width: 343px;
    width: 34%;
  }
  #contact .pdfList li.item03 {
    max-width: 328px;
    width: 33%;
  }
}
#contact .pdfList li a {
  display: inline-block;
  font-size: 1.5rem;
  letter-spacing: 0.015rem;
  line-height: 1.3;
  color: #13141C;
  position: relative;
  padding-left: 4rem;
}
@media screen and (min-width: 769px) {
  #contact .pdfList li a:hover {
    opacity: 0.8;
  }
}
#contact .pdfList li a:before {
  content: "";
  display: inline-block;
  background: url(../assets/images/pdf_icon.svg) no-repeat center center/contain;
  width: 35px;
  height: 17px;
  position: absolute;
  left: 0;
  top: 0;
}

/* アニメーション
---------------------------------------------- */
.fadeUp {
  -webkit-animation-name: fadeUpAnime;
          animation-name: fadeUpAnime;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-duration: 1.5s;
          animation-duration: 1.5s;
  -webkit-animation-delay: 0.5s;
          animation-delay: 0.5s;
  opacity: 0;
}

@-webkit-keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(100px);
            transform: translateY(100px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(100px);
            transform: translateY(100px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
.js-fadeUp {
  opacity: 0;
  -webkit-transform: translate(0, 20%);
          transform: translate(0, 20%);
  -webkit-transition: 1.5s;
  transition: 1.5s;
}
@media screen and (min-width: 769px) {
  .js-fadeUp.delay01 {
    -webkit-transition-delay: 0s;
            transition-delay: 0s;
  }
  .js-fadeUp.delay02 {
    -webkit-transition-delay: 0.6s;
            transition-delay: 0.6s;
  }
  .js-fadeUp.delay03 {
    -webkit-transition-delay: 1.2s;
            transition-delay: 1.2s;
  }
}

.js-fadeUp.is-show {
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
  opacity: 1;
}/*# sourceMappingURL=index.css.map */