@charset "UTF-8";
/*
       multi-class
========================================================================== */
html {
    font-size: 14px;
}
body {
    width: 100%;
    font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック体", YuGothic, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    line-height: 1.6;
    box-sizing: border-box;
    font-weight: 300;
    color: #333333;
    letter-spacing: 0.08em;
}
body * {
    box-sizing: border-box;
}
.page_wrapper {
    overflow: hidden;
}
a {
    text-decoration: none;
    color: #333333;
}
p {
    line-height: 1.8;
    word-wrap: break-word;
}
.cf:after {
    display: block;
    content: "";
    clear: both;
}
img {
    width: 100%;
    height: auto;
    vertical-align: bottom;
}
.pagetop {
    overflow: hidden;
    position: fixed;
    bottom: 5.4vw;
    right: 3vw;
    width: 7vw;
}
.pagetop:hover {
    opacity: .6;
}
.d_pc {
    display: none !important;
}
#content {
    margin-top: 15vw;
    padding-bottom: 18vw;
    background: url("../images/common/foot_tree.jpg") no-repeat 50% 100% / 150vw;
}
section .inner {
    padding-left: 6vw;
    padding-right: 6vw;
}
/* .sidr */
.sidr {
    background: #958c7a !important;
    box-shadow: none !important;
}
.sidr ul {
    border-bottom: none !important;
    border-top: none !important;
}
.sidr ul li {
    border-bottom: none !important;
    border-top-color: #7a7261 !important;
}
#sidr ul li {
    line-height: 1.2;
}
#sidr ul li a {
    display: block;
    padding: 18px 10px;
}
/* スクロールCSS */
.fade-in {
    opacity: 0;
}
.fade-in-up {
    transform: translate(0, 80px);
}
.fade-in-down {
    transform: translate(0, -80px);
}
.fade-in-left {
    transform: translate(-80px, 0);
}
.fade-in-right {
    transform: translate(80px, 0);
}
.scroll-in {
    animation: fadeIn 1.5s ease;
    animation-fill-mode: forwards;
}
@keyframes fadeIn {
    0% {
        opacity: 0;
    }
    50% {
        opacity: 0.4;
    }
    100% {
        opacity: 1;
        transform: translate(0, 0);
    }
}
.fade-in-op {
    opacity: 0;
}
.fade-in-op.scroll-in {
    animation: fadeIn-op 2s ease;
    animation-fill-mode: forwards;
    animation-delay: 0.2s;
}
@keyframes fadeIn-op {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}
.grecaptcha-badge { visibility: hidden; }
/*
     フォント
========================================================================== */
.barlow {
    font-family: "Barlow", serif;
}
.serif {
    font-family: 'Noto Serif JP', serif !important;
}
/*
     画像
========================================================================== */
.fade {
    -webkit-transition: .3s ease-in-out;
    -moz-transition: .3s ease-in-out;
    -o-transition: .3s ease-in-out;
    transition: .3s ease-in-out;
}
.img_right {
    float: right;
    margin: 0 0 10px 15px;
}
.img_left {
    float: left;
    margin: 0 15px 10px 0;
}
.alignC {
    text-align: center;
}
.alignR {
    text-align: right !important;
}
.alignL {
    text-align: left !important;
}
.img_1col_A {
    margin-left: auto;
    margin-right: auto;
    width: 100%;
}
.img_2col_A, .img_4col_A {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
}
.img_2col_A > * {
    width: 50%;
}
.img_4col_A > * {
    width: 25%;
}
.img_2col_B {
    margin-left: auto;
    margin-right: auto;
    width: 100%;
}
.img_2col_B .img {
    margin-bottom: 3vw;
}
.video_cont_wrap {
    max-width: 100%;
}
.video_cont_wrap video {
    width: 100%;
}
/* slider */
.slick-slide {
    position: relative;
}
.slider .dots-class {
    margin-bottom: 6vw;
}
.dots-class button {
    display: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    outline: none;
    padding: 0;
    border: none;
    background-color: transparent;
}
.dots-class {
    display: flex;
    justify-content: center;
    margin-top: 10px;
}
.dots-class li {
    width: 10px;
    height: 10px;
    background-color: #e6e6e6;
    border-radius: 50%;
    margin-right: 8px;
    cursor: pointer;
    transition: background-color .5s ease;
}
.dots-class li.slick-active {
    background-color: #808080;
}
.dots-class li:hover {
    background-color: #808080;
}
.dots-class li:last-child {
    margin-right: 0;
}
/*
     見出し
========================================================================== */
.ttl_A {
    display: block;
    margin: 0 auto 2em;
    text-align: center;
}
.ttl_A span {
    display: inline-block;
    padding-bottom: 0.2em;
    font-size: 5.6vw;
    line-height: 1.5;
    font-weight: 600;
    border-bottom: 3px solid #138a2b;
}
.ttl_B {
    position: relative;
    margin-bottom: 2em;
    padding-bottom: 11px;
}
.ttl_B span {
    font-size: 4.9vw;
    font-weight: bold;
    line-height: 1.5;
}
.ttl_B:before {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 10%;
    height: 3px;
    background: #138a2b;
    content: '';
}
.ttl_B:after {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 90%;
    height: 3px;
    background: #d5c675;
    content: '';
}
.ttl_C {
    display: block;
    margin-bottom: 1.4em;
    padding: 8px 12px 9px;
    background: #535353;
    border-radius: 3px;
    position: relative;
    box-shadow: 3px 3px #d3d3d3;
}
.ttl_C span {
    font-size: 3.9vw;
    line-height: 1.5;
    letter-spacing: 0.06em;
    color: #fff;
    font-weight: 600;
}
.ttl_D {
    display: block;
    margin-bottom: 0.5em;
    padding-left: 16px;
    border-radius: 4px;
    position: relative;
}
.ttl_D span {
    font-size: 4vw;
    line-height: 1.5;
    letter-spacing: 0.06em;
    font-weight: 500;
}
.ttl_D:before {
    position: absolute;
    top: 0.1em;
    left: 0;
    width: 8px;
    height: 95%;
    border-radius: 2px;
    background: #d3d3d3;
    content: '';
}
.ttl_marker_A {
    text-align: center;
}
.ttl_marker_A span {
    display: inline-block;
    padding: 0.5em 0.6em;
    background: #fff;
    line-height: 1;
    min-width: 8em;
    font-weight: bold;
}

