@charset "UTF-8";

/***************************************
01.Reset
02.共通
　ーヘッダー
　ーパンくず
　ーフッター
03.トップページ
04.
05.

***************************************/
/***************************************
01.Reset
***************************************/
/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
/***************************************
02.共通
***************************************/
body {
    font-size: 16px;
    color: #333;
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "メイリオ", Arial, Helvetica, "sans-serif";
    font-weight: 400;
    text-align: justify;
    text-justify: distribute; /*IE*/
    background: #fff;
    -webkit-text-size-adjust: 100%;
}
.text-01 p,
.text-02 p,
.text-03 p,
.text-04 p,
.text-05 p {
    line-height: 1.5em;
    padding-bottom: 1em;
}
p {
    line-height: 1.5em;
}
h1, h2, h3, h4, h5, h6 {
	font-weight: normal;
}

a {
	color: #37a171;
	text-decoration: none;
}
a:hover {
	color: #94cdb4;
	text-decoration: underline;
}

img {
	vertical-align: middle;
    width: 100%;
    margin: 0 auto;
}


.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	visibility: hidden;
	line-height: 0;
	height: 0;
}

.clear {
	clear: both;
}
.sp-only {
        display: none;
}
.pc-only {
    display: block;
}
.main {
    width: 80%;
    max-width: 1000px;
    margin: 10px auto 50px;
}
.main .lead-area span {
    color: #bf112e;
    font-weight: bold;
}
.main h3 {
    background-color: #66b894;
    font-size: 30px;
    font-weight: bold;
    color: #fff;
    padding: 8px 5px;
}
.main h3 p {
    border-bottom: 1px solid #cef3e3;
    position: relative;/*相対配置*/
    padding: 0 0 5px 80px;
}
.main h3 p:before {/*スペースを作る*/
    content: '';
    top: 0;
    left: 0;
    width: 100%;/*指定したい幅*/
    padding-top: 2%;/*画像の幅に対する高さ比率*/
    display: block;
}

.main h3 p:after {/*画像を絶対配置*/
    position: absolute;
    content: '';
    top: 0;
    left: 10px;
    display: block;
    width: 100%;/*幅*/
    height: 50px;/*どれだけデカくなってもはみ出ないであろう高さを指定*/
    background-image: url(../img/ttl-icon.png);
    background-size: contain;
    background-repeat: no-repeat;/*画像を繰り返さない*/
}
.main h4 {
    background-color: #cef3e3;
    font-size: 24px;
    font-weight: bold;
    color: #333;
    padding: 8px 5px;
}
.main h4 p {
    border-bottom: 1px solid #66b894;
    position: relative;/*相対配置*/
    padding: 0 0 10px 80px;
}
.main h4 p:before {/*スペースを作る*/
    content: '';
    top: 0;
    left: 0;
    width: 100%;/*指定したい幅*/
    padding-top: 2%;/*画像の幅に対する高さ比率*/
    display: block;
}

.main h4 p:after {/*画像を絶対配置*/
    position: absolute;
    content: '';
    top: 0;
    left:0;
    display: block;
    width: 100%;/*幅*/
    height: 50px;/*どれだけデカくなってもはみ出ないであろう高さを指定*/
    background-image: url("../img/sub-ttl-icon.png");
    background-size: contain;
    background-repeat: no-repeat;/*画像を繰り返さない*/
}
.main h3.r-span {
    
}
.main h3.r-span p:before {
    content: '';
    top: 0;
    left: 0;
    width: 100%;
    padding-top: 0px!important;
    display: block;
}
.main h3 span {
    color: #bf112e;
    font-size: 1.5em;
}

.main h5 {
    width: 25%;
    border-left: 6px solid #66b894;
    background-color: #eee;
    padding: 15px;
    font-size: 16px;
    font-weight: bold;
    color: #333;
}
.main .img-area {
    width: 55%;
    margin: 50px auto;
}
.btn {
    width: 35%;
    margin: 50px auto;
}
.btn:hover {
    opacity: 0.7;
}
.c-red-b {
    font-size: 28px;
    font-weight: bold;
    color: #be1f24;
}
.text-03 {
    width: 90%;
    margin: 30px auto;
}
.text-04 {
    font-size: 20px;
    font-weight: bold;
    width: 80%;
    margin: 0 auto;
}
.text-05 {
    font-size: 16px;
    width: 90%;
    margin: 30px auto;
}
.f-w-b {
    font-weight: bold;
}
.font-18 {
    font-size: 18px;
}
.font-20 {
    font-size: 20px;
}
/*------------ヘッダー-----------------*/

header {
    border-bottom: 2px solid #b5b5b5;
}
/*ヘッダートップ*/
.head-wrap {
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px 0px;
}
.head-wrap .h-top {
    height: 100px;
    padding-bottom: 30px;
}
.head-wrap .h-top .h-top-col1 {
    width: 45%;
    float: left;
}
.head-wrap .h-top .h-top-col1 p {
    font-size: 15px;
    padding: 5px 5px 0px 80px;
}
.head-wrap .h-top .h-top-col1 img {
    margin-top: -15px;
}
.head-wrap .h-top .h-top-col2 {
    width: 25%;
    text-align: center;
    float: left;
    padding-left: 10%;
}
.h-top-col2 li {
    padding-bottom: 5px;
}
.h-top-col2 .contact-text-01 {
    font-size: 13px;
}
.h-top-col2 span {
    color: #be1f24;
    font-weight: bold;
    font-size: 36px;
}
.h-top-col2 .contact-text-02 {
    font-size: 18px;
}
.h-top-col2 .contact-text-03{
	font-size:13px;
}
.head-wrap .h-top .h-top-col3 {
    width: 20%;
    float: left;
}

