@charset "UTF-8";
/* CSS Document */
@import url("https://cdn.jsdelivr.net/npm/yakuhanjp@4.1.1/dist/css/yakuhanjp.css");
@import url("https://fonts.googleapis.com/css2?family=Caveat:wght@400..700&family=Maven+Pro:wght@400..900&family=Noto+Sans+JP:wght@100..900&display=swap");
/*初期設定*/
* {
  margin: 0;
  padding: 0;
}

html {
  font-size: 10px;
}

.sp-vis {
  display: none !important;
}

@media screen and (max-width: 860px) {
  .sp-vis {
    display: block !important;
  }
  .pc-vis {
    display: none !important;
  }
}
body {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-size: 1.5rem;
  font-weight: 400;
  position: relative;
  margin: 0 auto;
  color: #1c1c1c;
  letter-spacing: 0.05em;
  /*border: 1px solid #000;*/
}
@media screen and (max-width: 860px) {
  body {
    font-size: clamp(12px, 2.32vw, 15px);
  }
}

/*floatクリア用*/
.clear {
  clear: both;
}

/*メインコンテンツブロック*/
.clearfix:after {
  content: " "; /* 新しい要素を作る */
  display: block; /* ブロックレベル要素に */
  clear: both;
  height: 0;
  visibility: hidden;
}

.clearfix {
  min-height: 1px;
  overflow: visible;
}

* html .clearfix {
  height: 1px;
  /*¥*/ /*/
height: auto;
overflow: hidden;
/**/
}

a {
  text-decoration: none;
  color: #3E3A39;
  transition: 0.5s;
}
a:hover {
  color: #07ad98;
}

a img {
  border: none;
  outline: none;
}

p {
  line-height: 1.7;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
  table-layout: fixed;
}

table img {
  display: block;
}

table td, table th {
  box-sizing: border-box;
}

.right {
  float: right;
}

.left {
  float: left;
}

.rela {
  position: relative;
}

.abso {
  position: absolute;
}

h1, h2, h3, h4 {
  text-align: center;
}

ul li {
  list-style: none;
}

/* iOSでのデフォルトスタイルをリセット */
input[type=submit],
input[type=button] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  -moz-appearance: button;
       appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}

input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}

input[type=submit]::focus,
input[type=button]::focus {
  outline-offset: -2px;
}

input, button, select, textarea {
  -webkit-appearance: none;
}

input[type=checkbox] {
  all: revert;
}

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

img {
  display: block;
  max-width: 100%;
}

.flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.flex.flex-r {
  flex-direction: row-reverse;
}

/* 画面外にいる状態 */
.square::after, .square::before {
  opacity: 0;
  transition: all 2000ms;
}

/* 画面内に入った状態 */
.square.scrollin::after, .square.scrollin::before {
  opacity: 1;
}

.slick-track {
  display: flex !important;
  align-items: stretch;
  justify-content: center;
}

@media (max-width: 845px) {
  .slick-track {
    justify-content: space-between;
  }
}
.slick-slide {
  height: auto !important;
}

.slick-slide > * {
  height: 100% !important;
}

section {
  position: relative;
}

.cont_size_box {
  width: 95%;
  margin: 0 auto;
  position: relative;
  max-width: 1440px;
}

.cont_size_box {
  max-width: 1270px;
  width: 80%;
  margin: 0 auto;
}
@media screen and (max-width: 860px) {
  .cont_size_box {
    width: 90%;
  }
}

.cont_size_box2 {
  max-width: 1425px;
  width: 90%;
  margin: 0 auto;
}

.top_ttl {
  text-align: left;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 860px) {
  .top_ttl {
    margin-bottom: 30px;
  }
}
.top_ttl small {
  display: block;
  font-size: 1.7rem;
  font-weight: 400;
  position: relative;
}
.top_ttl small::before {
  content: "";
  width: 0.65rem;
  height: 0.65rem;
  display: block;
  background: #07ad98;
  border-radius: 100%;
  position: absolute;
  top: 0;
  bottom: 0;
  left: -2rem;
  margin: auto;
}
@media screen and (max-width: 860px) {
  .top_ttl small::before {
    left: -1rem;
  }
}
.top_ttl strong {
  display: block;
  font-size: 4.2rem;
  font-weight: 900;
  line-height: 1.38;
  margin: 12.5px 0 15px;
}
@media screen and (max-width: 860px) {
  .top_ttl strong {
    font-size: 3rem;
  }
}
.top_ttl .en_ttl {
  display: block;
  font-family: YakuHanJP, "Maven Pro", sans-serif;
  font-size: 1.4rem;
  font-weight: 300;
}

.view {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  text-decoration: underline;
  color: #fff;
  font-family: YakuHanJP, "Maven Pro", sans-serif;
  margin-top: 3.3rem;
  font-size: 1.3rem;
}
.view::after {
  content: "";
  text-decoration: none;
  display: inline-block;
  margin-left: 0.5em;
  transition: 0.5s;
  width: 10px;
  height: 10px;
  background: url(../image/common/link_arrow.svg) no-repeat center/contain;
  position: relative;
  right: 0;
  transition: 0.5s;
}
.view:hover::after {
  right: -5px;
}