/*
     ナビゲーション
========================================================================== */
.low_nav ul {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
    margin-bottom: 8vw;
}
.low_nav ul li {
    margin-bottom: 1.6vw;
    width: 49%;
    background: #f8f8f8;
}
.low_nav ul li:nth-child(4n) {
    margin-right: 0;
}
.low_nav ul li a {
    display: block;
    padding: 3vw 33px 3vw 4vw;
    position: relative;
    font-weight: 500;
    font-size: 3.1vw;
    width: 100%;
}
.low_nav ul li a::after {
    display: block;
    content: '';
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 9px solid #138a2b;
    position: absolute;
    top: calc(50% - 4px);
    right: 15px;
}

/*
     ボタン
========================================================================== */
.btn_A {
    width: 70vw;
    max-width: 100%;
    padding: 0.8em 0.9em;
    display: block;
    position: relative;
    text-align: center;
    background: #138a2b;
    border-radius: 50px;
}
.btn_A.btn_A_gr {
    background: #138a2b;
}
.btn_A.btn_A_center {
    margin-left: auto;
    margin-right: auto;
}
.btn_A::after {
    display: block;
    content: '';
    width: 0;
    height: 0;
    border-left: 7px solid #fff;
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    position: absolute;
    top: calc(50% - 5px);
    right: 1em;
}
.btn_A a {
    color: #fff;
}
.btn_arrow_A a {
    position: relative;
    padding-right: 13px;
}
.btn_arrow_A a::after {
    display: block;
    content: '';
    position: absolute;
    top: calc(50% - 4px);
    right: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-left: 6px solid #898989;
    border-right: 0;
}
.btn_arrow_B a {
    position: relative;
    padding-right: 13px;
    padding-right: 3.1em;
    font-weight: bold;
}
.btn_arrow_B a::after {
    position: absolute;
    top: 37%;
    right: 0;
    transform: translateY(-50%);
    transform-origin: left;
    width: 2.7em;
    height: 0.7em;
    background-color: #138a2b;
    clip-path: polygon(0 100%, 100% 100%, 75% 35%, 75% 90%, 0% 90%);
    content: '';
    transition: transform .3s;
}
.btn_arrow_B a:hover::after {
    transform: translateY(-50%) scaleX(1.4);
}