@media (min-width: 768px) and (max-width: 1024px) {
    .header_bottom {
        width: 100%;
        margin: 0 auto;
    }
    .header_bottom nav .main_nav {
        font-size: 16px;
    }
    .head-wrap {
        width: 95%;
    }
    .head-wrap .h-top .h-top-col1 p {
        font-size: 11px;
        padding: 5px 5px 5px 50px;
    }
    .head-wrap .h-top .h-top-col2 {
        padding-left: 2%;
    }
    .h-top-col2 .contact-text-01 {
        font-size: 9px;
    }
    .h-top-col2 span {
        font-size: 24px;
    }
    .h-top-col2 .contact-text-02 {
        font-size: 14px;
    }
    .head-wrap .h-top .h-top-col3 {
        width: 25%;
        float: right;
    }
    .head-wrap .h-top {
        height: 60px;
    }
}

/*ナビゲーション PC*/
.header_bottom {
    width: 90%;
    margin: 0 auto;
}
.header_bottom nav .main_nav {
    display: flex;
    justify-content: space-between;
    width: 100%;
    margin: 0 auto;
    height: auto;
    font-size: 18px;
}
.nav {
    overflow: hidden;
    margin: 0 auto;
    padding: 0;
    display: flex;
}
.nav li {
    list-style: none;
}
.main_nav li {
    text-align: center;
    line-height: 1.3em;
}
.nav li a {
    text-align: center;
    text-decoration: none;
    box-sizing: border-box;
    color: #333;
}
.nav > li:hover > a {/*layer-1*/
    color: #76c7c0;
}
.nav .current {
    padding-bottom: 8px;
    border-bottom: 3px solid #66b894;
}

/*タブレットナビゲーション*/
@media (min-width: 768px) and (max-width: 1024px) {
    .header_bottom nav .main_nav {
        font-size: 16px;
    }
}
/*スマホ ナビゲーション*/
  @media only screen and (max-width: 767px) {
    #top-head .inner {
        display: block;
    }
    #global-nav {
        position: absolute;
        /* 開いてないときは画面外に配置 */
        top: -500px;
        background: #a0a0a0;
        width: 95%;
        text-align: center;
        -webkit-transition: .5s ease-in-out;
        -moz-transition: .5s ease-in-out;
        transition: .5s ease-in-out;
		/*height: 60vh;*/
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
        z-index: 10;
    }
    #global-nav ul {
        list-style: none;
        position: static;
        right: 0;
        bottom: 0;
        font-size: 14px;
        margin: 0 auto;
    }
	#global-nav ul.menu {
		display: block;
	}
    #global-nav ul li {
        float: none;
        position: static;
        padding: 8px 0;
    }
    .nav li ul {
        width: 250px;
    }
    .nav li ul li {
        padding: 5px 0 5px 30px!important;
    }
    .nav li ul li a {
        border-top: none;
        background: #222;
        text-align: center;
        padding: 0;
    }
    #global-nav .btn_contact a {
        color: #fff;
        background: #ac945d;
        border-radius: 5px;
        padding: 1em 2em;
        display: inline!important;
    }
	#global-nav .sp-contact li:first-child {
		padding: 0;
	}
	#global-nav .sp-contact li {
		padding: 18px 0;
		background-color: #222;
	}
	#global-nav .sp-contact li:last-child {
		border: none;
	}
    #global-nav .tel_top {
        font-size: 20px;
    }
    #global-nav .tel_top::before {
        content: '';
        display: inline-block;
        background-image: url("../img/f-tel.png");
        background-size: contain;
        background-repeat: no-repeat;
        vertical-align: baseline;
        width: 25px;
        height: 25px;
        padding-right: 0.5em;
    }
    #top-head #global-nav ul li a,
    #top-head.fixed #global-nav ul li a {
        width: 100%;
        display: block;
        color: #fff;
    }
	#top-head a, #top-head {
		color: #fff;
		text-decoration: none;
        z-index: 100;
	}
    #nav-toggle {
        display: block;
    }
    /* Toggle Button */
    #nav-toggle {
        position: absolute;
        right: 12px;
        top: 14px;
        width: 34px;
        height: 36px;
        cursor: pointer;
        z-index: 101;
    }
    #nav-toggle div {
        position: relative;
    }
    #nav-toggle span {
        display: block;
        position: absolute;
        height: 4px;
        width: 100%;
        background: #666;
        left: 0;
        -webkit-transition: .35s ease-in-out;
        -moz-transition: .35s ease-in-out;
        transition: .35s ease-in-out;
    }
    #nav-toggle span:nth-child(1) {
        top: 0;
    }
    #nav-toggle span:nth-child(2) {
        top: 11px;
    }
    #nav-toggle span:nth-child(3) {
        top: 22px;
    }
    /* #nav-toggle 切り替えアニメーション */
    .open #nav-toggle span:nth-child(1) {
        top: 11px;
        -webkit-transform: rotate(315deg);
        -moz-transform: rotate(315deg);
        transform: rotate(315deg);
    }
    .open #nav-toggle span:nth-child(2) {
        width: 0;
        left: 50%;
    }
    .open #nav-toggle span:nth-child(3) {
        top: 11px;
        -webkit-transform: rotate(-315deg);
        -moz-transform: rotate(-315deg);
        transform: rotate(-315deg);
    }
    /* #global-nav スライドアニメーション */
    .open #global-nav {
        /* #global-nav top + #mobile-head height */
        -moz-transform: translateY(570px);
        -webkit-transform: translateY(570px);
        transform: translateY(570px);
		height: 70vh;
        overflow-x: scroll;
        background-color: rgba(49,49,49,0.9);
    }
    .open .nav .btn_contact a {
        background: none;
    }
    .head-wrap {
        padding: 10px 0px;
      }
    .head-wrap .h-top {
        height: 50px;
        padding-bottom: 0;
    }  
    .head-wrap .h-top .h-top-col1 {
        width: 80%;
        float: none;
        color: #333;
    }
    .head-wrap .h-top .h-top-col1 p {
        font-size: 6px;
        padding: 5px 5px 10px 40px;
    }
    #global-nav .h-top-col3 {
        width: 50%;
        margin: 0 auto;
    }
    #global-nav .contact-text-01 {
        line-height: 1.5em;
        font-size: 0.8em;
        color: #cef3e3;
    }
    #global-nav .contact-text-01 span {
        font-size: 2em;
        font-weight: bold;
        line-height: 1.5em;
      }
}


