@charset "UTF-8";
/*
     multi-class
========================================================================== */
html {
    font-size: 16px;
}
body {
    font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック体", YuGothic, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    line-height: 1.6;
    font-weight: 400;
    color: #333333;
    letter-spacing: 0.08em;
    background: #fff;
}
body * {
    box-sizing: border-box;
    font-weight: inherit;
}
.page_wrapper {
    overflow: hidden;
}
a {
    color: #333333;
    text-decoration: none;
    transition: 0.4s ease-out;
}
a:hover {
    opacity: .6;
    filter: alpha(opacity=60);
}
img {
    max-width: 100%;
    vertical-align: bottom;
}
.pagetop {
    cursor: pointer;
    display: none;
    overflow: hidden;
    position: fixed;
    bottom: 55px;
    right: 20px;
    width: 35px;
    transition: 0.4s ease-out;
}
.pagetop:hover {
    opacity: .6;
}
.cf:after {
    display: block;
    content: "";
    clear: both;
}
.d_sp {
    display: none !important;
}
#content {
    max-width: 100%;
    margin: 0 auto;
    padding-bottom: 100px;
    background: url("../images/common/foot_tree.jpg") no-repeat 50% 100% / 100%;
}
p {
    line-height: 1.9;
    word-wrap: break-word;
}
/* スクロール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; }
/*
     レイアウト
========================================================================== */
.cont_inner {
    margin-left: auto;
    margin-right: auto;
    width: 1020px;
    max-width: 90%;
}
.box_800 {
    margin-left: auto;
    margin-right: auto;
    width: 800px;
    max-width: 100%;
}
/*
     フォント
========================================================================== */
.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: 600px;
}
.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 {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
}
.img_2col_B .img {
    width: 20%;
}
.img_2col_B .txt {
    width: 77%;
}
.video_cont_wrap {
    max-width: 100%;
}
.video_cont_wrap video {
    width: 100%;
}
/* slider */
.slick-dotted.slick-slider {
    margin-bottom: 0!important;
}
.slick-slide {
    position: relative;
}
.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;
    margin-bottom: 40px;
}
.dots-class li {
    width: 10px;
    height: 10px;
    background-color: #e6e6e6;
    border-radius: 50%;
    margin-right: 10px;
    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;
}
/* .slider_3column */
.slider.slider_3column .slick-slide {
    opacity: 0.4;
    transition: 0.6s ease-out;
}
.slider.slider_3column .slick-slide.slick-active {
    opacity: 1;
    transition: 0.6s ease-out;
}
/*
     見出し
========================================================================== */
.ttl_A {
    display: block;
    margin: 0 auto 2.2em;
    text-align: center;
}
.ttl_A span {
    display: inline-block;
    padding: 0 0.1em 0.2em;
    font-size: 2rem;
    line-height: 1.5;
    font-weight: bold;
    border-bottom: 4px solid #138a2b;
}
.ttl_B {
    position: relative;
    margin-bottom: 1.8em;
    padding-bottom: 12px;
}
.ttl_B span {
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.5;
}
.ttl_B:before {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 10%;
    height: 4px;
    background: #138a2b;
    content: '';
}
.ttl_B:after {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 90%;
    height: 4px;
    background: #d3d3d3;
    content: '';
}
.ttl_C {
    display: block;
    margin-bottom: 1.7em;
    padding: 8px 17px 9px;
    background: #535353;
    border-radius: 2px;
    position: relative;
    box-shadow: 3px 3px #d3d3d3;
}
.ttl_C span {
    font-size: 1.3rem;
    line-height: 1.5;
    letter-spacing: 0.06em;
    color: #fff;
    font-weight: 600;
}
.ttl_D {
    display: block;
    margin-bottom: 0.8em;
    padding-left: 17px;
    border-radius: 4px;
    position: relative;
}
.ttl_D span {
    font-size: 1.3rem;
    line-height: 1.5;
    letter-spacing: 0.06em;
    font-weight: 600;
}
.ttl_D:before {
    position: absolute;
    top: 0.1em;
    left: 0;
    width: 8px;
    height: 95%;
    border-radius: 2px;
    background: #f6aa15;
    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: flex-start;
    align-items: stretch;
    flex-wrap: wrap;
    margin-bottom: 40px;
}
.low_nav ul li {
    margin: 0 1% 10px 0;
    width: 24%;
    background: #f8f8f8;
    position: relative;
    display: flex;
    align-items: center;
}
.low_nav ul li:nth-child(4n) {
    margin-right: 0;
}
.low_nav ul li a {
    display: block;
    padding: 20px 33px 20px 20px;
    position: relative;
    font-weight: 500;
    width: 100%;
}
.low_nav ul li::after {
    display: block;
    content: '';
    width: 0;
    height: 0;
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-top: 10px solid #a11d45;
    position: absolute;
    top: calc(50% - 4px);
    right: 15px;
}

