@charset "UTF-8";
#page_header .catch {
  
}
#company_archive_bottom .top_catch {
    font-size: 28px
}
#company_list .title .main_title {
    font-size: 24px
}
#company_list .catch {
    font-size: 18px
}
#company_list .image:after {
    content: '';
    display: block;
    width: 50%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    background: -moz-linear-gradient(left,rgba(1,33,65,.5) 0,rgba(1,33,65,0) 100%);
    background: -webkit-linear-gradient(left,rgba(1,33,65,.5) 0,rgba(1,33,65,0) 100%);
    background: linear-gradient(to right,rgba(1,33,65,.5) 0,rgba(1,33,65,0) 100%)
}

@media screen and (max-width:750px) {
    #page_header .catch {
        font-size: px
    }
    #company_archive_bottom .top_catch {
        font-size: 18px
    }
    #company_list .title .main_title {
        font-size: 18px
    }
    #company_list .catch {
        font-size: 16px
    }
}

#page_header .overlay {
    background-color: rgba(0, 76, 99, .4)
}
#site_wrap {
    display: none
}
#site_loader_overlay {
    background: #00729f;
    opacity: 1;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    width: 100%;
    height: 100vh;
    z-index: 99999
}
#site_loader_overlay.slide_up {
	top: -100vh;
	opacity: 0;
	-webkit-transition: transition:top .7s cubic-bezier(.83, 0, .17, 1) .4s, opacity 0s cubic-bezier(.83, 0, .17, 1) 1.5s;
	transition: top .7s cubic-bezier(.83, 0, .17, 1) .4s, opacity 0s cubic-bezier(.83, 0, .17, 1) 1.5s
}
#site_loader_overlay.slide_down {
	top: 100vh;
	opacity: 0;
	-webkit-transition: transition:top .7s cubic-bezier(.83, 0, .17, 1) .4s, opacity 0s cubic-bezier(.83, 0, .17, 1) 1.5s;
	transition: top .7s cubic-bezier(.83, 0, .17, 1) .4s, opacity 0s cubic-bezier(.83, 0, .17, 1) 1.5s
}
#site_loader_overlay.slide_left {
	left: -100%;
	opactiy: 0;
	-webkit-transition: transition:left .7s cubic-bezier(.83, 0, .17, 1) .4s, opacity 0s cubic-bezier(.83, 0, .17, 1) 1.5s;
	transition: left .7s cubic-bezier(.83, 0, .17, 1) .4s, opacity 0s cubic-bezier(.83, 0, .17, 1) 1.5s
}
#site_loader_overlay.slide_right {
	left: 100%;
	opactiy: 0;
	-webkit-transition: transition:left .7s cubic-bezier(.83, 0, .17, 1) .4s, opacity 0s cubic-bezier(.83, 0, .17, 1) 1.5s;
	transition: left .7s cubic-bezier(.83, 0, .17, 1) .4s, opacity 0s cubic-bezier(.83, 0, .17, 1) 1.5s
}
#site_loader_logo {
    position: relative;
    width: 100%;
    height: 100%
}
#site_loader_logo_inner {
    position: absolute;
    text-align: center;
    width: 100%;
    top: 50%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}
#site_loader_overlay.active #site_loader_logo_inner {
    opacity: 0;
    -webkit-transition: all 1s cubic-bezier(0.22,1,0.36,1) 0;
    transition: all 1s cubic-bezier(0.22,1,0.36,1) 0
}
#site_loader_logo img.mobile {
    display: none
}
#site_loader_logo .catch {
    line-height: 1.6;
    padding: 0 50px;
    width: 100%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}
#site_loader_logo_inner .message {
    text-align: left;
    margin: 30px auto 0;
    display: table
}
#site_loader_logo.no_logo .message {
    margin-top: 0 !important
}
#site_loader_logo_inner .message.type2 {
    text-align: center
}
#site_loader_logo_inner .message.type3 {
    text-align: right
}
#site_loader_logo_inner .message_inner {
    display: inline;
    line-height: 1.5;
    margin: 0
}
@media screen and (max-width:750px) {
    #site_loader_logo.has_mobile_logo img.pc {
        display: none
    }
    #site_loader_logo.has_mobile_logo img.mobile {
        display: inline
    }
    #site_loader_logo .message {
        margin: 23px auto 0
    }
    #site_loader_logo .catch {
        padding: 0 20px
    }
}
#site_loader_logo .logo_image {
    opacity: 0
}
#site_loader_logo.use_normal_animation .catch {
    opacity: 0
}
#site_loader_logo.use_text_animation .catch span {
    opacity: 0;
    position: relative
}
#site_loader_logo .message {
    opacity: 0
}
#site_loader_logo.active .logo_image {
    -webkit-animation: opacityAnimation 1.4s ease forwards 0.5s;
    animation: opacityAnimation 1.4s ease forwards 0.5s
}
#site_loader_logo img.use_logo_animation {
    position: relative;
    -webkit-animation: slideUpDown 1.5s ease-in-out infinite 0;
    animation: slideUpDown 1.5s ease-in-out infinite 0
}
#site_loader_logo.use_normal_animation.active .catch {
    -webkit-animation: opacityAnimation 1.4s ease forwards 0.5s;
    animation: opacityAnimation 1.4s ease forwards 0.5s
}
#site_loader_logo.use_text_animation .catch span.animate {
    -webkit-animation: text_animation 0.5s ease forwards 0;
    animation: text_animation 0.5s ease forwards 0
}
#site_loader_logo.use_normal_animation.active .message {
    -webkit-animation: opacityAnimation 1.4s ease forwards 1.5s;
    animation: opacityAnimation 1.4s ease forwards 1.5s
}
#site_loader_logo.use_text_animation.active .message {
    -webkit-animation: opacityAnimation 1.4s ease forwards 2s;
    animation: opacityAnimation 1.4s ease forwards 2s
}
#site_loader_logo_inner .text {
    display: inline
}
#site_loader_logo_inner .dot_animation_wrap {
    display: inline;
    margin: 0 0 0 4px;
    position: absolute
}
#site_loader_logo_inner .dot_animation {
    display: inline
}
#site_loader_logo_inner i {
    width: 2px;
    height: 2px;
    margin: 0 4px 0 0;
    border-radius: 100%;
    display: inline-block;
    background: #000;
    -webkit-animation: loading-dots-middle-dots 0.5s linear infinite;
    -ms-animation: loading-dots-middle-dots 0.5s linear infinite;
    animation: loading-dots-middle-dots 0.5s linear infinite
}
#site_loader_logo_inner i:first-child {
    opacity: 0;
    -webkit-animation: loading-dots-first-dot 0.5s infinite;
    -ms-animation: loading-dots-first-dot 0.5s linear infinite;
    animation: loading-dots-first-dot 0.5s linear infinite;
    -webkit-transform: translate(-4px);
    -ms-transform: translate(-4px);
    transform: translate(-4px)
}
#site_loader_logo_inner i:last-child {
    -webkit-animation: loading-dots-last-dot 0.5s linear infinite;
    -ms-animation: loading-dots-last-dot 0.5s linear infinite;
    animation: loading-dots-last-dot 0.5s linear infinite
}
@-webkit-keyframes loading-dots-fadein {
    100% {
        opacity: 1
    }
}
@keyframes loading-dots-fadein {
    100% {
        opacity: 1
    }
}
@-webkit-keyframes loading-dots-first-dot {
    100% {
        -webkit-transform: translate(6px);
        -ms-transform: translate(6px);
        transform: translate(6px);
        opacity: 1
    }
}
@keyframes loading-dots-first-dot {
    100% {
        -webkit-transform: translate(6px);
        -ms-transform: translate(6px);
        transform: translate(6px);
        opacity: 1
    }
}
@-webkit-keyframes loading-dots-middle-dots {
    100% {
        -webkit-transform: translate(6px);
        -ms-transform: translate(6px);
        transform: translate(6px)
    }
}
@keyframes loading-dots-middle-dots {
    100% {
        -webkit-transform: translate(6px);
        -ms-transform: translate(6px);
        transform: translate(6px)
    }
}
@-webkit-keyframes loading-dots-last-dot {
    100% {
        -webkit-transform: translate(6px);
        -ms-transform: translate(6px);
        transform: translate(6px);
        opacity: 0
    }
}
@keyframes loading-dots-last-dot {
    100% {
        -webkit-transform: translate(6px);
        -ms-transform: translate(6px);
        transform: translate(6px);
        opacity: 0
    }
}
#site_loader_overlay.active #site_loader_animation {
    opacity: 0;
    -webkit-transition: all 1s cubic-bezier(0.22,1,0.36,1) 0;
    transition: all 1s cubic-bezier(0.22,1,0.36,1) 0
}
#site_loader_logo_inner .message {
    font-size: 16px;
    color: #fff
}
#site_loader_logo_inner i {
    background: #fff
}
#site_loader_logo_inner .catch {
    font-size: 30px;
    color: #fff
}
@media screen and (max-width:1100px) {
    #site_loader_logo_inner .catch {
        font-size: 26px
    }
}
@media screen and (max-width:750px) {
    #site_loader_logo_inner .message {
        font-size: 14px
    }
    #site_loader_logo_inner .catch {
        font-size: 21px
    }
}
#company_list .item {
    margin-bottom: 2px
}
#post_title2 .title {
    font-size: 26px
}
@media screen and (max-width:750px) {
    #post_title2 .title {
        font-size: 18px
    }
}
#site_wrap {
    display: none
}
#site_loader_overlay {
    background: #00729f;
    opacity: 1;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    width: 100%;
    height: 100vh;
    z-index: 99999
}
#site_loader_overlay.slide_up {
    top: -100vh;
    opacity: 0;
    -webkit-transition: transition: top 0.7s cubic-bezier(0.83,0,0.17,1) 0.4s, opacity 0 cubic-bezier(0.83,0,0.17,1) 1.5s;
    transition: top 0.7s cubic-bezier(0.83,0,0.17,1) 0.4s, opacity 0 cubic-bezier(0.83,0,0.17,1) 1.5s
}
#site_loader_overlay.slide_down {
    top: 100vh;
    opacity: 0;
    -webkit-transition: transition: top 0.7s cubic-bezier(0.83,0,0.17,1) 0.4s, opacity 0 cubic-bezier(0.83,0,0.17,1) 1.5s;
    transition: top 0.7s cubic-bezier(0.83,0,0.17,1) 0.4s, opacity 0 cubic-bezier(0.83,0,0.17,1) 1.5s
}
#site_loader_overlay.slide_left {
    left: -100%;
    opactiy: 0;
    -webkit-transition: transition: left 0.7s cubic-bezier(0.83,0,0.17,1) 0.4s, opacity 0 cubic-bezier(0.83,0,0.17,1) 1.5s;
    transition: left 0.7s cubic-bezier(0.83,0,0.17,1) 0.4s, opacity 0 cubic-bezier(0.83,0,0.17,1) 1.5s
}
#site_loader_overlay.slide_right {
    left: 100%;
    opactiy: 0;
    -webkit-transition: transition: left 0.7s cubic-bezier(0.83,0,0.17,1) 0.4s, opacity 0 cubic-bezier(0.83,0,0.17,1) 1.5s;
    transition: left 0.7s cubic-bezier(0.83,0,0.17,1) 0.4s, opacity 0 cubic-bezier(0.83,0,0.17,1) 1.5s
}
#site_loader_logo {
    position: relative;
    width: 100%;
    height: 100%
}
#site_loader_logo_inner {
    position: absolute;
    text-align: center;
    width: 100%;
    top: 50%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}
#site_loader_overlay.active #site_loader_logo_inner {
    opacity: 0;
    -webkit-transition: all 1s cubic-bezier(0.22,1,0.36,1) 0;
    transition: all 1s cubic-bezier(0.22,1,0.36,1) 0
}
#site_loader_logo img.mobile {
    display: none
}
#site_loader_logo .catch {
    line-height: 1.6;
    padding: 0 50px;
    width: 100%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}
