@import url(https://fonts.googleapis.com/css?family=Noto+Sans);
@import url(https://fonts.googleapis.com/earlyaccess/notosansjp.css);
body {
    margin: 0
}

address,
blockquote,
dl,
figure,
form,
iframe,
p,
pre,
table {
    margin: 0
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: inherit;
    line-height: inherit;
    font-weight: inherit;
    margin: 0
}

ol,
ul {
    margin: 0;
    padding: 0;
    list-style: none
}

*,
::after,
::before {
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

html {
    scroll-behavior: smooth
}

body {
    font-family: source-han-serif-japanese, "ヒラギノ明朝 Pro W3", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "メイリオ", Meiryo, serif;
    margin: 0;
    color: #2d2d34;
    font-size: 14px
}

img {
    max-width: 100%;
    height: auto
}

img[src$=".svg"] {
    fill: currentColor;
    width: 100%;
    height: auto
}

button:focus {
    outline: unset
}

button:hover {
    opacity: .9
}

a {
    text-decoration: none;
    color: #000
}

.l-footer {
    margin-top: 0!important;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%
}

.l-footer__left {
    background-color: #334f9e;
    width: 38%;
    padding: 100px 30px
}

.l-footer__right {
    background-color: #2d2d34;
    width: 62%;
    padding: 130px 40px;
    text-shadow: rgba(100, 100, 111, .2) 0 7px 29px 0;
    position: relative
}

.l-footer__right p {
    color: #fff;
    font-size: 20px
}

.l-footer__right-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.l-footer__right-item-column {
    width: 190px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-bottom: 20px
}

.l-footer__right-item-column-lead {
    text-align: center;
    border-bottom: 1.2px solid #fff;
    padding-bottom: 5px
}

.l-footer__right-item-column a {
    text-decoration: unset;
    color: #fff;
    padding-left: 10px;
    margin-top: 1em
}

.l-footer__logo {
    text-align: center
}

.l-footer__logo img {
    width: 200px
}

.l-footer__adress {
    text-align: center;
    margin-top: 50px
}

.l-footer__adress p {
    color: #fff;
    margin-top: 1em
}

.l-footer__adress p:nth-child(1) {
    border-bottom: 1.7px solid #fff;
    padding-bottom: 10px
}

@media screen and (max-width:1600px) {
    .l-footer__right-item-column {
        width: 170px
    }
    .l-footer__right-item-column a {
        font-size: 16px
    }
    .l-footer__right p {
        font-size: 16px
    }
}

@media only screen and (max-width:768px) {
    .l-footer {
        flex-direction: column-reverse;
    }
    .l-footer__left {
        width: 100%;
        padding: 100px 4%;
    }
    .l-footer__right {
        width: 100%;
        padding: 100px 4%;
    }
    .l-footer__right-item-column {
        width: 100%
    }
    .l-footer__right-item-column a {
        font-size: 16px
    }
    .l-footer__right p {
        font-size: 16px
    }
}

.c-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    width: 280px;
    height: 50px;
    border-radius: 50px;
    background-color: #334f9e;
    border: 1px solid #334f9e;
    color: #fff;
    text-align: center;
    font-family: source-han-serif-japanese, "ヒラギノ明朝 Pro W3", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "メイリオ", Meiryo, serif;
    -webkit-box-shadow: rgba(100, 100, 111, .2) 0 7px 29px 0;
    box-shadow: rgba(100, 100, 111, .2) 0 7px 29px 0;
    text-decoration: none !important;
    cursor: pointer;
    outline: none !important;
}

@media screen and (max-width: 400px) {
    .c-btn {
        width: 100%;
    }
}

.c-back-top {
    position: absolute;
    top: 0;
    right: 40px;
    transform: translateY(-100%);
}

.c-back-top a {
    text-decoration: unset;
    color: #fff;
    font-size: 20px;
    background-color: #303030;
    padding: 30px 60px;
    border-top-right-radius: 10px;
    border-top-left-radius: 10px;
    display: inline-block;
}

@media screen and (max-width: 768px) {
    .c-back-top {
        right: 15px;
    }
    .c-back-top a {
        font-size: 14px;
        padding: 13px 12px;
    }
}

.c-menu {
    position: fixed;
    top: 30px;
    right: 40px;
    cursor: pointer;
    z-index: 10000;
}

.c-menu-other {
    position: fixed;
    bottom: 40px;
    right: 30px;
    z-index: 99999;
}

.c-menu-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    z-index: 10
}

.c-menu__hamburger-link span {
    width: 66px;
    height: 8.25px;
    background-color: #2d2d34;
    display: block;
    border-radius: 5px
}

.c-menu__hamburger-link span:nth-child(2) {
    margin-top: 10px;
    margin-bottom: 10px
}

.c-head {
    position: sticky;
    top: 0px;
    z-index: 10000;
    border-bottom: 1px solid #f0f0f0;
}

.c-head__logo {
    padding: 15px 0 15px 70px;
    background-color: #fff;
}

.c-head__logo img {
    width: 200px
}

.c-title {
    margin-top: 90px;
    margin-left: 278px;
}

.c-title h3 {
    font-size: 72px;
    font-family: Noto Serif
}

.c-title p {
    font-size: 24px;
    font-family: Hiragino Mincho Pro
}

.c-pagination {
    display: inline-block;
    margin: 30px 0 230px;
    width: 100%;
}

.c-pagination a {
    color: #000;
    float: left;
    padding: 8px 16px;
    border: 1px solid #bbc5df;
    text-decoration: none
}

.tab {
    overflow: hidden
}

.tab a {
    background-color: #fff;
    float: left;
    border: none;
    outline: 0;
    cursor: pointer;
    padding: .5em 2em;
    -webkit-transition: .3s;
    transition: .3s;
    font-size: 16px;
    border: 1px solid #ccd3e7
}

.tab a.active {
    background-color: #ccd3e7;
    color: #fff
}

@media screen and (max-width:1300px) {
    .c-menu {
        right: 20px
    }
    .c-menu-other {
        right: 5px
    }
    
    .c-title {
        margin-top: 90px;
        margin-left: inherit;
        text-align: center;
    }
}
@media screen and (max-width:1040px) {
    .c-pagination{
        margin-bottom: 150px;
    }
}

@media only screen and (max-width:768px) {
    .c-menu {
        position: fixed;
        top: 22px;
        right: 20px
    }
    .c-menu-other {
        position: fixed;
        bottom: 20px;
        right: 12px
    }
    .c-menu-other img {
        width: 70px
    }
    .c-menu__hamburger-link span {
        width: 30px;
        height: 2px;
        background-color: #2d2d34;
        display: block;
        border-radius: 5px
    }
    .c-menu__hamburger-link span:nth-child(2) {
        margin-top: 10px;
        margin-bottom: 10px
    }
    .c-title {
        margin-top: 40px;
    }
    .c-title h3 {
        font-size: 35px
    }
    .c-title p {
        font-size: 20px
    }
    .c-head__logo {
        padding-left: 20px;
    }
    .c-head__logo img {
        width: 150px
    }
    .tab a {
        padding: .5em 1em;
        font-size: 13px;
        border: 1px solid #ccd3e7
    }
}

.p-top section {
    margin-top: 200px
}

.p-top-banner {
    margin-top: 0!important;
    position: relative;
    height: 100vh
}
.pc-banner{
    display: block;
}
.sp-banner{
    display: none;
}

.p-top-banner__img .swiper-slide{
    position: relative;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    height: 100vh;
}

.p-top-banner__img .swiper-slide::before{
    /* 透過した黒を重ねる */
    background-color: rgba(0,0,0,0.3);
    /* どの範囲に重ねるかを指定 */
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: ' ';
}

.p-top-banner__txt{
    position: absolute;
    top: calc(50% - 80px);
    right: 3%;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    z-index: 1;
}

.p-top-banner__txt h2 {
    color: #fff;
    font-size: 64px;
    line-height: 1.5;
    font-weight: unset;
    text-align: right;
    text-shadow: 2px 2px 5px rgba(0, 0, 0, .41);
}

.p-top-banner__txt h2 .sp-br{
    display: none;
}

.p-top-logo {
    position: absolute;
    top: 0;
    left: 0;
    background-color: #334f9e;
    transition: all .7s; /* 移動する速さ */
    z-index: 1;
}

.close{
    transform: translateX(-400px);
}

.p-top-logo img {
    width: 400px;
    padding: 50px
}

.p-top-plan-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.p-top-plan__img {
    width: 44.5%
}

.p-top-plan__img img {
    -webkit-box-shadow: 65px 65px #33509e18;
    box-shadow: 65px 65px #33509e18;
    width: 100%
}

.p-top-plan-txt {
    width: 45%
}

.p-top-plan-txt h3 {
    font-size: 35px;
    line-height: 1.5;
    font-weight: unset
}

.p-top-plan-txt p {
    font-size: 14px;
    line-height: 1.6;
    margin: .5em 0;
}

.p-top-plan__btn {
    margin-top: 150px;
    text-align: center
}

.p-top-category {
    background-color: #33509e18;
    padding: 150px 0
}

.p-top-category-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.p-top-category-item a {
    text-decoration: unset;
    color: #2d2d34;
    display: flex;
    flex-direction: column;
}



.p-top-category-column {
    width: 31%
}

.p-top-category-column__img {
    margin: 30px 0;
    background: url(../img/top/top_bg1.png) no-repeat;
    background-size: contain;
    background-position: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.p-top-category-column__img img {
    width: 100%;
    padding: 30px
}

.p-top-category-column__bottom {
    margin-top: 20px
}

.p-top-category-column__bottom img {
    width: 100%
}

.p-top-category-column__bottom p {
    text-align: right;
    color: #2d2d34
}

.p-top-category__lead {
    font-size: 35px;
    border-left: 9px solid #2d2d34;
    padding-left: 18px;
    line-height: 1.1;
    border-bottom: 1px solid #2d2d34;
    padding-bottom: 8px
}

.p-top-category__txt {
    margin-bottom: auto;
    margin-bottom: 5px;
}

.p-top-company {
    background-color: #33509e18;
    background: url(../img/top/top_bg2.png) no-repeat;
    background-size: 20% 100%;
    background-position: right;
    position: relative
}
.slick-track .p-top-company-item {
    padding: 250px 150px 80px;
    width: 100%;
    max-width: 1600px;
    margin: 0 auto;
}
.slick-track .p-top-company-item .u-mr{
    margin-right: 0;
}
.slick-track .p-top-company-item .u-ml{
    margin-left: 0;
}


.p-top-company-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    position: relative
}
.p-top-company-item .question{
    color: #334F9E;
}
.p-top-company-item .answer{
    margin-bottom: 30px;
    line-height: 2;
}


.p-top-company-item__left {
    width: 49%
}

.p-top-company-item__left img {
    width: 100%
}

.p-top-company-item__left h2 {
    font-size: 32px
}

.p-top-company-item__left p {
    font-size: 14px;
    padding: .5em 0
}

.p-top-company-item__right {
    width: 49%
}

.p-top-company-item__right img {
    width: 100%
}

.p-top-company-item__number {
    position: absolute;
    right: 20%;
    transform: translateX( calc(100% + 10px));
    bottom: -15px;
    font-size: 70px;
    color: #334f9e
}

.p-top-company__btn {
    text-align: center;
    padding-bottom: 100px
}

.p-top-company__txt {
    position: absolute;
    top: 100px;
    right: 40px
}

.p-top-company__txt p {
    font-size: 20px;
    color: #2d2d34;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl
}

.p-top-contact {
    background-image: url(../img/top/top_bg.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    padding: 200px 0
}

.p-top-contact-txt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.p-top-contact-txt h2 {
    font-size: 35px
}

.p-top-contact-txt p {
    font-size: 14px;
    padding: .5em 0
}

.p-top-contact__btn {
    text-align: center;
    margin-top: 60px;
    display: grid;
    grid-template-columns: repeat(2, 360px);
    grid-column-gap: 60px;
    max-width: 780px;
    margin-left: auto;
    margin-right: auto;
}

.p-top-news {
    background-color: #33509e18;
    padding: 230px 20px;
}

.p-top-news-item {
    margin: 0 auto;
    line-height: 1;
    margin: auto;
    width: 600px;
}

.p-top-news-item__lead {
    margin-bottom: 40px;
}

.p-top-news-item-row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    border-bottom: 1px dotted #000;
    padding: 0
}

.p-top-news-item-row p:nth-child(1) {
    margin-right: 4%
}


@media screen and (max-width:768px) {
    .p-top-news-item-row {
        display: inherit;
    }
    .p-top-news-item-row p:first-child{
        margin-bottom: 10px;
    }
    .p-top-news-item-row p:last-child{
        font-size: 20px;
    }

}

.p-top-news-item__lead h2 {
    font-size: 35px;
    text-align: center
}

.p-top-news-item__lead p {
    text-align: center;
    padding-bottom: 30px
}

.p-top-news-item a {
    text-decoration: unset;
    color: #2d2d34;
    margin: 5px 0;
    padding: 5px 0 8px;
}

.p-top-news__btn {
    text-align: center;
    margin-top: 50px
}

@media screen and (max-width:1600px) {
    .p-top section {
        margin-top: 150px
    }
    .p-top-banner__img{
        background-position: left;
    }
    .p-top-banner__txt h2 {
        font-size: 50px;
    }
    .p-top-logo img {
        width: 300px;
        padding: 55px
    }
    .p-top-plan-txt h3 {
        font-size: 35px
    }
    .p-top-plan-txt p {
        font-size: 20px
    }
    .p-top-category-column__bottom p {
        font-size: 14px
    }
    .p-top-category__lead {
        font-size: 35px
    }
    .p-top-category__txt {
        font-size: 18px
    }
    .p-top-company-item {
        padding: 200px 0 50px 0
    }
    .p-top-company-item__left h2 {
        font-size: 35px
    }
    .p-top-company-item__left p {
        font-size: 20px
    }
    .p-top-company__txt p {
        font-size: 20px
    }
    .p-top-contact-txt h2 {
        font-size: 35px
    }
    .p-top-contact-txt p {
        font-size: 20px
    }
    .p-top-news {
        padding: 200px 50px
    }
}

@media screen and (max-width:1300px) {
    .p-top section {
        margin-top: 100px
    }
    .p-top-banner__txt h2 {
        font-size: 40px
    }
    .p-top-logo img {
        width: 250px;
        padding: 50px
    }
    .p-top-plan-txt h3 {
        font-size: 30px
    }
    .p-top-plan-txt p {
        font-size: 18px
    }
    .p-top-category__lead {
        font-size: 30px
    }
    .p-top-category__txt {
        font-size: 18px
    }
    .p-top-company-item {
        padding: 150px 0 30px 0
    }
    .p-top-company-item__left h2 {
        font-size: 30px
    }
    .p-top-company-item__left p {
        font-size: 18px
    }
    .p-top-company__txt p {
        font-size: 18px
    }
    .p-top-contact-txt h2 {
        font-size: 30px
    }
    .p-top-contact-txt p {
        font-size: 18px
    }
    .p-top-news {
        padding: 150px 50px
    }
}

@media screen and (max-width:1040px) {
    .p-top section {
        margin-top: 100px
    }
    .p-top-banner__txt h2 {
        font-size: 30px
    }
    .p-top-logo img {
        width: 150px;
        padding: 30px
    }
    .p-top-plan-txt {
        width: 100%;
        margin-top: 20px;
        padding: 0;
    }
    .p-top-plan-txt h3 {
        font-size: 25px
    }
    .p-top-plan-txt p {
        font-size: 16px
    }
    .p-top-category__lead {
        font-size: 25px
    }
    .p-top-category__txt {
        font-size: 16px
    }
    .p-top-company-item {
        padding: 150px 0 30px 0
    }
    .p-top-company-item__left {
        margin-top: 0;
        width: 100%;
        padding: 20px;
    }
    .p-top-company-item__left h2 {
        font-size: 25px
    }
    .p-top-company-item__left p {
        font-size: 16px
    }
    .p-top-company__txt p {
        font-size: 16px
    }
    .p-top-contact-txt h2 {
        font-size: 25px
    }
    .p-top-contact-txt p {
        font-size: 16px
    }
    .p-top-news {
        padding: 150px 0
    }
}

@media only screen and (max-width:768px) {
    .p-top section {
        margin-top: 85px;
    }
    .pc-banner{
        display: none;
    }
    .sp-banner{
        display: block;
    }
    .p-top-banner__txt{
        text-align: center;
        display: block;
        top: calc(50%);
        right: 50%;
        transform: translateX(50%);
        text-align: center;
        display: block;
        width: 100%;
        padding: 0 5px;
    }
    .p-top-banner__txt h2 {
        font-size: 35px;
        text-align: left;
        display: inline-block;
    }
    .p-top-logo img {
        width: 120px;
        padding: 10px
    }
    .p-top-plan {
        padding-bottom: 50px;
    }
    .p-top-plan-txt h3 {
        font-size: 25px
    }
    .p-top-plan-txt p {
        font-size: 16px
    }
    .p-top-plan__img {
        width: 100%
    }
    .p-top-plan__btn {
        margin-top: 50px
    }
    .p-top-category {
        padding: 50px 0
    }
    .p-top-category-column {
        width: 100%;
        margin-top: 50px
    }
    .p-top-category__lead {
        font-size: 25px
    }
    .p-top-category__txt {
        font-size: 16px
    }
    .p-top-company-item {
        padding: 50px 0 50px 0;
        flex-direction: column-reverse
    }
    .p-top-company .p-top-company-item {
        flex-direction: column;
		padding: 150px 0;
    }
    .p-top-company-item__left h2 {
        font-size: 25px
    }
    .p-top-company-item__left p {
        font-size: 16px
    }
    .p-top-company-item__right {
        width: 100%
    }
    .p-top-company-item__number {
        font-size: 30px;
        bottom: -5px;
    }
    .p-top-company__txt p {
        font-size: 16px
    }
    .p-top-company__btn {
        padding: 0 20px 50px;
    }
    .p-top-contact {
        padding: 50px 20px;
    }
    .p-top-contact-txt h2 {
        font-size: 25px
    }
    .p-top-contact-txt p {
        font-size: 16px
    }
    .p-top-news {
        padding: 150px 20px;
    }
}

@media screen and (max-width: 650px) {
    .p-top-news-item {
        font-size: 18px;
        width: 100%;
    }
}

@media only screen and (max-width:550px) {
    .p-top-banner__txt h2{
        padding: 0 10px;
        font-size: 7vw;
    }
}

.p-about-intro {
    width: 100%;
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 150px;
}

.p-about-intro-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    align-items: center;
}