.btn a {
  color: white;
  border-radius: 999px;
  font-size: 1.6rem;
  font-family: YakuHanJP, "Maven Pro", sans-serif;
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #fff;
  text-align: left;
  width: 445px;
  padding: 4.2rem 5.3rem;
  box-sizing: border-box;
  line-height: 1;
  margin-left: auto;
  margin-top: 90px;
  transition: 0.5s;
}
@media screen and (max-width: 860px) {
  .btn a {
    max-width: 445px;
    width: 100%;
    padding: 2.4rem;
    margin-left: auto !important;
    margin-right: auto !important;
    margin-top: 40px;
  }
}
.btn a::after {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  background: url(../image/common/link_arrow.svg) no-repeat center/contain;
  transition: 0.5s;
}
@media screen and (max-width: 860px) {
  .btn a {
    margin-top: 45px;
  }
}
.btn a:hover::after {
  margin-right: -5px;
}
.btn.green a {
  background: #07ad98;
}
.btn.green a:hover {
  background: #212121;
}
.btn.red a {
  background: #df1a00;
}
.btn.square a {
  border-radius: 0;
}
.btn.center a {
  margin-left: auto;
  margin-right: auto;
}

#contactBnr {
  position: relative;
}
@media screen and (max-width: 860px) {
  #contactBnr {
    background: url(../image/common/contact_bnr_bg.png) no-repeat center top/cover;
    padding: 50px 0;
  }
}
#contactBnr .bg {
  display: block;
}
@media screen and (max-width: 860px) {
  #contactBnr .bg {
    display: none !important;
  }
}
#contactBnr .txt {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  text-align: center;
  width: 100%;
}
@media screen and (max-width: 860px) {
  #contactBnr .txt {
    position: static;
    transform: none;
  }
}
#contactBnr .txt h2 {
  font-size: 1.4rem;
  font-weight: 400;
}
#contactBnr .txt p {
  font-size: 4.2rem;
  font-weight: 900;
  margin: 25px auto;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 860px) {
  #contactBnr .txt p {
    font-size: 2.4rem;
  }
}
#contactBnr .txt p .balloon {
  position: absolute;
  top: -41px;
  left: -38px;
  width: 171.5px;
}
@media screen and (max-width: 860px) {
  #contactBnr .txt p .balloon {
    width: 120px;
    left: 0;
  }
}
#contactBnr .txt .btn a {
  margin-top: 0;
  width: 250px;
  padding: 20px;
}

.fadein, .fadein_auto {
  opacity: 0;
  transform: translateY(50px);
  transition: all 1s ease;
}

.fadein.active, .fadein_auto.active {
  opacity: 1;
  transform: translateY(0);
}

.fadein.delay1 {
  transition-delay: 0.1s;
}

.fadein.delay2 {
  transition-delay: 0.3s;
}

.fadein.delay3 {
  transition-delay: 0.5s;
}

.child_ttl {
  text-align: left;
  margin-bottom: 100px;
}
@media screen and (max-width: 860px) {
  .child_ttl {
    margin-bottom: 50px;
  }
}
.child_ttl small {
  display: block;
  font-size: 1.6rem;
  font-weight: 700;
  font-family: YakuHanJP, "Maven Pro", sans-serif;
}
@media screen and (max-width: 860px) {
  .child_ttl small {
    font-size: 1.4rem;
  }
}
.child_ttl small.en_ttl {
  font-size: 1.66rem;
  letter-spacing: 0.1em;
  line-height: 2.59;
  font-weight: 900;
}
@media screen and (max-width: 860px) {
  .child_ttl small.en_ttl {
    font-size: 1.4rem;
    line-height: 1.8;
  }
}
.child_ttl small.en_ttl span {
  font-family: YakuHanJP, "Caveat", cursive;
  font-weight: 300;
}
.child_ttl small a {
  color: #fff;
  display: inline-block;
  margin-left: 1em;
  font-size: 0.8em;
  text-decoration: underline;
}
.child_ttl small a::after {
  content: "▼";
}
.child_ttl strong {
  display: block;
  font-size: 4.8rem;
  margin: 30px auto 20px;
  font-weight: 900;
  line-height: 1.41;
}
@media screen and (max-width: 860px) {
  .child_ttl strong {
    font-size: 3.3rem;
  }
}

#pan {
  padding: 20px 40px;
  box-sizing: border-box;
  color: #fff;
  background: #216059;
}
@media screen and (max-width: 860px) {
  #pan {
    padding: 10px 20px;
  }
}
#pan ul {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
#pan ul li {
  font-size: 1.1rem;
  display: flex;
  align-items: center;
}
#pan ul li a {
  color: #fff;
  display: block;
  text-decoration: underline;
}
#pan ul li + li::before {
  content: ">";
  display: inline-block;
  margin: 0 10px;
}

.scroller {
  scrollbar-width: thin;
}

.container::-webkit-scrollbar-track {
  background-color: red;
}

.soon {
  margin: 100px auto;
  text-align: center;
  font-size: 2rem;
  font-weight: 400;
}/*# sourceMappingURL=base.css.map */