/*
     ボタン
========================================================================== */
.btn_A {
    padding: 15px 30px;
    max-width: 100%;
    display: block;
    position: relative;
    text-align: center;
    background: #138a2b;
    border-radius: 50px;
}
.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 {
    display: block;
    padding: 0.9em 1.6em 0.9em 0.8em;
    color: #fff;
    font-weight: 700;
    font-size: 1.1rem;
}
.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.4em;
    font-weight: bold;
}
.btn_arrow_B a::after {
    position: absolute;
    top: 55%;
    right: 0;
    transform: translateY(-50%);
    transform-origin: left;
    width: 3em;
    height: 0.6em;
    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%;
}
.table_A {
    border-left: 1px solid #333;
    border-top: 1px solid #333;
    background: #fff;
}
.table_A th {
    background: #f8f8f8;
    padding: 8px 25px;
    font-weight: 600;
    border-right: 1px solid #333;
    border-bottom: 1px solid #333;
}
.table_A td {
    padding: 15px 20px;
    border-right: 1px solid #333;
    border-bottom: 1px solid #333;
}
.table_B {
    border-top: 1px solid #333;
}
.table_B th, .table_B td {
    padding: 15px 20px;
    border-bottom: 1px solid #333;
}
/* 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 12px;
}
.table_C th:after{
  display: block;
  content: "";
  width: 0px;
  height: 0px;
  position: absolute;
  top:calc(50% - 10px);
  right:-10px;
  border-left: 10px solid #51a5cc;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
}
.table_C td{
  text-align: left;
  background-color: #eee;
  padding: 16px 12px;
}
/* table_dl_A */
.table_dl_A {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
}
.table_dl_A dt {
    padding: 18px 0;
    width: 20%;
    border-top: 3px solid #138a2b;
    font-weight: bold;
}
.table_dl_A dt.table_dl_last {
    border-bottom: 3px solid #138a2b;
}
.table_dl_A dd {
    padding: 18px 6px;
    width: 78%;
    border-top: 1px dotted #888;
}
.table_dl_A dd.table_dl_last {
    border-bottom: 1px dotted #888;
}
.table_dl_A dd.table_dl_indent {
    margin-left: 27%;
}
table tr.line_dot th, table tr.line_dot td {
    border-bottom: 1px dotted #333;
}
/*
     リスト
========================================================================== */
.list_num li {
    list-style-type: decimal;
    list-style-position: outside;
    margin-left: 1.5em;
}
.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: 10px;
    font-size: 1.14rem;
}
.list_flow dd {
    margin-bottom: 35px;
    padding-left: 1.3em;
    line-height: 1.9;
    font-size: 0.857rem;
}
/*
     column
========================================================================== */
.column-2 {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.column-2 > * {
    width: 49%;
}
.img_column3 {
    display: flex;
    justify-content: center;
    align-content: center;
}
.img_column3 img {
    width: calc(100% / 3);
}

/*
     img+textbox
========================================================================== */
.img_textbox_A,
.img_textbox_B {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.img_textbox_A .img {
    width: 30%;
}
.img_textbox_A .txt {
    width: 67%;
}
.img_textbox_B .img {
    width: 40%;
}
.img_textbox_B .txt {
    width: 57%;
}
.img_textbox_re {
    flex-direction: row-reverse;
}

/*
     box
========================================================================== */
.box_A_gray {
    margin: 0 auto;
    padding: 40px;
    width: 100%;
    box-sizing: border-box;
    background: #f8f8f8;
    border-radius: 8px;
}
.box_A_yellow {
    margin: 0 auto;
    padding: 40px;
    width: 100%;
    box-sizing: border-box;
    background: #fcfaed;
    border-radius: 8px;
}
.box_B_gray {
    margin: 0 auto;
    padding: 30px;
    width: 100%;
    box-sizing: border-box;
    background: #f8f8f8;
    border-radius: 8px;
}

/*
     テキスト
========================================================================== */
.p-link {
    color: #138a2b;
    text-decoration: underline;
    margin: 0 1px;
}
.uline {
    text-decoration: underline;
}
.mid_bold {
    font-weight: 500;
}
.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;
}
/* letter spacing */
.ls02 {
    letter-spacing: 0.2rem;
}
/* color */
.black {
    color: #494955 !important;
}
.gray {
    color: #808080 !important;
}
.gray_medium {
    color: #666 !important;
}
.gray_light {
    color: #a4a4aa !important;
}
.red {
    color: #a11d45 !important;
}
.blue {
    color: #104a7a !important;
}
.brown {
    color: #483e3f !important;
}
.green {
    color: #138a2b !important;
}
.olive {
    color: #676441 !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 {
    margin-bottom: 20px !important;
}
.mb25 {
    margin-bottom: 25px !important;
}
.mb30 {
    margin-bottom: 30px !important;
}
.mb40 {
    margin-bottom: 40px !important;
}
.mb50 {
    margin-bottom: 50px !important;
}
.mb60 {
    margin-bottom: 60px !important;
}
.mb70 {
    margin-bottom: 70px !important;
}
.mb80 {
    margin-bottom: 80px !important;
}
.mb90 {
    margin-bottom: 90px !important;
}
.mb100 {
    margin-bottom: 100px !important;
}
.mb1em {
    margin-bottom: 1em;
}
.mt5 {
    margin-top: 5px !important;
}
.mt10 {
    margin-top: 10px !important;
}
.mt15 {
    margin-top: 15px !important;
}
.mt20 {
    margin-top: 20px !important;
}
.mt30 {
    margin-top: 30px !important;
}
.mr5 {
    margin-right: 5px !important;
}
.mr10 {
    margin-right: 10px !important;
}
.mr15 {
    margin-right: 15px !important;
}
.mr20 {
    margin-right: 20px !important;
}
.mr30 {
    margin-right: 30px !important;
}
.ml5 {
    margin-left: 5px !important;
}
.ml10 {
    margin-left: 10px !important;
}
.ml15 {
    margin-left: 15px !important;
}
.ml20 {
    margin-left: 20px !important;
}
.ml30 {
    margin-left: 30px !important;
}
/*
     pagenavi
========================================================================== */
.pagenavi {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.428rem;
}
.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: 1.5px solid #494955;
}
.pagenavi .prev, .pagenavi .next {
    margin: 0 0.65em;
    transform: scaleX(1.5);
    font-size: 0.7rem;
}
/*
     slick
========================================================================== */
/* slick-dot */
#content .slick-dotted.slick-slider {
    margin-bottom: 0;
}
#content .slick-dots {
    bottom: 20px;
    z-index: 10;
}
#content .slick-dots li {
    width: 10px;
    height: 10px;
    margin: 0 3px;
}
#content .slick-dots li button {
    width: 10px;
    height: 10px;
    padding: 0;
}
#content .slick-dots li button:before {
    width: 10px;
    height: 10px;
    content: '';
    border-radius: 10px;
    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: 200px;
    margin: auto;
    padding: 0;
    width: 30px;
    height: 60px;
    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: 30px;
    height: 30px;
    border-top: 1.5px solid #b3b3b3;
    border-right: 1.5px solid #b3b3b3;
}
#content .cont_slider .slick-next {
    right: -50px;
}
#content .cont_slider .slick-next::after {
    right: 4px;
    transform: rotate(45deg);
}
#content .cont_slider .slick-prev {
    left: -50px;
}
#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;
}
/* cont_slider_B */
#content .cont_slider_B .slick-arrow {
    display: block;
    position: absolute;
    top: calc(50% - 20px);
    margin: auto;
    padding: 0;
    width: 16px;
    height: 40px;
    color: transparent;
    z-index: 1;
    transition: opacity 0.5s;
    transform: scaleX(0.75);
}
#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: 25px;
    height: 25px;
    border-top: 1.5px solid #b3b3b3;
    border-right: 1.5px solid #b3b3b3;
}
#content .cont_slider_B .slick-next {
    right: -40px;
}
#content .cont_slider_B .slick-next::after {
    right: 4px;
    transform: rotate(45deg);
}
#content .cont_slider_B .slick-prev {
    left: -40px;
}
#content .cont_slider_B .slick-prev::after {
    left: 4px;
    transform: rotate(-135deg);
}
#content .cont_slider_B .slick-dots {
    bottom: -30px;
}