.p-about-intro-itemu-sp-column-reverse{
    margin: 120px 0 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.main-description-block{
    margin: 20px 0 40px;
}

.profile-wrapper{
    margin-top: 50px;
}

.profile-block{
    width: 80%;
    line-height: 2;
    letter-spacing: 1.5px;
    background-color: #EBEEF6;
    border-left: solid 5px #334F9E;
    padding: 20px;
    margin: 0 auto;
}
.profile-title{
    font-weight: bold;
    font-size: 22px;
    margin-bottom: 10px;
}
.link_url a{
    text-decoration: underline;
}
.p-about-intro-item__left {
    width: 52%;
    line-height: 1.5;
}

.p-about-intro-item__left h4 {
    font-size: 20px;
    margin-bottom: 50px;
}

.p-about-intro-item__left h4::after{
    width: 80px;
    height: 1px;
    content: '';
    display: block;
    margin-top: 15px;
    background-color: #334F9E;
}

.p-about-intro-item__left h5 {
    font-size: 22px;
    margin-bottom: 30px;
}

.p-about-intro-item__left p {
    font-size: 14px;
    line-height: 1.875;
    margin: .5em 0;
}

.p-about-intro-item__left .name-text{
    text-align: right;
}

.p-about-intro-item__right {
    width: 40%
}

.p-about-intro-item__right img {
    box-shadow: 55px 55px #33509e18;
}

#concept{
    padding-top: 130px;
}