/*
     テーブル
========================================================================== */
.table_A, .table_B {
    width: 100%;
    font-size: 0.9rem;
}
.table_A {
    border-left: 1px solid #333;
    border-top: 1px solid #333;
    background: #fff;
}
.table_A th {
    background: #f8f8f8;
    padding: 2vw;
    font-weight: 600;
    border-right: 1px solid #333;
    border-bottom: 1px solid #333;
}
.table_A td {
    padding: 2vw;
    border-right: 1px solid #333;
    border-bottom: 1px solid #333;
}
.table_B {
    border-top: 1px solid #b3b3b3;
}
.table_B th, .table_B td {
    padding: 3vw 1vw;
    border-bottom: 1px solid #b3b3b3;
}
/* table_C */
.table_C {
  width: 100%;
  border-collapse: collapse;
}
.table_C tr{
  border-bottom: solid 3px white;
}
.table_C tr:last-child{
  border-bottom: none;
}
.table_C th{
  position: relative;
  background-color: #51a5cc;
  color: white;
  text-align: center;
  padding: 16px 8px;
}
.table_C th:after{
  display: block;
  content: "";
  width: 0px;
  height: 0px;
  position: absolute;
  top:calc(50% - 6px);
  right:-6px;
  border-left: 6px solid #51a5cc;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
}
.table_C td{
  text-align: left;
  background-color: #eee;
  padding: 16px 8px;
}
.table_dl_A dt {
    margin-bottom: 3vw;
    padding: 3vw 4vw;
    background: #ededee;
    border-top: 3px solid #138a2b;
    font-weight: bold;
}
.table_dl_A dd {
    padding: 0 4vw;
    margin-bottom: 4vw;
}
.table_dl_A dd.table_dl_indent {
    margin-left: 7vw;
    padding-top: 3vw;
    border-top: 1px dotted #888;
}
table tr.line_dot th, table tr.line_dot td {
    border-bottom: 1px dotted #b3b3b3;
}
.table_wrap_A, .table_wrap_B, .table_wrap_C, .table_wrap_D {
    width: 100%;
    overflow-x: scroll;
}
.table_wrap_A table {
    width: 150vw;
}
.table_wrap_B table {
    width: 220vw;
}
.table_wrap_C table {
    width: 120vw;
}
.table_wrap_D table {
    width: 100vw;
}
.tAlignL {
    text-align: left !important;
}
.tAlignC {
    text-align: center !important;
}
.tAlignR {
    text-align: right !important;
}
.tVAlignT {
    vertical-align: top !important;
}
.tVAlignM {
    vertical-align: middle !important;
}
.tVAlignB {
    vertical-align: bottom !important;
}
/*
     リスト
========================================================================== */
.list_num li {
    list-style-type: decimal;
    list-style-position: outside;
    margin-left: 1.8em;
}
.list_dot li {
    list-style: disc;
    margin-left: 1.5em;
}
.list_arrow li {
    list-style: none;
    padding-left: 1em;
    text-indent: -1em;
}
.list_arrow li::before {
    display: inline;
    content: '▶';
}
.list_note li, .list_circle li {
    list-style: none;
    padding-left: 1em;
    text-indent: -1em;
}
.list_note li::before {
    display: inline;
    content: '※';
}
.list_circle li::before {
    display: inline;
    content: '●';
}
.list_hyphen li {
    list-style: none;
    padding-left: 0.6em;
    text-indent: -0.6em;
}
.list_hyphen li::before {
    display: inline;
    content: '–';
}
.list_flow dt {
    margin-bottom: 1.5vw;
    font-size: 3.8vw;
}
.list_flow dd {
    margin-bottom: 5vw;
    padding-left: 1.3em;
    line-height: 1.9;
    font-size: 0.857rem;
}
/*
     img+textbox
========================================================================== */
.img_column2, .img_column3 {
    display: flex;
    justify-content: center;
    align-content: center;
}
.img_column2 img {
    width: calc(100% / 2);
}
.img_column3 img {
    width: calc(100% / 3);
}
.width_wide {
    margin: 0 calc(50% - 50vw);
    width: 100vw;
}

/*
     img+textbox
========================================================================== */
.img_textbox_A .img,
.img_textbox_B .img {
    margin-bottom: 6vw;
}

