@charset "UTF-8";
/* ==================================================

	basic layout

================================================== */
#wrapper { position: relative; width: 100%; height: 100%; -webkit-text-size-adjust: 100%; color: #333; overflow-x: hidden; font-size: 1.4rem; }

/* ▽ PC layout ========== */
@media print, screen and (min-width: 1024px) { #wrapper { min-width: 1030px; } }

/* ========== end △ */
/* サイト幅

-------------------------------------------------- */
.content, .site_wrap { -webkit-box-sizing: border-box; box-sizing: border-box; width: 100%; }

/* ▽ PC layout ========== */
@media print, screen and (min-width: 1024px) { .content { max-width: 1200px; width: 100%; margin: 0 auto; } }

/* ========== end △ */
/* ▽ SP layout ========== */
@media only screen and (max-width: 767px) { .content { padding: 0 3%; } }

/* ========== end △ */
/* ▽ PC layout ========== */
@media print, screen and (min-width: 1024px) { .site_wrap { width: 1030px; margin: 0 auto; } }

/* ========== end △ */
.pc { display: block; }

.sp { display: none; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 767px) { .pc { display: none; }
  .sp { display: block; }
  img { max-width: 100%; } }

/* ========== end △ */
/* ==================================================

	header

================================================== */
@-webkit-keyframes scrolltop { 0% { -webkit-transform: translateY(-80px); transform: translateY(-80px);
    opacity: 0;
    -webkit-transition: ease-in-out;
    -o-transition: ease-in-out;
    transition: ease-in-out; }
  100% { -webkit-transform: translateY(0); transform: translateY(0);
    opacity: 1; } }

@-moz-keyframes scrolltop { 0% { transform: translateY(-80px);
    opacity: 0;
    -webkit-transition: ease-in-out;
    -o-transition: ease-in-out;
    transition: ease-in-out; }
  100% { transform: translateY(0);
    opacity: 1; } }

@keyframes scrolltop { 0% { -webkit-transform: translateY(-80px); transform: translateY(-80px);
    -webkit-transform-origin: center;
    transform-origin: center;
    opacity: 0;
    -webkit-transition: ease-in-out;
    -o-transition: ease-in-out;
    transition: ease-in-out; }
  100% { -webkit-transform: translateY(0); transform: translateY(0);
    opacity: 1; } }

#header { font-family: 'M PLUS 1p', sans-serif; position: fixed; background-color: #fff; left: 0; right: 0; top: 0; z-index: 9999; -webkit-transition: all .2s ease-out; -moz-transition: all .2s ease-out; -o-transition: all .2s ease-out; transition: all .2s ease-out; }
#header .h_top::before{
  width: 100%;
  height: 0px;
  content: "";
  -webkit-transition: all .2s ease-out; -moz-transition: all .2s ease-out; -o-transition: all .2s ease-out; transition: all .2s ease-out;
  background-color: #fff;
  z-index: -1;
  position: absolute;
  top:0;
  left: 0;
}
#header.fixed .h_top:hover::before{
  height: 100%;
}
#header.fixed { -webkit-animation-iteration-count: 1; background-color: transparent;animation-iteration-count: 1; box-shadow: none!important;/*#gnav li a img { height: 0; }*/ }
#h_top, #h_logo{
  position: relative;
  z-index: 0;
}
#header.fixed .h_top .h_logo { -webkit-box-shadow: 0 2px 6px 1px rgba(0, 0, 0, 0.2); box-shadow: 0 2px 6px 1px rgba(0, 0, 0, 0.2); -webkit-transition: all .5s ease-in-out; -moz-transition: all .5s ease-in-out; -o-transition: all .5s ease-in-out; transition: all .5s ease-in-out; }

#header.fixed .site_wrap{ -webkit-transition: all 0.4s; -o-transition: all 0.4s; transition: all 0.4s; bottom:150%;}
#header.fixed #h_logo{
  visibility: hidden;
}
#header.fixed .h_top:hover #h_logo{
  visibility: visible;
  -webkit-transition-delay: 0.2s;
  -moz-transition-delay: 0.2s;
  -ms-transition-delay: 0.2s;
  transition-delay: 0.2s;
  -webkit-transition: all 0.2s; -o-transition: all 0.2s; transition: all 0.2s;
}
#header.fixed .h_top:hover .site_wrap{
  bottom:0px;
}
#header .h_top .h_logo { display: block; -webkit-transition: all .5s ease-in-out; -moz-transition: all .5s ease-in-out; -o-transition: all .5s ease-in-out; transition: all .5s ease-in-out; }

#header .h_top .h_logo img { margin: 0 auto; }

/* ▽ PC-TAB layout ========== */
@media print, screen and (min-width: 768px) { #header .h_top .h_logo { display: inline-block; position: absolute; top: 15px; -ms-transform: translate(-50%, 0); transform: translate(-50%, 0); -webkit-transform: translate(-50%, 0); -moz-transform: translate(-50%, 0); -o-transform: translate(-50%, 0); left: 50%; }
  }
  @media print, screen and (min-width: 640px){
    #header .h_top { padding: 10px 0 20px 0; }
  }
