/*! --------------------------------------------------------------
　　このCSSファイルは .scssファイルからコンパイルされたものです。
　　修正する際はscssファイルを編集するように注意してください。
--------------------------------------------------------------- */
.clearfix:after {
    content: "";
    display: block;
    clear: both
  }
  
  li {
    list-style: none
  }
  
  img {
    max-width: 100%;
    height: auto
  }
  
  a {
    color: inherit;
    text-decoration: none
  }
  
  .min {
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif
  }
  
  table {
    table-layout: fixed;
    border-collapse: collapse;
    border-spacing: 0
  }
  
  td input {
    max-width: 100%
  }
  
  i,
  em {
    font-style: normal
  }

  @media(min-width: 820px) {
    .blog_single .inner {
      max-width: 820px;
      margin: 0 auto;
    }
	.blog_related .inner {
      max-width: 820px;
      margin: 0 auto;
    }
  }
  
  .inner {
    width: 100%;
    position: relative
  }
  
  @media(min-width: 1200px) {
    .inner {
      max-width: 1120px;
      padding: 0 20px;
      margin: 0 auto
    }
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .inner {
      padding: 0 5vw
    }
  }
  
  @media(max-width: 767px) {
    .inner {
      padding: 0 5%
    }
  }
  
  .pc-only {
    display: inherit
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .pc-only {
      display: none
    }
  }
  
  @media(max-width: 767px) {
    .pc-only {
      display: none
    }
  }
  
  .tab-only {
    display: none
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .tab-only {
      display: inherit
    }
  }
  
  @media(max-width: 767px) {
    .tab-only {
      display: none
    }
  }
  
  .sp-only {
    display: none
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .sp-only {
      display: none
    }
  }
  
  @media(max-width: 767px) {
    .sp-only {
      display: inherit
    }
  }
  
  .pctab-only {
    display: inherit
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .pctab-only {
      display: inherit
    }
  }
  
  @media(max-width: 767px) {
    .pctab-only {
      display: none
    }
  }
  
  .tabsp-only {
    display: none
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .tabsp-only {
      display: inherit
    }
  }
  
  @media(max-width: 767px) {
    .tabsp-only {
      display: inherit
    }
  }
  
  a.tellink {
    pointer-events: none
  }
  
  @media(max-width: 767px) {
    a.tellink {
      pointer-events: inherit
    }
  }
  
  @media(max-width: 767px) {
    :root {
      font-size: 4.26666vw !important
    }
  }
  
  html,
  body {
    font-size: 1rem;
    line-height: 2;
    color: #333;
    font-family: "游ゴシック", "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif
  }
  
  html {
    overflow: auto
  }
  
  body {
    overflow: hidden
  }
  
  .zen {
    font-family: "IBM Plex Sans JP", sans-serif
  }

  .en {
    font-family: "Montserrat", sans-serif
  }
  
  .maru {
    font-family: "Zen Maru Gothic", serif
  }
  
  header {
    width: 100%;
    height: 125px;
    margin-bottom: -125px;
    position: relative;
    z-index: 2
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header {
      height: 60px;
      margin-bottom: -60px
    }
  }
  
  @media(max-width: 767px) {
    header {
      height: 16vw;
      margin-bottom: -16vw
    }
  }
  
  body.page header {
    margin-bottom: 0
  }
  
  header .topline {
    height: 75px;
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    align-content: stretch;
    padding-left: 2vw;
    position: relative
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .topline {
      display: none
    }
  }
  
  @media(max-width: 767px) {
    header .topline {
      display: none
    }
  }
  
  header .topline .left {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center
  }
  
  header .topline .left .head_logo {
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
    align-content: unset;
    flex-direction: column
  }
  
  header .topline .left .head_logo a:hover {
    opacity: .8
  }
  
  header .topline .right {
    height: 100%;
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-end;
    align-items: center;
    align-content: unset
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .topline .right {
      display: none
    }
  }
  
  @media(max-width: 767px) {
    header .topline .right {
      display: none
    }
  }
  
  header .topline .right .btn_tel {
    margin-right: 2vw
  }
  
  header .topline .right .btn_head {
    margin-left: 1px
  }
  
  header .btmline {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center
  }
  
  @media(min-width: 1200px) {
    header .btmline {
      height: 50px
    }
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .btmline {
      height: 60px;
      justify-content: flex-start;
      padding-left: 5vw
    }
  }
  
  @media(max-width: 767px) {
    header .btmline {
      height: 16vw;
      justify-content: flex-start;
      padding-left: 5vw
    }
  }
  
  header .btmline .head_logo {
    z-index: 10
  }
  
  @media(max-width: 767px) {
    header .btmline .head_logo {
      width: 84vw;
      height: 16vw
    }
  }
  
  header .btmline .head_logo a {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
    align-content: unset
  }
  
  header .btmline .head_logo a:hover {
    opacity: .8
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .btmline .head_logo img {
      width: 30vw
    }
  }
  
  @media(max-width: 767px) {
    header .btmline .head_logo img {
      width: 45.5333333333vw
    }
  }
  
  header .gnav {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center
  }
  
  @media(min-width: 1200px) {
    header .gnav {
      width: 100%;
      max-width: 880px;
      padding-right: 2vw;
      margin-inline: auto 0
    }
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .gnav {
      display: none;
      width: 100%;
      background-color: #01b514;
      position: absolute;
      top: 60px;
      left: 0;
      z-index: 11
    }
  }
  
  @media(max-width: 767px) {
    header .gnav {
      display: none;
      width: 100%;
      background-color: #01b514;
      position: absolute;
      top: 16vw;
      left: 0;
      z-index: 11
    }
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .gnav.open {
      display: block
    }
  }
  
  @media(max-width: 767px) {
    header .gnav.open {
      display: block
    }
  }
  
  header .gnav .ul_one {
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center
  }
  
  @media(min-width: 1200px) {
    header .gnav .ul_one {
      width: 100%
    }
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .gnav .ul_one {
      display: block;
      width: 100%;
      border-top: 1px solid #fff
    }
  }
  
  @media(max-width: 767px) {
    header .gnav .ul_one {
      display: block;
      width: 100%;
      border-top: 1px solid #fff
    }
  }
  
  header .gnav .ul_one>li>a {
    width: 100%;
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    align-content: unset;
    position: relative
  }
  
  @media(min-width: 1200px) {
    header .gnav .ul_one>li>a {
      padding: .5rem 0
    }
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .gnav .ul_one>li>a {
      justify-content: flex-start;
      padding: 1.2rem 5vw;
      border-bottom: 1px solid #fff
    }
  }
  
  @media(max-width: 767px) {
    header .gnav .ul_one>li>a {
      height: 8vh;
      justify-content: flex-start;
      padding: .5rem 5vw;
      border-bottom: 1px solid #fff
    }
  }
  
  @media(min-width: 1200px) {
    header .gnav .ul_one>li>a::before {
      content: "";
      width: 0;
      height: 1px;
      background-color: currentColor;
      position: absolute;
      bottom: 0;
      left: 0
    }
  }
  
  @media(min-width: 1200px) {
    header .gnav .ul_one>li>a:hover::before {
      width: 100%;
      transition: .5s ease
    }
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .ul_one li:not(.li_parent) a::after {
      content: "";
      font-size: 0.625rem;
      color: #fff;
      font-weight: 900;
      font-family: "Font Awesome 5 Free";
      position: absolute;
      top: 50%;
      right: 5vw;
      transform: translateY(-50%)
    }
  }
  
  @media(max-width: 767px) {
    .ul_one li:not(.li_parent) a::after {
      content: "";
      font-size: 0.625rem;
      color: #fff;
      font-weight: 900;
      font-family: "Font Awesome 5 Free";
      position: absolute;
      top: 50%;
      right: 5vw;
      transform: translateY(-50%)
    }
  }
  
  header .gnav .ul_one>li>a p {
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: .1em;
    text-align: center;
    position: relative
  }
  
  @media(min-width: 1200px)and (max-width: 1399px) {
    header .gnav .ul_one>li>a p {
      font-size: 0.75rem
    }
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .gnav .ul_one>li>a p {
      font-size: 1rem;
      color: #fff;
      text-align: left
    }
  }
  
  @media(max-width: 767px) {
    header .gnav .ul_one>li>a p {
      font-size: 1rem;
      color: #fff;
      text-align: left
    }
  }
  
  header .gnav .ul_one>li {
    position: relative
  }
  
  header .gnav .ul_one>li a.parent {
    position: relative
  }
  
  @media(max-width: 767px) {
    header .gnav .ul_one>li a.parent.open p i {
      transform: translateY(-50%) rotate(180deg)
    }
  }
  
  header .gnav .ul_one>li p {
    width: 100%;
    position: relative
  }
  
  header .gnav .ul_one>li p i {
    font-size: 0.625rem;
    color: currentColor;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    transition: .3s ease
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .gnav .ul_one>li p i {
      font-size: 0.875rem;
      position: absolute;
      top: 50%;
      left: unset;
      right: 0;
      transform: translateY(-50%)
    }
  }
  
  @media(max-width: 767px) {
    header .gnav .ul_one>li p i {
      font-size: 0.875rem;
      position: absolute;
      top: 50%;
      left: unset;
      right: 0;
      transform: translateY(-50%)
    }
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .gnav .ul_one>li p i:nth-child(1) {
      display: none
    }
  }
  
  @media(max-width: 767px) {
    header .gnav .ul_one>li p i:nth-child(1) {
      display: none
    }
  }
  
  @media(min-width: 1200px) {
    header .gnav .ul_one>li p i:nth-child(2) {
      display: none
    }
  }
  
  header .gnav .ul_one>li:hover .submenu {
    visibility: visible;
    opacity: 1
  }
  
  header .gnav .ul_one>li .submenu {
    visibility: hidden;
    opacity: 0;
    z-index: 1;
    padding: 1rem 1rem
  }
  
  @media(min-width: 1200px) {
    header .gnav .ul_one>li .submenu {
      width: 880px;
      background-color: #fff;
      border-radius: 10px;
      box-shadow: 0px 3px 6px rgba(0, 0, 0, .16);
      position: absolute;
      top: 100%;
      left: 50%;
      translate: -50% 0
    }
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .gnav .ul_one>li .submenu {
      display: none;
      background-color: #00760c;
      visibility: visible;
      border-radius: 0;
      box-shadow: unset;
      opacity: 1;
      width: 100%;
      max-width: unset;
      padding: 0
    }
  }
  
  @media(max-width: 767px) {
    header .gnav .ul_one>li .submenu {
      display: none;
      background-color: #00760c;
      visibility: visible;
      border-radius: 0;
      box-shadow: unset;
      opacity: 1;
      width: 100%;
      max-width: unset;
      padding: 0
    }
  }
  
  header .gnav .ul_one>li .submenu .ttl_sub {
    padding-bottom: .4em;
    border-bottom: 1px solid #01b514;
    margin-bottom: .8em
  }
  
  @media(min-width: 1200px) {
    header .gnav .ul_one>li .submenu ul {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
      gap: 1.2rem 2rem
    }
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .gnav .ul_one>li .submenu ul>li {
      border-bottom: 1px solid #fff
    }
  }
  
  @media(max-width: 767px) {
    header .gnav .ul_one>li .submenu ul>li {
      border-bottom: 1px solid #fff
    }
  }
  
  header .gnav .ul_one>li .submenu ul>li a {
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    align-content: unset;
    font-size: 0.875rem;
    font-weight: 700;
    line-height: 1.35;
    padding: 0rem 1rem 0 0;
    position: relative
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .gnav .ul_one>li .submenu ul>li a {
      color: #fff;
      padding: 1.2rem 5%
    }
  }
  
  @media(max-width: 767px) {
    header .gnav .ul_one>li .submenu ul>li a {
      height: 8vh;
      font-size: 1rem;
      color: #fff;
      padding: .5rem 5%
    }
  }
  
  @media(min-width: 1200px) {
    header .gnav .ul_one>li .submenu ul>li a::after {
      content: "";
      font-size: 0.625rem;
      color: currentColor;
      font-weight: 900;
      font-family: "Font Awesome 5 Free";
      position: absolute;
      top: 50%;
      right: 4%;
      transform: translateY(-50%)
    }
  }
  
  header .gnav .ul_one>li .submenu ul>li a:hover {
    transition: .3s ease
  }
  
  header .right_add {
    padding: 2rem 5%
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    header .right_add {
      display: block
    }
  }
  
  @media(max-width: 767px) {
    header .right_add {
      display: block
    }
  }
  
  header .right_add .btn_head {
    margin-inline: auto
  }
  
  header .right_add .btn_head:not(:last-child) {
    margin-bottom: 1.2rem
  }
  
  header .right_add .btn_tel {
    margin-inline: auto
  }
  
  .btn_tel {
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%
  }
  
  .btn_tel a {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center
  }
  
  .btn_tel a i {
    font-size: 1rem;
    margin-right: .2em;
    position: relative;
    top: -0.7em
  }
  
  @media(max-width: 767px) {
    .btn_tel a i {
      font-size: 1.25rem
    }
  }
  
  .btn_tel a p em {
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: .12em
  }
  
  @media(max-width: 767px) {
    .btn_tel a p em {
      font-size: 2rem
    }
  }
  
  .btn_tel a p span {
    display: block;
    font-size: 0.8125rem;
    font-weight: 700;
    letter-spacing: .1em
  }
  
  @media(max-width: 767px) {
    .btn_tel a p span {
      font-size: 1.0625rem
    }
  }
  
  .btn_tel.large a i {
    font-size: 2rem;
    top: -0.45em
  }
  
  @media(max-width: 767px) {
    .btn_tel.large a i {
      font-size: 1.625rem
    }
  }
  
  .btn_tel.large a p em {
    font-size: 2.8125rem
  }
  
  @media(max-width: 767px) {
    .btn_tel.large a p em {
      font-size: 2rem
    }
  }
  
  .btn_tel.large a p span {
    font-size: 1.1875rem
  }
  
  @media(max-width: 767px) {
    .btn_tel.large a p span {
      font-size: 1.0625rem
    }
  }
  
  .btn_tel.color_w a i,
  .btn_tel.color_w a p {
    color: #fff
  }
  
  .btn_tel.center {
    margin-inline: auto
  }
  
  .btn_head {
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%
  }
  
  .btn_head a {
    width: 125px;
    height: 75px;
    max-width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center
  }
  
  @media(min-width: 1200px) {
    .btn_head a {
      flex-direction: column
    }
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .btn_head a {
      width: 82vw;
      height: 3.5rem;
      border: 1px solid #fff
    }
  }
  
  @media(max-width: 767px) {
    .btn_head a {
      width: 82vw;
      height: 3.5rem;
      border: 1px solid #fff
    }
  }
  
  .btn_head a:hover {
    transition: .3s ease
  }
  
  .btn_head a>i {
    font-size: 1.25rem;
    line-height: 1;
    margin-bottom: .2em
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .btn_head a>i {
      font-size: 1.375rem;
      margin: 0 .5em 0 0
    }
  }
  
  @media(max-width: 767px) {
    .btn_head a>i {
      font-size: 1.375rem;
      margin: 0 .5em 0 0
    }
  }
  
  .btn_head a p {
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.3
  }
  
  .btn_head.bg_k a {
    background-color: #333;
    color: #fff
  }
  
  .btn_head.bg_k a:hover {
    background-color: #222;
    transition: .3s ease
  }
  
  .btn_head.bg_dg a {
    background-color: #186c21;
    color: #fff
  }
  
  .btn_head.bg_dg a:hover {
    background-color: #0a4511;
    transition: .3s ease
  }
  
  .btn_head.bg_eg a {
    background-color: #01b514;
    color: #fff
  }
  
  .btn_head.bg_eg a:hover {
    background-color: #00760c;
    transition: .3s ease
  }
  
  .icn_menu {
    width: 16vw;
    height: 16vw;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 13
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .icn_menu {
      width: 60px;
      height: 60px
    }
  }
  
  .icn_menu .menu-trigger,
  .icn_menu .menu-trigger span {
    display: inline-block;
    transition: all .4s
  }
  
  .icn_menu .menu-trigger {
    width: 100%;
    height: 100%;
    background: #01b514;
    padding: 1rem 1rem;
    position: relative
  }
  
  .icn_menu .menu-trigger .spanwrap {
    height: 100%;
    position: relative
  }
  
  .icn_menu .menu-trigger .spanwrap span {
    position: absolute;
    right: 0;
    width: 100%;
    height: 1px;
    background-color: #fff
  }
  
  .icn_menu .menu-trigger .spanwrap span:nth-of-type(1) {
    top: 0
  }
  
  .icn_menu .menu-trigger .spanwrap span:nth-of-type(2) {
    top: 50%;
    translate: 0 -50%
  }
  
  .icn_menu .menu-trigger .spanwrap span:nth-of-type(3) {
    bottom: 0
  }
  
  .icn_menu .menu-trigger.active span:nth-of-type(1) {
    width: 100%;
    translate: 0 -50%;
    rotate: -45deg;
    top: 50%
  }
  
  .icn_menu .menu-trigger.active span:nth-of-type(2) {
    opacity: 0
  }
  
  .icn_menu .menu-trigger.active span:nth-of-type(3) {
    width: 100%;
    translate: 0 -50%;
    rotate: 45deg;
    top: 50%
  }
  
  .main_home {
    height: calc(100vh - 0px);
    background: url(images/index/bg_main01.svg) center center/cover no-repeat;
    position: relative;
    overflow: hidden;
    z-index: 0
  }
  
  @media(max-width: 767px) {
    .main_home {
      height: calc(100vh - 0vw)
    }
  }
  
  .main_home video {
    height: auto;
    border-radius: 5vw 0 0 5vw;
    overflow: hidden;
    -o-object-fit: fill;
    object-fit: fill;
    position: absolute;
    right: 0;
    z-index: 1;
    filter: brightness(0.6)
  }
  
  @media(min-width: 1200px) {
    .main_home video {
      width: 70vw;
      height: calc(100vh - 125px - 68px);
      top: 125px;
      translate: unset
    }
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .main_home video {
      width: 80vw;
      height: calc(100vh - 60px - 30px);
      top: 60px;
      translate: unset
    }
  }
  
  @media(max-width: 767px) {
    .main_home video {
      width: 90vw;
      height: calc(100vh - 16vw - 8vw);
      top: 16vw;
      translate: unset
    }
  }
  
  .main_home .txtlayer {
    width: 100%;
    height: calc(100% - 125px);
    position: absolute;
    top: 125px;
    left: 0;
    z-index: 2
  }
  
  .main_home .txtlayer .txt {
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
    padding-left: 5vw
  }