/*
     box
========================================================================== */
.box_A_gray,
.box_B_gray {
    margin: 0 auto;
    padding: 5vw;
    width: 100%;
    box-sizing: border-box;
    background: #f8f8f8;
    border-radius: 1.5vw;
}
.box_A_yellow {
    margin: 0 auto;
    padding: 5vw;
    width: 100%;
    box-sizing: border-box;
    background: #fcfaed;
    border-radius: 1.5vw;
}

/*
     テキスト
========================================================================== */
.p-link {
    color: #138a2b;
    text-decoration: underline;
    margin: 0 1px;
}
.bold {
    font-weight: bold;
}
.txt160 {
  font-size: 160%;
}
.txt150 {
  font-size: 150%;
}
.txt140 {
  font-size: 140%;
}
.txt130 {
  font-size: 130%;
}
.txt120 {
  font-size: 120%;
}
.txt110 {
  font-size: 110%;
}
.txt90 {
  font-size: 90%;
}
.txt80 {
  font-size: 80%;
}
.txt70 {
  font-size: 70%;
}
.txt60 {
  font-size: 60%;
}
/* line height */
.lh10 {
    line-height: 1;
}
.lh12 {
    line-height: 1.2;
}
.lh13 {
    line-height: 1.3;
}
.lh15 {
    line-height: 1.5;
}
.lh16 {
    line-height: 1.6;
}
.lh18 {
    line-height: 1.8;
}
.lh20 {
    line-height: 2;
}
/* color */
.gray {
    color: #808080 !important;
}
.gray_medium {
    color: #666 !important;
}
.gray_light {
    color: #a4a4aa !important;
}
.red {
    color: #138a2b !important;
}
.blue {
    color: #104a7a !important;
}
.gold {
    color: #d5c675 !important;
}
.brown {
    color: #483e3f !important;
}
.green {
    color: #138a2b !important;
}
.white {
    color: #fff !important;
}
/*
     余白
========================================================================== */
.pt10 {
    padding-top: 10px !important;
}
.pr10 {
    padding-right: 10px !important;
}
.pl10 {
    padding-left: 10px !important;
}
.pb10 {
    padding-bottom: 10px !important;
}
.mb0 {
    margin-bottom: 0 !important;
}
.mb5 {
    margin-bottom: 5px !important;
}
.mb10 {
    margin-bottom: 10px !important;
}
.mb15 {
    margin-bottom: 15px !important;
}
.mb20,
.mb25 {
    margin-bottom: 5vw !important;
}
.mb30 {
    margin-bottom: 6vw !important;
}
.mb40 {
    margin-bottom: 6.5vw !important;
}
.mb50 {
    margin-bottom: 7vw !important;
}
.mb60 {
    margin-bottom: 8.5vw !important;
}
.mb70 {
    margin-bottom: 8.5vw !important;
}
.mb80 {
    margin-bottom: 9vw !important;
}
.mb90 {
    margin-bottom: 9.5vw !important;
}
.mb100 {
    margin-bottom: 11vw !important;
}
.mb1em {
    margin-bottom: 1em;
}
.mt5 {
    margin-top: 5px !important;
}
.mt10 {
    margin-top: 10px !important;
}
.mt15 {
    margin-top: 10px !important;
}
.mt20 {
    margin-top: 5vw !important;
}
.mt30 {
    margin-top: 6vw !important;
}
.mr5 {
    margin-right: 5px !important;
}
.mr10 {
    margin-right: 10px !important;
}
.mr15 {
    margin-right: 15px !important;
}
.mr20 {
    margin-right: 5vw !important;
}
.mr30 {
    margin-right: 6vw !important;
}
.ml5 {
    margin-left: 5px !important;
}
.ml10 {
    margin-left: 10px !important;
}
.ml15 {
    margin-left: 15px !important;
}
.ml20 {
    margin-left: 5vw !important;
}
.ml30 {
    margin-left: 6vw !important;
}
/*
     pagenavi
========================================================================== */
.pagenavi {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 4.2vw;
}
.pagenavi .pagenavi_list {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 0.5em;
}
.pagenavi .pagenavi_list li {
    margin: 0 0.5em;
    padding: 0 0.2em;
}
.pagenavi .pagenavi_list li.active {
    border-bottom: 1px solid #494955;
}
.pagenavi .prev, .pagenavi .next {
    margin: 0 0.5em;
    width: 0;
    height: 0;
    overflow: hidden;
    border-style: solid;
}
.pagenavi .prev {
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-right: 11px solid #494955;
    border-left: 0;
}
.pagenavi .next {
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-left: 11px solid #494955;
    border-right: 0;
}
/*
     slick
========================================================================== */
/* slick-dot */
#content .slick-dotted.slick-slider {
    margin-bottom: 0;
}
#content .slick-dots {
    bottom: 1.9vw;
    z-index: 10;
}
#content .slick-dots li {
    width: 1.9vw;
    height: 1.9vw;
    margin: 0 3px;
}
#content .slick-dots li button {
    width: 1.9vw;
    height: 1.9vw;
    padding: 0;
}
#content .slick-dots li button:before {
    width: 1.9vw;
    height: 1.9vw;
    content: '';
    border-radius: 1.9vw;
    background: #B3B3B3;
    opacity: 1;
}
#content .slick-dots li.slick-active button:before {
    background: #494955;
}
/* cont_slider */
#content .cont_slider .slick-arrow {
    display: block;
    position: absolute;
    top: 30vw;
    margin: auto;
    padding: 0;
    width: 6vw;
    height: 6vw;
    color: transparent;
    z-index: 1;
    transition: opacity 0.5s;
}
#content .cont_slider .slick-arrow:hover {
    opacity: 0.8;
}
#content .cont_slider .slick-next::before, #content .cont_slider .slick-next::after, #content .cont_slider .slick-prev::before, #content .cont_slider .slick-prev::after {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
}
#content .cont_slider .slick-next::after, #content .cont_slider .slick-prev::after {
    width: 4vw;
    height: 4vw;
    border-top: 1.5px solid #b3b3b3;
    border-right: 1.5px solid #b3b3b3;
}
#content .cont_slider .slick-next {
    right: 1.5vw;
}
#content .cont_slider .slick-next::after {
    right: 4px;
    transform: rotate(45deg);
}
#content .cont_slider .slick-prev {
    left: 1.5vw;
}
#content .cont_slider .slick-prev::after {
    left: 4px;
    transform: rotate(-135deg);
}
#content .cont_slider p {
    margin: 10px 0 20px;
    font-size: 0.857rem;
    line-height: 1.2;
    font-family: 'Noto Sans JP', serif;
}
#content .cont_slider_wrap {
    margin-left: auto;
    margin-right: auto;
    width: 640px;
    max-width: 100%;
}
#content .cont_slider_thumnail .slick-track {
    transform: unset !important;
    width: 100% !important;
    display: flex;
    justify-content: flex-start;
    flex-flow: row wrap;
}
#content .cont_slider_thumnail .slick-slide {
    display: block !important;
    float: none !important;
    margin-right: 1.5625%;
    flex: 0 0 17.1875%;
    cursor: pointer;
    opacity: 0.3;
    transition: all .5s;
}
#content .cont_slider_thumnail .slick-slide.slick-current {
    opacity: 1;
}
#content .cont_slider_thumnail .slick-track:before, #content .cont_slider_thumnail .slick-track:after {
    display: none;
}
#content .cont_slider_B .slick-arrow {
    display: block;
    position: absolute;
    top: 50%;
    margin: auto;
    padding: 0;
    width: 6vw;
    height: 6vw;
    color: transparent;
    z-index: 1;
    transition: opacity 0.5s;
}
#content .cont_slider_B .slick-arrow:hover {
    opacity: 0.8;
}
#content .cont_slider_B .slick-next::before, #content .cont_slider_B .slick-next::after, #content .cont_slider_B .slick-prev::before, #content .cont_slider_B .slick-prev::after {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
}
#content .cont_slider_B .slick-next::after, #content .cont_slider_B .slick-prev::after {
    width: 4vw;
    height: 4vw;
    border-top: 1.5px solid #b3b3b3;
    border-right: 1.5px solid #b3b3b3;
}
#content .cont_slider_B .slick-next {
    right: 1.5vw;
}
#content .cont_slider_B .slick-next::after {
    right: 4px;
    transform: rotate(45deg);
}
#content .cont_slider_B .slick-prev {
    left: 1.5vw;
}
#content .cont_slider_B .slick-prev::after {
    left: 4px;
    transform: rotate(-135deg);
}
#content .cont_slider_B .slick-dots {
    bottom: -5vw;
}
/*
     iOS ボタン
========================================================================== */
/* iOSでのデフォルトスタイルをリセット */
input[type="submit"], input[type="button"] {
    border-radius: 0;
    -webkit-box-sizing: content-box;
    -webkit-appearance: button;
    appearance: button;
    border: none;
    box-sizing: border-box;
    cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration, input[type="button"]::-webkit-search-decoration {
    display: none;
}
input[type="submit"]::focus, input[type="button"]::focus {
    outline-offset: -2px;
}

/*
       01. header
========================================================================== */
header {
    width: 100%;
    padding: 2.5vw 3vw;
    box-sizing: border-box;
    transition: all .5s;
    background: rgba(255, 255, 255, 0.9);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 999;
}
/* header_logo */
header .header_logo a {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
    width: fit-content;
    padding-left: 15vw;
    min-height: 9.5vw;
    background: url("../images/common/logo.png") no-repeat 0 0 / contain;
}
header .header_logo a span {
    line-height: 1;
    color: #138a2b;
    font-weight: 700;
}
header .header_logo a span:first-child {
    font-size: 2.6vw;
    padding-right: 0.2em;
}
header .header_logo a span:last-child {
    font-size: 4vw;
    font-weight: 700;
}
/* header_nav */
header .header_nav {
    position: absolute;
    top: 6.2vw;
    right: 16.5333vw;
    transition: all .5s;
}
header .header_nav > ul {
    display: flex;
    justify-content: flex-end;
    align-items: center;
}
header .header_nav > ul > li {
    display: flex;
    justify-content: center;
    align-items: center;
}
header .header_nav > ul > li > a {
    display: block;
    overflow: hidden;
    height: 0;
}
header .header_nav #header_nav_contact > a {
    margin-right: 4.6vw;
    width: 4.8vw;
    padding-top: 3.2vw;
    background: url("../images/common/ic_contact.svg") no-repeat 50% 50% / contain;
}
header .header_nav #header_nav_search .searchform .searchform_button {
    display: block;
    width: 3.6vw;
    padding-top: 3.6vw;
    background: url("../images/common/ic_search.svg") no-repeat 50% 50% / contain;
}
header .header_nav #header_nav_ig {
    display: none;
}
/* headerColorScroll */
header.headerColorScroll {
    padding-top: 2vw;
    padding-bottom: 2vw;
}
header.headerColorScroll .header_nav, header.headerColorScroll .navToggle {
    top: 3.5vw;
}