/*
       01. header
========================================================================== */
header {
    width: 100%;
}
/*
header .header_top {
    padding: 40px 0 38px;
    border-bottom: 1px solid #ccc;
    transition: all .5s;
    background: rgba(255, 255, 255, 0.9);
}
*/
header .header_inner {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
}
header .header_content {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding-right: 20px;
}
header .header_content .header_nav {
    width: fit-content;
    padding-right: 20px;
    display: flex;
    align-items: center;
}
/* header_logo */
header .header_logo {
    padding: 10px 20px;
}
header .header_logo a {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
    padding-left: 100px;
    min-height: 60px;
    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: 1rem;
    padding-right: 0.2em;
}
header .header_logo a span:last-child {
    font-size: 1.625rem;
    letter-spacing: 0.04em;
}
/* header_btn */
header .header_content .header_btn a {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 12px 30px;
    color: #fff;
    background: #138a2b;
    position: relative;
    margin-left: 1px;
    border-radius: 40px;
}
header .header_content .header_btn a span {
    display: block;
    font-weight: 500;
    font-size: 0.938rem;
}
header .header_content .header_btn .header_btn_contact img {
    display: block;
    margin-right: 6px;
    width: 27px;
}
/* header_nav_global */
header .header_content .header_nav_global ul {
    display: flex;
    justify-content: flex-end;
    align-items: center;
}
header .header_content .header_nav_global ul li a {
    padding: 0 1em;
    line-height: 1;
    font-weight: 600;
}
header .header_content .header_nav_global ul li:last-child a {
    padding-right: 0;
    border-right: none;
}
header .navToggle,
.globalMenuSp {
    display: none;
}
@media screen and (max-width: 850px) {
    header .header_content {
        display: none!important;
    }
    header .navToggle,
    .globalMenuSp {
        display: block;
    }
    .globalMenuSp {
        position: fixed;
        z-index: 1001;
        top: 0;
        right: 0;
        background: #f1f1f1;
        transform: translateY(-120%);
        transition: all 0.6s;
        width: 400px;
        letter-spacing: 0.2em;
        box-sizing: border-box;
        overflow-y: scroll;
        padding: 50px 30px;
        border-radius: 10px;
        box-shadow: 4px 2px 4px 4px rgba(0, 0, 0, 0.2);
    }
    /* このクラスを、jQueryで付与・削除する */
    .globalMenuSp.active {
        transform: translateY(0%);
        top: 0;
    }
    /* ハンバーガー用 */
    .navToggle {
        display: block;
        position: fixed;
        right: 25px;
        top: 20px;
        width: 60px;
        height: 40px;
        text-align: center;
        border-radius: 2px;
        transition: all .5s;
        z-index: 9999;
        cursor: pointer;
    }
    header.headerColorScroll .navToggle {
        top: 20px;
    }
    .navToggle span {
        display: block;
        position: absolute; /* .navToggleに対して */
        width: 50px;
        border-bottom: solid 5px #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: 16px;
    }
    .navToggle span:nth-child(3) {
        top: 32px;
    }
    .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: 20px;
        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: 20px;
        -webkit-transform: rotate(45deg);
        -moz-transform: rotate(45deg);
        transform: rotate(45deg);
    }
    /* gnav content */
    .globalMenuSp .globalMenuSp_main {
        margin-bottom: 30px;
        padding-bottom: 20px;
        border-bottom: 1px solid #e0e0e0;
    }
    .globalMenuSp .globalMenuSp_main li a {
        display: block;
        font-size: 1.15rem;
        margin-bottom: 18px;
        font-weight: 600;
    }
    .globalMenuSp .globalMenuSp_sub {
        margin-bottom: 20px;
        padding-bottom: 20px;
        border-bottom: 1px solid #e0e0e0;
    }
    .globalMenuSp .globalMenuSp_sub li a {
        display: block;
        margin: 10px 0;
    }
    .globalMenuSp .globalMenuSp_btn .globalMenuSp_btn_contact {
        width: 100%;
    }
    .globalMenuSp .globalMenuSp_btn .globalMenuSp_btn_contact a span {
        font-weight: 500;
    }
}