.main_home .txtlayer .txt h2 {
	width: 100%;
    height: 100%;
	place-content:center
}

.main_home .txtlayer .txt img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
	object-fit: contain;
}

@media (min-width: 768px) and (max-width: 1199px) {
	  .main_home .txtlayer {
		height: calc(100% - 60px);
		top: 60px;
	  }
}
  
  .main_home .ttl01,
  .main_home .ttl02 {
    color: #fff;
    font-weight: 500
  }
  
  .main_home .ttl01 {
    font-size: 3.75rem;
    line-height: 1.1;
    margin-bottom: .3em
  }
  
  @media(max-width: 767px) {
    .main_home .ttl01 {
      font-size: 2.25rem
    }
  }
  
  .main_home .ttl02 {
    font-size: 1.25rem;
    line-height: 1.8
  }
  
  @media(max-width: 767px) {
    .main_home .ttl02 {
      font-size: 0.875rem
    }
  }
  
  .section_cmn {
    padding: 5rem 0
  }
  
  @media(max-width: 767px) {
    .section_cmn {
      padding: 3rem 0
    }
  }
  
  .section_cmn.t_narrow {
    padding-top: 3.5rem
  }
  
  @media(max-width: 767px) {
    .section_cmn.t_narrow {
      padding-top: 2.5rem
    }
  }
  
  .section_cmn.b_narrow {
    padding-bottom: 3.5rem
  }
  
  @media(max-width: 767px) {
    .section_cmn.b_narrow {
      padding-bottom: 2.5rem
    }
  }
  
  .section_cmn.t_wide {
    padding-top: 7.5rem
  }
  
  @media(max-width: 767px) {
    .section_cmn.t_wide {
      padding-top: 3.5rem
    }
  }
  
  .section_cmn.b_wide {
    padding-bottom: 7.5rem
  }
  
  @media(max-width: 767px) {
    .section_cmn.b_wide {
      padding-bottom: 3.5rem
    }
  }
  
  .section_cmn.b_exwide {
    padding-bottom: 10rem
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .section_cmn.b_exwide {
      padding-bottom: 6rem
    }
  }
  
  @media(max-width: 767px) {
    .section_cmn.b_exwide {
      padding-bottom: 4rem
    }
  }
  
  .section_cmn.b_none {
    padding-bottom: 0
  }
  
  .ttl_cmn {
    font-size: 2.375rem;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: .06em;
    margin-bottom: .8em
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .ttl_cmn {
      font-size: 1.75rem
    }
  }
  
  @media(max-width: 767px) {
    .ttl_cmn {
      font-size: 1.25rem
    }
  }
  
  .ttl_cmn em {
    display: block;
    font-size: 6.125rem;
    line-height: 1;
    letter-spacing: .14em;
    margin-bottom: .2em
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .ttl_cmn em {
      font-size: 3.125rem
    }
  }
  
  @media(max-width: 767px) {
    .ttl_cmn em {
      font-size: 2.375rem
    }
  }
  
  .ttl_cmn em.color_eg {
    color: #01b514
  }
  
  .ttl_cmn em.color_w {
    color: #fff
  }
  
  .ttl_cmn.tac {
    text-align: center
  }
  
  .ttl_cmn.color_w {
    color: #fff
  }
  
  .ttl_cmn.color_eg {
    color: #01b514
  }
  
  .ttl_cmn.mb0 {
    margin-bottom: 0
  }
  
  .ttl_cmn.mb_w {
    margin-bottom: 1.5em
  }
  
  .ttl_cmn2 {
    font-size: 2.2rem;
    font-weight: 700;
    line-height: 1.5;
    margin-bottom: .8em
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .ttl_cmn2 {
      font-size: 1.5rem
    }
  }
  
  @media(max-width: 767px) {
    .ttl_cmn2 {
      font-size: 1.375rem
    }
  }
  
  .ttl_cmn2.medium {
    font-weight: 500
  }
  
  .ttl_cmn2.tac {
    text-align: center
  }
  
  .ttl_cmn2.bdb {
    padding-left: .1em;
    padding-bottom: .3em;
    border-bottom: .15em solid currentColor
  }
  
  .ttl_cmn2.color_eg {
    color: #01b514
  }
  
  .ttl_cmn2.color_dg {
    color: #186c21
  }
  
  .ttl_cmn2.color_w {
    color: #fff
  }
  
  .ttl_cmn2.large {
    font-size: 2.2rem
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .ttl_cmn2.large {
      font-size: 1.625rem
    }
  }
  
  @media(max-width: 767px) {
    .ttl_cmn2.large {
      font-size: 1.5rem
    }
  }
  
  .ttl_cmn2.mdl2 {
    font-size: 2rem
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .ttl_cmn2.mdl2 {
      font-size: 1.375rem
    }
  }
  
  @media(max-width: 767px) {
    .ttl_cmn2.mdl2 {
      font-size: 1.25rem
    }
  }
  
  .ttl_cmn2.mdsm {
    font-size: 1.5rem
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .ttl_cmn2.mdsm {
      font-size: 1.25rem
    }
  }
  
  @media(max-width: 767px) {
    .ttl_cmn2.mdsm {
      font-size: 1.125rem
    }
  }
  
  .ttl_cmn2.mdl {
    font-size: 1.375rem
  }
  
  @media(max-width: 767px) {
    .ttl_cmn2.mdl {
      font-size: 1.0625rem
    }
  }
  
  .ttl_cmn2.small {
    font-size: 1.25rem;
	  		font-weight:500
  }
  
  @media(max-width: 767px) {
    .ttl_cmn2.small {
      font-size: 1rem;
		font-weight:500
    }
  }
  
  .ttl_cmn2.mb0 {
    margin-bottom: 0
  }
  
  .ttl_cmn2.mb_w {
    margin-bottom: 1.5em
  }
  
  .txt_cmn {
    font-size: 1rem;
    font-weight: 400;
    line-height: 2;
    letter-spacing: .05em
  }
  
  @media(max-width: 767px) {
    .txt_cmn {
      font-size: 0.875rem;
      letter-spacing: 0
    }
  }
  
  .txt_cmn.lh_w {
    line-height: 2.4
  }
  
  .txt_cmn.lh_n {
    line-height: 1.75
  }
  
  .txt_cmn.tac {
    text-align: center
  }
  
  .txt_cmn.tar {
    text-align: right
  }
  
  .txt_cmn.medium {
    font-weight: 500
  }
  
  .txt_cmn.bold {
    font-weight: 700
  }
  
  .txt_cmn.color_w {
    color: #fff
  }
  
  .txt_cmn.color_eg {
    color: #01b514
  }
  
  .txt_cmn.color_dg {
    color: #186c21
  }
  
  .txt_cmn.large {
    font-size: 1.125rem
  }
  
  @media(max-width: 767px) {
    .txt_cmn.large {
      font-size: 1rem
    }
  }
  
  .txt_cmn.mdl {
    font-size: 0.875rem
  }
  
  @media(max-width: 767px) {
    .txt_cmn.mdl {
      font-size: 0.875rem
    }
  }
  
  .txt_cmn.small {
    font-size: 0.75rem
  }
  
  @media(max-width: 767px) {
    .txt_cmn.small {
      font-size: 0.75rem
    }
  }
  
  .btn_cmn {
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%
  }
  
  .btn_cmn a {
    max-width: 100%;
    width: 280px;
    height: 56px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    align-content: unset;
    position: relative
  }
  
  @media(max-width: 767px) {
    .btn_cmn a {
      width: 64vw;
      height: 3rem
    }
  }
  
  .btn_cmn a>i {
    font-size: 1rem;
    margin-right: .4em
  }
  
  .btn_cmn a p {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.5;
    text-align: center
  }
  
  .btn_cmn.bar a {
    position: relative
  }
  
  .btn_cmn.bar a::before {
    content: "";
    width: 1em;
    height: 1px;
    background-color: currentColor;
    position: absolute;
    top: 50%;
    right: 0;
    translate: 50% -50%
  }
  
  .btn_cmn.large a {
    width: 346px;
    height: 82px
  }
  
  @media(max-width: 767px) {
    .btn_cmn.large a {
      width: 74vw;
      height: 3.5rem
    }
  }
  
  .btn_cmn.large a>i {
    font-size: 2.25rem
  }
  
  @media(max-width: 767px) {
    .btn_cmn.large a>i {
      font-size: 1.25rem
    }
  }
  
  .btn_cmn.large a p {
    font-size: 1.625rem
  }
  
  @media(max-width: 767px) {
    .btn_cmn.large a p {
      font-size: 1.125rem
    }
  }
  
  .btn_cmn.center {
    margin-inline: auto
  }
  
  .btn_cmn.right {
    margin-inline: auto 0
  }
  
  .btn_cmn.round a {
    border-radius: 100vmax
  }
  
  .btn_cmn.bd_k a {
    border: 1px solid currentColor;
    background-color: #fff;
    color: #333
  }
  
  .btn_cmn.bd_k a:hover {
    background-color: #333;
    color: #fff;
    transition: .3s ease
  }
  
  .btn_cmn.bg_y a {
    background-color: #ff0;
    box-shadow: 1px 3px 10px #000
  }
  
  .btn_cmn.bg_y a:hover {
    background-color: #990;
    transition: .3s ease
  }
  
  .btn_cmn.bg_yg a {
    background-color: #73ea0d;
    box-shadow: 1px 3px 10px #000
  }
  
  .btn_cmn.bg_yg a:hover {
    background-color: #448908;
    transition: .3s ease
  }
  
  .btn_cmn.bg_ash a {
    background-color: #e3e3e3;
    box-shadow: 1px 3px 10px #000
  }
  
  .btn_cmn.bg_ash a:hover {
    background-color: #b0b0b0;
    transition: .3s ease
  }
  
  .btn_naked {
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%
  }
  
  .btn_naked a {
    max-width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    align-content: unset;
    position: relative
  }
  
  .btn_naked a p {
    font-size: 1rem;
    color: #01b514;
    font-weight: 700;
    line-height: 1.5;
    text-align: center;
    position: relative
  }
  
  @media(max-width: 767px) {
    .btn_naked a p {
      font-size: 0.8125rem
    }
  }
  
  .btn_naked a p::after {
    content: "";
    width: 0;
    height: 1px;
    background-color: currentColor;
    position: absolute;
    bottom: -2px;
    left: 0
  }
  
  .btn_naked a>i {
    margin-left: 1.5rem;
    position: relative;
    left: 0
  }
  
  .btn_naked:hover p::after {
    width: 100%;
    transition: .5s ease
  }
  
  .btn_naked:hover i {
    left: 1rem;
    transition: .5s ease
  }
  
  .btn_naked.center {
    margin-inline: auto
  }
  
  .btn_naked.right {
    margin-inline: auto 0
  }
  
  .over_cmn {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    align-content: unset;
    padding: 0rem calc(50vw - 50%) 0rem 0;
    margin: 0 calc(50% - 50vw);
    position: relative
  }
  
  @media(max-width: 767px) {
    .over_cmn {
      padding: 0
    }
  }
  
  .over_cmn figure {
    width: calc(100% - 540px);
    text-align: right
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .over_cmn figure {
      width: 49.0740740741%
    }
  }
  
  @media(max-width: 767px) {
    .over_cmn figure {
      width: 100%;
      margin-bottom: 1rem
    }
  }
  
  .over_cmn .txt {
    width: 480px
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .over_cmn .txt {
      width: 47.2222222222%
    }
  }
  
  @media(max-width: 767px) {
    .over_cmn .txt {
      width: 100%;
      padding: 0 8%
    }
  }
  
  @media(max-width: 767px) {
    .over_cmn:not(.reverse) figure {
      margin-right: 8vw
    }
  }
  
  .over_cmn.reverse {
    flex-direction: row-reverse;
    padding: 0rem 0 0rem calc(50vw - 50%)
  }
  
  @media(max-width: 767px) {
    .over_cmn.reverse {
      padding: 0
    }
  }
  
  .over_cmn.reverse figure {
    text-align: left
  }
  
  @media(max-width: 767px) {
    .over_cmn.reverse figure {
      margin-left: 8vw
    }
  }
  
  .over_cmn.a_start {
    align-items: flex-start
  }
  
  .side_cmn {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    align-content: unset
  }
  
  .side_cmn figure {
    width: 50%;
    text-align: center
  }
  
  @media(max-width: 767px) {
    .side_cmn figure {
      width: 100%;
      margin-bottom: 1rem
    }
  }
  
  .side_cmn .txt {
    width: 46.2962962963%
  }
  
  @media(max-width: 767px) {
    .side_cmn .txt {
      width: 100%
    }
  }
  
  .side_cmn.reverse {
    flex-direction: row-reverse
  }
  
  .side_cmn.a_start {
    align-items: flex-start
  }
  
  .side_cmn.alt figure {
    width: 46.2962962963%
  }
  
  @media(max-width: 767px) {
    .side_cmn.alt figure {
      width: 100%
    }
  }
  
  .side_cmn.alt .txt {
    width: 50%
  }
  
  @media(max-width: 767px) {
    .side_cmn.alt .txt {
      width: 100%
    }
  }
  
  .side_cmn.same figure {
    width: 48.1481481481%
  }
  
  @media(max-width: 767px) {
    .side_cmn.same figure {
      width: 100%
    }
  }
  
  .side_cmn.same .txt {
    width: 48.1481481481%
  }
  
  @media(max-width: 767px) {
    .side_cmn.same .txt {
      width: 100%
    }
  }
  
  .side_cmn.trouble figure {
    width: 34%
  }
  
  @media(max-width: 767px) {
    .side_cmn.trouble figure {
      width: 100%
    }
  }
  
  .side_cmn.trouble .txt {
    width: 62%
  }
  
  @media(max-width: 767px) {
    .side_cmn.trouble .txt {
      width: 100%
    }
  }
  
  .side_cmn.service {
    align-items: stretch
  }
  
  .side_cmn.service figure {
    width: 48.1481481481%
  }
  
  @media(max-width: 767px) {
    .side_cmn.service figure {
      width: 100%;
      margin-bottom: 0
    }
  }
  
  .side_cmn.service .txt {
    width: 51.8518518519%
  }
  
  @media(max-width: 767px) {
    .side_cmn.service .txt {
      width: 100%
    }
  }
  
  .side_cmn.footer figure {
    width: 100%
  }
  
  @media(max-width: 767px) {
    .side_cmn.footer figure {
      width: 50%;
      margin: 0 auto;
    }
  }
  
  .side_cmn.footer .txt {
    width: 68%
  }
  
  @media(max-width: 767px) {
    .side_cmn.footer .txt {
      width: 71%
    }
  }
  
  .side_cmn.scan figure {
    width: 16%
  }
  
  @media(max-width: 767px) {
    .side_cmn.scan figure {
      width: 25%;
      margin-bottom: 0
    }
  }
  
  .side_cmn.scan .txt {
    width: 79%
  }
  
  @media(max-width: 767px) {
    .side_cmn.scan .txt {
      width: 71%
    }
  }
  
  .scroll_up {
    transition: .8s ease-in-out;
    transform: translateY(30px);
    opacity: 0
  }
  
  .scroll_up.on {
    transform: translateY(0);
    opacity: 1
  }
  
  .scroll_left {
    transition: .8s ease-in-out;
    transform: translateX(-30px);
    opacity: 0;
    filter: alpha(opacity=0)
  }
  
  .scroll_left.on {
    opacity: 1;
    filter: alpha(opacity=100);
    transform: translateX(0)
  }
  
  .scroll_right {
    transition: .8s ease-in-out;
    transform: translateX(30px);
    opacity: 0;
    filter: alpha(opacity=0)
  }
  
  .scroll_right.on {
    opacity: 1;
    filter: alpha(opacity=100);
    transform: translateX(0)
  }
  
  .scroll_left_main {
    animation: scroll_left_anime 2s ease-in
  }
  
  .scroll_right_main {
    animation: scroll_right_anime 2s ease-in
  }
  
  @keyframes scroll_left_anime {
    0% {
      opacity: 0;
      transform: translateX(-50px)
    }
  
    30% {
      transform: translateX(0)
    }
  
    100% {
      transform: translateX(0)
    }
  
    30%,
    100% {
      opacity: 1
    }
  }
  
  @keyframes scroll_right_anime {
    0% {
      opacity: 0;
      transform: translateX(50px)
    }
  
    30% {
      transform: translateX(0)
    }
  
    100% {
      transform: translateX(0)
    }
  
    30%,
    100% {
      opacity: 1
    }
  }
  
  .home_second {
    background: url(images/index/bg_second01.svg) top left/100% auto repeat
  }
  
  .home_second .ttl01 {
    font-size: 10.875rem;
    color: rgba(0, 0, 0, 0);
    font-weight: 700;
    line-height: 1;
    letter-spacing: .14em;
    text-align: center;
    -webkit-text-stroke: 2px #73ea0d;
    margin-bottom: .3em
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .home_second .ttl01 {
      width: 92vw;
      font-size: 6.25rem;
      letter-spacing: 0;
      margin-inline: auto
    }
  }
  
  @media(max-width: 767px) {
    .home_second .ttl01 {
      width: 92vw;
      font-size: 5.25rem;
      line-height: 1.3;
      letter-spacing: 0;
      margin-inline: auto
    }
  }
  
  .home_second .ttl02 {
    width: -moz-fit-content;
    width: fit-content;
    font-size: 2.3125rem;
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: .1em;
    padding: 0 1em .4em;
    margin-inline: auto;
    margin-bottom: .5em;
    position: relative
  }
  
  @media(max-width: 767px) {
    .home_second .ttl02 {
      font-size: 1.0625rem
    }
  }
  
  .home_second .ttl02 em {
    font-size: 4.6875rem;
    color: #fc4949;
    line-height: 1;
    letter-spacing: 0
  }
  
  @media(max-width: 767px) {
    .home_second .ttl02 em {
      font-size: 2.1875rem
    }
  }
  
  .home_second .ttl02::before,
  .home_second .ttl02::after {
    content: "";
    width: 66px;
    aspect-ratio: 66/73;
    position: absolute;
    top: 50%;
    translate: 0 -50%
  }
  
  @media(max-width: 767px) {
  
    .home_second .ttl02::before,
    .home_second .ttl02::after {
      width: 7vw
    }
  }
  
  .home_second .ttl02::before {
    background: url(images/index/ttlbg_l.svg) center center/100% auto no-repeat;
    right: 100%
  }
  
  .home_second .ttl02::after {
    background: url(images/index/ttlbg_r.svg) center center/100% auto no-repeat;
    left: 100%
  }
  
  .home_second p.txt01 {
    letter-spacing: .1em;
    margin-bottom: 3em
  }
  
  .home_second .loopslider {
    margin-bottom: 10px
  }
  
  .loopslider {
    display: flex;
    align-items: center;
    overflow: hidden
  }
  
  .loopslider ul {
    display: flex;
    animation: loop-slide 20s infinite linear 1s both
  }
  
  .loopslider ul li {
    display: grid;
    place-content: center;
    width: 283px;
    height: 89px;
    margin-right: 30px
  }
  
  @media(max-width: 767px) {
    .loopslider ul li {
      width: 37.7333333333vw;
      height: 11.8666666667vw
    }
  }
  
  @keyframes loop-slide {
    from {
      transform: translateX(0)
    }
  
    to {
      transform: translateX(-100%)
    }
  }
  
  @keyframes loop-slide-reverse {
    from {
      transform: translateX(-100%)
    }
  
    to {
      transform: translateX(0%)
    }
  }
  
  .loopslider.slide-paused:hover ul {
    animation-play-state: paused
  }
  
  .loopslider.reverse ul {
    animation: loop-slide-reverse 20s infinite linear 1s both
  }
  
  .home_trouble {
    background: url(images/index/bg_trouble01.svg) center center/cover no-repeat
  }
  
  .home_trouble ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.2rem 3.7037037037%
  }
  
  @media(max-width: 767px) {
    .home_trouble ul {
      grid-template-columns: repeat(1, 1fr)
    }
  }
  
  .home_trouble ul li {
    background-color: #fff;
    border: 1px solid #01b514;
    border-radius: 5px;
    padding: 10px 2%
  }
  
  .home_trouble .txt_upper {
    display: inline-block;
    background-color: #01b514;
    padding: .3em .5em;
    line-height: 1.5;
    margin-bottom: .6em;
	 font-weight:500
  }
  
  .home_trouble .txt_sub {
    line-height: 1.5
  }
  
  .home_trouble .ttl01 {
    font-size: 1.125rem;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: .1em;
    margin-bottom: 1em
  }
  
  @media(max-width: 767px) {
    .home_trouble .ttl01 {
      font-size: 1.2rem
    }
  }
  
  .home_trouble .ttl01 span {
    font-size: 1rem
  }
  
  @media(max-width: 767px) {
    .home_trouble .ttl01 span {
      font-size: 0.75rem
    }
  }
  
  .home_degital {
    height: 100vh;
    position: relative
  }
  
  .home_degital video {
    width: 100%;
    height: 100%;
    overflow: hidden;
    -o-object-fit: fill;
    object-fit: fill;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    filter: brightness(0.6)
  }
  
  .home_degital .txtlayer {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2
  }
  
  .home_degital .txtlayer .inner {
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    flex-direction: column
  }
  
  .home_degital p.txt01 {
    line-height: 2.7;
    margin-bottom: 3em
  }
  
  @media(max-width: 767px) {
    .home_degital p.txt01 {
      line-height: 2
    }
  }
  
  .home_reason {
    background: url(images/index/bg_second01.svg) top left/100% auto repeat
  }
  
  .home_reason .side_cmn {
    padding: 4rem 4%;
    position: relative
  }
  
  @media(max-width: 767px) {
    .home_reason .side_cmn {
      padding: 2rem 0
    }
  }
  
  .home_reason .side_cmn::before {
    content: "";
    width: calc(50% + 50vw);
    height: 100%;
    position: absolute;
    top: 0;
    z-index: -1
  }
  
  .home_reason .side_cmn:not(:last-child) {
    margin-bottom: 2.5rem
  }
  
  .home_reason .side_cmn:not(.reverse)::before {
    background: linear-gradient(to right, rgba(64, 206, 58, 0.15), rgba(207, 242, 62, 0.15));
    right: 0
  }
  
  @media(max-width: 767px) {
    .home_reason .side_cmn:not(.reverse) .txt {
      padding-right: 1rem
    }
  }
  
  .home_reason .side_cmn.reverse::before {
    background: linear-gradient(to left, rgba(64, 206, 58, 0.15), rgba(207, 242, 62, 0.15));
    left: 0
  }
  
  @media(max-width: 767px) {
    .home_reason .side_cmn.reverse .txt {
      padding-left: 1rem
    }
  }
  
  .home_reason .btn_cmn {
    margin-top: 5rem
  }
  
  @media(max-width: 767px) {
    .home_reason .btn_cmn {
      margin-top: 2.5rem
    }
  }
  
  .home_reason h2.ttl_cmn2 b {
    font-size: 2.75rem;
    color: #01b514;
    line-height: 1.1
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .home_reason h2.ttl_cmn2 b {
      font-size: 1.625rem
    }
  }
  
  @media(max-width: 767px) {
    .home_reason h2.ttl_cmn2 b {
      font-size: 1.5rem
    }
  }
  
  .home_reason .num {
    font-size: 1.25rem;
    color: #186c21;
    font-weight: 700;
    line-height: 1.5;
    margin-bottom: .5em
  }
  
  @media(max-width: 767px) {
    .home_reason .num {
      font-size: 1rem
    }
  }
  
  .home_reason .num em {
    font-size: 3rem;
    line-height: 1;
    margin-left: .2em
  }
  
  @media(max-width: 767px) {
    .home_reason .num em {
      font-size: 1.5rem
    }
  }
  
  .home_reason h3.ttl_cmn2 {
    line-height: 1.4;
    margin-bottom: .4em
  }
  
  .home_service {
    background: url(images/index/bg_service01.svg) center center/cover no-repeat
  }
  
  .home_service h2.ttl_cmn {
    translate: 0 -80%;
    margin-bottom: 0
  }
  
  @media(min-width: 768px)and (max-width: 1199px) {
    .home_service h2.ttl_cmn {
      translate: 0 -100%
    }
  }
  
  @media(max-width: 767px) {
    .home_service h2.ttl_cmn {
      translate: 0 -100%
    }
  }
  
  .home_service .unit {
    background-color: #fff;
    box-shadow: 0 2px 10px rgba(0, 0, 0, .23)
  }
  
  .home_service .unit:not(:last-child) {
    margin-bottom: 3.5rem
  }
  
  @media(max-width: 767px) {
    .home_service .unit:not(:last-child) {
      margin-bottom: 2rem
    }
  }
  
  .home_service .unit figure img {
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
  }
  
  .home_service .unit .txt {
    padding: 3.5rem 3%;
    position: relative
  }
  
  @media(max-width: 767px) {
    .home_service .unit .txt {
      padding: 1.5rem 3% 2rem
    }
  }
  
  .home_service .unit .txt .num {
    font-size: 12.25rem;
    color: rgba(1, 181, 20, .1);
    font-weight: 700;
    line-height: .85;
    position: absolute;
    bottom: 0;
    right: 0
  }
  
  @media(max-width: 767px) {
    .home_service .unit .txt .num {
      font-size: 6.25rem
    }
  }
  
  .home_service .txt_upper {
    display: inline-block;
    background-color: #ff0;
    padding: .3em .5em;
    line-height: 1.5;
    margin-bottom: .6em
  }
  
  .home_service .ttl01 {
    letter-spacing: 0;
    margin-bottom: .2em
  }
  
  .home_service .ttl01 span {
    font-size: 1.25rem;
    letter-spacing: -0.05em
  }
  
  @media(max-width: 767px) {
    .home_service .ttl01 span {
      font-size: 0.9375rem
    }
  }
  
  .home_service .tagwrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 5px;
    margin-bottom: 2rem
  }
  
  @media(max-width: 767px) {
    .home_service .tagwrap {
      margin-bottom: 1.2rem
    }
  }
  
  .home_service .tagwrap span {
    display: inline-block;
    background-color: rgba(115, 234, 13, .2);
    border-radius: 4px;
    padding: .3em .8em;
    font-size: 0.875rem;
    color: #186c21;
    font-weight: 700;
    line-height: 1.5
  }
  
  @media(max-width: 767px) {
    .home_service .tagwrap span {
      font-size: 0.75rem
    }
  }
  
  .home_service p.txt01 {
    margin-bottom: 3em
  }
  
  @media(max-width: 767px) {
    .home_service p.txt01 {
      margin-bottom: 1.8em
    }
  }
  
  .home_service .btn_cmn {
    position: relative;
    z-index: 1
  }
  
  .home_price {
    background: url(images/index/bg_second01.svg) top left/100% auto repeat
  }
  
  .home_price .area {
    background-color: #f1ffe5;
    padding: 2.5rem 4%;
    box-shadow: 0 3px 6px rgba(0, 0, 0, .16)
  }
  
  .home_price .area p.txt01 {
    margin-bottom: 2em
  }
  
  .home_case {
    background: url(images/index/bg_case01.svg) center center/cover no-repeat
  }
  
  .home_case ul {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 3.5rem 2.7777777778%
  }
  
  @media(max-width: 767px) {
    .home_case ul {
      gap: 2rem 4%
    }
  }
  
  .home_case ul li {
    background-color: #fff;
    box-shadow: 0 0 6px rgba(0, 0, 0, .16)
  }
  
  .home_case ul li figure {
    position: relative
  }
  
  .home_case ul li figure img {
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
	aspect-ratio: 16 / 9;
  }
  
  .home_case ul li .wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
    position: absolute;
    bottom: 0;
    left: 0;
    translate: 0 50%
  }
  
  .home_case ul li .wrap .cate {
    display: inline-block;
    background-color: #ff0;
    font-size: 0.875rem;
    font-weight: 700;
    line-height: 1.5;
    padding: .3em .5em;
    margin-right: .6em
  }
  
  .home_case ul li .txt {
    padding: 2rem 3% 1.2rem
  }
  
  .home_twin .inner {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 2rem 4.6296296296%
  }
  
  .home_twin .inner .col {
    background-color: rgba(115, 234, 13, .09);
    padding: 1.5rem 5%
  }
  
  .home_twin .inner .col figure {
    text-align: center;
    margin-bottom: .5rem
  }
  
  .home_twin .inner .col h3 {
    margin-bottom: .5em
  }
  
  .home_twin .inner .col p.txt01 {
    margin-bottom: 1.2em
  }
  
  .home_news .inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    align-content: unset
  }
  
  .home_news .inner>.left {
    width: 13.8888888889%
  }
  
  @media(max-width: 767px) {
    .home_news .inner>.left {
      width: 100%
    }
  }
  
  .home_news .inner>.right {
    width: 84.2592592593%
  }
  
  @media(max-width: 767px) {
    .home_news .inner>.right {
      width: 100%
    }
  }
  
  .home_news .ttl11 {
    font-size: 6.125rem;
    color: rgba(1, 181, 20, .2);
    font-weight: 700;
    line-height: 1;
    writing-mode: vertical-rl
  }
  
  @media(max-width: 767px) {
    .home_news .ttl11 {
      font-size: 3.125rem;
		display:none
    }
  }
  
  .home_news ul {
    margin-bottom: 3rem
  }
  
  @media(max-width: 767px) {
    .home_news ul {
      margin-bottom: 1.5rem
    }
  }
  
  .home_news ul li {
    background-color: #f5f5f5
  }
  
  .home_news ul li:not(:last-child) {
    margin-bottom: 1.2rem
  }
  
  @media(max-width: 767px) {
    .home_news ul li:not(:last-child) {
      margin-bottom: .8rem
    }
  }
  
  .home_news ul li a {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    padding: 1rem 4%
  }
  
  .home_news ul li a time.date {
    display: inline-block;
    line-height: 1.5rem;
    margin-right: 3em
  }
  
  @media(max-width: 767px) {
    .home_news ul li a time.date {
      margin-right: 1em
    }
  }
  
  .home_news ul li a .ttl01 {
    line-height: 1.5rem
  }
  
  .home_blog ul {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2rem 2.7777777778%;
    margin-bottom: 3.3rem
  }
  
  @media(max-width: 767px) {
    .home_blog ul {
      margin-bottom: 2rem
    }
  }
  
  .home_blog ul li {
    box-shadow: 0 0 6px rgba(0, 0, 0, .16)
  }
  
  .home_blog ul li figure {
    position: relative
  }
  
  .home_blog ul li figure img {
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover
  }
  
  .home_blog ul li .txt {
    background-color: #fff;
    padding: 1.2rem 3% 1.2rem
  }
  
  .home_contact {
    background: url(images/index/bg_contact01.svg) center center/cover no-repeat
  }
  
  .home_contact .btn_tel {
    margin-bottom: 2rem
  }
  
  .home_contact .btnwrap {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem 1.9444444444%;
	place-items:center
  }
  
  @media(max-width: 767px) {
    .home_contact .btnwrap .btn_cmn {
      margin-inline: auto
    }
  }
  
  footer .fmain {
    padding: 2.5rem 0 2rem
  }
  
  footer .fmain .inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    align-content: unset
  }
  
  footer .fmain .inner>.left {
    width: 31.4814814815%
  }
  
  @media(max-width: 767px) {
    footer .fmain .inner>.left {
      width: 100%;
      margin-bottom: 2rem
    }
  }
  
  footer .fmain .inner>.right {
    width: 59.2592592593%
  }
  
  @media(max-width: 767px) {
    footer .fmain .inner>.right {
      width: 100%
    }
  }
  
  footer .foot_logo {
    margin-bottom: 1.5rem
  }
  
  footer p.txt01 {
    margin-bottom: .8em
  }
  
  footer p.txt_tel i {
    margin-right: .4em
  }
  
  footer .ttl01 {
    margin-bottom: .4em
  }
  
  /*footer .fnav ul {
    -moz-columns: 3 auto;
    columns: 3 auto
  }*/