/*
       02. gnav
========================================================================== */
.globalMenuSp {
    position: fixed;
    z-index: 1001;
    top: 1.4vw;
    right: 1.4vw;
    background: #f1f1f1;
    transform: translateY(-120%);
    transition: all 0.6s;
    width: 70vw;
    letter-spacing: 0.2em;
    box-sizing: border-box;
    overflow-y: scroll;
    padding: 10vw 6vw;
    border-radius: 2vw;
    box-shadow: 4px 2px 4px 4px rgba(0, 0, 0, 0.2);
}
/* このクラスを、jQueryで付与・削除する */
.globalMenuSp.active {
    transform: translateY(0%);
    top: 1.4vw;
}
/* ハンバーガー用 */
.navToggle {
    display: block;
    position: fixed;
    right: 5vw;
    top: 5vw;
    width: 5.3333vw;
    height: 5.3333vw;
    text-align: center;
    border-radius: 2px;
    transition: all .5s;
    z-index: 9999;
}
header.headerColorScroll .navToggle {
    top: 4vw;
}
.navToggle span {
    display: block;
    position: absolute; /* .navToggleに対して */
    width: 5.3333vw;
    border-bottom: solid 0.5333vw #138a2b;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
    left: 0;
    border-radius: 2px;
}
.navToggle span:nth-child(1) {
    top: 0;
}
.navToggle span:nth-child(2) {
    top: 1.6vw;
}
.navToggle span:nth-child(3) {
    top: 3.2vw;
}
.navToggle span:nth-child(4) {
    border: none;
    color: #eee;
    font-size: 9px;
    font-weight: bold;
    top: 34px;
}
/* 最初のspanをマイナス45度に */
.navToggle.active span:nth-child(1) {
    top: 2vw;
    left: 0;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
/* 2番目と3番目のspanを45度に */
.navToggle.active span:nth-child(2), .navToggle.active span:nth-child(3) {
    top: 2vw;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}
/* gnav content */
.globalMenuSp .globalMenuSp_main {
    margin-bottom: 6vw;
    padding-bottom: 2vw;
    border-bottom: 1px solid #e0e0e0;
}
.globalMenuSp .globalMenuSp_main li a {
    display: block;
    font-size: 3.8vw;
    margin-bottom: 3.2vw;
    font-weight: 600;
}
.globalMenuSp .globalMenuSp_btn .globalMenuSp_btn_contact {
    font-size: 4vw;
}
.globalMenuSp .globalMenuSp_btn .globalMenuSp_btn_contact a span {
    font-weight: 500;
}

/*
       03. footer
========================================================================== */
#footer .cont_inner {
    padding: 10vw 6vw 8vw;
    background: #f8f8f8;
}
/* footer_info */
#footer .footer_info {
    padding-bottom: 7vw;
    margin-bottom: 7vw;
    border-bottom: 1px solid #e0e0e0;
}
#footer .footer_info .footer_logo {
    display: block;
    width: 18vw;
    margin-bottom: 5px;
}
#footer .footer_info .footer_name {
    margin-bottom: 8px;
}
#footer .footer_info .footer_name span {
    font-size: 5vw;
    font-weight: 600;
    color: #138a2b;
}
#footer .footer_link .footer_bnr .footer_btn_contact {
    width: 100%;
    position: relative;
    text-align: center;
    background: #138a2b;
    border-radius: 50px;
}
#footer .footer_link .footer_bnr .footer_btn_contact a {
    padding: 0.9em;
    display: block;
    color: #fff;
    font-weight: 500;
    font-size: 1.1rem;
}
#footer .footer_link .footer_bnr .footer_btn_contact a span {
    position: relative;
    margin-left: 13%;
}
#footer .footer_link .footer_bnr .footer_btn_contact a span::before {
    display: block;
    content: '';
    position: absolute;
    top: 0;
    left: -28%;
    width: 20%;
    height: 100%;
    background: url("../images/common/ic_contact.png") no-repeat 0 50% / contain;
}
/* footer_link */
#footer .footer_link .footer_nav {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    margin-bottom: 30px;
    padding-bottom: 20px;
    border-bottom: 1px solid #c1c1c1;
}
#footer .footer_link .footer_nav ul:first-child {
    width: 40%;
}
#footer .footer_link .footer_nav ul:last-child {
    width: 60%;
}
#footer .footer_link .footer_nav ul li {
    margin-bottom: 10px;
    font-size: 3.2vw;
    letter-spacing: 0;
}
#footer .footer_link .footer_nav ul li:last-child {
    margin-bottom: 0;
}
#footer .footer_link .footer_bnr {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
}
#footer .footer_link .footer_bnr> * {
    display: block;
    margin-bottom: 15px;
}
#footer .footer_link .footer_bnr .footer_bnr_reservation {
    width: 69%;
    padding: 4vw 6vw 4vw 4vw;
    min-width: inherit;
}
#footer .footer_link .footer_bnr .footer_bnr_reservation a {
    font-weight: bold;
    font-size: 1.267rem;
}
#footer .footer_link .footer_bnr .footr_bnr_sns {
    width: 11.538%;
    margin-left: 3.6%;
}
#footer .footer_link .footer_bnr .footer_bnr_facilities {
    width: 23.846%;
    margin-right: 3.6%;
}
#footer .copy {
    padding: 15px;
    background: #138a2b;
    text-align: center;
    color: #fff;
    line-height: 1;
    font-size: 0.75rem;
}
/*
     04. top
 ========================================================================== */