/*------------パンくず-----------------*/
.breadcrumb {
  padding: 10px 10px 20px 10px;
    text-align: left;
}

.breadcrumb li {
  display: inline;
  font-size: 0.800em;
}

.breadcrumb li a {
  color: #333333;
}

.breadcrumb li a:hover {
  text-decoration: underline;
  color: #94cdb4;
}

/*------------フッター-----------------*/
footer {
    border-top: 1px solid #333;
    padding: 30px 0px;
}
.f-top {
    width: 90%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}
.f-left {
    width: 35%;
}
.f-left img {
    margin-top: -10px
}
.f-right {
    width: 35%;
    padding-left: 30%;
    line-height: 1.5em;
}
.h-top-col1 p {
    font-size: 0.8em;
    padding-left: 60px;
    padding-bottom: 0;
}
.f-bottom {
    padding: 20px 20px 0 20px;
    text-align: center;
}
/*ページトップ*/
.pagetop {
	position: fixed;
    bottom: 10px;
    right: 0;
    float: right;
}
.pagetop img {
	width: 50px;
}

/***************************************
03.トップページ
***************************************/
.home .mv-area {
    background: url("../img/mv-pc.jpg") no-repeat center center/cover;
    height: 0;
    padding-top: calc(600 / 1920 * 100%);
}
.home .main .lead-area {
    font-size: 24px;
    line-height: 2.3em;
    font-weight: bold;
    text-align: center;
    padding: 50px 0;
}
.home .text-01 {
    font-size: 20px;
    width: 80%;
    margin: 30px auto;
}
.check-bg-list {
    width: 70%;
    background: url("../img/bg-st.jpg")repeat;
    border: 3px solid #37a172;
    border-radius: 20px;
    padding: 40px;
    margin: 75px auto;
    font-size: 24px;
    font-weight: bold;
}
.check-bg-list li {
    line-height: 2.5em;
}
.check-bg-list span {
    color: #bf112e;
}

/*RSS*/
/*Blog-トップ*/
.blog-area .blog_box {
	width: 90%;
	margin: 0 auto;
	display: flex;
	justify-content: space-around;
}
.blog-area .blog_box .blog_col {
	width: 22%;
	border: 1px solid #b5b5b5;
	line-height: 1.25em;
}
.blog-area .blog_box .blog_col .header_box {
    padding: 0.5em;
    font-size: 15px;
}
.blog-area .blog_box .blog_col img {
	width: 100%;
    height: 150px;
    object-fit: cover;
}
.blog-area .blog_box .blog_col p {
	padding: 0.5em 1em 1em 1em;
	font-size: 0.875em;
}
.blog-area .blog_box .blog_col a.ttl {
    color: #333;
}
.blog-area .blog_box .blog_col a.ttl:hover {
    color: #94cdb4;
}
.blog-area .blog_box .blog_col .cate {
	font-size: 0.5em;
	background-color: #b7a694;
	color: #fff;
	border-radius: 5px;
	padding: 0.25em 0.5em;
	margin-top: 0.5em;
	float: left;
}
.blog-area .blog_box .blog_col .date {
	float: left;
	font-size: 0.75em;
}
.top-blog-thumb {
	overflow: hidden;
}
.top-blog-thumb img {
	-moz-transition: -moz-transform 0.5s linear;
    -webkit-transition: -webkit-transform 0.5s linear;
    -o-transition: -o-transform 0.5s linear;
    -ms-transition: -ms-transform 0.5s linear;
    transition: transform 0.5s linear;
}
.top-blog-thumb img:hover {
	-webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -o-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
}
/***************************************
04.弊社の強み
***************************************/
.strength .lead-area .text-01 {
    text-align: center;
    padding: 50px 0;
}
.strength .lead-area .text-02 {
    font-size: 18px;
    width: 80%;
    margin: 0 auto;
}
.strength .text-04 {
    font-size: 20px;
    font-weight: bold;
    width: 80%;
    margin: 0 auto;
}
.strength .text-05 {
    font-size: 16px;
    width: 80%;
    margin: 30px auto;
}
.strength .text-04 span {
    color: #be1f24;
}
.strength .main .sec-02 .img-area {
    width: 100%;
    display: flex;
    justify-content: space-between;
}
.strength .main .sec-02 .img-left {
    width: 40%;
}
.strength .main .sec-02 .img-right {
    width: 55%;
}
.strength .main .sec-03 .img-area {
    width: 100%;
    display: flex;
    justify-content: space-between;
}
.strength .main .sec-03 .img-left {
    width: 40%;
}
.strength .main .sec-03 .img-right {
    width: 50%;
}
/***************************************
05.サービス紹介
***************************************/
.service .btn {
    width: 40%;
}
.service .lead-area .text-01,
.recruit .lead-area .text-01 {
    font-size: 18px;
    padding: 30px 0;
    width: 90%;
    margin: 0 auto;
}
.service .lead-area .text-02 {
    font-size: 24px;
    font-weight: bold;
    width: 90%;
    margin: 0 auto;
}
.service .lead-area .text-02 .sub-ttl {
    text-align: center;
    color: #be1f24;
}
.sec-04 h4 span {
    /*background-color: #be1f24;
    color: #fff;
    padding: 8px;*/   
}
.sec-04 h4 span::after {
    display: inline-block;
    background: url(../img/recommend-6.png);
    content: '';
    width: 240px;
    height: 44px;
    margin-top: -10px;
    position: absolute;
    background-size: contain;
    background-repeat: no-repeat;
}
.service .prca-model {
    width: 90%;
    margin: 0 auto 80px;
    border: 4px solid #eee;
    padding: 40px 20px 20px 20px;
}
.service .sec-02 > p {
    font-size: 24px;
    font-weight: bold;
    text-align: center;
    padding-top: 50px;
}