#greeting{
    padding-top: 130px;
}

.p-about-company-ttl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 100px 0
}

.p-about-company-ttl h3 {
    font-size: 32px;
    height: 1.53125;
    border-bottom: 1px solid #bbc5df;
    padding: 0 40px
}

.p-about-company-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    line-height: 1.5
}

.p-about-company-item-ttl {
    width: calc(40% - 30px);
    margin-right: 30px;
    padding: 1.2em 0 1.2em .6em;
    border-top: 1px solid #bbc5df;
    font-weight: bold;
}

.p-about-company-item-txt {
    width: 60%;
    padding: 1.2em 0 1.2em .6em;
    border-top: 1px solid #bbc5df
}

.p-about-company-item:last-child .p-about-company-item-ttl,
.p-about-company-item:last-child .p-about-company-item-txt {
    border-bottom: 1px solid #bbc5df
}

.no-data-text {
    font-size: 20px;
    font-weight: 600;
    text-align: center;
    margin-top: 30px;
}

.p-about-img {
    margin: 30px 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.p-about-img img {
    width: 32%
}

.p-about-img img+img {
    margin-left: 2%
}

.p-about-map {
    margin-bottom: 50px
}

.p-about-map iframe {
    width: 100%;
    height: 400px
}

@media screen and (max-width:1040px) {
    .p-about-intro {
        margin-top: 50px;
        padding: 0 50px;
    }
    .p-about-intro-item {
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
        margin-top: 50px
    }
    .p-about-intro-item__left,
    .p-about-intro-item__right {
        width: 100%;
        margin-top: 10px;
    }
    .p-about-intro-itemu-sp-column-reverse{
        display: inherit;
        margin: 150px 0 100px;
    }
    #concept,#greeting{
        padding-top: 50px;
    }
    .p-about-company-ttl{
        margin: 0 0 100px;
    }
    .profile-wrapper{
        margin-top: 100px;
    }
    .u-sp-column-reverse {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column
    }
    .p-top-contact__btn {
        display: block;
    }
    .p-top-contact__btn a {
        margin-bottom: 20px;
    }
}