/* mv ============================ */
#top #mv {
    position: relative;
}
.add-animation.slider_zoomIn {
    animation: zoomIn 10s linear 0s normal both;
}
@keyframes zoomIn {
    0% {
        transform: scale(1.15);
    }
    100% {
        transform: scale(1);
    }
}
.add-animation.slider_zoomOut {
    animation: zoomOut 10s linear 0s normal both;
}
@keyframes zoomOut {
    0% {
        transform: scale(1);
    }
    100% {
        transform: scale(1.15);
    }
}
.add-animation.slider_toLeft {
    animation: toLeft 10s linear 0s normal both;
}
@keyframes toLeft {
    0% {
        transform: translateX(3%) scale(1.1);
    }
    100% {
        transform: translateX(-3%) scale(1.1);
    }
}
.add-animation.slider_toRight {
    animation: toRight 10s linear 0s normal both;
}
@keyframes toRight {
    0% {
        transform: translateX(-3%) scale(1.1);
    }
    100% {
        transform: translateX(3%) scale(1.1);
    }
}
.add-animation.slider_toUp {
    animation: toUp 10s linear 0s normal both;
}
@keyframes toUp {
    0% {
        transform: translateY(3%) scale(1.1);
    }
    100% {
        transform: translateY(-3%) scale(1.1);
    }
}
.add-animation.slider_toDown {
    animation: toDown 10s linear 0s normal both;
}
@keyframes toDown {
    0% {
        transform: translateY(-3%) scale(1.1);
    }
    100% {
        transform: translateY(3%) scale(1.1);
    }
}
@keyframes sk-scaleout {
    0% {
        transform: scale(0.9);
    }
    100% {
        transform: scale(1.0);
        opacity: 0;
    }
}