.service .check-bg-list {
    width: 90%;
    background: url("../img/bg-st.jpg")repeat;
    border: 3px solid #37a172;
    border-radius: 20px;
    padding: 40px;
    margin: 75px auto;
    font-weight: normal;
}
.service .check-bg-list dl {
    padding: 20px;
}
.service .check-bg-list dt {
    font-weight: bold;
}
.service .check-bg-list dd {
    font-weight: normal;
    font-size: 16px;
    padding-top: 20px;
}
.service .program-area {
    display: flex;
    justify-content: space-between;
    width: 80%;
    margin: 0 auto;
}
.service .main h5 {
    width: 100%;
    border-left: 6px solid #66b894;
    background-color: #eee;
    padding: 15px;
    font-size: 16px;
    font-weight: bold;
    color: #333;
}
.service .program-area .p-box .text-box {
    padding: 15px;
}
.service .program-area .p-box p{
    font-weight: bold;
    font-size: 18px;
    padding-bottom: 10px;
}
.service .program-area .p-box ul li {
    padding-bottom: 10px;
}
.service .spot {
    margin: 80px auto;
}
.service .spot .text-box-01 {
    padding-bottom: 30px;
}
.service .main .spot h5 {
    width: 30%;
}
.service .main .spot-area {
    display: flex;
    justify-content: space-between;
    padding: 30px 0px;
}
.service .main .spot-area .text-box {
    width: 60%;
}
.service .main .spot-area .img-area {
    width: 30%;
    margin: 0 auto;
}
.service .main .book-pr .spot-area .img-area {
    width: 40%;
    display: flex;
    justify-content: space-around;
}
.service .main .book-pr .spot-area .img-area p {
    width: 45%;
}
.service .main .book-pr p.yakudatsu span {
    padding-bottom: 5px;
    line-height: 1.2em;
    margin-bottom: 10px;
    font-weight: bold;
    font-size: 20px;
    color: #da2f3a;
    background: linear-gradient(#0000 60%, #f1ea14 60%);
}
.service .main .spot-area .img-area ul li {
    padding-bottom: 10px;
}
.service .main .spot-area .text-box p {
    padding-bottom: 10px;
    line-height: 1.5em;
}
.service .know-how {
    font-size: 24px;
    font-weight: bold;
    text-align: center;
    padding: 30px 0px;
}

.service .know-how-area .know-how-t-btn {
    display: flex;
    justify-content: space-around;
    align-items: center;
}
.service .know-how-area {
    border: 2px solid #66b894;
    padding: 20px;
    margin-bottom: 20px;
}
.recruit .know-how-area {
    width: 66%;
    border: 2px solid #66b894;
    padding: 2%;
    margin: 20px auto;
}
.service .know-how-area .know-how-box .ttl,
.recruit .know-how-area .know-how-box .ttl {
    font-size: 18px;
    font-weight: bold;
    color: #da2f3a;
    padding-bottom: 8px;
    border-bottom: 2px solid #bfbfbf;
}
.recruit .know-how-area .know-how-box .ttl {
    text-align: center;
}
.service .know-how-area .know-how-box {
    font-size: 18px;
    font-weight: bold;
    color: #da2f3a;
    padding-bottom: 8px;
}
.recruit .know-how-area .know-how-box {
    font-size: 18px;
    font-weight: bold;
    color: #da2f3a;
    padding-bottom: 15px;
}
.service .know-how-area .text-01{
    width: 60%;
}
.recruit .know-how-area .text-01 {
    width: 100%;
    padding-top: 10px;
}
.service .know-how-area .text-01 .target,
.recruit .know-how-area .text-01 .target {
    font-weight: bold;
    font-size: 18px;
} 
.service .know-how-area .btn-01 {
    width: 30%;
}
.service .know-how-area .btn-01:hover {
    opacity: 0.7;
}
.service .case-mini {
    border: 3px solid #b2b2b2;
    padding: 20px;
    line-height: 1.5em;
    font-weight: bold;
}
/*事例・実績*/
.service .main .case-area h5 {
    width: 30%;
    border-left: 6px solid #66b894;
    background-color: #eee;
    padding: 15px;
    font-size: 16px;
    font-weight: bold;
    color: #333;
}
.service .case-mv {
    margin-bottom: 80px;
}
.service　.case-area {
    
}
.service .case-area .catch {
    color: #bf112e;
    font-weight: bold;
    font-size: 28px;
    text-align: center;
    padding: 50px 0px;
    line-height: 1.5em;
}
.service .case-area .text-01 {
    width: 90%;
    margin: 0 auto;
    padding: 30px 0;
}
.service .case-area .sec-06 .after {
    padding-left: 20px;
    font-weight: bold;
    font-size: 18px;
}
.service .case-area .sec-06 .after p {
    position: relative;/*相対配置*/
    padding: 0 0 10px 80px;
}
.service .case-area .sec-06 .after p::before {/*スペースを作る*/
    content: '';
    top: 0;
    left: 0;
    width: 100%;/*指定したい幅*/
    display: block;
}

.service .case-area .sec-06 .after p::after {/*画像を絶対配置*/
    position: absolute;
    content: '';
    top: 5px;
    left:-20px;
    display: block;
    width: 100%;/*幅*/
    height: 15px;/*どれだけデカくなってもはみ出ないであろう高さを指定*/
    background-image: url("../img/arrow-01.png");
    background-size: contain;
    background-repeat: no-repeat;/*画像を繰り返さない*/
}
.service .case-area .case-box-01 h4 span,
.service .case-area .case-box-02 h4 span {
    background-color: #37a171;
    padding: 0.2em 0.45em;
    border-radius: 50%;
    color: #cef3e2;
}
/***************************************
06.会社概要
***************************************/
.about .sub-mv-area {
    padding-bottom: 80px;
}
.about .catch {
    padding: 50px 0px;
    text-align: center;
}
.about .consept-area {
    text-align: center;
    padding-top: 50px;
}
.about .text-02 {
    font-size: 18px;
    padding: 30px 0;
    width: 90%;
    margin: 0 auto;
}
.about .text-02 p {
    line-height: 2em;
}
.about .puls .text-01 {
    background-color: #eee;
    padding: 30px 20px 10px 20px;
}
.about .puls {
    position: relative;
    margin-bottom: 50px;
}
.about .puls .pr-ttl {
    background-color: #cef3e3;
    padding: 0.5em;
    margin-top: -10px;
    margin-left: -10px;
    /* margin-bottom: -10px; */
    position: absolute;
    z-index: 10;
}
.about .puls .pr-01 {
    margin-bottom: 30px;
}
.about .name {
    padding-top: 50px;
    font-size: 30px;
    font-weight: bold;
}
.about .position {
    padding: 20px 0px;
    line-height: 1.5em;
}

.about .profile {
    background-color: #cef3e3;
    padding: 20px;
    line-height: 1.5em;
    margin-bottom: 50px;
}
.about .profile p {
    padding-bottom: 10px;
}
.about .book {
    display: flex;
    justify-content: space-between;
}
.about .book .book-01 {
    width: 50%;
    display: flex;
    padding: 10px;
}
.about .book .book-01 .text-01  p {
    font-size: 15px;
    padding: 10px;
}
.about .book .book-01 .text-01 .ttl {
    font-size: 18px;
    font-weight: bold;
    width: 90%;
}
.about .book .book-01 .text-01 {
    width: 70%;
}
.about .book .img-area {
    width: 30%;
}
.about .message {
    padding-bottom: 50px;
}
.about .message .sub-mv-02 .img-area {
    width: 100%;
}
.about .message .text-01 {
    width: 90%;
    margin: 0 auto;
}
.about .message .img-area {
    width: 80%;
    margin: 0 auto;
}
.about table .company-01 {
    background-color: #e9f5f0;
    width: 20%;
    padding-left: 30px;
}
.about table td {
    padding: 1em;
    border: 1px solid #b5b5b5;
}
.about table {
    /*border: 1px solid #eee;*/
    width: 90%;
    margin: 30px auto;
}
.about table td li {
    padding-bottom: 10px;
    list-style: disc;
    list-style-position: inside;
}
.about .blog-area {
    margin-top: 30px;
}
/***************************************
07.実績・事例
***************************************/
.case .lead-area .text-01 {
    font-size: 18px;
    padding: 30px 0;
    width: 90%;
    margin: 0 auto;
}
.case .case-area .text-01 {
    width: 90%;
    margin: 0 auto;
    padding: 30px 0;
}
.case .case-area .catch {
    color: #bf112e;
    font-weight: bold;
    font-size: 28px;
    text-align: center;
    padding: 50px 0px;
    line-height: 1.5em;
}
.case .case-2 h4 {
    margin-bottom: 30px;
}
.case .sec-06 {
    margin-top: 50px;
}
.case .sec-06 .other {
    width: 70%;
    margin: 0 auto;
    border: 3px solid #b2b2b2;
    padding: 20px;
    line-height: 1.5em;
    font-weight: bold;
}
.case .sec-06 .other .other-1 {
    padding-bottom: 20px;
}
.case .matone {
    font-size: 18px;
    font-weight: bold;
    padding: 50px;
}
.case .matone p {
    line-height: 2em;
}
.case .btn {
    width: 50%;
}
/***************************************
08.採用情報
***************************************/
.recruit .sec-03 .text-05 .first-text {
    color: #bf112e;
    font-weight: bold;
    font-size: 1.5em;
    text-align: center;
}
.recruit .sec-03 .text-05 .second-text {
    font-weight: bold;
    font-size: 1.2em;
    text-align: center;
}
.recruit .sec-03 .text-05 .misson {
    padding: 40px 0;
}
.recruit .main .sec-04 h5 {
    width: 97%;
    font-size: 20px;
}
.recruit .sec-04 .text-img {
    display: flex;
    padding: 20px 0;
}
.recruit .sec-04 .text-05 {
    width: 60%;
    margin: 0 auto;
    padding-right: 15px;
}
.recruit .sec-04 .img-area {
    width: 40%;
    margin: 0 auto;
}
.recruit .sec-04 .box-01 {
    width: 100%;
    margin: 10px auto 80px;
    display: flex;
}
.recruit .sec-04 .box-01 .check-bg-list {
    width: 90%;
    padding: 15px;
}
.recruit .sec-04 .box-01 .recruitbox {
    width: 45%;
    margin: 0 auto;
    font-size: 18px;
}
.recruit .sec-04 .box-01 .recruitbox ul li::before {
    content: "";
    background: url("../img/check-1.png")no-repeat;
    background-size: cover;
    display: inline-block;
    margin-right: 10px;
    vertical-align: middle;
    width: 18px;
    height: 18px;
}
.recruit .sec-04 .text-06 {
    font-size: 18px;
    padding: 30px 0;
    width: 90%;
    margin: 0 auto;
}
.recruit .sec-04 h6 {
    background-color: #66b894;
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    padding: 1em;
}
.recruit .sec-04-2 h4 {
    background-color: #cef3e3;
    font-size: 20px;
    font-weight: bold;
    padding: 1em;
}
.recruit .sec-04 .company_outline table {
    width: 90%;
    margin: 0 auto 50px;
    font-size: 16px;
    border: solid 1px #ccc;
    color: #444;
}
.recruit .sec-04 .company_outline table .L {
    background: #F2F1F1;
    width: 25%;
    vertical-align: middle;
    text-align: center;
    font-size: 18px;
    font-weight: bold;
}
.recruit .sec-04 .company_outline table td {
    padding: 20px;
    border-bottom: dashed 1px #aaa;
}
.recruit .sec-04 .company_outline table td ul li {
    list-style: disc;
    list-style-position: inside;
    padding-bottom: 10px;
}
.recruit .know-how-area dl {
    padding-bottom: 20px;
}
.recruit .know-how-area dt{
    float: left;
    background-color: #2B99C6;
    color: #fff;
    padding: 0.5em;
}
.recruit .know-how-area  dd{
    margin-left: 100px;
    padding: 0.5em;
    font-weight: bold;
}
.recruit .know-how-area ul {
    margin: 30px 0 0 100px;
}
.recruit .know-how-area ul li {
    padding-bottom: 10px;
}
.recruit .know-how-area .dl-2 {
    border-bottom: 1px dashed #bfbfbf;
}
.recruit .process-card {
    display: flex;
    align-items: center;
    width: 90%;
    margin: 30px auto;
    padding: 30px;
    border: 2px solid #66b894;
}
.recruit .process-card p {
    padding-bottom: 10px;
    font-size: 18px;
}
.recruit .process-card ul {
    padding: 20px 0;
}
.recruit .process-card ul li {
    padding-bottom: 10px;
}
.recruit .process-card .number {
    width: 15%;
    text-align: center;
    background-color: #66b894;
    color: #fff;
    display: table;
    padding: 10px;
    border-radius: 50%;
}
.recruit .process-card .card-number{
    display: table-cell;
    vertical-align: middle;
}
.recruit .process-card .number .card-number p {
    padding-bottom: 0;
}
.recruit .process-card .number .card-number span {
    font-size: 2.5em;
    display: block;
    padding-top: 5px;
}
.recruit .process-card .ttl {
    width: 15%;
    color: #66b894;
    padding: 10px 10px 10px 20px;
    font-size: 24px;
    font-weight: bold;
}
.recruit .process-card .text {
    width: 70%;
}
.recruit .process-card .text p {
    font-weight: bold;
}
.recruit .process-card .text .email {
    color: #2b99c6;
    padding-top: 10px;
}
.recruit .process-card .text .email::before {
    content: "";
    display: inline-block;
    background: url("../img/mail.png")no-repeat;
    background-size: cover;
    width: 42px;
    height: 26px;
    margin-right: 10px;
    vertical-align: middle;
}

.recruit .recruit-info .email {
    padding-top: 20px;
}
.recruit .recruit-info .email::before {
    content: "";
    display: inline-block;
    background: url("../img/mail.png")no-repeat;
    background-size: cover;
    width: 42px;
    height: 26px;
    margin-right: 10px;
    vertical-align: middle;
}
.recruit .arrow-area {
    margin: 0 auto;
    width: 5%;
    text-align: center;
}
.recruit .process-card .arrow-area img {
    width: 100%;
}
.recruit .recruit-info {
    width: 80%;
    background-color: #bce3f3;
    padding: 10px;
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    margin: 0 auto; 
}
.recruit .recruit-info .inner {
    border: 1px solid #2b99c6;
    padding: 40px;
}
/***************************************
09.レスポンシブ
***************************************/
@media (min-width: 768px) and (max-width: 1024px) {
    .header_bottom nav .main_nav {
        
    }
    .main {
        width: 90%;
        margin: 10px auto 50px;
    }
    .main h3 {
        font-size: 20px;
    }
    .main h3 p:after {
        width: 100%;
        height: 40px;
    }
    .strength .lead-area .text-02 {
        width: 90%;
    }
    .text-04 {
        font-size: 18px;
    }
    .text-05 {
        font-size: 16px;
        width: 95%;
    }
    .home .main .lead-area {
        font-size: 18px;
    }
    .home .main .lead-area p {
        line-height: 2.3em;
    }
    .c-red-b {
        font-size: 24px;
    }
    .service .program-area {
        width: 100%;
    }
    .service .main h5 {
        width: 70%;
    }
    .service .case-area .catch {
        font-size: 22px;
    }
    .service .program-area .p-box .text-box ul {
        font-size: 13px;
    }
    .service .main .spot h5 {
        width: 50%;
    }
    .check-bg-list {
        width: 90%;
        font-size: 20px;
    }
    .btn {
        width: 40%;
        margin: 50px auto;
    }
    .f-top {
        width: 95%;
    }
    .f-left {
        width: 50%;
    }
    .h-top-col1 p {
        font-size: 0.7em;
    }
    .f-right {
        width: 40%;
        padding-left: 5%;
        font-size: 12px;
        line-height: 1.5em;
    }
    .blog-area .blog_box {
        width: 100%;
        margin: 0 auto;
        display: flex;
        justify-content: space-between;
    }
    .blog-area .blog_box .blog_col {
        width: 23%;
    }
    .blog-area .blog_box .blog_col img {
        width: 100%;
        height: 100px;
        object-fit: cover;
    }
    .blog-area .blog_box .blog_col p {
        padding: 0.5em 1em 1em 1em;
        font-size: 0.75em;
    }
    
}
@media only screen and (max-width: 767px) {
    
    .sp-only {
        display: block;
    }
    .pc-only {
        display: none;
    }
    .home .mv-area {
        background: url("../img/mv-sp.jpg") no-repeat center center/cover;
        height: 0;
        padding-top: calc(500 / 1000 * 100%);
    }
    /*共通*/
    .main {
        width: 90%;
        margin: 30px auto;
    }
    .c-red-b {
        font-size: 20px;
    }
    .main h3 {
        font-size: 20px;
    }
    .main h3 p {
        padding: 0 0 10px 45px;
    }
    .main h3 p:after {
        position: absolute;
        content: '';
        top: 0;
        left: 0;
        display: block;
        width: 75%;
        height: 30px;
        background-image: url(../img/ttl-icon.png);
        background-size: contain;
        background-repeat: no-repeat;
    }
    .main h4 {
        font-size: 18px;
        line-height: 1.25em;
    }
    .main h4 p {
        padding: 0 0 10px 45px;
    }
    .main h4 p:after {
        position: absolute;
        content: '';
        top: 0;
        left: 0;
        display: block;
        width: 75%;
        height: 30px;
        background-image: url(../img/sub-ttl-icon.png);
        background-size: contain;
        background-repeat: no-repeat;
    }
    .main h5 {
        width: 90%;
    }
    .main .img-area {
        width: 80%;
        margin: 30px auto;
    }
    .check-bg-list {
        width: 90%;
        background: url(../img/bg-st.jpg)repeat;
        border: 3px solid #37a172;
        border-radius: 20px;
        padding: 15px;
        margin: 30px auto;
        font-size: 16px;
        font-weight: bold;
    }
    .check-bg-list li {
        line-height: 1.5em;
        padding-bottom: 10px;
    }
    .btn {
        width: 90%;
        margin: 30px auto;
    }
    .nav .current {
        border-bottom: none;
    }
    
    /*フッター*/
    .f-top {
        display: block;
    }
    .f-left {
        width: 100%;
    }
    .f-left .h-top-col1 p {
        font-size: 0.6em;
        padding-left: 50px;
        padding-bottom: 0;
    }
    .f-right {
        width: 100%;
        padding-left: 0;
        line-height: 1.5em;
        font-size: 0.8em;
        text-align: center;
        padding: 10px 0px;
    }
    .f-bottom {
        padding: 20px 10px;
        text-align: center;
        font-size: 0.8em;
    }
    /*トップ*/
    .home .main .lead-area {
        font-size: 18px;
        line-height: 1.5em;
        text-align: left;
        padding-bottom: 20px;
    }
    .main .lead-area span {
        color: #bf112e;
        font-weight: bold;
        padding: 20px 0px;
        display: block;
        text-align: center;
    }
    .home .text-01 {
        font-size: 18px;
        width: 90%;
        margin: 30px auto 20px;
    }
    .home .main .img-area {
        width: 80%;
        margin: 0 auto 30px;
    }
    
    /*弊社の強み*/
    .strength .lead-area .text-01 {
        text-align: center;
        padding: 20px 0;
    }
    .strength .lead-area .text-02 {
        font-size: 16px;
        width: 90%;
        margin: 0 auto;
    }
    .strength .text-04 {
        font-size: 18px;
        font-weight: bold;
        width: 90%;
        margin: 0 auto;
    }
    .strength .main .sec-02 .img-area {
        display: block;
    }
    .strength .main .sec-02 .img-left {
        width: 60%;
        margin: 0 auto 20px;
    }
    .strength .main .sec-02 .img-right {
        width: 80%;
        margin: 0 auto;
    }
    .strength .main .img-area {
        margin: 0 auto 30px;
    }
    .strength .main .sec-03 .img-area {
        display: block;
    }
    .strength .main .sec-03 .img-area .img-left {
        width: 80%;
        margin: 0 auto 20px;
    }
    .strength .main .sec-03 .img-area .img-right {
        width: 80%;
        margin: 0 auto;
    }
    
    .strength .main .sec-04 .main .img-area {
        width: 80%;
        margin: 0 auto;
    }
    
    /*サービス紹介*/
    .service .btn {
        width: 80%;
    }
    .service .lead-area .text-02,
    .service .sec-02 > p {
    font-size: 18px;
    }
   .service .check-bg-list {
        width: 90%;
        background: url(../img/bg-st.jpg)repeat;
        border: 3px solid #37a172;
        border-radius: 20px;
        padding: 15px;
        margin: 30px auto;
        font-weight: normal;
       font-size: 16px;
    }
    .service .program-area {
        display: block;
        width: 90%;
        margin: 0 auto;
    }
    .service .main h5 {
        width: 90%;
    }
    .service .case-area .catch {
        font-size: 18px;
        line-height: 1.5em;
    }
    .service .main .case-area h5 {
        width: 50%;
    }
    .service .main .spot h5 {
        width: 90%;
    }
    .service .know-how {
        font-size: 20px;
    }
    .service .know-how-area .know-how-t-btn {
        display: block;
    }
    .service .know-how-area .text-01 {
        width: 90%;
        margin: 0 auto;
    }
    .service .know-how-area .btn-01 {
        width: 90%;
        margin: 0 auto;
    }
    .service .main .spot-area {
        display: block;
    }
    .service .main .spot-area .text-box {
        width: 90%;
        margin: 0 auto;
    }
    .service .main .spot-area .img-area {
        width: 90%;
        margin: 0 auto;
    }
    .service .main .book-pr .spot-area .img-area {
        width: 60%;
        margin: 0 auto;
    }
    .service .know-how-area .know-how-box .ttl {
        font-size: 18px;
        line-height: 1.5em;
        text-align: center;
        color: #da2f3a;
        padding-bottom: 8px;
        border-bottom: 2px solid #bfbfbf;
    }
    .service .sec-04 h4 span::after {
        display: inline-block;
        background: url(../img/recommend-6.png);
        content: '';
        width: 150px;
        height: 25px;
        top: -20px;
        left: 190px;
        transform: skewY(-10deg);
        position: absolute;
        background-size: contain;
        background-repeat: no-repeat;
    }
    /*会社概要*/
    .about .sub-mv-area {
        padding-bottom: 20px;
    }
    .about .catch {
        padding: 30px 0px;
    }
    .about　.c-red-b {
        font-size: 18px;
    }
    .about .text-02 {
        font-size: 16px;
        padding: 20px 0;
        width: 90%;
        margin: 0 auto;
    }
    .about .name {
        padding-top: 30px;
        font-size: 22px;
    }
    .about .book {
        display: block;
    }
    .about .book .book-01 {
        width: 90%;
        margin: 0 auto;
        display: block;
        padding: 10px;
    }
    .about .book .img-area {
        width: 60%;
    }
    .about .book .book-01 .text-01 {
        width: 90%;
        margin: 0 auto;
    }
    .about table .company-01 {
        background-color: #e9f5f0;
        width: 90%;
        padding-left: 10px;
    }
    .about table td {
        display: block;
    }
    .about table td li {
        padding-bottom: 10px;
        list-style: disc;
        list-style-position: unset;
        width: 90%;
        margin: 0 auto;
        font-size: 14px;
    }
    .blog-area .blog_box {
        width: 90%;
        display: block;
    }
    .blog-area .blog_box .blog_col {
        width: 100%;
        margin-bottom: 20px;
    }
    
    /*採用情報*/
    .recruit .sec-04 .text-img {
        display: block;
    }
    .recruit .sec-04 .text-05 {
        width: 90%;
    }
    .recruit .sec-04 .img-area {
        width: 90%;
        margin: 0 auto;
    }
    .recruit .sec-04 .box-01 {
        width: 90%;
        display: block;
    }
    .recruit .sec-04 .box-01 .recruitbox {
        width: 90%;
        font-size: 16px;
    }
    .recruit .check-bg-list li {
        line-height: 1.5em;
        padding-bottom: 15px;
        text-indent: -1.8em;
        padding-left: 1em;
    }
    .recruit .main .sec-04 h5 {
        width: 90%;
    }
    .recruit .sec-04 .company_outline table .L {
        width: 88%;
    }
    .recruit .sec-04 .company_outline table td {
        display: block;
    }
    .recruit .sec-04 .company_outline table ul {
        width: 90%;
    }
    .recruit .sec-04 .company_outline table td ul li {
        list-style: disc;
        list-style-position: inside;
        padding-bottom: 15px;
        text-indent: -1.4em;
        padding-left: 1em;
        line-height: 1.5em;
    }
    .recruit .know-how-area {
        width: 90%;
    }
    .recruit .know-how-area dt {
        float: none;
        text-align: center;
    }
    .recruit .know-how-area dd {
        margin-left: 0;
        padding: 1em;
        line-height: 1.5em;
        font-weight: bold;
    }
    .recruit .know-how-area ul {
        margin: 10px;
    }
    .recruit .know-how-area ul li {
        padding-bottom: 15px;
        line-height: 1.5em;
    }
    .recruit .process-card {
        display: block;
        padding: 5%;
    }
    .recruit .process-card .number {
        width: 90%;
        margin: 0 auto;
        border-radius: 10px;
        text-align: center;
    }
    .recruit .process-card .number .card-number span {
        font-size: 1em;
        display: inline-block;
    }
    .recruit .process-card .number p {
        padding-bottom: 0;
        font-size: 24px;
    }
    .recruit .process-card .ttl {
        width: 90%;
        padding: 20px;
        text-align: center;
        font-size: 28px;
    }
    .recruit .process-card .text {
        width: 100%;
    }
    .recruit .process-card ul {
        line-height: 1.5em;
    }
    .recruit .process-card .text .email {
        text-align: center;
    }
    .recruit .arrow-area {
        width: 10%;
    }
    .recruit .recruit-info {
        width: 95%;
    }
    .recruit .recruit-info .inner {
        padding: 30px;
    }
    
}