@media only screen and (max-width:768px) {
    .p-about-company-item {
        font-size: 16px;
        line-height: 1.5
    }
    .p-about-company-item-ttl {
        width: 100%;
        margin: 0;
        padding: 1.2em 0 1.2em .6em
    }
    .p-about-company-item-txt {
        width: 100%;
        padding: 1.2em 0 1.2em 0
    }
    .p-about-intro{
        margin: 50px 0 0 0;
        padding: 0 4%;
    }
    .p-about-intro-item {
        padding: 40px 0 0;
        margin-top: 0;
    }
    .p-about-intro-item__left p {
        font-size: 14px;
    }
    .p-about-intro-item__left h4 {
        font-size: 15px;
        text-align: center;
    }
    .p-about-intro-item__left h4::after{
        margin: 15px auto 0;
    }
    .p-about-intro-item__left h5 {
        font-size: 19px;
        text-align: center;
    }
    .p-about-intro .u-pc-none{
        text-align: center;
    }
    .p-about-intro-itemu-sp-column-reverse{
        margin: 100px 0 0;
    }
    #greeting{
        padding-top: 100px;
    }
    .main-description-block{
        margin: 60px 0 0;
    }
    .profile-block{
        width: 100%;
        background-color: inherit;
        border-left: inherit;
        padding: 0 4%;
        margin-top: 100px;
    }
    .profile-title{
        margin-bottom: 30px;
    }
    .profile-title::after{
        width: 80px;
        height: 1px;
        content: '';
        display: block;
        margin-top: 15px;
        background-color: #334F9E;
    }
    #company_profile{
        padding-top: 100px;
    }
}

.p-voice-lead {
    font-size: 20px;
    line-height: 2;
    margin-bottom: 2em
}

.p-voice-item {
    font-size: 16px;
    line-height: 2;
    border-top: 1px solid #bbc5df;
    padding: 1em 0 1em 2em
}

.p-voice-item:last-child {
    border-bottom: 1px solid #bbc5df
}

.p-voice-position {
    color: #334f9e;
    text-align: right
}
.p-voice-group .p-top-company-item {
    padding: 0 0 50px 0;
}
.p-voice-group h2{
    font-size: 32px;
}

.u-py10 {
    padding: 10px 0;
}

@media screen and (min-width: 1040px) {
    .u-pc-none {
        display: none;
    }
}

@media screen and (max-width: 1039px) {
    .u-sp-none {
        display: none;
    }
    .p-voice-content .p-top-company-item__left{
        width: 100%;
    }
}

.u-wrapper.p-voice {
    width: 100%;
    max-width: 1600px;
    margin: 0 auto;
    padding: 130px 150px 0;
}