/*
     03. footer
========================================================================== */
#footer {
    background: #f8f8f8;
}
#footer .cont_inner {
    padding: 60px 0;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
/* footer_info */
#footer .footer_info {
    width: 41%;
}
#footer .footer_info .footer_name {
    margin-bottom: 8px;
}
#footer .footer_info .footer_logo {
    width: 98px;
    margin-bottom: 8px;
}
#footer .footer_info .footer_name span {
    font-size: 1.3rem;
    font-weight: 600;
    color: #138a2b;
}
#footer .footer_info .footer_add {
   line-height: 1.6;
}
/* footer_link */
#footer .footer_link {
    padding-top: 78px;
    width: 54%;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
#footer .footer_link .footer_nav {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    width: inherit;
}
#footer .footer_link .footer_nav ul {
    width: 50%;
}
#footer .footer_link .footer_nav ul li {
    margin-bottom: 10px;
    font-size: 0.9rem;
}
#footer .footer_link .footer_bnr {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
    width: 250px;
}
#footer .footer_link .footer_bnr .footer_btn_contact {
    width: 100%;
    position: relative;
    text-align: center;
    background: #138a2b;
    border-radius: 40px;
}
#footer .footer_link .footer_bnr .footer_btn_contact a {
    padding: 0.8em;
    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 .footer_link .footer_bnr .footr_bnr_sns {
    width: 11.538%;
    margin-left: 3.6%;
}
#footer .copy {
    padding: 18px;
    background: #138a2b;
    text-align: center;
    color: #fff;
    line-height: 1;
    font-size: 0.9rem;
}