/* c_feature ============================ */
#top #c_feature {
    margin-bottom: 12vw;
    padding: 16vw 6vw;
    background: url("../images/common/bg_dot_g.png") repeat 0 0 / 2.5px;
}
#top #c_feature .feature_cont .txt {
    position: relative;
}
#top #c_feature .feature_cont .feature_cont_category {
    color: #5f5f5f;
    padding-left: 27px;
    position: relative;
    font-weight: 500;
    line-height: 1;
    margin-bottom: 15px;
}
#top #c_feature .feature_cont .feature_cont_category::before {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: -3px;
    background: url("../images/common/ic_qtech_y.png") no-repeat 0 0 / contain;
    width: 20px;
    height: 21px;
}
#top #c_feature .feature_cont .feature_cont_catch {
    font-size: 6vw;
    font-weight: 600;
    line-height: 1.5;
    color: #138a2b;
    margin-bottom: 6vw;
}
#top #c_feature .feature_cont .feature_cont_txt {
    font-size: 3.8vw;
    font-weight: 400;
    line-height: 2;
}

#top #c_feature .feature_cont01 {
    margin-bottom: 12vw;
}
#top #c_feature .feature_cont01 .txt::before {
    display: block;
    content: '';
    width: 87.44vw;
    height: 76.329vw;
    background: url("../images/top/feature_softcase_bg.png") no-repeat 0 0 / contain;
    position: absolute;
    bottom: -17vw;
    left: -18vw;
    z-index: -1;
}
#top #c_feature .feature_cont01 .img {
    margin: -1vw 0 0 auto;
    width: 64%;
}
#top #c_feature .feature_cont02 .txt::before {
    display: block;
    content: '';
    width: 72.222vw;
    height: 72.222vw;
    background: url("../images/top/feature_print_bg.png") no-repeat 0 0 / contain;
    position: absolute;
    bottom: -4vw;
    right: -2vw;
    z-index: -1;
}
#top #c_feature .feature_cont02 .img {
    margin: 6vw auto 0;
    width: 92%;
}
/* news ============================ */
#c_news {
    margin: 0 auto;
    width: 88vw;
    padding: 6vw;
    background: #fff;
    border: 4px solid #d0e8d5;
    border-radius: 8px;
}
#c_news .news_ttl_wrap {
    position: relative;
    margin-bottom: 3vw;
}
#c_news .news_ttl span:first-child {
    display: block;
    font-size: 4vw;
    color: #5f5f5f;
    font-weight: 500;
    letter-spacing: 0.1em;
}
#c_news .news_ttl span:last-child {
    display: block;
    font-size: 5vw;
    font-weight: 600;
    color: #138a2b;
    letter-spacing: 0.1em;
}
#c_news .news_list {
    margin-bottom: 6vw;
    border-top: 1px solid #e0e0e0;
    padding-top: 0.8em;
}
#c_news ul li a {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    padding-bottom: 0.8em;
    margin-bottom: 0.8em;
    border-bottom: 1px solid #e0e0e0;
}
#c_news ul li:last-child a {
    margin-bottom: 0;
}
#c_news ul li a .date {
    margin-right: 2vw;
    line-height: 1.8;
    letter-spacing: 0;
    color: #666;
}
#top #c_news ul li a .category {
    margin-top: 0.3em;
    padding: 0.5em 0.3em 0.2em;
    width: 7.5em;
    line-height: 1;
    color: #fff;
    font-size: 0.733rem;
    text-align: center;
    background: #138a2b;
}
#c_news ul li a .ttl {
    margin-top: 1vw;
    width: 100%;
    line-height: 1.5;
}