.p-voice-content {
    padding: 50px 0 230px;
}

.p-voice-content .p-about-company{
    padding: 0 150px;
}

.support-content{
    margin-top: 50px;
    margin-bottom: 100px;
}
@media screen and (max-width: 1040px){
    .p-voice-content {
        padding: 50px 30px 150px;
    }
}
@media screen and (max-width: 768px) {
    .u-wrapper.p-voice {
        padding: 50px 20px 0;
    }
    .p-voice-content {
        padding: 50px 20px 50px;
    }
    .p-voice-lead {
        font-size: 16px;
    }
    .p-top-plan-item {
        flex-direction: column-reverse;
    }
    .p-voice-content .p-top-company-item__left {
        padding: 0;
    }
    .p-top-company__txt {
        display: none;
    }
}

.c-btn .p-blogIndex-group {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding-top: 30px;
    border-top: 1px solid #ccc;
    border-bottom: 1px solid #ccc
}

.p-blogIndex-item {
    width: calc((100% - 40px)/ 3);
    margin-bottom: 30px
}

.p-blogIndex-item:nth-child(3n+1) {
    margin-right: 20px
}

.p-blogIndex-item:nth-child(3n+2) {
    margin-right: 20px
}

.p-blogIndex-item-img {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.p-blogIndex-item img {
    width: 100%
}

.p-blogIndex-item-txtarea {
    padding: 1em
}

.p-blogIndex-item-lead {
    font-size: 13px;
    line-height: 2.46154;
    color: #334f9e
}

.p-blogIndex-item-txt {
    font-size: 15px;
    line-height: 1.6
}

@media only screen and (max-width:768px) {
    .p-blogIndex-item {
        width: 100%;
        margin-right: 0
    }
}

.p-blogDetail-group {
    width: 75%;
    padding: 50px 40px;
    border-top: 1px solid #ccc;
    border-bottom: 1px solid #ccc
}

.p-blog-culm{
    display: flex;
    padding: 0 20px;
}

.p-blog-culm aside{
    flex: 1;
}

.sidebar-wrapper{
    margin-left: 15px;
}

.sidebar-wrapper ul{
    border-top: solid 1px #ccc;
    border-right: solid 1px #ccc;
    border-bottom: solid 1px #ccc;
    border-left: solid 1px #ccc;
}

.sidebar-title{
    font-weight: bold;
    font-size: 22px;
    padding: 10px 0 10px 10px;
    margin-bottom: 10px;
}

.sidebar-wrapper li a{
    display: block;
    padding: 10px 0 10px 10px;
    font-size: 18px;
}

.sidebar-wrapper li:not(:last-child){
    border-bottom: solid 1px #ccc;
}

/* サイドバーのレスポンシブ */
@media screen and (max-width:768px) {
    .p-blog-culm{
        display: inherit;
    }
    .p-blogDetail-group{
        width: 100%;
    }
}

.new-articles-block{
    margin-top: 30px;
}

.single-page-title{
    width: 100%;
    font-size: 50px;
    margin: 20px 0;
    font-weight: bold;
}

.p-blogDetail-img {
    text-align: center;
    margin-bottom: 100px;
    width: 100%;
    height: 400px;
}

.p-blogDetail-img img{
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.p-customBlog-img {
    text-align: center;
    margin-bottom: 20px;
}

.p-customBlog-txt {
    padding: 0 100px;
    margin-bottom: 30px;
    font-size: 16px;
    line-height: 1.4;
}

.p-blogDetail-txt {
    line-height: 2;
    margin-bottom: 80px;
}

.p-blogDetail-txt h2{
    text-align: center;
    margin: 50px 0 20px;
    color: #000;
    font-weight: bold;
    font-size: 26px;
}

.p-blogDetail-txt h3{
    position: relative;
    margin: 50px 0 20px;
    padding: 10px 0 8px 18px;
    font-size: 22px;
    line-height: 1.4;
    border-left: solid 2px rgba(0, 76, 102, 0.4);
    font-weight: bold;
}

.p-blogDetail-txt h4{
    position: relative;
    width: 80%;
    margin: 50px 0 30px;
    padding: 10px 0 8px 18px;
    font-size: 20px;
    line-height: 1.4;
    border-bottom: solid 2px rgba(0, 76, 102, 0.4);
    font-weight: bold;
}

.p-blogDetail-txt p{
    margin-bottom: 20px;
}

.p-blogDetail-txt p img{
    width: 100%;
    object-fit: cover;
    height: 340px;
}

.p-blogDetail-txt ol{
    padding-left: 30px;
    list-style-type: decimal;
    padding: 10px 10px 10px 30px;
}

.p-blogDetail-txt ul{
    list-style: inside;
    padding: 10px 10px 10px 15px;
}

.p-blogDetail-txt ol, .p-blogDetail-txt ul{
    border: 1px solid #999;
    border-radius: 10px;
    margin-bottom: 20px;
}

.p-blogDetail-btn {
    margin-top: 30px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

.p-blogDetail-btn a {
    display: flex;
    align-items: center;
    justify-content: center;
    outline: unset;
    border: 1px solid #b0bad9;
    background-color: #fff;
    font-size: 16px;
    line-height: 2;
    padding: .5em 0;
    width: 170px
}

.p-blogDetail-btn a+a {
    margin-left: 20px
}

@media only screen and (max-width:768px) {
    .p-blogDetail-group {
        padding: 20px 0
    }
    .p-blogDetail img {
        width: 100%;
        margin-bottom: 20px;
    }
    .p-blogDetail-txt {
        padding: 0;
    }
    .p-customBlog-txt {
        padding: 0;
        margin-bottom: 20px;
    }
    .p-blogDetail-btn {
        justify-content: space-between;
    }
    .p-blogDetail-btn a {
        width: 30%;
        margin: 0 0 20px 0!important
    }
    .p-blogDetail-img {
        margin-bottom: 80px;
        height: 300px;
    }
    .single-page-title{
        font-size: 40px;
    }
    .p-blogDetail-txt p img{
        height: 250px;
    }
}

@media only screen and (max-width:400px){
    .p-blogDetail-btn a {
        font-size: 12px;
    }
    .p-blog-culm{
        padding: inherit;
    }
}

.p-service-item {
    margin-bottom: 100px
}

.p-service-ttl {
    background-color: #fff;
    border-top: 1px solid #bbc5df;
    border-bottom: 1px solid #bbc5df
}

.p-service-ttl p {
    font-size: 24px;
    line-height: 1.5;
    background-color: #e9ecf4;
    margin: 2px 0;
    padding: .5em 1.5em
}

.p-service-txt {
    font-size: 14px;
    line-height: 2;
    padding: 1em 1.5em
}

.service-child-link-block{
    margin-top: 30px;
    text-align: center;
}

.service-child-link{
    display: inline-block;
    text-align: center;
    padding: 10px 30px;
    border-radius: 50px;
    background-color: #334F9E;
    color: #fff;
}

.service-bottom-block{
    margin-bottom: 230px;
}

.p-service .u-txt-center{
    padding-top: 100px;
    border-top: solid 1px #E9ECF4;

}

/* サービス内容 */
.service-wrapper{
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 150px;
}
.service-top-block{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-top: 130px;
    align-items: center;
}
.service-top-block__left{
    width: 50%;
    margin-left: 30px;
}
.service-top-block__left img{
    width: 85%;
    box-shadow: 65px 65px #33509e18;
}
.strengths-wrapper{
    margin: 150px auto;
}
.h2-title{
    font-size: 20px;
    text-align: center;
}
.h2-title::after{
    width: 80px;
    height: 1px;
    content: '';
    display: block;
    margin-top: 15px;
    background-color: #334F9E;
    margin: 15px auto 40px;

}
.strengths-list{
    display: flex;
    justify-content: space-around;
}
.strengths-item{
    width: 30%;
    margin: 0 auto;
    border: 2px solid #334F9E;
    padding: 15px;
    border-radius: 8px;
}
.strengths-item .sub-title{
    text-align: center;
    font-size: 20px;
}
.first-p{
    font-size: 25px;
    color: #334F9E;
    font-weight: bold;
}
.strengths-item .main-description-block{
    line-height: 2;
    margin-bottom: 10px;
}
.strengths-item .main-description-block p{
    margin-bottom: 20px;
}

/* サービスプロセス */
.service-process-wrapper{
    margin: 0 auto 150px;
}
.service-process-block{
    display: flex;
    justify-content: space-around;
    flex-flow: row wrap;
    margin-top: 50px;
}
.process-item{
    width: 30%;
    margin-bottom: 30px;
}
.process-img-block{
    text-align: center;
    margin-bottom: 30px;
    height: 200px;
    width: 100%;
}
.process-img-block img{
    width: 60%;
    height: 100%;
    object-fit: contain;
    text-align: center;
}
.process-description-block{
    display: flex;
    flex-direction: column;
    align-items: stretch;

}
.process-description-block h3{
    font-size: 20px;
    flex-grow: 1;
}
.process-description-block .main-description-block{
    line-height: 2;
    margin-top: 40px;
}

/* 実績の一例,料金 */
.achievement-wrapper{
    margin: 150px auto;
}
.price-wrapper{
    margin: 150px auto 200px;
}
.achievement-top-block, .price-top-block{
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin-top: 80px;
}

.achievement-top-block .p-about-intro-item__left{
    padding-left: 30px;
}

.achievement-top-block__left, .price-top-block__left{
    width: 40%;
}
.achievement-top-block__left img, .price-top-block__left img{
    width: 100%;
    box-shadow: 55px 55px #33509e18;
}
.achievement-top-block__left{
    margin-right: 50px;
}

/* 補助金支援事業 */
.types_of_subsidies{
    margin: 150px 0;
}
.types_of_subsidies-left h2{
    font-size: 20px;
    margin: 10px 0;
}
.types_of_subsidies-description{
    margin: 50px 0;
    line-height: 2;
}
.types-table thead{
    background-color: #f5f5f5;
}
.types-table tbody td{
    padding: 2px 10px;
}
.types-table thead tr th{
    font-size: 18px;
}
.types-table thead tr th:first-child{
    width: 30%;
}
.types-table thead tr th:nth-child(2){
    width: 8%;
}

/* 支援の流れ */
.flow-block::after{
    content: "";
    display: block;
    width: 63%;
    height: 0;
}
.flow-wrapper{
    padding: 0 100px;
}
.u-wrapper .p-contact{
    padding-bottom: 150px;
    padding-right: 20px;
    padding-left: 20px;
}

.p-contact-form-wrap {
    margin-bottom: 50px;
}

.p-contact .wpcf7 form .wpcf7-response-output {
    margin: 1.5em 0 1.5em;
    padding: 1em 1.2em 0.8em;
    border: 2px solid #00a0d2;
    border-radius: 5px;
    font-size: 16px;
}

.contact-top-p-block{
    font-size: 18px;
    margin-bottom: 50px;
    line-height: 2;
}
.p-contact .c-btn {
    margin-bottom: 0.8em;
}

.c-menu-item__other a {
    display: block;
}

.p-contact-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 100%
}
.p-contact-item:nth-child(8) .p-contact-item__left{
    padding-top: 20px;
}

.p-contact-item__left {
    width: 33%;
    border-bottom: 1px solid #bbc5df;
    padding-top: 30px
}

.p-contact-item__left p {
    font-size: 16px;
    position: relative
}

.p-contact-item__left p.req-none::after {
    content: none
}

.p-contact-item__left .mandatory::after{
    content: "必須";
    background-color: #d7171a;
    color: #fff;
    font-size: 14px;
    padding: 3px 10px;
    position: absolute;
    top: 0;
    right: 0
}

.checkbox-block{
    text-align: center;
    margin-bottom: 30px;
}

.checkbox-link{
    text-decoration: underline;
    margin-left: 20px;
}
.checkbox-block-p{
    margin-top: 10px;
    color: #d7171a;
}

.p-contact-item__right {
    width: 62%;
    border-bottom: 1px solid #bbc5df;
    padding-bottom: 20px;
    padding-top: 20px
}

.p-contact-item__right input[type=email],
.p-contact-item__right input[type=text],
.p-contact-item__right input[type=tel] {
    width: 100%;
    height: 45px;
    background-color: #fff;
    border: 1px solid #bbc5df;
    font-size: 15px;
    padding-left: 10px
}

.p-contact-item__right input[type=email]:focus,
.p-contact-item__right input[type=text]:focus {
    outline: unset
}

.p-contact-item__right textarea {
    width: 100%;
    background-color: #fff;
    border: 1px solid #bbc5df;
    font-size: 15px;
    padding: 10px
}

.p-contact-item__right textarea:focus {
    outline: unset
}

.p-contact-item:nth-of-type(1) .p-contact-item__left,
.p-contact-item:nth-of-type(1) .p-contact-item__right {
    border-top: 1px solid #bbc5df
}



@media only screen and (max-width:1200px) {
    .process-item{
        width: 45%;
    }
    .flow-block::after{
        content: "";
        display: block;
        width: 48%;
        height: 0;
    }
}
@media only screen and (max-width:1040px) {
    .strengths-list{
        display: inherit;
    }
    .strengths-item{
        width: 100%;
        margin-bottom: 50px;
    }
    .strengths-item .main-description-block{
        width: 100%;
        max-width: 450px;
        margin: 20px auto 40px;
    }
    .service-top-block{
        padding: 0 30px;
    }
    .service-top-block__left{
        width: 70%;
    }
    .service-top-block__left img{
        box-shadow: 40px 40px #33509e18;
    }
    .service-bottom-block{
        margin-bottom: 150px;
    }
    /* 実績の一例 */
    .achievement-wrapper, .price-wrapper{
        margin: 150px 100px;
    }
    .achievement-top-block, .price-top-block{
        display: flex;
        justify-content: space-around;
        align-items: center;
        margin-top: 80px;
    }
    .achievement-top-block__left, .price-top-block__left{
        width: 55%;
    }
    .achievement-top-block__left img, .price-top-block__left img{
        width: 100%;
        box-shadow: 40px 40px #33509e18;
    }
    .achievement-top-block__left, .price-top-block .p-about-intro-item__left .main-description-block{
        margin-right: 65px;
    }
    .achievement-top-block .main-description-block p{
        margin: 20px 0;
    }
    /* 補助金の種類 */
    .types_of_subsidies{
        padding: 0 30px;
    }
    /* 補助金の実績の一例 */
    .subsidy-wrapper .achievement-top-block__left{
        width: 70%;
    }
}
@media only screen and (max-width:768px) {
    .p-contact-item {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-pack: unset;
        -ms-flex-pack: unset;
        justify-content: unset;
        width: 100%;
        margin-bottom: 30px;
    }
    .p-contact-item__left {
        width: 100%;
        border-bottom: unset;
        padding-top: 10px
    }
    .p-contact-item__right {
        width: 100%;
        padding-bottom: 10px;
        padding-top: 10px
    }
    .p-contact-item:nth-of-type(1) .p-contact-item__left {
        border-top: 1px solid #bbc5df
    }
    .p-contact-item:nth-of-type(1) .p-contact-item__right {
        border-top: unset
    }
    .profile-wrapper{
        margin-top: 0;
    }
    .service-wrapper .u-pc-none{
        text-align: center;
        padding: 0 30px;
    }
    .service-top-block{
        display: block;
        padding: 0;
    }
    .service-top-block .p-about-intro-item__left .u-pc-none img{
        width: 90%;
        height: 350px;
        object-fit: cover;
        margin-bottom: 30px;
        box-shadow: 40px 40px #33509e18;

    }
    .service-top-block__left{
        width: 50%;
        margin-left: 30px;
    }
    .process-description-block h3{
        text-align: center;
    }
    .p-about-intro-item__left img{
        width: 80%;
        box-shadow: 40px 40px #33509e18;
    }
    .strengths-wrapper{
        padding: 0 20px;
    }
    .strengths-wrapper .main-description-block{
        max-width: 100%;
        margin: 20px 0;
    }
    .strengths-wrapper .main-description-block p{
        width: 100%;
    }
    .service-process-wrapper{
        padding: 0 50px;
    }
    .service-process-block{
        display: inherit;
    }
    .process-item{
        width: 100%;
        margin-bottom: 70px;
    }
    .p-service-item .p-service-txt{
        padding: 15px 2%;
    }

    .types_of_subsidies{
        padding: 0;
    }
    /* 実績の一例 */
    .achievement-wrapper, .price-wrapper{
        margin: 150px 0;
        padding: 0 4%;
    }
    .achievement-top-block .p-about-intro-item__left{
        padding: 0;
    }
    .achievement-wrapper .p-about-intro-item__left .u-pc-none,
    .price-wrapper .p-about-intro-item__left .u-pc-none{
        width: 100%;
        text-align: center;
        height: 350px;
        margin-bottom: 60px;
    }
    .achievement-wrapper .p-about-intro-item__left .u-pc-none img,
    .price-wrapper .p-about-intro-item__left .u-pc-none img{
        width: 90%;
        height: 100%;
        object-fit: cover;
    }
    .price-top-block .p-about-intro-item__left .main-description-block{
        margin-right: 0;
    }
    .process-img-block img{
        width: 50%;
    }
}

.u-inner {
    margin: 0 150px
}

.main{
    width: 100%;
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 150px;
}

.u-wrapper {
    max-width: 1600px;
    width: 100%;
    margin: 0 auto;
    padding: 130px 150px 230px
}

.u-txt-center {
    text-align: center
}

.overlay {
    position: relative;
    height: 100%;
    width: 100%;
    visibility: hidden;
    opacity: 0;
    position: fixed;
    z-index: 99999;
    left: 0;
    top:0;
    background-color: #eceff6;
    overflow-x: hidden;
    -webkit-transition: 0.1s;
    transition: 0.1s;
}

.overlay-content {
    position: relative;
    top: 10%;
    width: 100%;
    padding: 0 0 0 47px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.overlay-content__img {
    width: 40%;
    margin-left: 10%;
    transform: translateX(-1000px);
    transition: all .7s; /* 移動する速さ */
    height: 500px;
}


.overlay-content__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.overlay-content__link {
    width: 35%;
    transform: translateX(1000px);
    transition: all .7s; /* 移動する速さ */
}

.open{
    transform: translateX(0);
}

.overlay-content__btn {
    margin-top: 30px
}

.click-close{
    position: relative;
}

.click-close::before{
    width: 22px;
    height: 1px;
    content: '';
    position:absolute;
    display: block;
    top: 50%;
    left: -30px;
    background-color: #073061;
    opacity: 0;
    visibility: hidden;
    transition: .3s;
}

.click-close:hover::before{
    left: -22px;
    opacity: 1;
    visibility: visible;
}

.logo-bg-color{
    background-color: #eceff6;
    width: 250px;
    box-sizing: border-box;
    transform: translateY(-500px);
    transition: all .7s; /* 移動する速さ */
}

.open1{
    transform: translateY(0);
}

.logo-bg-color a{
    width: 100%;
}

.overlay-content__btn p {
    font-size: 16px;
    color: #2d2d34
}

.overlay-content__btn .c-btn {
    margin: 15px 0 0 0;
    color: white !important;
}

@media screen and (max-width: 1200px) {
    .overlay-content__btn .c-btn {
        width: 285px;
    }
}
@media screen and (max-width: 1040px) {
    .main{
        padding: 0 4%;
    }
    .u-wrapper.p-voice{
        padding-left: 4%;
        padding-right: 4%;
    }
}



.wp-pagenavi{
    display: flex;
    justify-content: center;
}

.wp-pagenavi a,
.wp-pagenavi span {
    color: #000;
    float: left;
    padding: 8px 16px;
    border: 1px solid #bbc5df;
    text-decoration: none;
    margin-right: 10px;
    margin-bottom: 8px;
}

.wp-pagenavi span.pages {
    display: none;
}

.overlay a {
    padding: 8px;
    text-decoration: none;
    font-size: 25px;
    color: #2d2d34;
    display: block;
    -webkit-transition: .3s;
    transition: .3s
}

.service-child-list a{
    font-size: 18px;
    margin-left: 30px;
}

.overlay a:focus,
.overlay a:hover {
    color: #2d2d34
}

.overlay-close {
    position: absolute;
    top: 20px;
    right: 50px;
    cursor: pointer;
    width: 40px;
    height: 40px;
}

.overlay-close span {
    cursor: pointer;
    width: 60px;
    height: 2px;
    background-color: #2d2d34;
    display: block;
    -webkit-transition: .4s;
    transition: .4s
}

.overlay-close span:nth-child(1) {
    transform: rotate( -45deg) translate(-21px, 4px);
}

.overlay-close span:nth-child(2) {
    transform: rotate( 45deg) translate(-1px, 16px);
    margin-top: 5px;
}

@media screen and (max-width: 768) {
    .overlay-close span:nth-child(1) {
        transform: rotate( -45deg) translate(-13px, 15px);
    }
    .overlay-close span:nth-child(2) {
        transform: rotate( 45deg) translate(10px, 8px);
        margin-top: 5px;
    }
}

.u-ml {
    margin-left: 150px;
    margin-top: 20px;
}
.small_block{
    display: flex;
    width: 100%;
    justify-content: space-between;
    margin-top: 20px;
}
.small_block img{
    max-width: 49%;
}
.small_block img:first-child{
    margin-right: 10px;
}

.u-mr {
    margin: 80px;
}

.p-top-company-item__left .u-top{
    margin-top: 20px;
}

.u-br {
    white-space: pre-line;
}

.slick-slide {
    position: relative;
}

.slick-dots {
    bottom: -70px;
}

@media screen and (max-width:1300px) {
    .u-inner {
        margin: 0 100px
    }
    .u-ml {
        margin-left: 150px;
    }
}
@media screen and (max-width:1040px) {
    .u-ml{
        margin-left: 0;
    }
    .u-mr{
        margin: 0;
    }
    .p-voice-content .p-about-company{
        padding: 0;
    }
}



@media screen and (max-width:1000px) {
    .u-inner {
        margin: 0
    }
    .u-mr {
        margin-right: 0;
    }
    .u-wrapper {
        padding-bottom: 150px;
    }
    .p-contact{
        padding-bottom: 150px;
        padding-right: 25px;
        padding-left: 25px;
    }
}

@media screen and (max-width:800px) {
    .overlay-content__img {
        display: none
    }
    .overlay-content__link {
        width: 100%
    }
}

@media only screen and (max-width:768px) {
    .u-inner {
        width: 100%;
        padding: 0 4%
    }
    .u-wrapper {
        width: 100%;
        padding: 50px 4% 150px;
    }
    .overlay-close {
        top: 14px;
        right: 0px
    }
    .overlay-close span {
        width: 35px
    }
}

/* ブログページ */
.blog-wrapper{
    width: 100%;
    max-width: 1200px;
    margin: 150px auto 0;
    padding: 0 10px 0 30px;
}

.blog-wrapper-inner{
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    margin-bottom: 100px;
}

.blog-wrapper-inner:after{
    content: "";
    display: block;
    width: 48%;
    height: 0;
}

.thumbnail-block{
    overflow: hidden;
    height: 180px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.article-link{
    display: block;
    color: #000;
}

.article-link :hover{
    opacity: 0.9;
}

.article:hover img{
    transform: scale(1.2);
    transition-duration: 0.3s;
}

.article{
    width: 21%;
    margin-bottom: 40px;
    margin-right: 2%;
    margin-left: 2%;
}

.article img{
    object-fit: contain;
    height: auto;
}



.article-title{
    font-size: 18px;
    padding: 10px 0;
}
.time-category-block{
    display: flex;
}

.time-category-block .category-block{
    margin-left: 5px;
}

@media screen and (max-width:768px) {
    .article{
        width: 40%;
        margin-bottom: 20px;
        margin-right: 5%;
        margin-left: 5%;
    }
    .time-category-block{
        display: inherit;
    }
    .time-category-block .category-block{
        margin: inherit;
    }
    .thumbnail-block{
        height: 150px;
    }
    .article-title{
        padding: 5px 0;
    }
    .blog-wrapper{
        padding: 0 10px;
    }

}

/* カテゴリーページ */
.cat-title{
    font-size: 60px;
    margin-bottom: 30px;
}


@media screen and (max-width:768px) {
    .cat-title{
        font-size: 40px;
    }
}

/* プライバシーポリシー */
.terms-wrapper {
    margin-top: 150px;
    margin-bottom: 150px;
}
.terms-wrapper h2{
    text-align: center;
    margin: 50px 0 20px;
    font-weight: bold;
    font-size: 26px;
}