.fnav_menu_list {
	display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.fnav_menu_list .fnav_menu_01 {
	display: flex;
    flex-direction: column;
	width: calc(50% - 10px);
}

.fnav_menu_list .fnav_menu_02 {
	width: calc(50% - 10px);
    display: flex;
    flex-direction: column;
}

.fnav_menu_list .fnav_menu_02 li {
	width: 50%;
}
  
  @media(max-width: 767px) {
    footer .fnav ul {
      -moz-columns: 2 auto;
      columns: 2 auto
    }
  }
  
  footer .fnav ul li {
    margin-bottom: .5rem
  }
  
  @media(max-width: 767px) {
    footer .fnav ul li {
      margin-bottom: .2rem
    }
  }
  
  footer .fnav ul li a {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.5;
    display: inline-block;
  }
  
  @media(max-width: 767px) {
    footer .fnav ul li a {
      font-size: 0.75rem;
      line-height: 1rem;
      display: inline-block;
    }
  }
  
  footer .copyright {
    background-color: #eee;
    padding: 1.8rem 0 2.8rem
  }
  
  @media(max-width: 767px) {
    footer .copyright {
      padding: 1.2rem 0 2rem
    }
  }
  
  footer .copyright .inner {
    display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 1rem 1.8518518519%;
	align-items: start;
  }
  
  footer .copyright .inner .unit p.txt02 {
    line-height: 1.6
  }
  
/* blog用 */
.blog_single .aligncenter {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

.has-text-align-center {
	text-align: center;
}

.blog_single figure.aligncenter img {
    display: block;
    margin: 0 auto;
}

.blog_single figure.alignleft img {
    float: left;
    margin-right: 1em;
}

.blog_single figure.alignright img {
    float: right;
    margin-left: 1em;
}

/* ヘッダー追従 */
.bg_w {
	background-color: #fff;
	border-bottom: solid 1px #01b514;
	z-index: 100;
}

.header_top {
	transition: all 0.3s ease 0s;
}

.header_top.bg_w {
	position: fixed;
	top: 0;
}

/*フッター　ロゴレイアウト変更*/
.footer-logo-list {
	flex-direction: column;
    justify-content: center;
    align-items: center;
}

.footer-logo-list figure {
	margin-bottom: 0.5rem;
}

.footer-logo-list .txt {
	width: 100%!important;
	margin-top: 0.5rem;
}
.fa-arrow-up-right-from-square {
	margin: 0 0 0 0.5rem;
}
.home_reason i.fa-chevron-right {
	margin: 0 0.5rem 0 0;
}
.forPrivacy {
	margin: 0 auto 3rem;
	text-align: center;
}

/* プライバシーポリシー　表 */
.pp_table {
	border: solid 1px #a3a3a3;
    margin: 1rem 0 0;
}

.pp_table tr {
	border-bottom: solid 1px #a3a3a3;
}

.pp_table tr th {
	border-right: solid 1px #a3a3a3;
	padding: 0.5rem 0;
}

.pp_table tr:first-of-type {
	background-color: #e1e1e1;
}

.pp_table tr:not(:first-of-type) th {
	text-align: left;
    padding: 0.5rem 1rem;
    width: 20%;
    line-height: 1.8rem;
}

.pp_table td {
	padding: 0.5rem 1rem;
    line-height: 1.8rem;
}

.pp_box {
	margin-bottom: 3rem;
}

@media(max-width: 767px) {
	.pp_table tr:not(:first-of-type) th {
		width: 30%;
	}
}

/* フッター　調整 */
.nav_menu_box {
	display: flex;
}

.nav_menu_box ul {
    display: flex;
    flex-direction: column;
    height: 160px;
}

.nav_menu_box ul:first-of-type {
	padding-right: 1rem;
}

.nav_menu_box ul:last-of-type {
	flex-wrap: wrap;
	border-left: solid 1px #2b322f;
}

.nav_menu_box ul:last-of-type li {
	padding: 0 1rem;
}

@media(max-width: 900px) {
	.nav_menu_box ul {
		height: auto;
	}
}

@media(max-width: 767px) {
	.nav_menu_box {
		flex-direction: column;
	}
	
	.nav_menu_box ul:last-of-type {
		border-left: none;
		border-top: solid 1px #2b322f;
		padding-top: 1rem;
		margin-top: 1rem;
	}
	
	.nav_menu_box ul:last-of-type li {
		padding: 0;
	}
}

  /*# sourceMappingURL=style.css.map */