@media screen and (max-width: 1150px) {
    #footer .footer_info .footer_add {
        font-size: 0.9rem;
    }
    #footer .footer_link .footer_bnr {
        width: 35%;
    }
    #footer .footer_link .footer_bnr .footer_btn_contact a {
        font-size: 0.9rem;
    }
}

/*
     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: 80px;
    padding: 95px 0;
    background: url("../images/common/bg_dot_g.png") repeat 0 0 / 2.5px;
}
#top #c_feature .feature_cont {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 auto;
}
#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: 1.938rem;
    font-weight: 600;
    line-height: 1.5;
    color: #138a2b;
    margin-bottom: 25px;
}
#top #c_feature .feature_cont .feature_cont_txt {
    font-size: 1.1rem;
    font-weight: 400;
    line-height: 2;
}

#top #c_feature .feature_cont01 {
    width: 835px;
    max-width: 100%;
    margin-bottom: 100px;
}
#top #c_feature .feature_cont01 .txt {
    width: 57.485%;
    position: relative;
}
#top #c_feature .feature_cont01 .txt::before {
    display: block;
    content: '';
    width: 362px;
    height: 316px;
    background: url("../images/top/feature_softcase_bg.png") no-repeat 0 0 / contain;
    position: absolute;
    bottom: -60px;
    left: -19%;
    z-index: -1;
}
#top #c_feature .feature_cont01 .img {
    width: 40.12%;
}
#top #c_feature .feature_cont02 {
    flex-direction: row-reverse;
    width: 1020px;
    max-width: 100%;
}
#top #c_feature .feature_cont02 .txt {
    width: 51.961%;
    position: relative;
}
#top #c_feature .feature_cont02 .txt::before {
    display: block;
    content: '';
    width: 299px;
    height: 298px;
    background: url("../images/top/feature_print_bg.png") no-repeat 0 0 / contain;
    position: absolute;
    bottom: -20px;
    right: 19%;
    z-index: -1;
}
#top #c_feature .feature_cont02 .img {
    width: 43.725%;
}

/* news ============================ */
#top #c_news .news_inner {
    margin: 0 auto;
    width: 920px;
    max-width: 94%;
    padding: 40px 50px;
    background: #fff;
    border: 5px solid #d0e8d5;
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    min-height: 210px;
    border-radius: 10px;
}
#top #c_news .news_ttl_wrap {
    width: 12rem;
    position: relative;
}
#top #c_news .news_ttl span:first-child {
    display: block;
    font-size: 1.1rem;
    color: #5f5f5f;
    font-weight: 500;
    letter-spacing: 0.1em;
}
#top #c_news .news_ttl span:last-child {
    display: block;
    font-size: 1.88rem;
    font-weight: 600;
    color: #138a2b;
    letter-spacing: 0.1em;
}
#top #c_news .news_more_btn {
    position: absolute;
    bottom: 0;
    left: 0;
}
#top #c_news .news_list {
    width: calc(100% - 12rem);
}
#top #c_news ul li a {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    margin-bottom: 1.2em;
}
#top #c_news ul li:last-child a {
    margin-bottom: 0;
}
#top #c_news ul li a .date {
    margin-right: 0.5em;
    width: 7em;
    line-height: 1.7;
    font-weight: 500;
}
#top #c_news ul li a .ttl {
    width: calc(100% - 7em);
    line-height: 1.7;
}
@media screen and (max-width: 1100px) {
    header .header_logo a span:first-child {
        font-size: 1.5vw;
    }
    header .header_logo a span:last-child {
        font-size: 2.3vw;
    }
    header .header_content .header_nav_global ul li a {
        font-size: 1.5vw;
    }
    header .header_content .header_btn a span {
        font-size: 1.5vw;
    }
    #top #c_feature .feature_cont .feature_cont_txt {
        font-size: 1.6vw;
    }
}
@media screen and (max-width: 900px) {
    #footer .footer_info .footer_tel a {
        font-size: 1.5vw;
    }
    #footer .footer_info .footer_tel a .num {
        font-size: 3vw;
    }
}