#site_loader_logo_inner .message {
    text-align: left;
    margin: 30px auto 0;
    display: table
}
#site_loader_logo.no_logo .message {
    margin-top: 0 !important
}
#site_loader_logo_inner .message.type2 {
    text-align: center
}
#site_loader_logo_inner .message.type3 {
    text-align: right
}
#site_loader_logo_inner .message_inner {
    display: inline;
    line-height: 1.5;
    margin: 0
}
@media screen and (max-width:750px) {
    #site_loader_logo.has_mobile_logo img.pc {
        display: none
    }
    #site_loader_logo.has_mobile_logo img.mobile {
        display: inline
    }
    #site_loader_logo .message {
        margin: 23px auto 0
    }
    #site_loader_logo .catch {
        padding: 0 20px
    }
}
#site_loader_logo .logo_image {
    opacity: 0
}
#site_loader_logo.use_normal_animation .catch {
    opacity: 0
}
#site_loader_logo.use_text_animation .catch span {
    opacity: 0;
    position: relative
}
#site_loader_logo .message {
    opacity: 0
}
#site_loader_logo.active .logo_image {
    -webkit-animation: opacityAnimation 1.4s ease forwards 0.5s;
    animation: opacityAnimation 1.4s ease forwards 0.5s
}
#site_loader_logo img.use_logo_animation {
    position: relative;
    -webkit-animation: slideUpDown 1.5s ease-in-out infinite 0;
    animation: slideUpDown 1.5s ease-in-out infinite 0
}
#site_loader_logo.use_normal_animation.active .catch {
    -webkit-animation: opacityAnimation 1.4s ease forwards 0.5s;
    animation: opacityAnimation 1.4s ease forwards 0.5s
}
#site_loader_logo.use_text_animation .catch span.animate {
    -webkit-animation: text_animation 0.5s ease forwards 0;
    animation: text_animation 0.5s ease forwards 0
}
#site_loader_logo.use_normal_animation.active .message {
    -webkit-animation: opacityAnimation 1.4s ease forwards 1.5s;
    animation: opacityAnimation 1.4s ease forwards 1.5s
}
#site_loader_logo.use_text_animation.active .message {
    -webkit-animation: opacityAnimation 1.4s ease forwards 2s;
    animation: opacityAnimation 1.4s ease forwards 2s
}
#site_loader_logo_inner .text {
    display: inline
}
#site_loader_logo_inner .dot_animation_wrap {
    display: inline;
    margin: 0 0 0 4px;
    position: absolute
}
#site_loader_logo_inner .dot_animation {
    display: inline
}
#site_loader_logo_inner i {
    width: 2px;
    height: 2px;
    margin: 0 4px 0 0;
    border-radius: 100%;
    display: inline-block;
    background: #000;
    -webkit-animation: loading-dots-middle-dots 0.5s linear infinite;
    -ms-animation: loading-dots-middle-dots 0.5s linear infinite;
    animation: loading-dots-middle-dots 0.5s linear infinite
}
#site_loader_logo_inner i:first-child {
    opacity: 0;
    -webkit-animation: loading-dots-first-dot 0.5s infinite;
    -ms-animation: loading-dots-first-dot 0.5s linear infinite;
    animation: loading-dots-first-dot 0.5s linear infinite;
    -webkit-transform: translate(-4px);
    -ms-transform: translate(-4px);
    transform: translate(-4px)
}
#site_loader_logo_inner i:last-child {
    -webkit-animation: loading-dots-last-dot 0.5s linear infinite;
    -ms-animation: loading-dots-last-dot 0.5s linear infinite;
    animation: loading-dots-last-dot 0.5s linear infinite
}
@-webkit-keyframes loading-dots-fadein {
    100% {
        opacity: 1
    }
}
@keyframes loading-dots-fadein {
    100% {
        opacity: 1
    }
}
@-webkit-keyframes loading-dots-first-dot {
    100% {
        -webkit-transform: translate(6px);
        -ms-transform: translate(6px);
        transform: translate(6px);
        opacity: 1
    }
}
@keyframes loading-dots-first-dot {
    100% {
        -webkit-transform: translate(6px);
        -ms-transform: translate(6px);
        transform: translate(6px);
        opacity: 1
    }
}
@-webkit-keyframes loading-dots-middle-dots {
    100% {
        -webkit-transform: translate(6px);
        -ms-transform: translate(6px);
        transform: translate(6px)
    }
}
@keyframes loading-dots-middle-dots {
    100% {
        -webkit-transform: translate(6px);
        -ms-transform: translate(6px);
        transform: translate(6px)
    }
}
@-webkit-keyframes loading-dots-last-dot {
    100% {
        -webkit-transform: translate(6px);
        -ms-transform: translate(6px);
        transform: translate(6px);
        opacity: 0
    }
}
@keyframes loading-dots-last-dot {
    100% {
        -webkit-transform: translate(6px);
        -ms-transform: translate(6px);
        transform: translate(6px);
        opacity: 0
    }
}
#site_loader_overlay.active #site_loader_animation {
    opacity: 0;
    -webkit-transition: all 1s cubic-bezier(0.22,1,0.36,1) 0;
    transition: all 1s cubic-bezier(0.22,1,0.36,1) 0
}
#site_loader_logo_inner .message {
    font-size: 16px;
    color: #fff
}
#site_loader_logo_inner i {
    background: #fff
}
#site_loader_logo_inner .catch {
    font-size: 30px;
    color: #fff
}
@media screen and (max-width:1100px) {
    #site_loader_logo_inner .catch {
        font-size: 26px
    }
}
@media screen and (max-width:750px) {
    #site_loader_logo_inner .message {
        font-size: 14px
    }
    #site_loader_logo_inner .catch {
        font-size: 21px
    }
}
.sub_content_title {
    width: 1150px;
    margin: auto
}
.sub_content_title h1 {
    margin: 0;
    padding: 0
}
.content_block {
    width: 1150px;
    margin: 0 auto 80px
}
.content_block p {
    line-height: 1.7
}
.content_block h1 {
    position: relative;
    border-bottom: 1px solid #ddd;
    font-weight: 600;
    font-size: 30px;
    color: #3a5800;
    text-align: center;
    padding: 60px 0;
    margin-bottom: 80px;
    line-height: 1.6
}
.content_block h1:before {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 20%;
    height: 4px;
    content: '';
    background: #3a5800
}
.content_block h2 {
    font-weight: 600;
    font-size: 28px;
    text-align: center;
    line-height: 1.8;
    margin-bottom: 60px
}
.content_navi {
    display: flex;
    justify-content: space-between;
    margin: 80px
}
.content_navi li {
    width: 23%;
    border: 1px solid #3a5800;
    display: flex;
    justify-content: center;
    align-items: center;
    line-height: 1.6
}
.content_navi li a {
    color: #3a5800;
    font-weight: 600;
    display: block !important;
    padding: 20px 10px;
    text-align: center
}
.content_navi li a:hover {
    color: #fff;
    background: #3a5800;
    font-weight: 600;
    display: block !important;
    padding: 20px 10px;
    text-align: center;
    width: 100%
}
.content_navi02 {
    display: flex;
    justify-content: space-between;
    margin: 80px
}
.content_navi02 li {
    width: 48.5%;
    border: 1px solid #3a5800
}
.content_navi02 li a {
    color: #3a5800;
    font-weight: 600;
    display: block !important;
    padding: 20px 10px;
    text-align: center
}
.content_navi02 li a:hover {
    color: #fff;
    background: #3a5800;
    font-weight: 600;
    display: block !important;
    padding: 20px 10px;
    text-align: center
}
.content_imgL {
    width: 100%;
    margin-bottom: 60px
}
.content_imgL img {
    width: 100%;
    height: auto
}
.content_980 {
    width: 980px;
    margin: auto
}
.company_lineup {
    border-bottom: 1px solid #ddd;
    padding-bottom: 60px;
    margin-bottom: 60px
}
.company_list_header {
    display: flex;
    justify-content: space-between;
    margin-bottom: 30px
}
.company_list_add {
    width: 70%
}
.company_list_add .logo {
    width: 270px
}
.company_list_add .logo img {
    width: 100%;
    height: auto
}
.company_list_add .name {
    font-size: 22px;
    font-weight: 600;
    color: #3a5800
}
.company_list_add p {
    font-size: 16px;
    line-height: 1.7
}
.company_list_ph {
    width: 25%
}
.company_list_ph img {
    width: 100%;
    height: auto
}
.company_lineup iframe {
    width: 100%;
    height: 350px
}
@media screen and (max-width: 1200px) {
    .sub_content_title {
        width: auto;
        margin: auto 10px
    }
    .sub_content_title h1 {
        margin: 0;
        padding: 0
    }
    .content_block {
        width: auto;
        margin: 0 15px 40px
    }
    .content_block h1 {
        position: relative;
        font-size: 18px;
        padding: 40px 0;
        margin-bottom: 40px
    }
    .content_block h1:before {
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        margin: auto;
        width: 20%;
        height: 4px;
        content: ''
    }
    .content_block h2 {
        font-size: 16px;
        margin-bottom: 30px
    }
    .content_block h3 {
        position: relative;
        padding: 1.5rem;
        font-size: 16px;
        color: #3a5800;
        margin-bottom: 30px
    }
    .content_block h3:before {
        position: absolute;
        bottom: 0;
        left: calc(50% - 20px);
        width: 40px;
        height: 4px;
        content: ''
    }
    .content_navi {
        display: flex;
        justify-content: space-between;
        margin: 0 auto;
        flex-wrap: wrap;
        width: 90%
    }
    .content_navi li {
        width: 48%;
        margin-bottom: 8px
    }
    .content_navi li a {
        color: #3a5800;
        font-weight: 600;
        display: block !important;
        padding: 20px 10px;
        text-align: center;
        font-size: 12px
    }
    .content_navi02 {
        display: flex;
        justify-content: space-between;
        margin: 0 auto;
        width: 90%
    }
    .content_navi02 li {
        width: 48.5%;
        border: 1px solid #3a5800
    }
    .content_navi02 li a {
        color: #3a5800;
        font-weight: 600;
        display: block !important;
        padding: 20px 10px;
        text-align: center;
        font-size: 12px
    }
    .content_navi02 li a:hover {
        color: #fff;
        background: #3a5800;
        font-weight: 600;
        display: block !important;
        padding: 20px 10px;
        text-align: center
    }
    .content_imgL {
        width: 100%;
        margin-bottom: 20px
    }
    .content_imgL img {
        width: 100%;
        height: auto
    }
    .content_980 {
        width: auto;
        margin: auto
    }
    .company_lineup {
        padding-bottom: 30px;
        margin-bottom: 30px
    }
    .company_list_header {
        display: flex;
        justify-content: space-between;
        flex-direction: column-reverse;
        margin-bottom: 15px
    }
    .company_list_add {
        width: auto
    }
    .company_list_add .logo {
        width: 200px;
        margin: auto
    }
    .company_list_add .logo img {
        width: 100%;
        height: auto
    }
    .company_list_add .name {
        font-size: 16px;
        font-weight: 600
    }
    .company_list_add p {
        font-size: 12px;
        line-height: 1.7
    }
    .company_list_ph {
        width: auto;
        margin-bottom: 10px
    }
    .company_list_ph img {
        width: 100%;
        height: auto
    }
    .company_lineup iframe {
        width: 100%;
        height: 250px
    }
}
.group_lineup .logo {
    width: 320px;
    margin: auto auto 5px;
}
.group_lineup .logo img {
    width: 100%;
    height: auto
}
.group_lineup .name {
    font-size: 30px;
    font-weight: 600;
    text-align: center;
    color: #3a5800;
    margin-bottom: 40px
}
.jigyo {
    display: flex;
    justify-content: space-between;
    margin: 0 auto 20px;
    flex-wrap: wrap;
}
.jigyo li {
    width: 30.8%;
    margin-bottom: 8px;
    color: #fff;
    font-weight: 600;
    padding: 20px 10px;
    text-align: center;
    background: #70b42b;
    line-height: 1.7;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 8px
}
.jigyo02 {
    display: flex;
    justify-content: space-between;
    margin: 0 auto 30px;
    flex-wrap: wrap;
}
.jigyo02 li {
    width: 47%;
    margin-bottom: 8px;
    color: #3a5800;
    font-weight: 600;
    padding: 20px 10px;
    text-align: center;
    border: 1px solid #3a5800;
    line-height: 1.7;
    display: flex;
    justify-content: center;
    align-items: center
}
table#table-01 {
    border: 1px #e3e3e3 solid;
    border-collapse: collapse;
    border-spacing: 0;
    margin-bottom: 40px
}
table#table-01 th {
    padding: 20px;
    border: #ddd solid;
    border-width: 0 0 1px 1px;
    background: #f5f5f5;
    line-height: 120%;
    text-align: left;
    width: 15%
}
table#table-01 td {
    padding: 20px;
    border: 1px #ddd solid;
    border-width: 0 0 1px 1px;
    text-align: left;
    line-height: 1.7
}
.button_box {
    display: flex;
    justify-content: space-between;
    width: 810px;
    margin: auto
}
.cta {
    border: 1px solid #ddd
}
.cta h2 {
    font-size: 22px;
    color: #3a5800;
    border-bottom: 1px solid #ddd;
    padding: 30px 0;
    margin: 0
}
.cta h2 span {
    font-size: 18px;
    color: #000
}
.cta_navi {
    display: flex;
    justify-content: space-between;
    padding: 30px
}
.cta_navi li {
    text-align: center;
    width: 50%
}
.cta_navi li:first-child {
    border-right: 1px solid #ddd
}
.cta_navi p {
    font-size: 18px;
    margin-bottom: 10px;
    font-weight: 600
}
.cta_phone {
    font-size: 36px;
    font-weight: 600;
    position: relative
}
.cta_phone:before {
    content: "";
    display: inline-block;
    width: 35px;
    height: 35px;
    background: url("../images/common/phone.png") no-repeat;
    background-position: left 8px;
    background-size: 30px
}
.cta_mail {
    font-size: 24px;
    font-weight: 600;
    position: relative
}
.cta_mail:before {
    content: "";
    display: inline-block;
    width: 35px;
    height: 35px;
    background: url("../images/common/mail.png") no-repeat;
    background-position: left 10px;
    background-size: 30px
}
.group_lineup .linkbutton {
    margin-bottom: 20px
}
@media screen and (max-width: 1200px) {
    .group_lineup {
        padding-bottom: 30px;
        margin-bottom: 0
    }
    .group_lineup .logo {
        width: 200px;
        margin: auto
    }
    .group_lineup .logo img {
        width: 100%;
        height: auto
    }
    .group_lineup .name {
        font-size: 16px;
        font-weight: 600;
        margin-bottom: 20px
    }
    .jigyo {
        display: flex;
        justify-content: space-between;
        margin: 0 auto 10px;
        flex-wrap: wrap;
        flex-direction: column
    }
    .jigyo li {
        width: auto;
        margin-bottom: 5px;
        font-weight: 600;
        padding: 6px 10px;
        text-align: center;
        line-height: 1.7;
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 12px;
        border-radius: 5px
    }
    .jigyo02 {
        display: flex;
        justify-content: space-between;
        margin: 0 auto 15px;
        flex-wrap: wrap;
        flex-direction: column
    }
    .jigyo02 li {
        width: auto;
        margin-bottom: 5px;
        color: #3a5800;
        font-weight: 600;
        padding: 6px 10px;
        text-align: center;
        border: 1px solid #3a5800;
        line-height: 1.7;
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 12px
    }
    table#table-01 {
        border: 1px #e3e3e3 solid;
        border-collapse: collapse;
        border-spacing: 0;
        margin-bottom: 20px;
        font-size: 14px
    }
    table#table-01 th {
        padding: 20px;
        border: #ddd solid;
        border-width: 0 0 1px 1px;
        background: #f5f5f5;
        line-height: 120%;
        text-align: left;
        width: 80px
    }
    table#table-01 td {
        padding: 20px;
        border: 1px #ddd solid;
        border-width: 0 0 1px 1px;
        text-align: left;
        line-height: 1.7
    }
    .button_box {
        display: flex;
        justify-content: space-between;
        flex-direction: column;
        width: auto;
        margin: auto
    }
    .group_lineup .design_button {
        margin-bottom: 6px;
        height: auto;
        line-height: auto
    }
    .group_lineup .design_button a {
        margin-bottom: 6px;
        height: auto;
        line-height: 1.5;
        padding: 15px 10px;
        font-size: 14px
    }
    .cta {
        border: 1px solid #ddd
    }
    .cta h2 {
        font-size: 16px;
        color: #3a5800;
        border-bottom: 1px solid #ddd;
        padding: 15px 0;
        margin: 0;
        line-height: 1.6
    }
    .cta h2 span {
        font-size: 12px;
        color: #000
    }
    .cta_navi {
        display: flex;
        justify-content: space-between;
        flex-direction: column;
        padding: 15px 15px 0
    }
    .cta_navi li {
        text-align: center;
        width: auto;
        margin-bottom: 20px;
        padding-bottom: 20px
    }
    .cta_navi li:first-child {
        border-right: 0 solid #ddd;
        border-bottom: 1px solid #ddd
    }
    .cta_navi li:last-child {
        padding-bottom: 0
    }
    .cta_navi p {
        font-size: 14px;
        margin-bottom: 10px;
        font-weight: 600
    }
    .cta_phone {
        font-size: 24px;
        font-weight: 600;
        position: relative
    }
    .cta_phone:before {
        content: "";
        display: inline-block;
        width: 24px;
        height: 24px;
        background: url("../images/common/phone.png") no-repeat;
        background-position: left 6px;
        background-size: 20px
    }
    .cta_mail {
        font-size: 16px;
        font-weight: 600;
        position: relative
    }
    .cta_mail:before {
        content: "";
        display: inline-block;
        width: 24px;
        height: 24px;
        background: url("../images/common/mail.png") no-repeat;
        background-position: left 9px;
        background-size: 18px
    }
    .innerbg.grouplist {
        padding-bottom: 0 !important
    }
    .svwaku.grouplist {
        padding-bottom: 0 !important
    }
}
#gaiyou {
    background: #f5f5f5;
    border: 1px solid #ddd;
    border-top: 0;
    width: 100%;
    font-size: 16px;
    line-height: 180%;
    margin-bottom: 20px;
    line-height: 1.8
}
dl#gaiyou dl,
dl#gaiyou dt,
dl#gaiyou dd {
    margin: 0;
    padding: 0
}
dl#gaiyou dt {
    border-top: 1px solid #ddd;
    clear: left;
    float: left;
    padding: 20px 40px 20px 20px;
    width: 200px
}
dl#gaiyou dd {
    background: #fff;
    border-left: 1px solid #ddd;
    border-top: 1px solid #ddd;
    margin-left: 240px;
    padding: 20px
}
table#table-02 {
    border: 1px #e3e3e3 solid;
    border-collapse: collapse;
    border-spacing: 0;
    margin-bottom: 40px
}
table#table-02 th {
    padding: 20px;
    border: #ddd solid;
    border-width: 0 0 1px 1px;
    background: #f5f5f5;
    line-height: 120%;
    text-align: center;
    width: 10%
}
table#table-02 td {
    padding: 20px;
    border: 1px #ddd solid;
    border-width: 0 0 1px 1px;
    text-align: left;
    line-height: 1.7
}
table#table-02 th span {
    color: #3a5800
}
@media screen and (max-width: 1200px) {
    #gaiyou {
        background: #f5f5f5;
        border: 1px solid #ddd;
        border-top: 0;
        width: 100%;
        font-size: 14px;
        line-height: 180%;
        margin-bottom: 20px;
        line-height: 1.7
    }
    dl#gaiyou dl,
    dl#gaiyou dt,
    dl#gaiyou dd {
        margin: 0;
        padding: 0
    }
    dl#gaiyou dt,
    dl#gaiyou dd {
        padding: 10px
    }
    dl#gaiyou dt {
        border-top: 1px solid #ddd;
        clear: left;
        float: none;
        width: auto
    }
    dl#gaiyou dd {
        background: #fff;
        border-left: 0 solid #ddd;
        border-top: 1px solid #ddd;
        margin-left: auto
    }
    table#table-02 {
        border: 1px #e3e3e3 solid;
        border-collapse: collapse;
        border-spacing: 0;
        margin-bottom: 40px;
        font-size: 14px
    }
    table#table-02 th {
        padding: 10px;
        border: #ddd solid;
        border-width: 0 0 1px 1px;
        background: #f5f5f5;
        line-height: 120%;
        text-align: center;
        width: 10%
    }
    table#table-02 td {
        padding: 10px;
        border: 1px #ddd solid;
        border-width: 0 0 1px 1px;
        text-align: left;
        line-height: 1.7
    }
    table#table-02 th span {
        color: #3a5800
    }
}
.rinen {
    color: #3a5800;
    font-weight: bold;
    font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
    font-size: 22px;
    text-align: center;
    margin-bottom: 40px
}
.rinenbox {
    display: flex;
    border-bottom: 1px solid #ddd;
    margin-bottom: 20px;
    padding-bottom: 20px
}
.rinenbox .num {
    width: 20px;
    padding: 15px 18px;
    background: #3a5800;
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: bold;
    font-size: 24px
}
.rinentxt {
    margin-left: 10px;
    padding: 10px;
    font-size: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: bold;
    font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", "HiraMinProN-W6", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif
}
.syomei {
    text-align: right;
    margin-top: 40px
}
.syomei .daihyo {
    text-align: right;
    font-size: 20px;
    font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
    font-weight: 600
}
@media screen and (max-width: 1200px) {
    .rinen {
        color: #3a5800;
        font-weight: bold;
        font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
        font-size: 16px;
        text-align: center;
        margin-bottom: 20px;
        line-height: 1.7
    }
    .rinenbox {
        display: flex;
        border-bottom: 1px solid #ddd;
        margin-bottom: 20px;
        padding-bottom: 20px;
        flex-direction: column
    }
    .rinenbox .num {
        width: 20px;
        margin: 0 auto 10px;
        padding: 15px 18px;
        background: #3a5800;
        color: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
        font-weight: bold;
        font-size: 20px
    }
    .rinentxt {
        margin-left: 10px;
        padding: 10px;
        font-size: 16px;
        display: flex;
        justify-content: center;
        align-items: center;
        font-weight: bold;
        font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", "HiraMinProN-W6", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
        line-height: 1.7;
        text-align: center
    }
    .syomei {
        text-align: right;
        margin-top: 40px
    }
    .syomei p {
        font-size: 14px !important
    }
    .syomei .daihyo {
        text-align: right;
        font-size: 16px !important;
        font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
        font-weight: 600
    }
}
.bloglist {
    border-top: 0 solid #ddd;
    padding-top: 40px
}
.bloglist li {
    display: flex;
    justify-content: space-between;
    position: relative;
    border-bottom: 1px solid #ddd;
    margin-bottom: 40px;
    padding-bottom: 40px
}
.bloglist .photo {
    width: 48%
}
.bloglist .photo img {
    width: 100%;
    height: auto;
    object-fit: cover;
    background: url("../images/common/green_st.png");
    padding: 20px;
    border-radius: 10px;
    box-sizing: border-box
}
.bloglist .bloglist_cont {
    width: 48%;
    display: flex;
    justify-content: center;
    flex-direction: column
}
.cate_date {
    display: flex
}
.bloglist .bloglist_cont h3 {
    font-size: 22px;
    font-weight: 600;
    margin: 15px 0;
    padding-bottom: 10px;
    line-height: 1.7;
    border-bottom: 2px solid #70b42b;
    line-height: 1.7;
    text-align: left !important
}
.bloglist .bloglist_cont p {
    line-height: 1.7;
    text-overflow: ellipsis !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
    overflow: hidden !important
}
.cate_date .date {
    color: #404040;
    margin-top: 7px
}
.bloglist a {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden
}
.work_cate01 {
    background: #70b42b
}
@media screen and (max-width: 1200px) {
    .bloglist {
        border-top: 0 solid #ddd;
        padding-top: 10px;
        margin: 0
    }
    .bloglist li {
        display: flex;
        justify-content: space-between;
        position: relative;
        border-bottom: 1px solid #ddd;
        margin-bottom: 20px;
        padding-bottom: 20px;
        flex-direction: column
    }
    .bloglist .photo {
        width: auto;
        margin-bottom: 10px
    }
    .bloglist .photo img {
        width: 100%;
        height: auto;
        object-fit: cover;
        padding: 10px
    }
    .bloglist .bloglist_cont {
        width: auto;
        display: flex;
        justify-content: center;
        flex-direction: column
    }
    .cate_date {
        display: flex
    }
    .bloglist .bloglist_cont h3 {
        font-size: 16px;
        font-weight: 600;
        margin: 10px 0;
        line-height: 1.6
    }
    .bloglist .bloglist_cont p {
        line-height: 1.7;
        text-overflow: ellipsis;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        overflow: hidden
    }
    .cate_date .date {
        color: #404040;
        margin-top: 7px
    }
    .bloglist a {
        position: absolute;
        width: 100%;
        height: 100%;
        top: 0;
        left: 0;
        text-indent: 100%;
        white-space: nowrap;
        overflow: hidden
    }
}
.newslist {
    border-top: 1px solid #ddd;
    padding-top: 40px;
    margin-bottom: 60px
}
.newslist li {
    display: flex;
    border-bottom: 1px solid #ddd;
    margin-bottom: 40px;
    padding-bottom: 40px;
    position: relative
}
.newslist .date {
    margin-right: 20px;
    color: #3a5800
}
.newslist p {
    margin-right: 20px;
    color: #404040;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    overflow: hidden
}
.newslist li a {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden
}
@media screen and (max-width: 1200px) {
    .newslist {
        border-top: 1px solid #ddd;
        padding-top: 20px;
        margin: 0 15px 30px;
    }
    .newslist li {
        display: flex;
        border-bottom: 1px solid #ddd;
        margin-bottom: 20px;
        padding-bottom: 20px;
        position: relative
    }
    .newslist .date {
        margin-right: 10px;
        color: #3a5800
    }
    .newslist p {
        margin-right: 0;
        color: #404040;
        text-overflow: ellipsis;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 1;
        overflow: hidden
    }
    .newslist li a {
        position: absolute;
        width: 100%;
        height: 100%;
        top: 0;
        left: 0;
        text-indent: 100%;
        white-space: nowrap;
        overflow: hidden
    }
}
.faq_list p {
    line-height: 1.7
}
@media screen and (max-width: 1200px) {}
.box_gray {
    padding: 30px 40px;
    background: #f3f3f3;
    margin: 40px 0 0
}
.box_gray h4 {
    font-size: 18px;
    color: #3a5800;
    margin: 0 0 20px;
    padding: 0;
}
.box_gray p {
    font-size: 14px
}
@media screen and (max-width: 1200px) {
    .box_gray {
        padding: 20px;
        background: #f3f3f3;
        margin: 20px 0 0
    }
    .box_gray h4 {
        font-size: 14px;
        color: #3a5800;
        margin: 0 0 10px;
        padding: 0;
        line-height: 1.6
    }
    .box_gray p {
        font-size: 12px
    }
}
.list_sitemap {
    display: block;
    overflow: hidden;
    clear: both;
    margin-bottom: 40px;
    display: flex;
    flex-wrap: wrap
}
.list_sitemap li {
    width: 31.3%;
    margin-right: 1%;
    margin-left: 1%;
    margin-bottom: 15px;
    font-size: 16px;
    line-height: 1.6
}
.list_sitemap li a {
    display: block;
    color: #fff;
    font-weight: bold;
    text-align: center;
    padding: 20px 0;
    position: relative;
    background: #70b42b;
    border-radius: 8px
}
.list_sitemap li a:hover {
    background: #7cc830;
    color: #fff
}
.list_sitemap li a:after {
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto 0;
    right: 15px;
    width: 8px;
    height: 8px;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    content: ""
}
.list_sitemap li a:hover:after {
    border-top: solid 2px #fff;
    border-right: solid 2px #fff
}
@media screen and (max-width: 1200px) {
    .list_sitemap {
        display: block;
        overflow: hidden;
        clear: both;
        margin-bottom: 20px
    }
    .list_sitemap li {
        float: none;
        width: auto;
        margin-right: 1%;
        margin-bottom: 10px;
        font-size: 12px
    }
    .list_sitemap li a {
        display: block;
        font-weight: bold;
        text-align: center;
        padding: 20px 0;
        position: relative
    }
    .list_sitemap li a:hover {
        color: #fff
    }
    .list_sitemap li a:after {
        display: block;
        position: absolute;
        top: 0;
        bottom: 0;
        margin: auto 0;
        right: 15px;
        width: 8px;
        height: 8px;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        content: ""
    }
    .list_sitemap li a:hover:after {
        border-top: solid 2px #fff;
        border-right: solid 2px #fff
    }
}
.button_box02 {
    display: flex;
    justify-content: center;
    margin: -40px auto 0;
}
.button_box02 .design_button {
    margin-bottom: 0 !important
}
.bottom_content {
    padding: 80px 0 20px
}
.more {
    position: relative;
    display: inline-block;
    padding: 25px 20px;
    background-color: #3a5800;
    border: 2px solid #3a5800;
    color: #fff;
    text-align: center;
    text-decoration: none;
    transition: all 0.3s;
    margin: 0 10px;
    width: 300px;
    font-size: 16px
}
.more:hover {
    background-color: #b5bc20;
    border: 2px solid #b5bc20
}
.more.m_loguin {
    position: relative
}
.more.m_loguin:before {
    position: absolute;
    top: 25%;
    left: 20px;
    content: "";
    display: inline-block;
    width: 40px;
    height: 40px;
    background: url("../images/common/login.png")no-repeat;
    background-size: 30px;
    background-position: left 0
}
.more.m_loguin {
    position: relative
}
.more.m_file:before {
    position: absolute;
    top: 25%;
    left: 20px;
    content: "";
    display: inline-block;
    width: 40px;
    height: 40px;
    background: url("../images/common/file.png")no-repeat;
    background-size: 30px;
    background-position: left 0
}
a.more {
    color: #fff !important
}
.cta_mail02 {
    position: relative;
    display: inline-block;
    padding: 25px 20px;
    background-color: #3a5800;
    border: 2px solid #3a5800;
    color: #fff;
    text-align: center;
    text-decoration: none;
    transition: all 0.3s;
    margin: 0 10px;
    width: 350px;
    font-size: 16px
}
.cta_mail02:before {
    position: absolute;
    top: 25%;
    left: 20px;
    content: "";
    display: inline-block;
    width: 40px;
    height: 40px;
    background: url("../images/common/mail02.png")no-repeat;
    background-size: 30px;
    background-position: left 0
}
.cta_mail02:hover {
    background-color: #b5bc20;
    border: 2px solid #b5bc20
}
@media screen and (max-width: 1200px) {
    .button_box02 {
        display: flex;
        justify-content: center;
        flex-direction: column;
        margin: 0 auto;
    }
    .button_box02 .design_button {
        margin-bottom: 0 !important
    }
    .bottom_content {
        padding: 40px 0 20px
    }
    .more {
        position: relative;
        display: inline-block;
        padding: 25px 20px;
        background-color: #3a5800;
        border: 2px solid #3a5800;
        color: #fff;
        text-align: center;
        text-decoration: none;
        transition: all 0.3s;
        margin: 0 auto 10px;
        width: 70%;
        font-size: 14px
    }
    .more:hover {
        background-color: #b5bc20;
        border: 2px solid #b5bc20
    }
    .more.m_loguin {
        position: relative
    }
    .more.m_loguin:before {
        position: absolute;
        top: 25%;
        left: 20px;
        content: "";
        display: inline-block;
        width: 40px;
        height: 40px;
        background: url("../images/common/login.png")no-repeat;
        background-size: 22px;
        background-position: left 5px
    }
    .more.m_loguin {
        position: relative
    }
    .more.m_file:before {
        position: absolute;
        top: 25%;
        left: 20px;
        content: "";
        display: inline-block;
        width: 40px;
        height: 40px;
        background: url("../images/common/file.png")no-repeat;
        background-size: 22px;
        background-position: left 5px
    }
    a.more {
        color: #fff !important
    }
    .cta_mail02 {
        position: relative;
        display: inline-block;
        padding: 25px 10px;
        background-color: #3a5800;
        border: 2px solid #3a5800;
        color: #fff;
        text-align: center;
        text-decoration: none;
        transition: all 0.3s;
        margin: 0 10px;
        width: 80%;
        font-size: 14px
    }
    .cta_mail02:before {
        position: absolute;
        top: 25%;
        left: 10px;
        content: "";
        display: inline-block;
        width: 40px;
        height: 40px;
        background: url("../images/common/mail02.png")no-repeat;
        background-size: 22px;
        background-position: left 5px
    }
    .cta_mail02:hover {
        background-color: #b5bc20;
        border: 2px solid #b5bc20
    }
}
.input_txt {
    background: #fff;
    border: 1px solid #ddd;
    width: 890px;
    padding: 15px;
    font-size: 22px
}
.login_wrap {
    margin-bottom: 30px;
    margin-top: 10px
}
.form_title {
    font-weight: 600px;
    margin-bottom: 10px;
    font-size: 18px
}
.forget {
    margin: 30px 0 10px
}
.forget a {
    text-decoration: underline
}
@media screen and (max-width: 1200px) {
    .input_txt {
        background: #fff;
        border: 1px solid #ddd;
        width: 90%;
        padding: 10px;
        font-size: 18px
    }
    .login_wrap {
        margin-bottom: 20px;
        margin-top: 10px
    }
    .form_title {
        font-weight: 600px;
        margin-bottom: 10px;
        font-size: 14px
    }
    .forget {
        margin: 20px 0 10px;
        text-align: center
    }
    .forget a {
        text-decoration: underline
    }
}
.project_box {
    margin-bottom: 60px;
    padding-bottom: 60px;
    border-bottom: 1px solid #ddd
}
.project_box .title {
    background: #434343;
    color: #fff;
    padding: 20px;
    font-weight: 600;
    font-size: 18px;
    line-height: 1.7
}
.project_button {
    display: flex;
    justify-content: space-between;
    width: 620px;
    margin: 40px auto auto;
}
@media screen and (max-width: 1200px) {
    .project_box {
        margin-bottom: 30px;
        padding-bottom: 30px;
        border-bottom: 1px solid #ddd
    }
    .project_box .title {
        background: #434343;
        color: #fff;
        padding: 15px;
        font-weight: 600;
        font-size: 16px;
        line-height: 1.7
    }
    .project_button {
        display: flex;
        justify-content: space-between;
        flex-direction: column;
        width: auto;
        margin: 30px auto auto;
    }
}
.cbc_small {
    font-size: 24px
}
.cbc_top_photo {
    display: flex;
    justify-content: space-between;
    margin-bottom: 50px
}
.cbc_top_photo01 {
    width: 50%
}
.cbc_top_photo01 img {
    width: 100%;
    height: auto
}
.photo_flex {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap
}
.photo_flex_2clm {
    width: 48.5%
}
.photo_flex_2clm img {
    width: 100%;
    height: auto
}
.gmap {
    margin-bottom: 20px
}
.gmap iframe {
    width: 100%;
    height: 450px
}
@media screen and (max-width: 1200px) {
    .cbc_small {
        font-size: 12px
    }
    .cbc_top_photo {
        display: flex;
        justify-content: space-between;
        margin-bottom: 50px
    }
    .cbc_top_photo01 {
        width: 50%
    }
    .cbc_top_photo01 img {
        width: 100%;
        height: auto
    }
    .photo_flex {
        display: flex;
        justify-content: space-between;
        flex-direction: column
    }
    .photo_flex_2clm {
        width: auto
    }
    .photo_flex_2clm img {
        width: 100%;
        height: auto
    }
    .gmap {
        margin-bottom: 10px
    }
    .gmap iframe {
        width: 100%;
        height: 250px
    }
}
.title_box h4 {
    font-size: 22px;
    color: #3a5800;
    margin-bottom: 15px;
    font-weight: 600
}
.title_box p {
    margin-bottom: 30px
}
.hinmoku {
    background: #f0f5e7;
    padding: 40px;
    margin-bottom: 50px
}
.hinmoku .title {
    background: #a4aa38;
    text-align: center;
    color: #fff;
    font-size: 18px;
    font-weight: 600;
    padding: 15px 10px;
    margin-bottom: 30px
}
.hinmoku_box {
    display: flex;
    justify-content: space-between
}
.hinmoku_box div {
    width: 110px;
    text-align: center
}
.hinmoku_box div img {
    width: 100%;
    height: auto;
    border-radius: 50%;
    height: 110px;
    object-fit: cover;
    margin-bottom: 10px
}
.photo_flex_2clm .title {
    font-size: 20px;
    color: #3a5800;
    margin-bottom: 10px;
    font-weight: 600;
    line-height: 1.6;
    margin-top: 10px
}
.cbc_tokucyo {
    margin-bottom: 40px
}
.bg_gray {
    background: #f6f6f6;
    padding: 40px;
    margin-bottom: 60px
}
.cbc_end {
    display: flex;
    justify-content: space-between
}
.cbc_end_ph {
    width: 30%
}
.cbc_end_ph img {
    width: 100%;
    height: auto
}
.cbc_end_txt {
    width: 65%;
    display: flex;
    justify-content: center;
    flex-direction: column
}
.cbc_end .title {
    font-size: 20px;
    color: #3a5800;
    margin-bottom: 10px;
    font-weight: 600;
    line-height: 1.6;
    margin-top: 10px
}
.cta_single {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 20px 0 30px;
    flex-direction: column;
    font-weight: 600
}
.cta_single p {
    margin-bottom: 10px
}
.cta_fax {
    font-size: 40px;
    font-weight: 600;
    position: relative
}
.cta_fax:before {
    content: "";
    display: inline-block;
    width: 35px;
    height: 35px;
    background: url("../images/common/fax.png") no-repeat;
    background-position: left 6px;
    background-size: 30px
}
.cta_single_button {
    margin-top: 20px
}
@media screen and (max-width: 1200px) {
    .btmM {
        margin-bottom: 40px !important
    }
    .title_box h4 {
        font-size: 16px;
        color: #3a5800;
        margin-bottom: 10px;
        font-weight: 600
    }
    .title_box p {
        margin-bottom: 20px
    }
    .hinmoku {
        background: #f0f5e7;
        padding: 15px;
        margin-bottom: 30px
    }
    .hinmoku .title {
        background: #a4aa38;
        text-align: center;
        color: #fff;
        font-size: 14px;
        font-weight: 600;
        padding: 10px;
        margin-bottom: 20px
    }
    .hinmoku_box {
        display: flex;
        justify-content: center;
        flex-wrap: wrap
    }
    .hinmoku_box div {
        width: 80px;
        text-align: center;
        margin: 0 8px 15px
    }
    .hinmoku_box div img {
        width: 80px;
        height: auto;
        border-radius: 50%;
        height: 80px;
        object-fit: cover;
        margin-bottom: 10px
    }
    .photo_flex_2clm .title {
        font-size: 16px;
        color: #3a5800;
        margin-bottom: 5px;
        font-weight: 600;
        line-height: 1.6;
        margin-top: 10px
    }
    .cbc_tokucyo {
        margin-bottom: 30px
    }
    .bg_gray {
        background: #f6f6f6;
        padding: 15px;
        margin-bottom: 30px
    }
    .cbc_end {
        display: flex;
        justify-content: space-between;
        flex-direction: column
    }
    .cbc_end_ph {
        width: auto
    }
    .cbc_end_ph img {
        width: 100%;
        height: auto
    }
    .cbc_end_txt {
        width: auto;
        display: flex;
        justify-content: center;
        flex-direction: column
    }
    .cbc_end .title {
        font-size: 16px;
        color: #3a5800;
        margin-bottom: 5px;
        font-weight: 600;
        line-height: 1.6;
        margin-top: 10px
    }
    .cta_single {
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
        padding: 15px 0 20px;
        flex-direction: column;
        font-weight: 600
    }
    .cta_single p {
        margin-bottom: 0
    }
    .cta_fax {
        font-size: 30px;
        font-weight: 600;
        position: relative
    }
    .cta_fax:before {
        content: "";
        display: inline-block;
        width: 35px;
        height: 35px;
        background: url("../images/common/fax.png") no-repeat;
        background-position: left 6px;
        background-size: 30px
    }
    .cta_single_button {
        margin-top: 10px
    }
}
.single_button {
    text-align: center;
    margin-top: 30px
}
.service_list {
    display: flex;
    justify-content: space-between;
    max-height: 450px;
    color: #fff;
    line-height: 1.7
}
.service_list_item01 {
    background: #3a5800;
    width: 30%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    padding: 5% 5% 5% 15%
}
.service_list_item02 {
    width: 50%
}
.service_list_item03 {
    background: #3a5800;
    width: 30%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    padding: 5% 15% 5% 5%
}
.service_list_item01 img,
.service_list_item03 img {
    width: 70px;
    height: auto;
    margin-bottom: 10px
}
.service_list_item02 img {
    object-fit: cover;
    width: 100%;
    height: 100%
}
.service_list h3 {
    font-size: 18px;
    font-weight: 600;
    text-align: center;
    margin-bottom: 10px
}
ul.circle_list {
    margin-left: 0 !important;
    margin-top: 20px;
    padding: 0 !important;
    justify-content: left;
    align-items: left;
    flex-direction: column;
    font-size: 16px;
    width: 100%
}
ul.circle_list li {
    line-height: 1.7;
    padding: 0 !important;
    margin: 0 !important;
    width: 100%;
    background: 0;
    border: 0
}
ul.circle_list li:before {
    font-family: "Font Awesome 5 Free";
    content: "\f111";
    font-weight: 900;
    padding-right: 10px;
    color: #a4aa38
}
@media screen and (max-width: 1200px) {
    .single_button {
        text-align: center;
        margin-top: 30px
    }
    .service_list {
        display: flex;
        justify-content: space-between;
        flex-direction: column;
        max-height: 100%;
        color: #fff;
        line-height: 1.7
    }
    .service_list_item01 {
        background: #3a5800;
        width: auto;
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        padding: 25px 15px
    }
    .service_list_item02 {
        width: auto;
        height: 200px
    }
    .service_list_item03 {
        background: #3a5800;
        width: auto;
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        padding: 25px 15px
    }
    .service_list_item01 img,
    .service_list_item03 img {
        width: 50px;
        height: auto;
        margin-bottom: 10px
    }
    .service_list_item02 img {
        object-fit: cover;
        width: 100%;
        height: 100%
    }
    .service_list h3 {
        font-size: 18px;
        font-weight: 600;
        text-align: center;
        margin-bottom: 10px
    }
    ul.circle_list {
        margin-left: 0;
        margin-top: 20px;
        font-size: 14px
    }
    ul.circle_list li {
        line-height: 1.7
    }
    ul.circle_list li:before {
        font-family: "Font Awesome 5 Free";
        content: "\f111";
        font-weight: 900;
        padding-right: 10px;
        color: #82c501
    }
    .res {
        flex-direction: column-reverse
    }
}
.bassai_txt {
    margin-top: 10px;
    text-align: center
}
.p_left {
    margin-bottom: 40px
}
.bg_gray02 {
    background: #f6f6f6;
    padding: 40px;
    margin-bottom: 40px
}
.bg_gray02 .title {
    font-size: 24px;
    font-weight: 600;
    color: #3a5800;
    border-bottom: 2px solid #000;
    padding-bottom: 10px;
    margin-bottom: 20px;
    line-height: 1.6
}
.bg_gray02 .title_sub {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 20px;
    line-height: 1.6
}
.item_deta {
    display: flex;
    flex-wrap: wrap;
    font-size: 14px;
    margin-bottom: 20px;
    line-height: 1.6
}
.item_deta_title {
    width: 12%;
    background: #a4aa38;
    text-align: center;
    color: #fff;
    font-weight: 600;
    padding: 10px;
    margin-bottom: 10px;
    margin-right: 10px;
    display: flex;
    justify-content: center;
    align-items: center
}
.item_deta_txt {
    width: 80%;
    padding: 10px;
    margin-bottom: 10px;
    display: flex;
    align-items: center
}
table#table-04 {
    border: 1px #e3e3e3 solid;
    border-collapse: collapse;
    border-spacing: 0;
    margin-bottom: 30px;
    font-size: 14px
}
table#table-04 th {
    padding: 20px;
    border: #ddd solid;
    border-width: 0 0 1px 1px;
    background: #e9efde;
    line-height: 120%;
    text-align: center;
    vertical-align: middle
}
table#table-04 td {
    padding: 20px;
    border: 1px #ddd solid;
    border-width: 0 0 1px 1px;
    text-align: left;
    line-height: 1.7;
    background: #fff;
    vertical-align: middle;
    text-align: center
}
.flex-single {
    justify-content: center !important
}
.flex_bottom {
    margin-bottom: 10px !important
}
.cyu {
    font-size: 14px
}
.bg_green {
    background: #e9efde;
    padding: 40px;
    margin-bottom: 40px
}
.bg_green .title {
    font-size: 24px;
    font-weight: 600;
    color: #3a5800;
    border-bottom: 2px solid #000;
    padding-bottom: 10px;
    margin-bottom: 20px;
    line-height: 1.6
}
.inner_bg {
    background: #fff;
    border-radius: 10px;
    padding: 30px;
    margin-bottom: 30px
}
.inner_bg .title_sub {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 30px;
    color: #3a5800
}
.inner_bg .title_sub span {
    color: #a4aa38
}
.smalllist {
    font-size: 14px !important
}
.inner_bg img {
    width: 100%;
    height: auto;
    margin-bottom: 10px
}
.imgR {
    float: right
}
.imgR img {
    width: 180px;
    height: 180px;
    border-radius: 50%;
    object-fit: cover
}
.photo_flex_3clm {
    width: 32%
}
.photo_flex_3clm img {
    width: 100%;
    height: auto
}
.flex_inner {
    margin-bottom: 40px !important
}
table#table-03 {
    border: 1px #e3e3e3 solid;
    border-collapse: collapse;
    border-spacing: 0;
    font-size: 14px;
    line-height: 1.7
}
table#table-03 th {
    padding: 20px;
    border: #ddd solid;
    border-width: 0 0 1px 1px;
    background: #e9efde;
    line-height: 120%;
    text-align: left;
    width: 20%;
    vertical-align: middle
}
table#table-03 td {
    padding: 20px;
    border: 1px #ddd solid;
    border-width: 0 0 1px 1px;
    text-align: left;
    line-height: 1.7;
    vertical-align: middle;
    background: #fff
}
.bg_gray02 .title_sub02 {
    font-size: 20px;
    font-weight: 600;
    margin-top: 20px;
    line-height: 1.6;
    text-align: center
}
.item_wc {
    text-align: center;
    font-weight: 600;
    margin: 20px 0
}
@media screen and (max-width: 1200px) {
    .bassai_txt {
        margin-top: 10px;
        text-align: center;
        font-size: 12px
    }
    .p_left {
        margin-bottom: 20px
    }
    .bg_gray02 {
        background: #f6f6f6;
        padding: 15px;
        margin-bottom: 40px
    }
    .bg_gray02 .title {
        font-size: 18px;
        font-weight: 600;
        color: #3a5800;
        border-bottom: 2px solid #000;
        padding-bottom: 5px;
        margin-bottom: 10px;
        line-height: 1.6
    }
    .bg_gray02 .title_sub {
        font-size: 14px;
        font-weight: 600;
        margin-bottom: 10px;
        line-height: 1.6
    }
    .item_deta {
        display: flex;
        flex-wrap: wrap;
        font-size: 12px;
        margin-bottom: 10px;
        line-height: 1.6;
        flex-direction: column
    }
    .item_deta_title {
        width: auto;
        background: #a4aa38;
        text-align: center;
        color: #fff;
        font-weight: 600;
        padding: 5px;
        margin-bottom: 5px;
        margin-right: 0;
        display: flex;
        justify-content: center;
        align-items: center
    }
    .item_deta_txt {
        width: auto;
        padding: 5px;
        margin-bottom: 5px;
        display: flex;
        align-items: center
    }
    table#table-04 {
        border: 1px #e3e3e3 solid;
        border-collapse: collapse;
        border-spacing: 0;
        margin-bottom: 15px;
        font-size: 14px
    }
    table#table-04 th {
        padding: 20px;
        border: #ddd solid;
        border-width: 0 0 1px 1px;
        background: #e9efde;
        line-height: 120%;
        text-align: center;
        vertical-align: middle
    }
    table#table-04 td {
        padding: 20px;
        border: 1px #ddd solid;
        border-width: 0 0 1px 1px;
        text-align: left;
        line-height: 1.7;
        background: #fff;
        vertical-align: middle;
        text-align: center
    }
    .flex-single {
        justify-content: center !important
    }
    .flex_bottom {
        margin-bottom: 10px !important
    }
    .cyu {
        font-size: 10px
    }
    .bg_green {
        background: #e9efde;
        padding: 15px;
        margin-bottom: 20px
    }
    .bg_green .title {
        font-size: 16px;
        font-weight: 600;
        color: #3a5800;
        border-bottom: 2px solid #000;
        padding-bottom: 5px;
        margin-bottom: 10px;
        line-height: 1.6
    }
    .inner_bg {
        background: #fff;
        border-radius: 10px;
        padding: 15px;
        margin-bottom: 15px
    }
    .inner_bg .title_sub {
        font-size: 16px;
        font-weight: 600;
        margin-bottom: 15px;
        color: #3a5800
    }
    .inner_bg .title_sub span {
        color: #a4aa38
    }
    .smalllist {
        font-size: 12px !important
    }
    .inner_bg img {
        width: 100%;
        height: auto;
        margin-bottom: 0
    }
    .imgR {
        float: none;
        text-align: center;
        margin-bottom: 15px
    }
    .imgR img {
        width: 120px;
        height: 120px;
        border-radius: 50%;
        object-fit: cover
    }
    .photo_flex_3clm {
        width: auto
    }
    .photo_flex_3clm img {
        width: 100%;
        height: auto
    }
    .flex_inner {
        margin-bottom: 20px !important
    }
    table#table-03 {
        border: 1px #e3e3e3 solid;
        border-collapse: collapse;
        border-spacing: 0;
        font-size: 12px;
        line-height: 1.7
    }
    table#table-03 th {
        padding: 20px;
        border: #ddd solid;
        border-width: 0 0 1px 1px;
        background: #e9efde;
        line-height: 120%;
        text-align: left;
        width: 20%;
        vertical-align: middle
    }
    table#table-03 td {
        padding: 20px;
        border: 1px #ddd solid;
        border-width: 0 0 1px 1px;
        text-align: left;
        line-height: 1.7;
        vertical-align: middle;
        background: #fff
    }
    .bg_gray02 .title_sub02 {
        font-size: 14px;
        font-weight: 600;
        margin-top: 10px;
        line-height: 1.6;
        text-align: center
    }
    .item_wc {
        text-align: left;
        font-weight: 600;
        margin: 10px 0 20px
    }
    .tb_scroll table {
        display: block;
        overflow-x: scroll;
        white-space: nowrap;
        -webkit-overflow-scrolling: touch
    }
    .tb_scroll table#table-04 {
        font-size: 12px !important
    }
}
.cta_fax02 {
    font-size: 36px;
    font-weight: 600;
    position: relative
}
.cta_fax02:before {
    content: "";
    display: inline-block;
    width: 35px;
    height: 35px;
    background: url("../images/common/fax.png") no-repeat;
    background-position: left 5px;
    background-size: 30px
}
#mailform {
    border-bottom: 1px solid #ddd;
    border-top: 0;
    width: 100%;
    font-size: 16px;
    line-height: 180%;
    margin-bottom: 40px;
    line-height: 1.8;
    margin-top: 50px
}
dl#mailform dl,
dl#mailform dt,
dl#mailform dd {
    margin: 0;
    padding: 0
}
dl#mailform dt,
dl#mailform dd {
    padding: 20px
}
dl#mailform dd p {
    margin-bottom: 10px
}
dl#mailform dt {
    border-top: 1px solid #ddd;
    clear: left;
    float: left;
    width: 230px
}
dl#mailform dd {
    background: #fff;
    border-top: 1px solid #ddd;
    margin-left: 270px
}
#mailform dt span {
    background: #e60012;
    color: #fff;
    font-size: 12px;
    text-align: center;
    padding: 2px 10px;
    float: right
}
@media screen and (max-width: 1200px) {
    .cta_fax02 {
        font-size: 16px;
        font-weight: 600;
        position: relative
    }
    .cta_fax02:before {
        content: "";
        display: inline-block;
        width: 24px;
        height: 24px;
        background: url("../images/common/fax.png") no-repeat;
        background-position: left 9px;
        background-size: 18px
    }
    #mailform {
        border-bottom: 1px solid #ddd;
        border-top: 0;
        width: 100%;
        font-size: 14px;
        line-height: 180%;
        margin-bottom: 30px;
        line-height: 1.8;
        margin-top: 30px
    }
    dl#mailform dl,
    dl#mailform dt,
    dl#mailform dd {
        margin: 0;
        padding: 0
    }
    dl#mailform dt,
    dl#mailform dd {
        padding: 10px
    }
    dl#mailform dt {
        border-top: 1px solid #ddd;
        clear: left;
        float: none;
        width: auto
    }
    dl#mailform dd {
        background: #fff;
        border-top: 1px solid #ddd;
        margin-left: auto
    }
    #mailform dt span {
        background: #e60012;
        color: #fff;
        font-size: 10px;
        text-align: center;
        padding: 2px 10px;
        float: right
    }
}
.recruit_page .flex {
    display: flex
}
.recruit_page .content_navi li {
    width: 18%;
    border: 1px solid #3a5800
}
.recruit_page #company_list {
    justify-content: center
}
.text_center {
    text-align: center
}
.recruit_page .content_navi {
    margin: 80px 0;
    width: 100%
}
.recruit_page .content_navi li a {
    line-height: 66px;
    padding: 0 10px
}
.recruit_page .content_navi li:nth-of-type(3) a {
    padding: 8px 10px;
    line-height: 25px
}
.recruit_page .concept .midoritenki p:first-of-type {
    font-size: 35px;
    font-weight: 600;
    text-align: center;
    margin-bottom: 30px
}
.recruit_page .concept h3 {
    font-size: 32px;
    text-align: center;
    margin-bottom: 40px
}
.recruit_page .concept ul.content_980 {
    margin-bottom: 90px
}
.recruit_page .concept .content_980 li {
    margin-bottom: 30px;
    background: #2c8241;
    color: white
}
.recruit_page .concept li dl {
    padding: 36px 60px
}
.recruit_page .concept li dl dt {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 30px
}
.recruit_page .concept li dl dd {
    line-height: 24px
}
.recruit_page .inview .inview_outer {
    width: 980px;
    margin: 0 auto
}
.recruit_page .inview .inview_outer li {
    border-bottom: solid 1px #cecece;
    padding-bottom: 80px;
    margin-bottom: 80px
}
.recruit_page .inview .inview_outer .flex {
    justify-content: space-between;
    margin-bottom: 30px
}
.recruit_page .inview .inview_outer .flex div p:first-of-type {
    line-height: 48px;
    background: #a4aa38;
    color: white;
    padding: 0 20px;
    width: fit-content;
    font-weight: bold;
    margin-bottom: 20px
}
.recruit_page .inview .inview_outer .flex div p:last-of-type {
    font-weight: bold;
    font-size: 22px;
    margin-right: 10px;
    margin-bottom: 80px
}
.recruit_page .job_description .youkou_cmt {
    margin-bottom: 50px
}
.recruit_page .job_description #gaiyou .design_button {
    margin: 30px auto
}
.recruit_page .job_description #gaiyou {
    margin-bottom: 50px
}
.recruit_page .recruit_about .about_list li {
    margin-bottom: 30px;
    background: #2c8241;
    color: white
}
.recruit_page .recruit_about .about_list li dl {
    padding: 36px 45px
}
.recruit_page .recruit_about .about_list li dl dt {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 30px;
    text-align: center
}
.recruit_page .recruit_about .about_list li dl dd {
    line-height: 24px
}
.hyouka_list li {
    margin-bottom: 40px
}
.hyouka_list_title {
    background: #68ae38;
    padding: 10px;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px
}
.hyouka_list #gaiyou {
    margin-bottom: 0;
    width: auto;
    font-size: 18px
}
.hyouka_list #gaiyou dt {
    width: 180px
}
.hyouka_list_title span {
    line-height: 48px;
    color: white;
    padding: 0 20px;
    font-weight: bold;
    display: inline-block;
    font-size: 24px
}
.hyouka_list_title span:first-of-type {
    background: #fba500;
    font-size: 18px
}
.hyouka_list_title span:last-of-type {
    background: #68ae38
}
#gaiyou .gaiyou_bg:first-child {
    background: #f2f0e2 !important;
    text-align: center;
    width: 220px !important;
    padding: 20px 10px !important
}
#gaiyou .gaiyou_bg:nth-child(2) {
    background: #f2f0e2 !important;
    text-align: center;
    width: auto !important;
    padding: 20px 10px !important
}
.hyouka_list li div {
    border: 1px solid #ddd;
    border-top: 0;
    padding: 20px
}
.hyouka_list li div p:first-of-type {
    color: #2c8241;
    margin-bottom: 8px
}
.recruit_page .youkou_cmt {
    margin-bottom: 50px
}
.recruit_page .entry .tel_area {
    border: 1px solid #ddd;
    margin-top: 55px
}
.recruit_page .entry .tel_area dt {
    color: #3a5800;
    font-weight: bold;
    font-size: 22px;
    text-align: center;
    padding: 35px;
    border-bottom: 1px solid #ddd
}
.recruit_page .entry .tel_area dd {
    font-weight: bold;
    font-size: 22px;
    text-align: center;
    padding: 35px
}
.recruit_page .entry .tel_area dd {
    padding: 33px
}
.recruit_page .entry .tel_area dd p {
    font-weight: bold;
    font-size: 18px;
    text-align: center
}
.recruit_page .entry .tel_area dd p:last-of-type {
    font-weight: bold;
    font-size: 42px;
    text-align: center
}
.recruit_page .entry .tel_area dd img {
    padding-right: 8px
}
@media screen and (max-width:895px) {
    .recruit_page .content_navi li {
        width: 48%
    }
    #gaiyou .gaiyou_bg:first-child {
        background: #f2f0e2 !important;
        text-align: center;
        width: 100px !important;
        padding: 20px 10px !important
    }
    #gaiyou .gaiyou_bg:nth-child(2) {
        background: #f2f0e2 !important;
        text-align: center;
        width: auto !important;
        padding: 20px 10px !important
    }
}
@media screen and (max-width:750px) {
    .recruit_page .archive_desc {
        margin-top: 0
    }
    .recruit_page .concept .content_980 li {
        display: block;
        width: 90%;
        max-width: 405px;
        margin: 0 auto 30px
    }
    .recruit_page .concept .content_980 li img {
        width: 100%
    }
    .recruit_page .concept .content_980 li:nth-of-type(2) {
        display: flex;
        flex-direction: column-reverse
    }
    .recruit_page .concept .midoritenki p:first-of-type {
        font-size: 25px
    }
    .recruit_page .concept h3 {
        font-size: 22px
    }
    .recruit_page .inview .inview_outer .flex {
        display: block
    }
    .recruit_page .inview .inview_outer .flex div {
        width: 100%
    }
    .recruit_page .inview .inview_outer {
        width: 100%
    }
    .recruit_page .inview .inview_outer .flex div img {
        width: 100%
    }
    .recruit_page .inview .inview_outer .flex div p:last-of-type {
        font-size: 18px;
        margin-right: 0;
        margin-bottom: 20px
    }
    .recruit_page .inview .inview_outer li {
        padding-bottom: 40px;
        margin-bottom: 40px
    }
    .recruit_page .entry .tel_area dd p:last-of-type {
        font-size: 33px
    }
    .recruit_page .content_navi li {
        width: 48%
    }
    .recruit_page .recruit_about .about_list li img {
        width: 100%
    }
    .hyouka_list_title span {
        padding: 0 11px;
        font-size: 16px !important;
        line-height: 1.5;
        margin-bottom: 5px
    }
    .hyouka_list #gaiyou {
        font-size: 12px
    }
    .hyouka_list #gaiyou dt {
        float: left
    }
    .hyouka_list #gaiyou dt {
        width: 30%
    }
    .hyouka_list #gaiyou dt,
    .hyouka_list #gaiyou dd {
        text-align: center
    }
}
@media screen and (max-width: 1200px) {
    .hyouka_list #gaiyou dt {
        float: left
    }
    .recruit_page .recruit_about .about_list li img {
        width: 100%
    }
    .hyouka_list #gaiyou dt,
    .hyouka_list #gaiyou dd {
        text-align: center
    }
}
.single_news_date {
    text-align: center;
    margin-bottom: 20px
}
.blog_content p {
    margin-bottom: 20px
}
@media screen and (max-width: 1200px) {
    .single_news_date {
        text-align: center;
        margin-bottom: 10px
    }
    .blog_content p {
        margin-bottom: 15px
    }
}
.width100.content_block {
    width: 100% !important;
    padding: 60px 0;
    margin-bottom: 0
}
.width100.content_block .photo_flex .photo_flex_2clm {
    width: 33%
}
.gree_text {
    font-size: 22px;
    color: #3a5800;
    text-align: center;
    font-weight: bold;
    padding-top: 16px
}
.width100.content_block .photo_flex {
    justify-content: space-around
}
.cb_headline .black {
    color: #000
}
@media screen and (max-width: 1200px) {
    .gree_text {
        font-size: 16px;
        color: #3a5800;
        text-align: center;
        font-weight: bold;
        padding-top: 16px
    }
    .width100.content_block {
        width: auto !important;
        padding: 20px 0;
        margin-bottom: 0
    }
    .width100.content_block .photo_flex .photo_flex_2clm {
        width: 90%;
        margin: 0 auto 20px
    }
}
.wctop_licence {
    background: #000;
    color: #fff;
    text-align: center;
    font-size: 16px;
    padding: 10px;
    width: 480px;
    margin: auto auto 10px;
}
h3.wc_title02 {
    position: relative;
    padding: 1.5rem 0 !important;
    text-align: center;
    font-weight: 600;
    font-size: 36px;
    color: #000;
    margin-bottom: 30px;
    line-height: 1.7;
    font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif
}
.content_block .wc_title02:before {
    position: relative;
    bottom: 0;
    left: calc(50% - 30px);
    width: 0;
    height: 0;
    content: '';
    border-radius: 0;
    background: 0
}
.wc_zu {
    width: 800px;
    margin: auto
}
.wc_zu img {
    width: 100%;
    margin: auto
}
.block_gray {
    background: #f6f6f6;
    padding: 60px 0;
    margin-bottom: 60px
}
.wptokucyo_bg {
    background: #fff;
    padding: 40px;
    margin-top: 100px
}
.wptokucyo_title {
    background: #3a5800;
    padding: 20px 15px;
    width: 200px;
    margin: -90px auto 0;
    text-align: center;
    color: #fff;
    font-weight: 600;
    font-size: 24px;
}
.wptokucyo_title:before {
    content: attr(data-text);
    display: block;
    font-size: 16px;
    line-height: 1.2;
    border-bottom: 1px solid #fff;
    padding-bottom: 10px;
    margin-bottom: 10px
}
.wctokucyo {
    margin-top: 40px
}
.wctokucyo li {
    display: flex;
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-bottom: #ddd 1px dashed;
    font-weight: 600
}
.wctokucyo .no {
    background: #a4aa38;
    text-align: center;
    color: #fff;
    font-size: 18px;
    font-weight: 600;
    width: 50px;
    height: 50px;
    line-height: 50px;
    margin-right: 20px
}
.wctokucyo .txt {
    display: flex;
    align-items: center;
    width: 90%;
    line-height: 1.6
}
.wc_photo {
    margin-top: 50px
}
.wptokucyo_title02 {
    background: #3a5800;
    padding: 30px;
    text-align: center;
    color: #fff;
    font-weight: 600;
    font-size: 20px;
    margin: 80px 0 40px
}
.block_gray h2 {
    font-weight: 600;
    font-size: 28px;
    text-align: center;
    line-height: 1.8;
    margin-bottom: 60px
}
.caseblock {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap
}
.caseblock .case {
    width: 49.9%;
    padding-top: 40px;
    border-bottom: 1px solid #ddd
}
.caseblock .case:nth-child(odd) {
    border-right: 1px solid #ddd
}
.case .title {
    background: #3a5800;
    text-align: center;
    font-size: 18px;
    font-weight: 600;
    padding: 10px;
    width: 150px;
    margin: 0 auto 30px;
    color: #fff
}
.case .title02 {
    color: #3a5800;
    font-size: 18px;
    font-weight: 600;
    border-bottom: 1px solid #3a5800;
    padding-bottom: 20px;
    margin-bottom: 20px;
    margin-right: 30px;
    line-height: 1.6
}
.case .title02b {
    color: #3a5800;
    font-size: 18px;
    font-weight: 600;
    border-bottom: 1px solid #3a5800;
    padding-bottom: 20px;
    margin-bottom: 20px;
    margin-left: 30px;
    line-height: 1.6
}
.caseitem {
    display: flex;
    justify-content: space-between;
    margin-right: 30px;
    margin-bottom: 30px
}
.caseitem02 {
    display: flex;
    justify-content: space-between;
    margin-left: 30px;
    margin-bottom: 30px
}
.caseitem_l {
    width: 37%;
    position: relative;
    line-height: 1.6
}
.caseitem_r {
    width: 60%
}
.caseitem_l img {
    width: 100%;
    height: auto
}
.caseitem_l .txt {
    position: absolute;
    bottom: 0
}
.caseitem_r img {
    width: 100%;
    height: auto
}
.case_ch {
    font-weight: 600;
    margin-bottom: 40px
}
.case_ch02 {
    font-weight: 600;
    margin-bottom: 10px;
    margin-left: 30px
}
.wptokucyo_title03 {
    background: #3a5800;
    padding: 40px 10%;
    text-align: center;
    color: #fff;
    font-weight: 600;
    font-size: 22px;
    width: 80%;
    margin-bottom: 40px
}
.wptokucyo_title03 {
    display: flex;
    justify-content: space-between
}
.wptokucyo_title03_item {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column
}
.nom {
    background: #000;
    text-align: center;
    color: #fff;
    font-size: 12px;
    padding: 10px 15px;
    margin-bottom: 20px
}
.wptokucyo_title03_item span {
    font-size: 50px
}
.bg_gray h4 {
    color: #3a5800;
    font-size: 20px;
    text-align: center;
    margin-bottom: 40px
}
.zu {
    margin-bottom: 40px
}
.zu img {
    width: 100%;
    height: auto
}
.zu02 {
    margin-bottom: 20px
}
.zu02 img {
    width: 100%;
    height: auto
}
.pcimg {
    display: block
}
.spimg {
    display: none
}
.grn {
    color: #3a5800
}
.block_gray .title_sub {
    text-align: center;
    line-height: 1.8;
    font-size: 18px;
    font-weight: 600;
    margin-top: -20px;
    margin-bottom: 0
}
.wptokucyo_bg02 {
    background: #fff;
    padding: 40px;
    margin-top: 50px;
    margin-bottom: 20px
}
.wctokucyo02 li {
    display: flex;
    margin-bottom: 40px
}
.wctokucyo02 .no {
    background: #a4aa38;
    text-align: center;
    color: #fff;
    font-size: 18px;
    font-weight: 600;
    width: 50px;
    height: 50px;
    line-height: 50px;
    margin-right: 20px
}
.wctokucyo02 .txt {
    width: 90%;
    line-height: 1.6
}
.wctokucyo02 .txt .title {
    font-size: 18px;
    border-bottom: 1px #ddd dashed;
    padding-bottom: 10px;
    margin-bottom: 10px;
    font-weight: 600
}
.taclogo {
    width: 220px;
    margin: 0 auto 40px
}
.taclogo img {
    width: 100%;
    height: auto
}
.ctatac_mail {
    position: relative;
    display: inline-block;
    padding: 25px 20px;
    background-color: #3a5800;
    border: 2px solid #3a5800;
    color: #fff;
    text-align: center;
    text-decoration: none;
    transition: all 0.3s;
    margin: 10px 10px 40px;10px;
    width: 350px;
    font-size: 16px
}
.ctatac_mail:before {
    position: absolute;
    top: 25%;
    left: 20px;
    content: "";
    display: inline-block;
    width: 40px;
    height: 40px;
    background: url("../images/common/mail02.png")no-repeat;
    background-size: 30px;
    background-position: left 0
}
.ctatac_mail:hover {
    background-color: #b5bc20;
    border: 2px solid #b5bc20;
    color: #fff
}
.p_center {
    margin-bottom: 40px;
    text-align: center
}
@media screen and (max-width: 1200px) {
    .wctop_licence {
        background: #000;
        color: #fff;
        text-align: center;
        font-size: 12px;
        padding: 10px;
        width: auto;
        margin: auto auto 10px;
    }
    h3.wc_title02 {
        position: relative;
        padding: 1.5rem 0 !important;
        text-align: center;
        font-weight: 600;
        font-size: 20px;
        color: #000;
        margin-bottom: 0;
        margin-top: -30px;
        line-height: 1.7;
        font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif
    }
    .wc_content .content_navi {
        margin-bottom: 30px
    }
    .content_block .wc_title02:before {
        position: relative;
        bottom: 0;
        left: calc(50% - 30px);
        width: 0;
        height: 0;
        content: '';
        border-radius: 0;
        background: 0
    }
    .wc_zu {
        width: auto;
        margin: auto
    }
    .wc_zu img {
        width: 100%;
        margin: auto
    }
    .block_gray {
        background: #f6f6f6;
        padding: 30px 10px;
        margin-bottom: 60px
    }
    .wptokucyo_bg {
        background: #fff;
        padding: 15px;
        margin-top: 80px
    }
    .wptokucyo_title {
        background: #3a5800;
        padding: 20px 15px;
        width: 200px;
        margin: -60px auto 0;
        text-align: center;
        color: #fff;
        font-weight: 600;
        font-size: 18px;
    }
    .wptokucyo_title:before {
        content: attr(data-text);
        display: block;
        font-size: 12px;
        line-height: 1.2;
        border-bottom: 1px solid #fff;
        padding-bottom: 10px;
        margin-bottom: 10px
    }
    .wctokucyo {
        margin-top: 40px
    }
    .wctokucyo li {
        display: flex;
        margin-bottom: 15px;
        padding-bottom: 15px;
        border-bottom: #ddd 1px dashed;
        font-weight: 600
    }
    .wctokucyo .no {
        background: #a4aa38;
        text-align: center;
        color: #fff;
        font-size: 18px;
        font-weight: 600;
        width: 50px;
        height: 50px;
        line-height: 50px;
        margin-right: 20px
    }
    .wctokucyo .txt {
        display: flex;
        align-items: center;
        width: 90%;
        line-height: 1.6;
        font-size: 14px
    }
    .wc_photo {
        margin-top: 30px
    }
    .wptokucyo_title02 {
        background: #3a5800;
        padding: 15px;
        text-align: center;
        color: #fff;
        font-weight: 600;
        font-size: 18px;
        margin: 40px 0 20px;
        line-height: 1.6
    }
    .block_gray h2 {
        font-weight: 600;
        font-size: 16px;
        text-align: center;
        line-height: 1.8;
        margin: 0 10px;
    }
    .caseblock {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        flex-direction: column
    }
    .caseblock .case {
        width: auto;
        padding-top: 20px;
        border-bottom: 1px solid #ddd
    }
    .caseblock .case:nth-child(odd) {
        border-right: 0 solid #ddd
    }
    .case .title {
        background: #3a5800;
        text-align: center;
        font-size: 16px;
        font-weight: 600;
        padding: 10px;
        width: 120px;
        margin: 0 auto 20px;
        color: #fff
    }
    .case .title02 {
        color: #3a5800;
        font-size: 16px;
        font-weight: 600;
        border-bottom: 1px solid #3a5800;
        padding-bottom: 10px;
        margin-bottom: 10px;
        margin-right: 0;
        line-height: 1.6
    }
    .case .title02b {
        color: #3a5800;
        font-size: 16px;
        font-weight: 600;
        border-bottom: 1px solid #3a5800;
        padding-bottom: 10px;
        margin-bottom: 10px;
        margin-left: 0;
        line-height: 1.6
    }
    .caseitem {
        display: flex;
        justify-content: space-between;
        flex-direction: column;
        margin-right: 0 !important;
        margin-bottom: 15px
    }
    .caseitem02 {
        display: flex;
        justify-content: space-between;
        flex-direction: column;
        margin-left: 0 !important;
        margin-bottom: 15px
    }
    .caseitem_l {
        width: auto;
        position: relative;
        line-height: 1.6;
        margin-bottom: 15px
    }
    .caseitem_r {
        width: auto;
        margin-bottom: 15px
    }
    .caseitem_l img {
        width: 100%;
        height: auto
    }
    .caseitem_l .txt {
        position: relative;
        bottom: auto;
        font-size: 12px
    }
    .caseitem_r img {
        width: 100%;
        height: auto
    }
    .case_ch {
        font-weight: 600;
        margin-bottom: 20px
    }
    .case_ch02 {
        font-weight: 600;
        margin-bottom: 10px;
        margin-left: 0
    }
    .wptokucyo_title03 {
        background: #3a5800;
        padding: 20px 10%;
        text-align: center;
        color: #fff;
        font-weight: 600;
        font-size: 18px;
        width: auto;
        margin-bottom: 20px
    }
    .wptokucyo_title03 {
        display: flex;
        justify-content: space-between;
        flex-direction: column
    }
    .wptokucyo_title03_item {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        margin-bottom: 10px
    }
    .nom {
        background: #000;
        text-align: center;
        color: #fff;
        font-size: 10px;
        padding: 10px 15px;
        margin-bottom: 10px
    }
    .wptokucyo_title03_item span {
        font-size: 30px
    }
    .bg_gray h4 {
        color: #3a5800;
        font-size: 16px;
        text-align: center;
        margin-bottom: 20px;
        line-height: 1.6
    }
    .zu {
        margin-bottom: 20px
    }
    .zu img {
        width: 100%;
        height: auto
    }
    .zu02 {
        margin-bottom: 20px
    }
    .zu02 img {
        width: 100%;
        height: auto
    }
    .pcimg {
        display: none
    }
    .spimg {
        display: block
    }
    .grn {
        color: #3a5800
    }
    .block_gray .title_sub {
        text-align: center;
        line-height: 1.7;
        font-size: 14px;
        font-weight: 600;
        margin-top: 20px;
        margin-bottom: 0
    }
    .wptokucyo_bg02 {
        background: #fff;
        padding: 20px 15px;
        margin-top: 50px;
        margin-bottom: 20px
    }
    .wctokucyo02 li {
        display: flex;
        margin-bottom: 20px
    }
    .wctokucyo02 .no {
        background: #a4aa38;
        text-align: center;
        color: #fff;
        font-size: 18px;
        font-weight: 600;
        width: 50px;
        height: 50px;
        line-height: 50px;
        margin-right: 20px
    }
    .wctokucyo02 .txt {
        width: 90%;
        line-height: 1.6
    }
    .wctokucyo02 .txt .title {
        font-size: 16px;
        border-bottom: 1px #ddd dashed;
        padding-bottom: 10px;
        margin-bottom: 10px;
        font-weight: 600
    }
    .taclogo {
        width: 150px;
        margin: -20px auto 20px
    }
    .taclogo img {
        width: 100%;
        height: auto
    }
    .ctatac_mail {
        position: relative;
        display: inline-block;
        padding: 25px 20px;
        background-color: #3a5800;
        border: 2px solid #3a5800;
        color: #fff;
        text-align: center;
        text-decoration: none;
        transition: all 0.3s;
        margin: 10px 10px 40px 10px;
        width: 70%;
        font-size: 14px
    }
    .ctatac_mail {
        font-size: 14px;
        font-weight: 600;
        position: relative
    }
    .ctatac_mail:before {
        content: "";
        display: inline-block;
        width: 24px;
        height: 24px;
        background: url("../images/common/mail02.png") no-repeat;
        background-position: left 7px;
        background-size: 18px
    }
    .p_center {
        margin-bottom: 40px;
        text-align: center
    }
    .wc_content .content_block h3 {
        margin-top: -40px
    }
}
.wc_cace_h4 {
    font-size: 22px;
    font-weight: 600;
    color: #3a5800;
    margin-bottom: 20px
}
.wc_wrap {
    margin-bottom: 60px
}
.table_frame {
    height: 600px;
    width: 100%;
    overflow: auto
}
table#table-05 {
    border: 1px #e3e3e3 solid;
    border-collapse: collapse;
    border-spacing: 0;
    margin-bottom: 40px
}
table#table-05 th {
    padding: 20px;
    border: #ddd solid;
    border-width: 0 0 1px 1px;
    background: #f5f5f5;
    line-height: 120%;
    text-align: left
}
table#table-05 td {
    padding: 20px;
    border: 1px #ddd solid;
    border-width: 0 0 1px 1px;
    text-align: left;
    line-height: 1.7;
    width: 30%
}
table#table-05 th span {
    color: #3a5800
}
.works_content .title01 {
    color: #3a5800;
    font-size: 24px;
    line-height: 1.7;
    text-align: center;
    font-weight: 600;
    margin-bottom: 60px
}
.works_flex {
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px
}
.works_flex_item {
    width: 49%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column
}
.works_flex_item02 {
    width: 49%;
    margin-bottom: 20px
}
.works_flex_item02 p {
    line-height: 1.6
}
.works_flex_item02 img {
    width: 100%;
    height: auto;
    margin-bottom: 10px
}
.works_flex_item .title02 {
    color: #3a5800;
    font-size: 24px;
    line-height: 1.7;
    text-align: center;
    font-weight: 600
}
.works_content .title03 {
    background: #3a5800;
    color: #fff;
    font-size: 18px;
    line-height: 1.7;
    padding: 15px 5%;
    font-weight: 600;
    margin-bottom: 20px;
    width: 90%
}
.works_content .title03 span {
    font-size: 16px
}
.works_content .title04 {
    color: #f69f09;
    font-size: 24px;
    line-height: 1.7;
    padding: 15px 20px;
    font-weight: 600;
    margin-bottom: 20px;
    text-align: center
}
@media screen and (max-width: 1200px) {
    table#table-05 {
        border: 1px #e3e3e3 solid;
        border-collapse: collapse;
        border-spacing: 0;
        margin-bottom: 40px;
        font-size: 14px
    }
    table#table-05 th {
        padding: 10px;
        border: #ddd solid;
        border-width: 0 0 1px 1px;
        background: #f5f5f5;
        line-height: 120%;
        text-align: center;
        width: 10%
    }
    table#table-05 td {
        padding: 10px;
        border: 1px #ddd solid;
        border-width: 0 0 1px 1px;
        text-align: left;
        line-height: 1.7
    }
    table#table-05 th span {
        color: #3a5800
    }
    .works_content .title01 {
        color: #3a5800;
        font-size: 16px;
        line-height: 1.7;
        text-align: center;
        font-weight: 600;
        margin-bottom: 20px
    }
    .works_flex {
        display: flex;
        justify-content: space-between;
        flex-direction: column
    }
    .works_flex_item {
        width: auto;
        display: flex;
        justify-content: center;
        align-items: center;
        margin-bottom: 10px
    }
    .works_flex_item img {
        width: 100%;
        height: auto
    }
    .works_flex_item02 {
        width: auto;
        margin-bottom: 10px
    }
    .works_flex_item02 p {
        line-height: 1.6;
        font-size: 14px
    }
    .works_flex_item02 img {
        width: 100%;
        height: auto;
        margin-bottom: 5px
    }
    .works_flex_item .title02 {
        color: #3a5800;
        font-size: 18px;
        line-height: 1.7;
        text-align: center;
        font-weight: 600;
        margin-bottom: 20px
    }
    .works_content .title03 {
        background: #3a5800;
        color: #fff;
        font-size: 16px;
        line-height: 1.7;
        padding: 15px 5%;
        font-weight: 600;
        margin-bottom: 15px;
        width: 90%
    }
    .works_content .title03 span {
        font-size: 14px
    }
    .works_content .title04 {
        color: #f69f09;
        font-size: 16px;
        line-height: 1.7;
        padding: 15px 20px;
        font-weight: 600;
        margin-bottom: 20px;
        text-align: center
    }
}
.entry_button {
    margin: 80px 0 0
}
@media screen and (max-width: 1200px) {
    .entry_button {
        margin: 40px 0 0
    }
}
.inview .content_navi .target a {
    background: #3a5800 !important;
    color: #fff;
    width: 100%
}
#kijyun {
    margin-top: -100px;
    padding-top: 100px
}
.gree_text_s {
    font-size: 95%;
    margin: 10px 20px
}
.works_content h4 {
    font-size: 18px;
    color: #3a5800;
    margin: 0 0 20px;
    padding: 0;
    text-align: center;
    line-height: 1.7
}
.photo_flex_4clm {
    width: 24%
}
.photo_flex_4clm img {
    width: 100%;
    height: auto
}
@media screen and (max-width: 1200px) {
    .glay_txt {
        margin: 0 0 30px
    }
    .padding_sp {
        margin: 0 15px
    }
    .photo_flex_4clm {
        width: auto
    }
    .works_content h4 {
        font-size: 16px;
        color: #3a5800;
        margin: 0 0 20px;
        padding: 0;
        text-align: center;
        line-height: 1.7
    }
    .mg_sp {
        margin-bottom: 25px
    }
}
.cont_smart {
    width: 800px;
    margin: 100px auto 0
}
.cont_smart img {
    width: 100%;
    height: auto
}
@media screen and (max-width: 1200px) {
    .cont_smart {
        width: 80%;
        margin: 0 auto 60px
    }
    .cont_smart img {
        width: 100%;
        height: auto
    }
}
.dlfile {
    text-decoration: underline;
    color: #0059fd
}
.innerbg.sitemap {
    margin-bottom: 20px
}
@media screen and (max-width: 1200px) {
    .innerbg.sitemap {
        margin-bottom: 10px
    }
}
.policy p {
    font-size: 16px !important
}
.pcenter {
    text-align: center
}
@media screen and (max-width: 1200px) {
    .policy p {
        font-size: 12px !important
    }
    .pcenter {
        text-align: left
    }
}
.newstitle {
    font-size: 36px !important;
    color: #70b42b;
    padding: 0 0 10px !important;
    margin: 0 0 20px !important;
    text-align: center;
    border-bottom: 1px solid #a0a0a0
}
.newsdate {
    text-align: center;
    color: #7d7d7d
}
.newsbody {
    padding: 40px 0 0
}
@media screen and (max-width: 1200px) {
    .newstitle {
        font-size: 18px !important;
        color: #70b42b;
        padding: 0 0 10px !important;
        margin: 10px 0 20px !important;
        text-align: left !important;
        border-bottom: 1px solid #a0a0a0;
        line-height: 1.4 !important
    }
    .newsdate {
        text-align: center;
        color: #7d7d7d
    }
    .newsbody {
        padding: 20px 0 10px
    }
}
.pagediscription {
    font-size: 20px;
    margin-bottom: 40px;
    text-align: center
}
.content_blog {
    max-width: 1150px;
    margin: 0 auto 80px
}
.blogsingle h3 {
    font-size: 30px;
    font-weight: 600;
    margin: 20px 0 40px;
    padding-bottom: 10px;
    line-height: 1.7;
    border-bottom: 2px solid #70b42b;
    line-height: 1.7
}
.blogsingle p {
    line-height: 1.7;
    margin-bottom: 16px
}
.blogsingle p img {
    width: 80%;
    height: auto;
    object-fit: cover;
    background: url("../images/common/green_st.png");
    padding: 20px;
    border-radius: 10px;
    box-sizing: border-box;
    margin: auto auto 30px;
    display: block;
}
.sigleph {
    text-align: center;
    margin: 0 auto 40px;
    max-width: 80%;
}
.sigleph img {
    width: 100%;
    height: auto
}
@media screen and (max-width: 1200px) {
    .content_blog {
        max-width: auto;
        margin: 0 10px 40px
    }
    .blogsingle h3 {
        font-size: 16px;
        font-weight: 600;
        margin: 10px 0 20px;
        padding-bottom: 10px;
        line-height: 1.7;
        border-bottom: 2px solid #70b42b;
        line-height: 1.7
    }
    .blogsingle p {
        line-height: 1.7;
        margin-bottom: 16px
    }
    .blogsingle p img {
        width: 80%;
        height: auto;
        object-fit: cover;
        background: url("../images/common/green_st.png");
        padding: 10px;
        border-radius: 10px;
        box-sizing: border-box;
        margin: auto auto 20px;
        display: block;
    }
    .sigleph {
        text-align: center;
        margin: 0 auto 20px;
        max-width: 80%;
    }
    .sigleph img {
        width: 100%;
        height: auto
    }
}
.content_work {
    max-width: 1150px;
    margin: 0 auto 80px
}
.work_result {
    display: flex;
    flex-wrap: wrap
}
.work_result li {
    width: 31%;
    border: 4px solid #70b42b;
    list-style-type: none;
    border-radius: 20px;
    overflow: hidden;
    position: relative;
    margin: 0 8px 20px;
    background: #fff
}
.work_result li img {
    width: 100%;
    height: auto
}
.work_result .cate {
    background: #70b42b;
    text-align: center;
    color: #fff;
    font-size: 14px;
    padding: 10px;
    position: absolute;
    border-bottom-right-radius: 20px;
    width: 200px
}
.work_result .date {
    padding: 10px 20px 0;
    font-size: 14px;
    color: #70b42b;
    margin-bottom: 0
}
.work_result h3 {
    padding: 10px 20px 20px;
    font-size: 18px;
    line-height: 1.5
}
.work_result li a:hover {
    color: #70b42b
}
.linkbox {
    display: flex;
    justify-content: space-between;
    margin-bottom: 40px
}
.linkbox a {
    width: 48.5%;
    box-sizing: border-box
}
@media screen and (max-width: 1200px) {
    .content_work {
        max-width: auto;
        margin: 0 10px 80px
    }
    .work_result {
        display: flex;
        flex-direction: column;
        flex-wrap: wrap
    }
    .work_result li {
        width: auto;
        border: 2px solid #70b42b;
        list-style-type: none;
        border-radius: 20px;
        overflow: hidden;
        position: relative;
        margin: 0 0 15px
    }
    .work_result li img {
        width: 100%;
        height: auto
    }
    .work_result .cate {
        background: #70b42b;
        text-align: center;
        color: #fff;
        font-size: 12px;
        padding: 10px;
        position: absolute;
        border-bottom-right-radius: 20px;
        width: 200px
    }
    .work_result .date {
        padding: 10px 10px 0;
        font-size: 12px;
        color: #70b42b;
        margin-bottom: 0
    }
    .work_result h3 {
        padding: 10px;
        font-size: 16px;
        line-height: 1.5
    }
    .work_result li a:hover {
        color: #70b42b
    }
    .linkbox {
        display: flex;
        justify-content: space-between;
        flex-direction: column;
        margin-bottom: 10px
    }
    .linkbox a {
        width: auto;
        box-sizing: border-box;
        margin-bottom: 10px
    }
}
.page_ph01_line {
    width: auto;
    margin-bottom: 40px;
    padding: 0
}
.page_ph01_line img {
    width: 100%;
    height: auto;
    border-radius: 10px;
    background: url("../images/common/green_st.png");
    padding: 10px;
    box-sizing: border-box
}
.textred {
    color: #c9151f
}
.mission {
    color: #3a5800;
    font-family: "Arial";
    font-size: 60px;
    font-weight: bold;
    text-align: center;
    margin-bottom: 40px
}
.mission_img img {
    margin-bottom: 20px
}
@media screen and (max-width: 1200px) {
    .mission {
        color: #3a5800;
        font-family: "Arial";
        font-size: 30px;
        font-weight: bold;
        text-align: center;
        margin-bottom: 10px
    }
    .mission_img img {
        margin-bottom: 20px
    }
}
.footernav {
    display: flex;
    justify-content: space-between;
    max-width: 1150px;
    margin: auto auto 50px;
}
.footernav_l,
.footernav_r {
    width: 50%;
    padding: 20px 40px;
    box-sizing: border-box
}
.footernav_l {
    border-right: 1px solid #dcdcdc;
    box-sizing: border-box
}
.footernav_l h2,
.footernav_r h2 {
    font-size: 20px;
    color: #70b42b;
    padding: 0;
    margin: 0 0 15px;
}
.footernav_l h2 a,
.footernav_r h2 a {
    color: #70b42b
}
.footernav_l ul,
.footernav_r ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap
}
.footernav_l li,
.footernav_r li {
    width: 49%;
    margin-bottom: 10px;
    font-size: 14px
}
.footernav_l li a,
.footernav_r li a {
    display: block
}
@media screen and (max-width: 1200px) {
    .footernav {
        display: flex;
        justify-content: space-between;
        flex-direction: column;
        max-width: auto;
        margin: auto auto 15px;
    }
    .footernav_l,
    .footernav_r {
        width: auto;
        padding: 0 20px;
        box-sizing: border-box;
        margin-bottom: 20px
    }
    .footernav_l {
        border-right: 0 solid #dcdcdc;
        box-sizing: border-box
    }
    .footernav_l h2,
    .footernav_r h2 {
        font-size: 16px;
        color: #70b42b;
        padding: 0;
        margin: 0 0 15px;
    }
    .footernav_l h2 a,
    .footernav_r h2 a {
        color: #70b42b
    }
    .footernav_l ul,
    .footernav_r ul {
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap
    }
    .footernav_l li,
    .footernav_r li {
        width: 49%;
        margin-bottom: 10px;
        font-size: 14px
    }
    .footernav_l li a,
    .footernav_r li a {
        display: block
    }
}
.cp_breadcrumb *,
.cp_breadcrumb *:after,
.cp_breadcrumb *:before {
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}
.cp_breadcrumb {
    padding: 10px 0
}
.cp_breadcrumb a {
    text-decoration: none;
    font-size: 14px
}
.cp_breadcrumb .breadcrumbs {
    padding-left: 0;
    margin: auto;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    max-width: 1120px;
}
.cp_breadcrumb li {
    display: inline-block;
    position: relative;
    padding-right: calc(16px + 8px);
    margin-right: 2px;
    font-size: 14px
}
.cp_breadcrumb li::before {
    content: '›';
    width: 1em;
    height: 1em;
    line-height: 1;
    text-align: center;
    font-size: 1.5em;
    color: inherit;
    position: absolute;
    top:5px;
    right: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}
.cp_breadcrumb li:last-child {
    margin-right: 0;
    padding-right: 0;
    color: #fff
}
.cp_breadcrumb li:last-child::before {
    content: normal
}
@media screen and (max-width: 834px){
    .cp_breadcrumb a {
        font-size: 12px
    }
    .cp_breadcrumb .breadcrumbs {
        width: auto;
        margin: auto 10px
 }
}