@charset "UTF-8";
@media screen and (max-width: 767.999px) {
  /* 看板  */
  /************/
  #mv_area {
    position: relative;
  }
  #mv_area .breadcrumb {
    margin-bottom: 76px;
  }
  #mv_area .breadcrumb ul {
    padding: 20px 20px;
    display: flex;
  }
  #mv_area .breadcrumb ul li {
    font-size: 1.2rem;
    position: relative;
  }
  #mv_area .breadcrumb ul li:nth-of-type(n+2) {
    margin-left: 22px;
    padding-left: 12px;
  }
  #mv_area .breadcrumb ul li:nth-of-type(n+2)::before {
    content: "";
    display: block;
    width: 10px;
    height: 1px;
    position: absolute;
    top: 50%;
    left: -10px;
  }
  #mv_area .breadcrumb ul li a:hover {
    text-decoration: underline;
  }
  #mv_area .mv_ttl h1 {
    font-size: 3.2rem;
    font-weight: 600;
    line-height: 1.32;
    letter-spacing: 0.1em;
    margin-bottom: 20px;
    position: relative;
  }
  #mv_area .mv_ttl h1::before {
    content: attr(data-en);
    font-family: "Rubik", sans-serif;
    font-size: 1.3rem;
    font-weight: 400;
    position: absolute;
    left: 0;
    top: -24px;
    letter-spacing: 0.05em;
  }
  #mv_area.index {
    height: calc(100svh - 56px);
    margin-bottom: 75px;
  }
  #mv_area.index .mv_ttl {
    position: absolute;
    inset: auto 40px 40px 24px;
  }
  #mv_area.index .mv_ttl h1::before {
    font-size: 1.3rem;
    line-height: 1.28;
  }
  #mv_area.index .mv_img {
    position: absolute;
    inset: 0;
    z-index: -1;
  }
  #mv_area.index .mv_img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  #mv_area.index .description {
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.5;
  }
  #mv_area:not(.index) {
    background: url(/common/image/base/line_bg_fv_sp.png) no-repeat;
    background-size: 100% auto;
    padding-bottom: 60px;
    margin-bottom: 75px;
  }
  #mv_area:not(.index)::before {
    content: "";
    background-image: linear-gradient(to top, white, rgba(255, 255, 255, 0.3) 400px), linear-gradient(45deg, rgba(68, 119, 171, 0.3) 0%, rgba(211, 217, 219, 0.3) 36%, rgba(192, 213, 240, 0.3) 90%, rgba(255, 219, 219, 0.3) 100%);
    position: absolute;
    inset: 100% 0 auto 0;
    z-index: -1;
    height: 1400px;
  }
  #mv_area:not(.index) .mv_ttl {
    padding: 0 24px 0;
    margin: 0 auto;
  }
  #mv_area:not(.index) .mv_ttl h1 {
    font-size: 2.8rem;
  }
  #mv_area:not(.index) .mv_img {
    margin-top: 35px;
    padding: 0 20px;
  }
  #mv_area:not(.index) .mv_img img {
    border-radius: 12px;
  }
  #mv_area:not(.index) .description {
    padding-left: 32px;
    margin-top: 32px;
    position: relative;
  }
  #mv_area:not(.index) .description::before {
    content: "";
    width: 16px;
    height: 1px;
    background: #83a9db;
    position: absolute;
    top: 10px;
    left: 6px;
  }
  #mv_area:not(.index) .description p + p {
    margin-top: 30px;
  }
  #mv_area.lower {
    padding-bottom: 0;
  }
  #mv_area.lower::before {
    content: "";
    background-image: linear-gradient(to top, white, rgba(255, 255, 255, 0.3) 400px), linear-gradient(45deg, rgba(68, 119, 171, 0.3) 0%, rgba(211, 217, 219, 0.3) 36%, rgba(192, 213, 240, 0.3) 90%, rgba(255, 219, 219, 0.3) 100%);
    position: absolute;
    inset: calc(100% - 180px) 0 auto 0;
    z-index: -1;
    height: 1520px;
  }
  /* ボタン  */
  /************/
  .link_bl {
    margin-top: 30px;
  }
  .link_bl a {
    background: linear-gradient(to right, #4984d1, #83a9db);
    color: #fff;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-left: none;
    border-top-right-radius: 46px;
    border-bottom-right-radius: 46px;
    padding: 0 28px 1px 32px;
    margin-left: 23px;
    font-size: 1.3rem;
    height: 46px;
    box-sizing: border-box;
  }
  .link_bl a[target="_blank"] {
    background: url(/common/image/base/ico_blank_w.svg) no-repeat right 30px center, linear-gradient(to right, #4984d1, #83a9db);
    padding-right: 46px;
  }
  .link_bl a::before {
    content: "";
    width: 46px;
    height: 46px;
    background: url(/common/image/base/link_arw_hover.png) no-repeat;
    background-size: 46px 46px;
    position: absolute;
    left: -24px;
    top: calc(50% - 23px);
  }
}
