/*! --------------------------------------------------------------
　　この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
}
.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%
    }
}
@media(min-width: 1200px) {
    .inner.wide {
        max-width: 1240px
    }
}
@media(min-width: 1200px) {
    .inner.narrow {
        max-width: 820px
    }
}
.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: #0f170c;
    font-family: "游ゴシック", "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif
}
html {
    overflow: auto
}
body {
    overflow: hidden
}
.noto {
    font-family: "Noto Sans JP", sans-serif
}
.gara {
    font-family: "EB Garamond", serif
}
.zen {
    font-family: "Zen Old Mincho", serif
}
header {
    width: 100%;
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    align-content: stretch;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 3
}
@media(min-width: 1200px) {
    header {
        height: 80px;
        padding: 0 2vw
    }
}
@media(min-width: 768px)and (max-width: 1199px) {
    header {
        height: 60px;
        justify-content: flex-start;
        padding-left: 5vw
    }
}
@media(max-width: 767px) {
    header {
        height: 16vw;
        justify-content: flex-start;
        padding-left: 5vw
    }
}
header.bg_w {
    background-color: #fff
}
header.bg_w .gnav {
    background-color: #fff
}
header.bg_w .gnav>ul>li>a p {
    color: #0f170c
}
@media(min-width: 768px)and (max-width: 1199px) {
    header.bg_w .gnav>ul>li>a p {
        color: #fff
    }
}
@media(max-width: 767px) {
    header.bg_w .gnav>ul>li>a p {
        color: #fff
    }
}
header.bg_w .right_add .sns a {
    color: #0f170c
}
@media(min-width: 768px)and (max-width: 1199px) {
    header.bg_w .right_add .sns a {
        color: #fff
    }
}
@media(max-width: 767px) {
    header.bg_w .right_add .sns a {
        color: #fff
    }
}
header.bg_w .head_logo img.logo_w {
    display: none
}
header.bg_w .head_logo img.logo_k {
    display: block
}
header .head_logo {
    z-index: 12
}
@media(min-width: 768px)and (max-width: 1199px) {
    header .head_logo {
        width: 30vw
    }
}
@media(max-width: 767px) {
    header .head_logo {
        width: 84vw;
        height: 16vw
    }
}
header .head_logo a {
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
    align-content: unset
}
header .head_logo a:hover {
    opacity: .8
}
@media(max-width: 767px) {
    header .head_logo img {
        width: 49.0666666667vw
    }
}
header .head_logo img.logo_w {
    display: block
}
header .head_logo img.logo_k {
    display: none
}
header .gnav {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center
}
@media(min-width: 1200px) {
    header .gnav {
        width: 100%;
        max-width: 930px
    }
}
@media(min-width: 1200px)and (max-width: 1399px) {
    header .gnav {
        max-width: 840px
    }
}
@media(min-width: 768px)and (max-width: 1199px) {
    header .gnav {
        display: none;
        width: 100%;
        background-color: #0f170c;
        padding-top: 60px;
        position: absolute;
        top: 0px;
        left: 0;
        z-index: 11
    }
}
@media(max-width: 767px) {
    header .gnav {
        display: none;
        width: 100%;
        background-color: #0f170c;
        padding-top: 16vw;
        position: absolute;
        top: 0vw;
        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 {
        gap: 0 2rem
    }
}
@media(min-width: 1200px)and (max-width: 1399px) {
    header .gnav .ul_one {
        gap: 0 1.5rem
    }
}
@media(min-width: 768px)and (max-width: 1199px) {
    header .gnav .ul_one {
        display: block;
        width: 100%;
        background-color: #0f170c;
        border-top: 1px solid #fff
    }
}
@media(max-width: 767px) {
    header .gnav .ul_one {
        display: block;
        width: 100%;
        background-color: #0f170c;
        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: 768px)and (max-width: 1199px) {
    .ul_one li:not(.li_parent) a::after {
        content: "";
        font-size: 0.75rem;
        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.75rem;
        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: 0.9375rem;
    color: #fff;
    font-weight: 700;
    line-height: 1.5;
    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: 1.0625rem;
        text-align: left
    }
}
@media(max-width: 767px) {
    header .gnav .ul_one>li>a p {
        font-size: 1.0625rem;
        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: calc(100% + .2em);
    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;
    transition: .5s;
    padding: 1rem 1rem
}
@media(min-width: 1200px) {
    header .gnav .ul_one>li .submenu {
        width: 100%;
        min-width: 220px;
        background-color: #fff;
        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: #0f170c;
        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: #0f170c;
        visibility: visible;
        border-radius: 0;
        box-shadow: unset;
        opacity: 1;
        width: 100%;
        max-width: unset;
        padding: 0
    }
}
@media(min-width: 1200px) {
    header .gnav .ul_one>li .submenu ul {
        display: grid;
        gap: 1rem 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.9375rem;
    color: #0f170c;
    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 {
        font-size: 1.0625rem;
        color: #fff;
        padding: 1.2rem 5%
    }
}
@media(max-width: 767px) {
    header .gnav .ul_one>li .submenu ul>li a {
        height: 8vh;
        font-size: 1.0625rem;
        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: 0%;
        transform: translateY(-50%)
    }
}
header .gnav .ul_one>li .submenu ul>li a:hover {
    transition: .3s ease
}
header .right_add {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: stretch;
    gap: 0 1.2vw
}
@media(min-width: 768px)and (max-width: 1199px) {
    header .right_add {
        display: block;
        padding: 1.2rem 5% 2rem;
        background-color: #0f170c
    }
}
@media(max-width: 767px) {
    header .right_add {
        display: block;
        padding: 1.2rem 5% 2rem;
        background-color: #0f170c
    }
}
header .right_add .sns {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0 1.2vw
}
@media(min-width: 768px)and (max-width: 1199px) {
    header .right_add .sns {
        gap: 0 4vw;
        margin-bottom: 1.8rem
    }
}
@media(max-width: 767px) {
    header .right_add .sns {
        gap: 0 4vw;
        margin-bottom: 1.8rem
    }
}
header .right_add .sns a {
    font-size: 1.1875rem;
    color: #fff;
    line-height: 1
}
@media(min-width: 768px)and (max-width: 1199px) {
    header .right_add .sns a {
        font-size: 1.9375rem
    }
}
@media(max-width: 767px) {
    header .right_add .sns a {
        font-size: 1.9375rem
    }
}
header .right_add .btn_head {
    margin-inline: auto
}
@media(min-width: 768px)and (max-width: 1199px) {
    header .right_add .btn_head:not(:last-child) {
        margin-bottom: 1.2rem
    }
}
@media(max-width: 767px) {
    header .right_add .btn_head:not(:last-child) {
        margin-bottom: 1.2rem
    }
}
.btn_head {
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%
}
.btn_head a {
    width: 158px;
    height: 46px;
    max-width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: .2em .5em
}
@media(min-width: 768px)and (max-width: 1199px) {
    .btn_head a {
        width: 90vw;
        height: 4rem
    }
}
@media(max-width: 767px) {
    .btn_head a {
        width: 90vw;
        height: 4rem
    }
}
.btn_head a:hover {
    transition: .3s ease
}
.btn_head a>i {
    font-size: 1rem;
    line-height: 1;
    position: relative;
    top: .1em
}
.btn_head a p {
    font-size: 0.9375rem;
    font-weight: 700;
    line-height: 1.3
}
.btn_head a p i {
    font-size: 0.625rem;
    margin-left: .6em;
    position: relative;
    top: -0.1em
}
.btn_head.bg_or a {
    background-color: #c6b116;
    color: #fff
}
.btn_head.bg_or a:hover {
    background-color: rgb(106.2, 94.9363636364, 11.8);
    color: #fff;
    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%;
    padding: 1.2rem 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: 2px;
    background-color: #fff;
    border-radius: 100vmax
}
.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%
}
header.bg_w .icn_menu .menu-trigger .spanwrap span {
    background-color: #0f170c
}
.main_home {
    height: calc(100vh - 0px);
    overflow: hidden;
    z-index: 0
}
@media(min-width: 1200px) {
    .main_home {
        min-height: 700px
    }
}
@media(min-width: 768px)and (max-width: 1199px) {
    .main_home {
        height: calc(100vh - 0px)
    }
}
@media(max-width: 767px) {
    .main_home {
        height: calc(100vh - 0vw)
    }
}
.main_home video {
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    position: fixed;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: -1
}
.main_home .txtlayer {
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(15, 23, 12, 0) 0%, rgba(15, 23, 12, 0) 55%, #0f170c 100%);
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2
}
.main_home .txtlayer .inner {
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    flex-direction: column;
    padding-top: 80px
}
@media(min-width: 768px)and (max-width: 1199px) {
    .main_home .txtlayer .inner {
        padding-top: 8vh
    }
}
@media(max-width: 767px) {
    .main_home .txtlayer .inner {
        padding-top: 8vh
    }
}
.main_home p.txt_sub {
    margin-bottom: 1.5vh
}
.main_home .ttl_main {
    font-size: 1.625rem;
    color: #fff;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: .05em;
    margin-bottom: 4vh
}
@media(max-width: 767px) {
    .main_home .ttl_main {
        font-size: 1.25rem
    }
}
.main_home p.txt01 {
    font-size: 0.625rem;
    color: #fff;
    font-weight: 600;
    line-height: 1.8;
    letter-spacing: .07em
}
.scroll_up_main {
    animation: scroll_up_anime 2s ease-in
}
@keyframes scroll_up_anime {
    0% {
        opacity: 0;
        transform: translateY(50px)
    }
    30% {
        transform: translateY(0)
    }
    100% {
        transform: translateY(0)
    }
    30%, 100% {
        opacity: 1
    }
}
.fix_right {
    position: fixed;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    z-index: 6;
    opacity: 0
}
@media(max-width: 767px) {
    .fix_right {
        width: 100%;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: stretch;
        align-content: unset;
        top: unset;
        bottom: 0;
        transform: unset
    }
}
.fix_right .btn {
    width: 80px;
    height: 80px
}
@media(max-width: 767px) {
    .fix_right .btn {
        width: 25vw;
        height: 18vw
    }
}
@media(min-width: 1200px) {
    .fix_right .btn:not(:last-child) {
        margin-bottom: 2px
    }
}
@media(min-width: 768px)and (max-width: 1199px) {
    .fix_right .btn:not(:last-child) {
        margin-bottom: 2px
    }
}
@media(max-width: 767px) {
    .fix_right .btn:not(:last-child) {
        border-right: 1px solid #fff
    }
}
.fix_right .btn a {
    width: 100%;
    height: 100%;
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    align-content: center;
    flex-direction: column;
    padding: 0rem 0
}
@media(max-width: 767px) {
    .fix_right .btn a {
        width: 100%;
        height: 100%;
        flex-wrap: wrap;
        border: none;
        border-radius: 0;
        padding: .4rem 0
    }
}
.fix_right .btn a>i {
    font-size: 1.375rem;
    line-height: 1;
    margin-bottom: .3em
}
.fix_right .btn a p {
    font-size: 0.875rem;
    font-weight: 700;
    line-height: 1.2
}
@media(min-width: 1200px) {
    .fix_right .btn a p {
        text-align: center
    }
}
.fix_right .btn.bg_dg a {
    background-color: #224d39;
    color: #fff
}
.fix_right .btn.bg_dg a:hover {
    transition: .3s ease
}
.fix_right.active {
    opacity: .8
}
.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.t_exwide {
    padding-top: 10rem
}
@media(min-width: 768px)and (max-width: 1199px) {
    .section_cmn.t_exwide {
        padding-top: 6rem
    }
}
@media(max-width: 767px) {
    .section_cmn.t_exwide {
        padding-top: 4rem
    }
}
.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.t_none {
    padding-top: 0
}
.section_cmn.b_none {
    padding-bottom: 0
}
.ttl_cmn {
    font-size: 2.25rem;
    font-weight: 400;
    line-height: 1.2;
    margin-bottom: .8em
}
@media(min-width: 768px)and (max-width: 1199px) {
    .ttl_cmn {
        font-size: 1.625rem
    }
}
@media(max-width: 767px) {
    .ttl_cmn {
        font-size: 1.5rem
    }
}
.ttl_cmn span {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1;
    letter-spacing: .07em;
    margin-bottom: 1.4em;
    position: relative
}
@media(min-width: 768px)and (max-width: 1199px) {
    .ttl_cmn span {
        font-size: 0.75rem
    }
}
@media(max-width: 767px) {
    .ttl_cmn span {
        font-size: 0.75rem
    }
}
.ttl_cmn span.color_or {
    color: #c6b116
}
.ttl_cmn span.dc_w::before {
    content: url(images/index/dc_w.svg);
    display: inline-block;
    width: 7px;
    aspect-ratio: 1/1;
    margin-right: .5em
}
.ttl_cmn span.dc_or::before {
    content: url(images/index/dc_or.svg);
    display: inline-block;
    width: 7px;
    aspect-ratio: 1/1;
    margin-right: .5em
}
.ttl_cmn.tac {
    text-align: center
}
.ttl_cmn.color_w {
    color: #fff
}
.ttl_cmn.color_br {
    color: #60431d
}
.ttl_cmn.color_ma {
    color: #432900
}
.ttl_cmn.mb0 {
    margin-bottom: 0
}
.ttl_cmn.mb_w {
    margin-bottom: 1.8em
}
.ttl_cmn2 {
    font-size: 1.75rem;
    font-weight: 600;
    line-height: 1.5;
    margin-bottom: .8em
}
@media(min-width: 768px)and (max-width: 1199px) {
    .ttl_cmn2 {
        font-size: 1.375rem
    }
}
@media(max-width: 767px) {
    .ttl_cmn2 {
        font-size: 1.25rem
    }
}
.ttl_cmn2 span.sub {
    font-size: 0.875rem
}
@media(max-width: 767px) {
    .ttl_cmn2 span.sub {
        font-size: 0.75rem
    }
}
.ttl_cmn2 span.sub2 {
    display: block;
    font-size: 1.375rem;
    font-weight: 400
}
@media(max-width: 767px) {
    .ttl_cmn2 span.sub2 {
        font-size: 1rem
    }
}
.ttl_cmn2.bold {
    font-weight: 700
}
.ttl_cmn2.medium {
    font-weight: 500
}
.ttl_cmn2.regular {
    font-weight: 400
}
.ttl_cmn2.lh_w {
    line-height: 2.4
}
.ttl_cmn2.tac {
    text-align: center
}
.ttl_cmn2.tar {
    text-align: right
}
.ttl_cmn2.color_br {
    color: #60431d
}
.ttl_cmn2.color_dg {
    color: #224d39
}
.ttl_cmn2.color_ma {
    color: #432900
}
.ttl_cmn2.color_w {
    color: #fff
}
.ttl_cmn2.bg_dg {
    background-color: #224d39;
    padding: .4em .8em
}
.ttl_cmn2.bg_dg2 {
    background-color: #0f3b28;
    padding: .4em .8em
}
.ttl_cmn2.sidebar {
    position: relative
}
.ttl_cmn2.sidebar::before {
    content: "";
    width: 100%;
    height: 1px;
    background-color: currentColor;
    position: absolute;
    top: 50%;
    left: 0
}
.ttl_cmn2.sidebar span {
    display: inline-block;
    background-color: #fff;
    padding-right: 1.5em;
    position: relative;
    z-index: 1
}
.ttl_cmn2.sidebar.color_w span {
    background-color: #0f170c
}
.ttl_cmn2.sidebar.color_w.side_dg span {
    background-color: #224d39
}
.ttl_cmn2.sidebar_both {
    display: flex;
    align-items: center;
    gap: 0 .6em
}
.ttl_cmn2.sidebar_both::before, .ttl_cmn2.sidebar_both::after {
    content: "";
    height: 1px;
    background-color: currentColor;
    flex-grow: 1
}
.ttl_cmn2.huge {
    font-size: 4rem
}
@media(min-width: 768px)and (max-width: 1199px) {
    .ttl_cmn2.huge {
        font-size: 1.75rem
    }
}
@media(max-width: 767px) {
    .ttl_cmn2.huge {
        font-size: 1.625rem
    }
}
.ttl_cmn2.large2 {
    font-size: 2.25rem
}
@media(min-width: 768px)and (max-width: 1199px) {
    .ttl_cmn2.large2 {
        font-size: 1.625rem
    }
}
@media(max-width: 767px) {
    .ttl_cmn2.large2 {
        font-size: 1.5rem
    }
}
.ttl_cmn2.large {
    font-size: 1.875rem
}
@media(min-width: 768px)and (max-width: 1199px) {
    .ttl_cmn2.large {
        font-size: 1.5rem
    }
}
@media(max-width: 767px) {
    .ttl_cmn2.large {
        font-size: 1.375rem
    }
}
.ttl_cmn2.mdl {
    font-size: 1.5rem
}
@media(max-width: 767px) {
    .ttl_cmn2.mdl {
        font-size: 1.125rem
    }
}
.ttl_cmn2.mdsm {
    font-size: 1.375rem
}
@media(max-width: 767px) {
    .ttl_cmn2.mdsm {
        font-size: 1.125rem
    }
}
.ttl_cmn2.small {
    font-size: 1.25rem
}
@media(max-width: 767px) {
    .ttl_cmn2.small {
        font-size: 1rem
    }
}
.ttl_cmn2.mb0 {
    margin-bottom: 0
}
.ttl_cmn2.mb_w {
    margin-bottom: 1.5em
}
.txt_cmn {
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.9
}
@media(max-width: 767px) {
    .txt_cmn {
        font-size: 0.875rem
    }
}
.txt_cmn.bg_dg {
    background-color: #224d39;
    padding: .2em .8em
}
.txt_cmn.bg_dg_wide {
    background-color: #224d39;
    padding: .8em 1.1em
}
.txt_cmn.ttlside {
    position: relative
}
.txt_cmn.ttlside::before {
    content: "";
    width: 30vw;
    height: 1px;
/*     background-color: currentColor; */
    position: absolute;
    top: 50%;
    right: calc(100% + .5em)
}
.txt_cmn.lh_w {
    line-height: 2.4
}
.txt_cmn.lh_n {
    line-height: 1.5
}
.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_gr {
    color: #707070
}
.txt_cmn.color_br {
    color: #60431d
}
.txt_cmn.color_w {
    color: #fff
}
.txt_cmn.large {
    font-size: 1.125rem
}
@media(max-width: 767px) {
    .txt_cmn.large {
        font-size: 1rem
    }
}
.txt_cmn.mdsm {
    font-size: 0.9375rem
}
@media(max-width: 767px) {
    .txt_cmn.mdsm {
        font-size: 0.8125rem
    }
}
.txt_cmn.mdl {
    font-size: 0.875rem
}
@media(max-width: 767px) {
    .txt_cmn.mdl {
        font-size: 0.75rem
    }
}
.txt_cmn.small {
    font-size: 0.75rem
}
@media(max-width: 767px) {
    .txt_cmn.small {
        font-size: 0.625rem
    }
}
.btn_cmn {
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%
}
.btn_cmn a {
    max-width: 100%;
    width: 298px;
    height: 66px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    align-content: unset;
    position: relative
}
@media(max-width: 767px) {
    .btn_cmn a {
        width: 90vw;
        height: 3.5rem
    }
}
.btn_cmn a p {
    font-size: 0.9375rem;
    font-weight: 400;
    line-height: 1.5;
    text-align: center;
    position: relative;
    top: .1em
}
.btn_cmn a p i {
    font-size: 1.25rem;
    line-height: 1;
    margin-right: .6em
}
.btn_cmn a>i {
    font-size: 0.75rem;
    position: absolute;
    top: 50%;
    right: 6%;
    transform: translateY(-50%)
}
.btn_cmn.alt a {
    width: 288px;
    height: 58px
}
@media(max-width: 767px) {
    .btn_cmn.alt a {
        width: 90vw;
        height: 3.2rem
    }
}
.btn_cmn.alt a p {
    font-size: 1rem;
    font-weight: 700
}
.btn_cmn.shadow a {
    box-shadow: 2px 2px 18px rgba(0, 0, 0, .16)
}
.btn_cmn.center {
    margin-inline: auto
}
.btn_cmn.right {
    margin-inline: auto 0
}
.btn_cmn.bg_k a {
    border: 1px solid currentColor;
    background-color: rgba(0, 0, 0, .5);
    color: #fff
}
.btn_cmn.bg_k a:hover {
    background-color: #000;
    transition: .3s ease
}
.btn_cmn.bg_bk a {
    border: 1px solid currentColor;
    background-color: #000;
    color: #fff
}
.btn_cmn.bg_bk a:hover {
    background-color: #0f170c;
    transition: .3s ease
}
.btn_cmn.bg_mg a {
    border: 1px solid currentColor;
    background-color: #41715b;
    color: #fff
}
.btn_cmn.bg_mg a:hover {
    background-color: hsl(152.5, 26.9662921348%, 14.9019607843%);
    transition: .3s ease
}
.btn_cmn.bg_or a {
    border: 1px solid currentColor;
    background-color: #c6b116;
    color: #fff
}
.btn_cmn.bg_or a:hover {
    background-color: rgb(106.2, 94.9363636364, 11.8);
    transition: .3s ease
}
.btn_cmn.bg_w a {
    background-color: #fff
}
.btn_cmn.bg_w a:hover {
    background-color: #0f170c;
    color: #fff;
    transition: .3s ease
}
.btn_cmn.bd_none a {
    border: unset
}
.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
}
.over_cmn.alt figure {
    width: calc(100% - 608px)
}
@media(min-width: 768px)and (max-width: 1199px) {
    .over_cmn.alt figure {
        width: 47.2222222222%
    }
}
@media(max-width: 767px) {
    .over_cmn.alt figure {
        width: 100%
    }
}
.over_cmn.alt .txt {
    width: 520px
}
@media(min-width: 768px)and (max-width: 1199px) {
    .over_cmn.alt .txt {
        width: 49.0740740741%
    }
}
@media(max-width: 767px) {
    .over_cmn.alt .txt {
        width: 100%
    }
}
.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: 48.1481481481%
}
@media(max-width: 767px) {
    .side_cmn.alt figure {
        width: 100%
    }
}
.side_cmn.alt .txt {
    width: 48.1481481481%
}
@media(max-width: 767px) {
    .side_cmn.alt .txt {
        width: 100%
    }
}
.side_cmn.solid figure {
    width: 100%
}
@media(max-width: 767px) {
    .side_cmn.solid figure {
        width: 100%
    }
}
.side_cmn.solid .txt {
    width: 100%
}
@media(max-width: 767px) {
    .side_cmn.solid .txt {
        width: 100%
    }
}
.side_cmn.kinowa figure {
    width: 16.2037037037%
}
@media(max-width: 767px) {
    .side_cmn.kinowa figure {
        width: 100%
    }
}
.side_cmn.kinowa .txt {
    width: 80.5555555556%
}
@media(max-width: 767px) {
    .side_cmn.kinowa .txt {
        width: 100%
    }
}
.side_cmn.hatagaya figure {
    width: 21%
}
@media(max-width: 767px) {
    .side_cmn.hatagaya figure {
        width: 100%
    }
}
.side_cmn.hatagaya .txt {
    width: 76%
}
@media(max-width: 767px) {
    .side_cmn.hatagaya .txt {
        width: 100%
    }
}
.side_cmn.crosswood figure {
    width: 37.037037037%
}
@media(max-width: 767px) {
    .side_cmn.crosswood figure {
        width: 100%
    }
}
.side_cmn.crosswood .txt {
    width: 61.1111111111%
}
@media(max-width: 767px) {
    .side_cmn.crosswood .txt {
        width: 100%
    }
}
.side_cmn.woodbe2 figure {
    width: 24.5%
}
@media(max-width: 767px) {
    .side_cmn.woodbe2 figure {
        width: 100%
    }
}
.side_cmn.woodbe2 .txt {
    width: 72.5%
}
@media(max-width: 767px) {
    .side_cmn.woodbe2 .txt {
        width: 100%
    }
}
.side_cmn.housereformer figure {
    width: 31%
}
@media(min-width: 768px)and (max-width: 1199px) {
    .side_cmn.housereformer figure {
        width: 100%
    }
}
@media(max-width: 767px) {
    .side_cmn.housereformer figure {
        width: 100%
    }
}
.side_cmn.housereformer .txt {
    width: 63%
}
@media(min-width: 768px)and (max-width: 1199px) {
    .side_cmn.housereformer .txt {
        width: 100%
    }
}
@media(max-width: 767px) {
    .side_cmn.housereformer .txt {
        width: 100%
    }
}
.ul_postcmn {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 3.5rem 2.7777777778%
}
@media(min-width: 768px)and (max-width: 1199px) {
    .ul_postcmn {
        gap: 2rem 6%
    }
}
@media(max-width: 767px) {
    .ul_postcmn {
        gap: 2.5rem 0
    }
}
.ul_postcmn li {
    width: 31.4814814815%
}
@media(min-width: 768px)and (max-width: 1199px) {
    .ul_postcmn li {
        width: 47%
    }
}
@media(max-width: 767px) {
    .ul_postcmn li {
        width: 100%
    }
}
.li_postcmn figure {
    overflow: hidden;
    border-radius: .8rem;
    margin-bottom: .7rem
}
@media(max-width: 767px) {
    .li_postcmn figure {
        margin-bottom: .5rem
    }
}
.li_postcmn figure img {
    width: 100%;
    max-height: 240px;
    -o-object-fit: cover;
    object-fit: cover
}
.li_postcmn figure img:hover {
    transform: scale(1.15);
    transition: .5s ease
}
.li_postcmn time {
    display: block
}
.li_postcmn p.txt01:not(:last-child) {
    margin-bottom: 1.2em
}
.li_postcmn .btn_cmn:not(:last-child) {
    margin-bottom: 1rem
}
.li_postcmn .wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
    margin-bottom: .5rem
}
.li_postcmn .wrap .cate {
    display: inline-block;
    background-color: #224d39;
    border-radius: 3px;
    line-height: 1.5;
    padding: .3em .5em;
    margin-right: .6em
}
.btn_naked {
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%
}
.btn_naked a {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    align-items: center;
    align-content: unset;
    padding-left: .4em;
    padding-bottom: .4rem;
    position: relative
}
.btn_naked a p {
    font-size: 0.9375rem;
    font-weight: 700;
    line-height: 1.5;
    text-align: center
}
@media(max-width: 767px) {
    .btn_naked a p {
        font-size: 0.8125rem
    }
}
.btn_naked a>i {
    display: grid;
    place-content: center;
    width: 32px;
    aspect-ratio: 1/1;
    border: 1px solid currentColor;
    border-radius: 100vmax;
    font-size: 0.75rem;
    line-height: 1;
    margin-left: 1.6em
}
@media(max-width: 767px) {
    .btn_naked a>i {
        font-size: 0.625rem
    }
}
.btn_naked a::after {
    content: "";
    width: 0;
    height: 1px;
    background-color: currentColor;
    position: absolute;
    bottom: 0;
    left: 0
}
.btn_naked a:hover::after {
    width: 100%;
    transition: .5s ease
}
.btn_naked.alt a p {
    font-size: 1.125rem
}
@media(max-width: 767px) {
    .btn_naked.alt a p {
        font-size: 0.875rem
    }
}
.btn_naked.alt a>i {
    width: unset;
    border: unset;
    font-size: 0.5rem
}
.btn_naked.center {
    margin-inline: auto
}
.btn_naked.right {
    margin-inline: auto 0
}
.btn_naked.color_w a {
    color: #fff
}
.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)
}
main {
    position: relative;
    z-index: 1
}
.home_about {
    background: #0f170c url(images/index/bg_about01.svg) bottom center no-repeat;
    position: relative
}
.home_about p.txt01 {
    margin-bottom: 2em
}
.home_about .imgwrap figure[class^=img] {
    position: absolute
}
@media(max-width: 767px) {
    .home_about .imgwrap figure[class^=img] {
        display: none
    }
}
.home_about .imgwrap figure[class^=img] img {
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover
}
.home_about .imgwrap .img01 {
    width: 23.1944444444vw;
    aspect-ratio: 334/175;
    top: 10vh;
    left: 4vw
}
@media(min-width: 768px)and (max-width: 1199px) {
    .home_about .imgwrap .img01 {
        width: 21.3333333333vw;
        left: 0
    }
}
.home_about .imgwrap .img02 {
    width: 17.9861111111vw;
    aspect-ratio: 259/136;
    bottom: 8vh;
    left: 10vw
}
@media(min-width: 768px)and (max-width: 1199px) {
    .home_about .imgwrap .img02 {
        width: 18.6666666667vw;
        left: 5vw
    }
}
.home_about .imgwrap .img03 {
    width: 23.1944444444vw;
    aspect-ratio: 334/175;
    top: 6vh;
    right: 8vw
}
@media(min-width: 768px)and (max-width: 1199px) {
    .home_about .imgwrap .img03 {
        width: 21.3333333333vw;
        right: 4vw
    }
}
.home_about .imgwrap .img04 {
    width: 17.9861111111vw;
    aspect-ratio: 259/136;
    bottom: 15vh;
    right: 4vw
}
@media(min-width: 768px)and (max-width: 1199px) {
    .home_about .imgwrap .img04 {
        width: 18.6666666667vw;
        right: 0
    }
}
.home_product {
    background-color: #0f170c
}
.home_product p.txt01 {
    margin-bottom: 3.5em
}
@media(max-width: 767px) {
    .home_product p.txt01 {
        margin-bottom: 2em
    }
}
.home_list {
    background: #0f170c url(images/index/bg_list01.svg) bottom center no-repeat
}
.home_list .ttl01 {
    font-size: 1.375rem;
    color: #fff;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: .05em;
    margin-bottom: 1em;
    position: relative
}
@media(max-width: 767px) {
    .home_list .ttl01 {
        font-size: 1.125rem
    }
}
.home_list .ttl01::before {
    content: "";
    width: 100%;
    height: 1px;
    background-color: currentColor;
    position: absolute;
    top: 50%;
    left: 0
}
.home_list .ttl01 span {
    display: inline-block;
    background-color: #0f170c;
    padding-right: 1.5em;
    position: relative;
    z-index: 1
}
.home_list ul {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 2.4rem 1.8518518519%
}
@media(min-width: 768px)and (max-width: 1199px) {
    .home_list ul {
        grid-template-columns: repeat(3, 1fr)
    }
}
@media(max-width: 767px) {
    .home_list ul {
        grid-template-columns: repeat(2, 1fr)
    }
}
.home_list ul li figure {
    margin-bottom: .3rem;
    overflow: hidden
}
.home_list ul li figure img {
    width: 100%;
    max-height: 140px;
    -o-object-fit: cover;
    object-fit: cover
}
.home_list ul li figure img:hover {
    transform: scale(1.15);
    transition: .5s ease
}
.home_list ul li p.txt01 {
    line-height: 1.3
}
.home_business {
    background-color: rgba(0, 0, 0, .7)
}
.home_business .side_cmn {
    margin-bottom: 2rem
}
.home_business p.txt01 {
    margin-bottom: 3.5em
}
@media(max-width: 767px) {
    .home_business p.txt01 {
        margin-bottom: 2em
    }
}
.home_business .ul01 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 3rem 2.7777777778%
}
@media(min-width: 768px)and (max-width: 1199px) {
    .home_business .ul01 {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.8rem 4%
    }
}
@media(max-width: 767px) {
    .home_business .ul01 {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.8rem 4%
    }
}
.home_business .ul01 li figure {
    margin-bottom: .2rem
}
.home_business .ul01 li figure img {
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover
}
.home_business .ul01 li p.txt02 {
    line-height: 1.5;
    padding-right: 1em;
    position: relative
}
.home_business .ul01 li p.txt02::after {
    content: "";
    font-size: 0.625rem;
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    position: absolute;
    top: 50%;
    right: 0vw;
    transform: translateY(-50%)
}
.home_reason {
    background-color: #0f170c
}
.home_reason p.txt01 {
    max-width: 884px;
    margin-inline: auto;
    margin-bottom: 2.5em
}
@media(max-width: 767px) {
    .home_reason p.txt01 {
        margin-bottom: 1.5em
    }
}
.home_reason .btn_naked {
    margin-bottom: 4rem
}
@media(max-width: 767px) {
    .home_reason .btn_naked {
        margin-bottom: 2.4rem
    }
}
.home_reason .swiper {
    padding-bottom: 2.5rem
}
@media(max-width: 767px) {
    .home_reason .swiper {
        padding-bottom: 1.5rem
    }
}
.home_reason .swiper ul li figure {
    margin-bottom: .3rem
}
.home_reason .swiper ul li figure img {
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover
}
.home_reason .swiper ul li p.txt02 {
    line-height: 1.3
}
.home_reason .swiper-scrollbar {
    position: relative
}
.home_reason .swiper-scrollbar::before {
    content: "";
    width: 100%;
    height: 1px;
    background-color: #fff;
    position: absolute;
    top: 50%;
    left: 0
}
.home_reason .swiper-scrollbar .swiper-scrollbar-drag {
    height: 4px;
    background-color: #fff
}
.home_casepre {
    background: url(images/index/bg_case01.jpg) center center/cover no-repeat
}
.home_casestudy {
    background-color: #0f170c
}
.home_casestudy ul {
    margin-bottom: 2.4rem
}
@media(max-width: 767px) {
    .home_casestudy ul {
        margin-bottom: 1.5rem
    }
}
.home_casestudy ul li figure {
    margin-bottom: .3rem;
    position: relative
}
.home_casestudy ul li figure .cate {
    width: -moz-fit-content;
    width: fit-content;
    background-color: #354f46;
    padding: .2em 1em;
    line-height: 1.5;
    position: absolute;
    top: 0;
    left: 0
}
.home_casestudy .slick-slider {
    line-height: 0
}
.home_casestudy .slick-slider .slick-slide {
    margin-inline: 1vw
}
@media(max-width: 767px) {
    .home_casestudy .slick-slider .slick-slide {
        margin-inline: 2vw
    }
}
.home_casestudy .slick-slider .slick-slide li img {
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}
.home_triple {
    background-color: #0f170c
}
.home_triple .inner {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.7rem 5%
}
@media(min-width: 768px)and (max-width: 1199px) {
    .home_triple .inner {
        grid-template-columns: repeat(2, 1fr)
    }
}
@media(max-width: 767px) {
    .home_triple .inner {
        grid-template-columns: repeat(1, 1fr)
    }
}
.home_triple .inner .col {
    background-color: #224d39;
    padding: 2rem 5% 1.5rem
}
@media(max-width: 767px) {
    .home_triple .inner .col {
        padding: 1.2rem 4% 1rem
    }
}
.home_triple .inner .col i {
    display: block;
    text-align: center;
    margin-bottom: .4rem
}
.home_triple .inner .col p.txt01 {
    margin-bottom: 1.5em
}
.home_recruit {
    background-color: #fff
}
.home_recruit .under {
    padding-top: 2.2rem
}
.home_recruit .under .inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    align-content: unset
}
.home_recruit .under .inner .left {
    width: 46.2962962963%
}
@media(min-width: 768px)and (max-width: 1199px) {
    .home_recruit .under .inner .left {
        width: 100%;
        margin-bottom: 2rem
    }
}
@media(max-width: 767px) {
    .home_recruit .under .inner .left {
        width: 100%;
        margin-bottom: 1rem
    }
}
.home_recruit .under .inner .right {
    width: 50%
}
@media(min-width: 768px)and (max-width: 1199px) {
    .home_recruit .under .inner .right {
        width: 100%
    }
}
@media(max-width: 767px) {
    .home_recruit .under .inner .right {
        width: 100%
    }
}
.home_recruit p.txt01 {
    margin-bottom: 1.5em
}
.home_recruit .right ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .8rem 4%
}
@media(max-width: 767px) {
    .home_recruit .right ul {
        grid-template-columns: repeat(1, 1fr)
    }
}
.home_recruit .right ul li a {
    display: block;
    padding-left: .8rem;
    border-bottom: 1px solid #c6b116
}
.home_recruit .right ul li a p {
    padding-left: 1.2em;
    padding-bottom: .3em;
    position: relative
}
.home_recruit .right ul li a p::before {
    content: "";
    font-size: 0.625rem;
    color: #c6b116;
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%)
}
@media(max-width: 767px) {
    .home_recruit .right ul li a p::before {
        right: 0
    }
}
.home_recruit .img01 {
    position: relative
}
.home_recruit .img01 .btn01 {
    position: absolute;
    bottom: 20%;
    left: 50%;
    transform: translateX(-50%)
}
.loopslider_cmn {
    height: 340px;
    display: flex;
    align-items: center;
    overflow: hidden
}
@media(max-width: 767px) {
    .loopslider_cmn {
        height: 45.3333333333vw
    }
}
.loopslider_cmn ul {
    display: flex;
    animation: loop-slide 20s infinite linear 1s both
}
.loopslider_cmn ul li {
    width: 360px;
    height: 340px;
    margin-right: 0px
}
@media(max-width: 767px) {
    .loopslider_cmn ul li {
        width: 48vw;
        height: 45.3333333333vw
    }
}
@keyframes loop-slide {
    from {
        transform: translateX(0)
    }
    to {
        transform: translateX(-100%)
    }
}
.loopslider_cmn.slide-paused:hover ul {
    animation-play-state: paused
}
.loopslider_cmn.proce {
    height: unset
}
.loopslider_cmn.proce ul li {
    width: 297px;
    height: unset;
    aspect-ratio: 297/198;
    margin-right: .5rem
}
@media(max-width: 767px) {
    .loopslider_cmn.proce ul li {
        width: 39.6vw
    }
}
.bg_wrap01 {
    background: #0f170c url(images/index/bg_news01.png) center top/cover no-repeat
}
.home_news {
    margin-bottom: 7.5rem
}
@media(min-width: 768px)and (max-width: 1199px) {
    .home_news {
        margin-bottom: 4rem
    }
}
@media(max-width: 767px) {
    .home_news {
        margin-bottom: 3.5rem
    }
}
.home_news .colwrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    background-color: #fff;
    padding: 3.5rem 0 2rem;
    position: relative
}
@media(max-width: 767px) {
    .home_news .colwrap {
        padding: 2rem 0 1.4rem
    }
}
.home_news .colwrap::before {
    content: "";
    width: 30vw;
    height: 100%;
    background-color: #fff;
    position: absolute;
    top: 0;
    right: 100%
}
.home_news .colwrap .ttlarea {
    width: 18.5185185185%
}
@media(max-width: 767px) {
    .home_news .colwrap .ttlarea {
        width: 100%;
        margin-bottom: 2rem
    }
}
.home_news .colwrap .content {
    width: 77.7777777778%;
    padding-right: 8%
}
@media(max-width: 767px) {
    .home_news .colwrap .content {
        width: 100%
    }
}
.home_news ul {
    margin-bottom: 1.6rem
}
@media(max-width: 767px) {
    .home_news ul {
        margin-bottom: 1.2rem
    }
}
.home_news ul li {
    padding-bottom: 1rem;
    border-bottom: 1px solid #cfcfcf
}
@media(max-width: 767px) {
    .home_news ul li {
        padding-bottom: .6rem
    }
}
.home_news ul li:not(:last-child) {
    margin-bottom: 1rem
}
@media(max-width: 767px) {
    .home_news ul li:not(:last-child) {
        margin-bottom: .6rem
    }
}
.home_news ul li a {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    padding-right: 1.6rem;
    position: relative
}
.home_news ul li a time.date {
    display: inline-block;
    font-size: 1.0625rem;
    font-weight: 600;
    line-height: 1.5rem;
    margin-right: 3em
}
@media(max-width: 767px) {
    .home_news ul li a time.date {
        font-size: 0.875rem;
        margin-right: 1em
    }
}
.home_news ul li a .ttl01 {
    line-height: 1.5rem
}
.home_news ul li a::after {
    content: "";
    font-size: 0.625rem;
    font-weight: 900;
    font-family: "Font Awesome 5 Free";
    position: absolute;
    top: 50%;
    right: .8rem;
    transform: translateY(-50%)
}
@media(max-width: 767px) {
    .home_news ul li a::after {
        right: 0
    }
}
.home_column {
    margin-bottom: 4.5rem
}
@media(min-width: 768px)and (max-width: 1199px) {
    .home_column {
        margin-bottom: 3rem
    }
}
@media(max-width: 767px) {
    .home_column {
        margin-bottom: 2.5rem
    }
}
.home_column .ttl11 {
    font-size: 2rem;
    color: #fff;
    font-weight: 400;
    line-height: 1.5;
    text-align: center;
    margin-bottom: .8em
}
@media(max-width: 767px) {
    .home_column .ttl11 {
        font-size: 1.5rem
    }
}
.home_column .ttl11 span {
    display: block;
    font-size: 1rem
}
@media(max-width: 767px) {
    .home_column .ttl11 span {
        font-size: 0.75rem
    }
}
.home_column ul {
    margin-bottom: 3rem
}
@media(max-width: 767px) {
    .home_column ul {
        margin-bottom: 2rem
    }
}
.home_column ul li figure {
    margin-bottom: .2rem;
    position: relative;
	height:240px
}
.home_column ul li figure img {
    width: 100%;
    max-height: 207px;
    -o-object-fit: cover;
    object-fit: cover
}
.home_column ul li time {
    display: inline-block;
    font-size: 1.0625rem;
    color: #fff;
    font-weight: 600;
    line-height: 1.5;
    margin-bottom: .2em
}
@media(max-width: 767px) {
    .home_column ul li time {
        font-size: 0.875rem
    }
}
.home_column ul li .ttl01 {
    line-height: 1.5;
    margin-bottom: .4em
}
.home_column ul li .arw_r {
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto 0
}
.home_column .slick-slider {
    line-height: 0
}
.home_column .slick-slider .slick-slide {
    margin-inline: 1vw
}
@media(max-width: 767px) {
    .home_column .slick-slider .slick-slide {
        margin-inline: 2vw
    }
}
.home_column .slick-slider .slick-slide li img {
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}
.home_bnr .bnr {
    max-width: 678px;
    margin-inline: auto
}
.home_bnr .bnr a {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    align-content: center;
    flex-direction: column;
    background-color: #404e3a;
    border: 2px solid #7a9170;
    padding: 1.5rem 4%;
    position: relative
}
.home_bnr .bnr a .ttl01, .home_bnr .bnr a .ttl02 {
    position: relative;
    z-index: 1
}
.home_bnr .bnr a .ttl01 {
    font-size: 1.375rem;
    color: #fff;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: .19em;
    text-align: center;
    margin-bottom: 1em
}
@media(max-width: 767px) {
    .home_bnr .bnr a .ttl01 {
        font-size: 1.125rem
    }
}
.home_bnr .bnr a .ttl02 {
    font-size: 1.25rem;
    color: #fff;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: .1em;
    text-align: center
}
@media(max-width: 767px) {
    .home_bnr .bnr a .ttl02 {
        font-size: 1rem
    }
}
.home_bnr .bnr a .ttl02 em {
    font-size: 2.5rem;
    line-height: 1
}
@media(max-width: 767px) {
    .home_bnr .bnr a .ttl02 em {
        font-size: 1.875rem
    }
}
.home_bnr .bnr a .bgtxt {
    font-size: 7rem;
    color: rgba(53, 79, 70, .56);
    font-weight: 600;
    line-height: .8;
    letter-spacing: .05em;
    mix-blend-mode: overlay;
    position: absolute;
    bottom: -0.05em;
    left: 0
}
@media(max-width: 767px) {
    .home_bnr .bnr a .bgtxt {
        font-size: 3.5rem
    }
}
.home_twin {
    background: url(images/index/bg_twin01.jpg) center center/cover no-repeat
}
.home_twin .colwrap {
    max-width: 1028px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem 0;
    margin-inline: auto
}
@media(min-width: 768px)and (max-width: 1199px) {
    .home_twin .colwrap {
        grid-template-columns: repeat(1, 1fr)
    }
}
@media(max-width: 767px) {
    .home_twin .colwrap {
        grid-template-columns: repeat(1, 1fr)
    }
}
.home_twin .colwrap .col {
    background-color: rgba(15, 23, 12, .9);
    padding: 1.8rem 8% 2.5rem
}
@media(max-width: 767px) {
    .home_twin .colwrap .col {
        padding: 1.4rem 4% 1.8rem
    }
}
.home_twin .colwrap .col .ttl01 {
    margin-bottom: .6em
}
.home_twin .colwrap .col .ttl01 i {
    margin-right: 1rem
}
.home_twin .colwrap .col p.txt01 {
    margin-bottom: 1.5em
}
footer {
    background-color: #fff
}
footer .fmain {
    padding: 2.5rem 0 .5rem
}
@media(max-width: 767px) {
    footer .fmain {
        padding: 2rem 0 .4rem
    }
}
footer .fmain .topline {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 1.5rem 2.5rem;
    margin-bottom: 2.5rem
}
@media(max-width: 767px) {
    footer .fmain .topline {
        margin-bottom: 1.5rem
    }
}
footer .fmain .fnav {
    padding-bottom: 2.5rem;
    border-bottom: 1px solid #ddd;
    margin-bottom: 1.2rem
}
@media(max-width: 767px) {
    footer .fmain .fnav {
        padding-bottom: 1.5rem
    }
}
footer .fmain .addlink {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    gap: 0 1.2rem;
    margin-bottom: 3.5rem
}
@media(max-width: 767px) {
    footer .fmain .addlink {
        margin-bottom: 2rem
    }
}
footer .fmain .logowrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0 4%;
    margin-bottom: .8rem
}
footer .fmain p.txt_iso {
    font-weight: 300
}
@media(min-width: 768px)and (max-width: 1199px) {
    footer .foot_logo {
        text-align: center;
        margin-inline: auto
    }
}
@media(max-width: 767px) {
    footer .foot_logo {
        text-align: center;
        margin-inline: auto
    }
}
footer .fnav {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2.5rem 2.7777777778%
}
@media(min-width: 768px)and (max-width: 1199px) {
    footer .fnav {
        grid-template-columns: repeat(2, 1fr)
    }
}
@media(max-width: 767px) {
    footer .fnav {
        grid-template-columns: repeat(1, 1fr)
    }
}
footer .fnav .unit h3.txt_cmn {
    padding-bottom: .4em;
    border-bottom: 1px solid #c5b115;
    margin-bottom: .6em
}
footer .fnav .unit ul li {
    line-height: 1.5
}
footer .fnav .unit ul li:not(:last-child) {
    margin-bottom: .6em
}
footer .fnav .unit ul li a {
    font-size: 0.875rem;
    font-weight: 400;
    line-height: 1.5
}
@media(max-width: 767px) {
    footer .fnav .unit ul li a {
        font-size: 0.75rem
    }
}
footer .copyright {
    background-color: #f0f0f0;
    border-bottom: 10px solid #0f170c;
    padding: .8rem 0
}
footer .copyright small {
    display: block;
    text-align: center;
    font-weight: 600
}
/*# sourceMappingURL=style.css.map */