/* ========== end △ */
/* ▽ SP layout ========== */
@media only screen and (max-width: 767px) { #header.fixed .h_top .h_logo { display: none; visibility: hidden; }
  #header .h_top .h_logo img { width: 58%; } }

/* ========== end △ */
/* ==================================================

	gnav

================================================== */
/*#gnav_open,

#gnav_close {

    display: none;

}



@include media(sp) {

    .nav_shade {

        position: fixed;

        z-index: 10;

        top: 0;

        width: 100%;

        height: 100%;

        cursor: pointer;

        background-color: #333;

        background-color: rgba(0, 0, 0, 0.7);

    }

    #gnav_open {

        display: block;

        position: absolute;

        top: 15px;

        right: 15px;

        color: #fff;

        font-size: 3.5rem;

    }

    #gnav_close {

        display: none;

        padding: 15px 15px 10px 0;

        color: #fff;

        font-size: 3.5rem;

        font-weight: normal;

        text-align: right;

    }

    #gnav {

        position: absolute;

        z-index: 11;

        top: 0;

        right: -100%;

        width: 100%;

        overflow-y: auto;

        transition: all 0.2s ease;

        &.openMenu {

            right: 0;

        }

    }

    #gnav.openMenu {

        #gnav_open {

            display: none;

        }

        #gnav_close {

            display: block;

        }

    }

}*/
#gnav { background-color: #fff; }

#gnav li { position: relative; float: left; width: 20%; text-align: center; }

#gnav li.hsub ul { display: none; }

#gnav li.hsub ul li { width: 100%; }

#gnav li:last-child a img { height: auto !important; }

#gnav li a { display: block; font-family: 'M PLUS 1p', sans-serif; padding: 15px 5px; text-decoration: none; color: #231815; font-weight: 600; font-size: 1.4rem; }

/* ▽ PC-TAB layout ========== */
@media print, screen and (min-width: 768px) { #gnav li a img { display: block; height: 50px; margin: auto; -webkit-transition: all .4s ease-out; -moz-transition: all .4s ease-out; -o-transition: all .4s ease-out; transition: all .4s ease-out; } }

/* ========== end △ */
/* ▽ PC layout ========== */
@media print, screen and (min-width: 1024px) { #gnav li a:hover { background-color: #ffb64c; } }

/* ========== end △ */
/* ▽ PC-TAB layout ========== */
@media print, screen and (min-width: 768px) { #gnav li { width: 14%; border-top: none; display: inline-block; }
  #gnav li:nth-child(4) { margin-left: 16%; }
  #gnav li a img { filter: brightness(0) invert(0); -webkit-filter: brightness(0) invert(0); }
  #gnav li.hsub ul { position: absolute; width: 100%; left: 0; top: 100%; background: white none repeat scroll 0% 0%; } }

/* ========== end △ */
/* ▽ SP layout ========== */
@media only screen and (max-width: 767px) { #gnav li { background: #231815; }
  #gnav li a { padding: 0 0 5% 0; font-size: 2.7vw; color: #fff; position: relative; }
  #gnav li a img { width: 64%; filter: brightness(0) invert(1); -webkit-filter: brightness(0) invert(1); }
  #gnav li a:before { content: ''; position: absolute; left: 0; top: 0; background-color: #fff; height: 100%; width: 2px; }
  #gnav li.hsub { position: unset; }
  #gnav li.hsub ul { position: absolute; width: 100%; left: 0; }
  #gnav li.hsub ul li { background: #fff; }
  #gnav li.hsub ul li a { color: #000; font-size: 149%; padding: 3% 0; border-bottom: 2px solid #000; } }

@media only screen and (max-width: 767px) and (max-width: 320px) { #gnav li.hsub ul li a { font-size: 100%; } }

@media only screen and (max-width: 767px) { #gnav li.hsub ul li:last-child { display: block; }
  #gnav li.hsub ul li:last-child a { border-bottom: none; }
  #gnav li:first-child a:before, #gnav li:last-child { display: none; } }

/* ========== end △ */
/* ==================================================

	footer

================================================== */
#footer { text-align: center; position: relative; background: url("../common_img/bg.webp"), #2c6129; padding: 95px 0 100px 0; background-repeat: no-repeat; }

#footer .f_nav { padding-bottom: 5%; }

#footer .f_nav ul li a { color: #ffb64c; font-family: "M PLUS 1p"; font-weight: 600; font-size: 114%; text-decoration: none; display: block; margin-bottom: 30px; }

#footer .f_nav ul li ul li a { margin-bottom: 15px; color: #fff; font-size: 14px; }

#footer .f_logo { margin-bottom: 60px; }

#footer .btns_link { padding-bottom: 70px; }

#footer .btns_link img { max-width: 100%; }

#footer .btns_link a { width: 21.5%; }

#footer:before { content: ''; position: absolute; background: url("../common_img/f_h.webp"); width: 89px; height: 120px; top: -120px; left: 50%; -ms-transform: translate(-50%, 0); transform: translate(-50%, 0); -webkit-transform: translate(-50%, 0); -o-transform: translate(-50%, 0); -webkit-transform: translate(-50%, 0); }

#footer .f_contact { position: fixed; background: #fff; padding: 15px 0 15px 0; bottom: 0; z-index: 999; width: 100%; margin: 0 auto; }

#footer .f_contact .site_wrap { padding: 0 30px; }

#footer .f_contact .cnt { width: 27.9%; }

#footer .f_contact .cnt:nth-child(1) { background-color: #ffb64c; color: #4a3725; }

#footer .f_contact .cnt:nth-child(1) a { color: #4a3725; }

#footer .f_contact .cnt:nth-child(1) a:after { content: ''; background: url("../common_img/mail.webp"); background-repeat: no-repeat; background-position: center; background-size: 100% auto; position: absolute; top: 50%; width: 40px; height: 32px; left: 11%; -ms-transform: translate(0, -50%); transform: translate(0, -50%); -webkit-transform: translate(0, -50%); -o-transform: translate(0, -50%); -moz-transform: translate(0, -50%); }

#footer .f_contact .cnt:nth-child(2) { background-color: #00b900; color: #fff; }

#footer .f_contact .cnt:nth-child(2) a { color: #fff; }
#footer .f_contact .cnt:nth-child(2) button { color: #fff; text-align:left;}

#footer .f_contact .cnt:nth-child(2) a:after { content: ''; background: url("../common_img/line.webp"); background-repeat: no-repeat; background-position: center; background-size: 100% auto; width: 60px; height: 60px; position: absolute; top: 50%; left: 4%; -ms-transform: translate(0, -50%); transform: translate(0, -50%); -webkit-transform: translate(0, -50%); -o-transform: translate(0, -50%); -moz-transform: translate(0, -50%); }
#footer .f_contact .cnt:nth-child(2) button:after { content: ''; background: url("../common_img/line.webp"); background-repeat: no-repeat; background-position: center; background-size: 100% auto; width: 60px; height: 60px; position: absolute; top: 50%; left: 4%; -ms-transform: translate(0, -50%); transform: translate(0, -50%); -webkit-transform: translate(0, -50%); -o-transform: translate(0, -50%); -moz-transform: translate(0, -50%); }

#footer .f_contact .cnt:nth-child(3) { background-color: #158530; color: #fff; }
#footer .f_contact .cnt:nth-child(3) a { color: #fff; }
#footer .f_contact .cnt:nth-child(3)  a.button { padding-left:10px;}


#footer .f_contact a { font-size: 18px; text-decoration: none; font-family: "M PLUS 1p"; font-weight: 700; display: block; position: relative; }
#footer .f_contact button { font-size: 18px; font-weight: 700; display: block; position: relative; }

#footer .f_contact a.button { padding: 19px 10px 19px 65px; position: relative; }
#footer .f_contact button.button { padding: 19px 10px 19px 75px; position: relative; background-color: #00b900; border:none;}

#footer .f_contact .f_tel { width: 32%; padding-left: 60px; color: #231815; font-size: 100%; font-weight: 400; position: relative; }

#footer .f_contact .f_tel:before { content: ''; position: absolute; background: url("../common_img/phone.webp"); background-repeat: no-repeat; background-position: center; background-size: 100% auto; width: 60px; height: 60px; left: 0; top: 50%; -ms-transform: translate(0, -50%); transform: translate(0, -50%); -webkit-transform: translate(0, -50%); -o-transform: translate(0, -50%); -moz-transform: translate(0, -50%); }

#footer .f_contact .f_tel a { display: block; text-decoration: none; color: #231815; }

#footer .f_contact .f_tel span { letter-spacing: -2px; font-size: 44px; line-height: 1.0; display: block; font-weight: 700; }

#footer .f_contact .page_up { display: inline-block; float: right; padding-right: 15px; padding-top:15px;}

#footer .f_logo img {height:auto;}
/* ▽ PC-TAB layout ========== */
@media print, screen and (min-width: 768px) { #footer .f_logo img { width: 375px; }
  #footer .btns_link { max-width: 190px; margin: 0 auto; width: 100%; }
  #footer .f_contact .cnt { overflow: hidden; position: relative; }
  #footer .f_contact .cnt:nth-child(1):before { content: ""; background-color: #4a3725; left: 50%; right: 50%; position: absolute; -webkit-transition: .3s; -o-transition: .3s; transition: .3s; width: 0; top: 0; bottom: 0; }
  #footer .f_contact .cnt:nth-child(1):hover:before { width: 100%; left: 0; right: 0; }
  #footer .f_contact .cnt:nth-child(1):hover a { color: #fff; }
  #footer .f_contact .cnt:nth-child(1):hover a:after { filter: brightness(0) invert(1); -webkit-filter: brightness(0) invert(1); }
  #footer .f_contact .cnt:nth-child(2):hover { -webkit-box-shadow: 0 0 5px 1px rgba(0, 0, 0, 0.4); box-shadow: 0 0 5px 1px rgba(0, 0, 0, 0.4); }
  #footer .f_contact .cnt:nth-child(2):hover a:after { -webkit-animation: toTopFromBottom 0.3s forwards; -moz-animation: toTopFromBottom 0.3s forwards; animation: toTopFromBottom 0.3s forwards; } }

/* ========== end △ */
/* ▽ TAB-SP layout ========== */
@media only screen and (max-width: 1023px) { #footer .f_contact .f_tel span { font-size: 3.8vw; }
  #footer .f_contact .page_up { padding-top: 1%; }
  #footer .f_contact .page_up img{ height: auto; }
}

/* ========== end △ */
/* ▽ SP layout ========== */
@media only screen and (max-width: 767px) { #footer { padding: 14% 0 15% 0; }
  #footer .f_contact { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -webkit-justify-content: space-between; -moz-justify-content: space-between; -ms-justify-content: space-between; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-align-items: center; -moz-align-items: center; -ms-align-items: center; text-align: left; padding: 3%; width: calc(100% - 6%); }
  #footer .f_contact .page_up { padding: 0; float: none; -webkit-box-ordinal-group: 2; -ms-flex-order: 1; order: 1; width: 10%; }
  #footer .f_contact .page_up img { width: 100%; }
  #footer .f_contact .cnt:nth-child(2) a:after { width: 9vw; height: 100%; left: 0;}
  #footer .f_contact .cnt:nth-child(2) button:after { width: 9vw; height: 100%; left: 0;}
  /*#footer .f_contact .cnt:nth-child(1) a.button { padding: 6.9% 5% 6.9% 45%; }*/
  #footer .f_contact .cnt:nth-child(1) a.button { padding: 6% 0% 6% 36%; }
  #footer .f_contact .cnt:nth-child(2) a.button { padding: 6% 0% 6% 32%; }
  #footer .f_contact .cnt:nth-child(2) button.button { padding: 7% 0% 4% 32%; line-height:1.5em}
  #footer .f_contact .cnt:nth-child(1) a:after { width: 7vw; height: 7vw; left: 5%; }
  #footer .f_contact .site_wrap { width: 89%; -webkit-box-ordinal-group: 1; -ms-flex-order: 0; order: 0; padding: 0; }
  #footer .f_contact .site_wrap .cnt { width: 32.5%; }
  #footer .f_contact .site_wrap .f_tel { width: 32.5%; padding-left: 0; background-color: #158530; }
  #footer .f_contact .site_wrap .f_tel:before { filter: brightness(0) invert(1); -webkit-filter: brightness(0) invert(1); width: 6.5vw; height: 6.5vw; left: 2%; background-size: 83% auto;}
  #footer .f_contact .site_wrap .f_tel a { color: #fff; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; padding-left: 12%; -ms-flex-align: center; align-items: center; -webkit-align-items: center; -moz-align-items: center; -ms-align-items: center; height: 100%; width: 100%; }
  #footer .f_contact .site_wrap .f_tel span { display: none; }
  /*#footer .f_contact a { font-size: 2.4vw; }*/
  #footer .f_contact a { font-size: 3vw; }
  #footer .f_contact button { font-size: 3vw; }
  #footer .f_contact a.button { padding: 6.9% 5% 6.9% 38%; }
  #footer .f_contact .cnt:nth-child(3) a.button { padding-left:5px;}
  #footer .f_contact .cnt { max-height: 50px !important;}
  #footer .f_nav ul { display: block; }
  #footer .f_nav ul .hsub { border-bottom: 2px solid #fff; }
  #footer .f_nav ul .hsub a,#footer .f_nav ul .hsub div { position: relative;font-weight: 500;font-family: "M PLUS 1p"; }
  #footer .f_nav ul .hsub.open span:before { -webkit-transform: rotate(-180deg); -ms-transform: rotate(-180deg); transform: rotate(-180deg); }
  #footer .f_nav ul .hsub.open span:after { -webkit-transform: rotate(-270deg); -ms-transform: rotate(-270deg); transform: rotate(-270deg); visibility: hidden; }
  #footer .f_nav ul .hsub span { display: block; }
  #footer .f_nav ul .hsub span:after { position: absolute; content: ''; display: block; top: 50%; background-color: #fff; transition: All 0.3s ease; -webkit-transition: All 0.3s ease; -moz-transition: All 0.3s ease; -o-transition: All 0.3s ease; }
  #footer .f_nav ul .hsub span:before { position: absolute; content: ''; display: block; top: 50%; background-color: #fff; transition: All 0.3s ease; -webkit-transition: All 0.3s ease; -moz-transition: All 0.3s ease; -o-transition: All 0.3s ease; right: 12px; width: 20px; height: 3px; margin-top: -1px; }
  #footer .f_nav ul .hsub span:after { right: 20px; width: 3px; height: 20px; margin-top: -9px; }
  #footer .f_nav ul .hsub:first-child { border-top: 2px solid #fff; }
  #footer .f_nav ul .hsub:last-child { border-bottom: none; }
  #footer .f_nav ul .hsub a, #footer .f_nav ul .hsub>div { text-align: left; font-size: 4vw;color: #fff; margin-bottom: 0; padding: 5% 0; }
  #footer .f_nav ul .hsub ul { display: none; }
  #footer .f_nav ul .hsub li { border-bottom: 1px dashed #fff; }
  #footer .f_nav ul .hsub li:first-child { border-top: 1px dashed #fff; }
  #footer .f_nav ul .hsub li:last-child { border-bottom: none; }
  #footer .btns_link { width: 55%; padding: 0; margin: 0 auto 10% auto; }
  #footer:before { width: 12vw; height: 16vw; top: -15.5vw; background-size: 100% auto; background-repeat: no-repeat; }
  #footer .f_logo { width: 60%; margin: 0 auto 7% auto; } }

/* ========== end △ */
@-webkit-keyframes toTopFromBottom { 49% { -webkit-transform: translateY(-100%); }
  50% { opacity: 0;
    -webkit-transform: translateY(100%); }
  51% { opacity: 1; } }

@-moz-keyframes toTopFromBottom { 49% { -moz-transform: translateY(-100%); }
  50% { opacity: 0;
    -moz-transform: translateY(100%); }
  51% { opacity: 1; } }

@keyframes toTopFromBottom { 49% { -webkit-transform: translateY(-100%); transform: translateY(-100%); }
  50% { opacity: 0;
    -webkit-transform: translateY(100%);
    transform: translateY(100%); }
  51% { opacity: 1; } }

#main .tit01 { color: #ffb64c; font-size: 28px; font-family: "M PLUS 1p"; text-align: center; margin-bottom: 50px; }

#main .tit01 span { display: block; font-family: "DFSoGei"; font-size: 96px; color: #fff; font-weight: 500; -ms-transform: scale(0.7, 1); transform: scale(0.7, 1); -webkit-transform: scale(0.7, 1); -o-transform: scale(0.7, 1); -moz-transform: scale(0.7, 1); letter-spacing: -10px; padding-bottom: 10px; }

#main .tit02 { color: #158530; font-size: 28px; font-family: "M PLUS 1p"; text-align: center; margin-bottom: 50px; }

#main .tit02 span { display: block; font-family: "DFSoGei"; font-size: 72px; margin-bottom: 20px; font-weight: 500; -ms-transform: scale(0.65, 1); transform: scale(0.65, 1); -webkit-transform: scale(0.65, 1); -o-transform: scale(0.65, 1); -moz-transform: scale(0.65, 1); }

#main .col_2 .tit02 { font-size: 16px; }

#main .col_2 .tit02 span { font-size: 64px; }

#main .col_2 .btn.green { max-width: 240px; }

#main .col_2 .btn.green a { font-size: 16px; padding: 11px; }

#main .col_2 .btn.green a:after { border-left: 9px solid #158530 !important; border-bottom: 6px solid transparent !important; border-top: 6px solid transparent !important; }

#main .btn { max-width: 480px; text-align: center; margin: 0 auto; overflow: hidden; position: relative; border: 4px solid #fff; background-color: transparent; }

#main .btn.green { border: 4px solid #158530; }

#main .btn.green a { color: #158530; }

#main .btn.green a:after { border-left-color: #158530 !important; }

#main .btn a { padding: 20px 0; margin: 0 auto; display: block; text-decoration: none; color: #fff; font-family: "M PLUS 1p"; font-size: 28px; text-align: center; font-weight: 600; position: relative; }

#main .btn.current a {
	color: #333; background-color: #fff;
}

#main .btn a:after { content: ""; -ms-transform: translate(0, -50%); transform: translate(0, -50%); -webkit-transform: translate(0, -50%); -moz-transform: translate(0, -50%); -o-transform: translate(0, -50%); width: 0px; height: 0px; top: 50%; border-bottom: 13px solid transparent ; border-top: 13px solid transparent; border-left: 20px solid #fff; position: absolute; right: 15px; font-weight: 600; }

/* ▽ PC-TAB layout ========== */
@media print, screen and (min-width: 768px) { #main .btn:before { content: ""; background-color: #fff; left: 50%; right: 50%; position: absolute; top: 0; height: 100%; bottom: 0; -webkit-transition: .3s; -o-transition: .3s; transition: .3s; }
  #main .btn:hover:before { left: 0; right: 0; }
  #main .btn:hover a { color: #333; }
  #main .btn:hover a:after { border-left-color: #333; }
  #main .btn.green:before { content: ""; background-color: #158530; }
  #main .btn.green:hover a { color: #fff; }
  #main .btn.green:hover a:after { border-left-color: #fff !important; } }

/* ========== end △ */
/* ▽ SP layout ========== */
@media only screen and (max-width: 767px) { #main, #main p{ font-size: 16px; }
  #main .tit01 { font-size: 4vw; }
  #main .tit01 span { font-size: 12vw; }
  #main .tit02 { font-size: 4vw !important; margin-bottom: 5.5vw; }
  #main .tit02 span { font-size: 9vw !important; }
  #main .btn { max-width: 70% !important; }
  #main .btn a { padding: 6% 0 !important; font-size: 16px !important; }
  #main .btn a:after { border-bottom: 1.7vw solid transparent !important; border-top: 1.7vw solid transparent !important; border-left: 2.5vw solid #fff !important; }
  #main .btn.green.tt4 a { background-color: #158530; color: #fff; }
  #main .btn.green.tt4 a:after { border-left-color: #fff !important; }
  }

/* ========== end △ */
.tel_link { cursor: default; text-decoration: none !important; color: #231815 !important; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 767px) { .tel_link { cursor: pointer; text-decoration: underline !important; } }

/* ========== end △ */
.banner_contact { background: url("../images/bg_contact_02.webp"); background-repeat: no-repeat; background-position: center top; font-family: "M PLUS 1p"; font-weight: 500; position: relative; background-size: cover; padding: 30px 100px; margin-top: 40px; }

.banner_contact:before { content: ''; position: absolute; bottom: 0; right: 17%; background: url("../images/bg_contact_01.webp"); width: 301px; height: 301px; background-size: 100% auto; background-position: center bottom; z-index: 0; }

.banner_contact .banner_contact_inner { width: 70%; max-width: 485px; color: #fff; font-size: 114%; font-family: "M PLUS 1p"; font-weight: 700; }

.banner_contact .banner_contact_inner h2 { font-size: 32px; margin-bottom: 15px; }

.banner_contact .banner_contact_inner p { margin-bottom: 15px; }

.banner_contact .banner_contact_inner p:last-child { margin-bottom: 0; }

.banner_contact .banner_contact_inner a { display: block; margin-bottom: 15px; background: url("../common_img/phone_y.webp"); background-repeat: no-repeat; background-size: 9% auto; padding-left: 13%; }

.banner_contact .banner_contact_inner a img { width: 87%; }

/* ▽ TAB-SP layout ========== */
@media only screen and (max-width: 1023px) { .banner_contact { padding: 30px 50px; }
  .banner_contact:before { right: 5%; } }

/* ========== end △ */
/* ▽ SP layout ========== */
@media only screen and (max-width: 767px) { .banner_contact { background-size: auto 100%; padding: 3%; }
.f_contact .site_wrap p.sp{
  font-size: 3vw !important;
}
  .banner_contact:before { width: 36vw; height: 36vw; }
  .banner_contact .banner_contact_inner h2 { font-size: 19px; margin-bottom: 2%; }
  .banner_contact .banner_contact_inner a { background-size: 8% auto; }
  .banner_contact .banner_contact_inner a img { width: 80%; }
  .banner_contact .banner_contact_inner p { margin-bottom: 4%; font-size: 2.7vw; } }

/* ========== end △ */
/*====================================================================================

■01.CLEAR FLOAT

====================================================================================*/
.clearfix:after { clear: both; display: block; content: " "; height: 0px; visibility: hidden; }

/* Hide these rules from IE-mac \*/
* html .clearfix { height: 1%; }

.clearfix { display: block; }

.w1per { width: 1% !important; }

.w2per { width: 2% !important; }

.w3per { width: 3% !important; }

.w4per { width: 4% !important; }

.w5per { width: 5% !important; }

.w6per { width: 6% !important; }

.w7per { width: 7% !important; }

.w8per { width: 8% !important; }

.w9per { width: 9% !important; }

.w10per { width: 10% !important; }

.w11per { width: 11% !important; }

.w12per { width: 12% !important; }

.w13per { width: 13% !important; }

.w14per { width: 14% !important; }

.w15per { width: 15% !important; }

.w16per { width: 16% !important; }

.w17per { width: 17% !important; }

.w18per { width: 18% !important; }

.w19per { width: 19% !important; }

.w20per { width: 20% !important; }

.w21per { width: 21% !important; }

.w22per { width: 22% !important; }

.w23per { width: 23% !important; }

.w24per { width: 24% !important; }

.w25per { width: 25% !important; }

.w26per { width: 26% !important; }

.w27per { width: 27% !important; }

.w28per { width: 28% !important; }

.w29per { width: 29% !important; }

.w30per { width: 30% !important; }

.w31per { width: 31% !important; }

.w32per { width: 32% !important; }

.w33per { width: 33% !important; }

.w34per { width: 34% !important; }

.w35per { width: 35% !important; }

.w36per { width: 36% !important; }

.w37per { width: 37% !important; }

.w38per { width: 38% !important; }

.w39per { width: 39% !important; }

.w40per { width: 40% !important; }

.w41per { width: 41% !important; }

.w42per { width: 42% !important; }

.w43per { width: 43% !important; }

.w44per { width: 44% !important; }

.w45per { width: 45% !important; }

.w46per { width: 46% !important; }

.w47per { width: 47% !important; }

.w48per { width: 48% !important; }

.w49per { width: 49% !important; }

.w50per { width: 50% !important; }

.w51per { width: 51% !important; }

.w52per { width: 52% !important; }

.w53per { width: 53% !important; }

.w54per { width: 54% !important; }

.w55per { width: 55% !important; }

.w56per { width: 56% !important; }

.w57per { width: 57% !important; }

.w58per { width: 58% !important; }

.w59per { width: 59% !important; }

.w60per { width: 60% !important; }

.w61per { width: 61% !important; }

.w62per { width: 62% !important; }

.w63per { width: 63% !important; }

.w64per { width: 64% !important; }

.w65per { width: 65% !important; }

.w66per { width: 66% !important; }

.w67per { width: 67% !important; }

.w68per { width: 68% !important; }

.w69per { width: 69% !important; }

.w70per { width: 70% !important; }

.w73per { width: 73% !important; }

.w80per { width: 80% !important; }

.w81per { width: 81% !important; }

.w82per { width: 82% !important; }

.w83per { width: 83% !important; }

.w85per { width: 85% !important; }

.w90per { width: 90% !important; }

.w92per { width: 92% !important; }

.w99per { width: 99% !important; }

.w100per { width: 100% !important; }
/*
.fix_link { padding-top: 180px; margin-top: -180px; }
#pp { padding-top: 180px; margin-top: -180px; }
.pp_content { padding-top: 80px;}
*/

/*■02.FLEX*/
.flex { display: -webkit-box; display: -ms-flexbox; display: flex; display: -webkit-flex; /* Safari */ display: -moz-flex; /* Firefox */ display: -ms-flex; /* IE */ }

/*justify-content*/
.flex_jus_start { -webkit-box-pack: start; -ms-flex-pack: start; justify-content: flex-start; -webkit-justify-content: flex-start; -moz-justify-content: flex-start; -ms-justify-content: flex-start; }

.flex_jus_end { -webkit-box-pack: end; -ms-flex-pack: end; justify-content: flex-end; -webkit-justify-content: flex-end; -moz-justify-content: flex-end; -ms-justify-content: flex-end; }

.flex_jus_center { -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-justify-content: center; -moz-justify-content: center; -ms-justify-content: center; }

.flex_jus_between { -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -webkit-justify-content: space-between; -moz-justify-content: space-between; -ms-justify-content: space-between; }

.flex_jus_around { -ms-flex-pack: distribute; justify-content: space-around; -webkit-justify-content: space-around; -moz-justify-content: space-around; -ms-justify-content: space-around; }

.flex_jus_ini { -webkit-box-pack: initial; -ms-flex-pack: initial; justify-content: initial; -webkit-justify-content: initial; -moz-justify-content: initial; -ms-justify-content: initial; }

/*align-items*/
.flex_align_item_start { -webkit-box-align: start; -ms-flex-align: start; align-items: flex-start; -webkit-align-items: flex-start; -moz-align-items: flex-start; -ms-align-items: flex-start; }

.flex_align_item_end { -webkit-box-align: end; -ms-flex-align: end; align-items: flex-end; -webkit-align-items: flex-end; -moz-align-items: flex-end; -ms-align-items: flex-end; }

.flex_align_item_stretch { -webkit-box-align: stretch; -ms-flex-align: stretch; align-items: stretch; -webkit-align-items: stretch; -moz-align-items: stretch; -ms-align-items: stretch; }

.flex_align_item_baseline { -webkit-box-align: baseline; -ms-flex-align: baseline; align-items: baseline; -webkit-align-items: baseline; -moz-align-items: baseline; -ms-align-items: baseline; }

.flex_align_item_center { -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-align-items: center; -moz-align-items: center; -ms-align-items: center; }

.flex_align_item_ini { -webkit-box-align: initial; -ms-flex-align: initial; align-items: initial; -webkit-align-items: initial; -moz-align-items: initial; -ms-align-items: initial; }

.flex_container { -webkit-flex-wrap: wrap; -moz-flex-wrap: wrap; -ms-flex-wrap: wrap; flex-wrap: wrap; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { #h_menu_n { padding: 3.62319% 0; } .hidden_639{display: none;} }

/* ========== end △ */
#h_menu_n .wrap_nav { width: 1170px; margin: auto; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-align: end; -ms-flex-align: end; align-items: flex-end; position: relative; }

@media only screen and (max-width: 1170px) { #h_menu_n .wrap_nav { width: 98%; } }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { #h_menu_n .wrap_nav { width: 95.41063%; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; } }

/* ========== end △ */
#h_menu_n .wrap_nav ul { width: 918px; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; position: absolute;
height: 100%;left: 182px;bottom:0px; }

@media only screen and (max-width: 1170px) { #h_menu_n .wrap_nav ul { width: calc(100% - 252px); } }
#h_menu_n .wrap_nav ul figure img{ height:auto;}
/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { 
  #h_menu_n .wrap_nav ul { display: none; }
}

/* ========== end △ */
#h_menu_n .wrap_nav ul li { width: 10%; }

#h_menu_n .wrap_nav ul li a { display: block; font-family: "M PLUS 1p", sans-serif; padding: 15px 5px; text-decoration: none; color: #231815; font-weight: 600; font-size: 1.1rem; text-align: center; -webkit-transition: all 0.3s; -o-transition: all 0.3s; transition: all 0.3s; }

#h_menu_n .wrap_nav ul li a figure img { display: block; height: 39px; margin: auto; }

#h_menu_n .wrap_nav ul li a:hover { background-color: #ffb64c; }

#h_menu_n .wrap_nav ul li .sub_menu { display: none; }

#h_menu_n .wrap_nav #h_logo { width: 182px; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { #h_menu_n .wrap_nav #h_logo { width: 45.6962%; } }

/* ========== end △ */
#h_menu_n .wrap_nav #btn_mn { width: 70px; height: 70px; position: relative; -ms-flex-item-align: end; align-self: flex-end; border: 2px solid #ffb64c; -webkit-box-sizing: border-box; box-sizing: border-box; font-weight: 650; font-size: 14px; color: #ffb64c; text-align: center; padding-top: 43px; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { #h_menu_n .wrap_nav #btn_mn { width: 45px; height: 45px; position: absolute; right: 0; top: 50%;
  transform: translateY(-50%); -webkit-transform:translateY(-50%);-moz-transform: translateY(-50%);-ms-transform:translateY(-50%);-o-transform: translateY(-50%);padding-top: 28px; } }

/* ========== end △ */
#h_menu_n .wrap_nav #btn_mn:hover { cursor: pointer; }

#h_menu_n .wrap_nav #btn_mn span { width: 35px; height: 3px; background-color: #ffb64c; display: block; position: absolute; top: 13px; left: 50%; -webkit-transform: translateX(-50%); -ms-transform: translateX(-50%); transform: translateX(-50%); }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { #h_menu_n .wrap_nav #btn_mn span { top: 9px; width: 23px; height: 2px; } }

/* ========== end △ */
#h_menu_n .wrap_nav #btn_mn span:nth-child(2) { top: 24px; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { #h_menu_n .wrap_nav #btn_mn span:nth-child(2) { top: 16px; } }

/* ========== end △ */
#h_menu_n .wrap_nav #btn_mn span:nth-child(3) { top: 35px; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { #h_menu_n .wrap_nav #btn_mn span:nth-child(3) { top: 23px; } }

/* ========== end △ */
/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { #h_menu_n .wrap_nav #btn_mn p { font-size: 9px; } }

/* ========== end △ */
.full_menu { padding: 15px 0 0; position: fixed; top: 0; left: 0; bottom: 0; right: 0; background-color: #fff; z-index: 999; display: none; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { .full_menu { padding-top: 0; top: 9%; } }

@media only screen and (max-width: 639px) and (max-width: 374px) and (min-width: 320px) { .full_menu { top: 6%; } }

/* ========== end △ */
.full_menu #btn_cls { width: 70px; height: 70px; position: relative; -ms-flex-item-align: end; align-self: flex-end; border: 2px solid #ffb64c; -webkit-box-sizing: border-box; box-sizing: border-box; font-weight: 650; font-size: 14px; color: #ffb64c; text-align: center; padding-top: 43px; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) {
   .full_menu #btn_cls { display: none; }
   .logo_pc{
     display: none;
   }
   img.logo_sp {
     height:auto;
   }
}
@media only screen and (min-width: 640px) {
  .logo_sp{
    display: none;
  }
  img.logo_sp {
    width:205px;
    height:33px;
  }
}

/* ========== end △ */
.full_menu #btn_cls:hover { cursor: pointer; }

.full_menu #btn_cls span { width: 40px; height: 3px; background-color: #ffb64c; display: block; position: absolute; top: 22px; left: 50%; -webkit-transform: translateX(-50%) rotate(45deg); -ms-transform: translateX(-50%) rotate(45deg); transform: translateX(-50%) rotate(45deg); }

.full_menu #btn_cls span:nth-child(2) { -webkit-transform: translateX(-50%) rotate(-45deg); -ms-transform: translateX(-50%) rotate(-45deg); transform: translateX(-50%) rotate(-45deg); }

.full_menu .wrap_bt { width: 1170px; margin: auto; text-align: center; }

@media only screen and (max-width: 1170px) { .full_menu .wrap_bt { width: 98%; } }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { .full_menu .wrap_bt { width: 95.41063%; } }

/* ========== end △ */
.full_menu .wrap_bt #btn_cls { float: right; }

.full_menu .site_wrap { display: -webkit-box; display: -ms-flexbox; display: flex; width: 1170px; padding: 50px 0px 0 0; }


@media only screen and (max-width: 1170px) { .full_menu .site_wrap { width: 100%; padding: 0 20px; } }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { .full_menu .site_wrap { width: 95.41063%; margin: auto; padding: 0; display: block;max-height: 90%; overflow-y: auto; } }

/* ========== end △ */
/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { .full_menu .site_wrap > li { border-bottom: 1px solid #231815; }
  .full_menu .site_wrap > li:last-child { border-bottom: 0; } }

/* ========== end △ */
.full_menu .site_wrap li a,.full_menu .site_wrap li div  { display: inline-block; font-family: "M PLUS 1p", sans-serif; padding: 10px 5px; text-decoration: none; color: #231815; font-weight: 600; font-size: 1.3rem; text-align: center; -webkit-transition: all 0.3s; -o-transition: all 0.3s; transition: all 0.3s; font-size: 18px; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { .full_menu .site_wrap li a, .full_menu .site_wrap li div { font-size: 16px; padding: 4.55696% 0; display: block; text-align: left; } }

/* ========== end △ */
.full_menu .site_wrap li a figure,.full_menu .site_wrap li div figure { display: inline-block; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { 
  .full_menu .site_wrap li a figure, .full_menu .site_wrap li div figure { display: none; }
  .full_menu .site_wrap li div figure img{ height: auto; }
}

/* ========== end △ */
.full_menu .site_wrap li a figure img, .full_menu .site_wrap li div figure img { display: inline-block; height: 39px; margin: auto; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { .full_menu .site_wrap li a br { display: none; } }

/* ========== end △ */
.full_menu .site_wrap li a:hover { background-color: #ffb64c; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { .full_menu .site_wrap li a:hover { background-color: transparent; } }

/* ========== end △ */
/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { .full_menu .site_wrap li .sub_menu { border-top: 1px solid #231815; display: none; } }

/* ========== end △ */
.full_menu .site_wrap li .sub_menu li a { font-size: 12px; display: block; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) {
  .full_menu .site_wrap li .sub_menu li a { font-size: 16px; padding: 2.02532% 0 2.02532% 10px; }
  .full_menu .site_wrap li .sub_menu li a:before{content: "";}
}

/* ========== end △ */
.full_menu .site_wrap li .sub_menu li a:before { width: 6px; height: 6px; display: inline-block; background-color: #000; vertical-align: 2px; margin-right: 10px; }

/* ▽ SP layout ========== */
/* ========== end △ */
.full_menu > .site_wrap > li { width: calc(1170px / 7);text-align: center; }

/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { .full_menu > .site_wrap > li { width: 100%; } }

/* ========== end △ */
/* ▽ SP layout ========== */
@media only screen and (max-width: 639px) { .full_menu > .site_wrap > li > a, .full_menu .site_wrap li div { position: relative; }
  .full_menu .site_wrap li div::after { content: ""; width: 2px; height: 16px; background-color: #231815; position: absolute; display: block; right: 17px; top: 50%; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%);-webkit-transition: all 0.3s; -o-transition: all 0.3s; transition: all 0.3s; }
  .full_menu .site_wrap li div::before { content: ""; width: 16px; height: 2px; background-color: #231815; position: absolute; display: block; right: 10px; top: 50%; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); -webkit-transition: all 0.3s; -o-transition: all 0.3s; transition: all 0.3s; } }

/* ========== end △ */
.full_menu > .site_wrap > li.open div:after { -webkit-transform: translateY(-50%) rotate(90deg); -ms-transform: translateY(-50%) rotate(90deg); transform: translateY(-50%) rotate(90deg); }

@media only screen and (min-width: 768px){
  .hidden_pc{
      display: none!important;
  }
}
@media print
{
  .hidden_pc{
    display: none!important;
  }
}
@media only screen and (max-width: 767px){
  .hidden_sp{
      display: none !important;
  }

}
.last_logo{
    padding-bottom: 8%;
    width:60px;
}
.last_logo img{
    box-shadow: 10px 15px 15px #00000024;
    -webkit-box-shadow: 10px 15px 15px #00000024;
    -ms-box-shadow: 10px 15px 15px #00000024;
    width:60px;
    position: relative;
    top: -145px;
}
@media only screen and (max-width: 767px){
  .last_logo img{
      width:60px;
      position: relative;
      top: 0;
  }
  .last_logo{
      width:100%;
  }
}
.secTopics .btn.green a:after{
	border-bottom: 6px solid transparent !important;
	border-top: 6px solid transparent !important;
	border-left: 9px solid #fff !important;
}

/* placeholder */
::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: #231815;
  opacity: 1; /* Firefox */
}

:-ms-input-placeholder { /* Internet Explorer 10-11 */
  color: #231815;
}

::-ms-input-placeholder { /* Microsoft Edge */
  color: #231815;
}

#h_menu_n .wrap_nav ul {
    width:1000px;
    left:166px;
}

#recruit-btn {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 250px;
    margin:0 auto;
    padding-right: 2em;
    border: none;
    border-radius: 5px;
    background-color: #30d025;
    color: #fff;
    font-weight: 600;
    font-size: 1em;
}

#recruit-btn::after {
    transform: rotate(45deg);
    width: 5px;
    height: 5px;
    margin-left: -10px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    content: '';
}

#recruit-btn:hover {
    background-color: #20c015;
}
#recruit-btn a{
    text-decoration: none;
    color:#fff;
    display:block;
    padding: .9em 1em .9em 2em;
    width:100%;
    height:100%;
}
