@charset "utf-8";
/* CSS Document */
.anker {padding-top: 150px; margin-top: -150px;}


/*about*/
#about .main01 {background: url("img/about/main01_bg.jpg")top center no-repeat; background-color: #3687d2; border: 1px solid #3687d2; height: 400px; padding: 75px 0 80px; box-sizing: border-box; margin-top: 80px;}
#about .main01 .txt01 {font-size: 28px; line-height: 1; background: #3687d2; display: table; margin: auto; padding: 10px; margin-top: 3px;}
#about .main01 .txt01:nth-of-type(1) {margin-top: 0;}
#about .main01 .txt02 {font-size: 60px; line-height: 1; margin: 50px auto 20px;}
#about .main01 .txt03 {font-size: 30px; line-height: 1;}
#about .box01 {background: url("img/about/box01_bg.jpg")top left repeat; padding: 50px 0;}
#about .box01 .min_title {font-size: 20px; line-height: 1; margin-bottom: 20px;}
#about .box01 .title {font-size: 30px; line-height: 1; word-break: keep-all;}
#about .box01 .title::before {content: ''; width: 385px; height: 3px; background: #3687d2;}
#about .box01 .title::after {content: ''; width: 385px; height: 3px; background: #3687d2;}
#about .box01 .inner {margin-top: 50px; padding: 0 50px; font-size: 16px; line-height: 2;}
#about .box01 .inner .img01 {margin-right: 50px;}
#about .box01 .inner .img02 {margin-left: 50px;}
#about .bnr01 {outline: 1px solid #fff; outline-offset: -10px;}
#about .bnr01 .left {background: url("img/about/bnr01_bg01.jpg") top left no-repeat; width: 753px; height: 280px; padding: 70px 0; box-sizing: border-box;}
#about .bnr01 .left p {background: rgba(255,255,255,.85); padding: 30px; font-size: 30px; line-height: 1.5;}
#about .bnr01 .right {background: url("img/about/bnr01_bg02.jpg") top left repeat; width: 447px; height: 280px; padding: 70px 0; box-sizing: border-box;}
#about .bnr01 .right .logo {margin: auto;}
#about .bnr01 .right .txt01 {font-size: 50px; line-height: 1; margin: 20px auto 15px;}
#about .bnr01 .right .txt02 {font-size: 21px; line-height: 1;}
#about .main02 {background: url("img/about/main02_bg.jpg")top center no-repeat; background-color: #184a78; border: 1px solid #184a78; height: 400px; padding: 75px 0 80px; box-sizing: border-box; margin-top: 80px;}
#about .main02 .txt01 {font-size: 28px; line-height: 1; background: #184a78; display: table; margin: auto; padding: 10px; margin-top: 3px;}
#about .main02 .txt01:nth-of-type(1) {margin-top: 0;}
#about .main02 .txt02 {font-size: 60px; line-height: 1; margin: 50px auto 20px;}
#about .main02 .txt03 {font-size: 30px; line-height: 1;}
#about .box02 {background: url("img/about/box01_bg.jpg")top left repeat; padding: 50px 0;}
#about .box02 .min_title {font-size: 20px; line-height: 1; margin-bottom: 20px;}
#about .box02 .title {font-size: 30px; line-height: 1; word-break: keep-all;}
#about .box02 .title::before {content: ''; width: 385px; height: 3px; background: #184a78;}
#about .box02 .title::after {content: ''; width: 385px; height: 3px; background: #184a78;}
#about .box02 .con_box {margin-top: 50px; padding: 0 50px;}
#about .box02 .con {margin-top: 50px; padding: 0 50px;}
#about .box02 .con h3 {background: url("img/about/box02_con_bg01.jpg")top left repeat; height: 50px;}
#about .box02 .con h3 p {font-size: 28px; line-height: 1; background: #3687d2; height: 100%; padding: 0 360px; position: relative; word-break: keep-all;}
#about .box02 .con h3 p::before {content: ''; width: 0; height: 0; border-style: solid; border-width: 25px 10px 25px 0; border-color: transparent #3687d2 transparent transparent; position: absolute; left: -10px; top: 0; bottom: 0; margin: auto;}
#about .box02 .con h3 p::after {content: ''; width: 0; height: 0; border-style: solid; border-width: 25px 0 25px 10px; border-color: transparent transparent transparent #3687d2; position: absolute; right: -10px; top: 0; bottom: 0; margin: auto;}
#about .box02 .inner {margin-top: 50px; font-size: 16px; line-height: 2;}
#about .box02 .img01 {margin-right: 50px;}
#about .box02 .con02 h3 {background: url("img/about/box02_con_bg02.jpg")top left repeat;}
#about .box02 .con02 h3 p {background: #184a78;}
#about .box02 .con02 h3 p::before {content: ''; width: 0; height: 0; border-style: solid; border-width: 25px 10px 25px 0; border-color: transparent #184a78 transparent transparent; position: absolute; left: -10px;}
#about .box02 .con02 h3 p::after {content: ''; width: 0; height: 0; border-style: solid; border-width: 25px 0 25px 10px; border-color: transparent transparent transparent #184a78; position: absolute; right: -10px; word-break: keep-all;}
#about .box02 .img02 {margin-left: 50px;}
#about .bnr02 .left {background: url("img/about/bnr02_bg01.jpg") top left no-repeat;}
#about .bnr02 .right {background: url("img/about/bnr02_bg02.jpg") top left repeat; }
#about .end {margin-top: 100px; position: relative;}
#about .end .over {background: url("img/about/end_bg01.jpg")top left no-repeat; padding: 90px 0;}
#about .end .over .txt01 {font-size: 30px; line-height: 1; background: #3687d2; padding: 20px; border-radius: 10px; position: relative; display: table; margin: auto;}
#about .end .over .txt01::after {content: ''; width: 0; height: 0; border-style: solid; border-width: 13px 13px 0 13px; border-color: #3687d2 transparent transparent transparent; position: absolute; bottom: -13px; right: 0; left: 0; margin: auto;}
#about .end .over .txt02 {position: relative; display: table; margin: auto; margin-top: 40px;}
#about .end .over .txt02 span {font-size: 50px; line-height: 1; position: relative; display: table; margin: auto; z-index: 20;}
#about .end .over .txt02::before {content: ''; width: 60px; height: 60px; background: url("img/about/end_icon01.svg") no-repeat; position: absolute; top: -30px; left: 0;}
#about .end .over .txt02::after {content: ''; width: 60px; height: 60px; background: url("img/about/end_icon02.svg") no-repeat; position: absolute; bottom: -30px; right: 0;}
#about .end .under {padding: 30px 0; background-color: #3687d2;height: 150px; box-sizing: border-box; position: relative;}
#about .end .under .txt03 {font-size: 25px; line-height: 1; margin-bottom: 15px;}
#about .end .under .txt04 {font-size: 45px; line-height: 1;}
#about .end .under img {margin-right: 30px; margin-top: 10px;}
#about .end .triangle01 {width: 0; height: 0; border-style: solid; border-width: 75px 0 0 75px; border-color: transparent transparent transparent #0a2136; position: absolute; bottom: 0; left: 0;}
#about .end .triangle02 {width: 0; height: 0; border-style: solid; border-width: 0 0 75px 75px; border-color: transparent transparent #0a2136 transparent; position: absolute; bottom: 0; right: 0;}
#about .end .filter {width: 100%; height: 100%; background: url("img/about/end_bg02.svg")top left repeat; position: absolute; z-index: 10; top: 0;}
#con01,#con02,#con03,#con04 {margin-top: -100px; padding-top: 100px;}

/*content*/
#contact {padding-bottom: 0;}
#content .main {background: url("img/content/main_bg.jpg")top left no-repeat; padding: 65px 0; margin-top: 80px}
#content .main .txt01 {width: 512px; position: relative; height: 50px; background: #000; box-sizing: border-box; margin: 0 auto; transform: skewX(20deg);}
#content .main .txt01 p {font-size: 30px; padding: 0 30px; transform: skewX(-20deg);}
#content .main .txt01::before {content: '';width: 0; height: 0; border-style: solid; border-width: 0 0 50px 30px; border-color: transparent transparent #000 transparent; position: absolute; top: 0; left: -15px;}
#content .main .txt01::after {content: '';width: 0; height: 0; border-style: solid; border-width: 50px 30px 0 0; border-color: #000000 transparent transparent transparent; position: absolute; top: 0; right: -15px;} 
#content .main .txt02 {background: rgba(255,255,255,.85); padding: 30px 50px; margin-top: 30px;}
#content .main .txt02 p:nth-of-type(1) {font-size: 40px; line-height: 1;}
#content .main .txt02 p:nth-of-type(2) {font-size: 65px; line-height: 1; margin-top: 20px;}
#content .link_box {margin-top: 50px;}
#content .link_box .con {width: 50%; position: relative; padding: 65px 0; height: 320px; box-sizing: border-box;}
#content .link_box .con01 {background: url("img/index/box02_img01.jpg")top left no-repeat; background-size: cover;}
#content .link_box .con02 {background: url("img/index/box02_img02.jpg")top left no-repeat; background-size: cover;}
#content .link_box .con03 {background: url("img/index/box02_img03.jpg")top left no-repeat; background-size: cover;}
#content .link_box .con04 {background: url("img/index/box02_img04.jpg")top left no-repeat; background-size: cover;}
#content .link_box .con .link {font-size: 20px; line-height: 1;}
#content .link_box .con .big {font-size: 40px; line-height: 1; margin-top:30px; transition-duration: .3s;}
#content .link_box .con:before {content: ''; width: 100%; height: 100%; background: rgba(0,0,0,.7); position: absolute; top: 0; left: 0; right: 0; bottom: 0; margin: auto; transition-duration: .3s;}
#content .link_box .con:hover::before {width: calc(100% - 60px); height: calc(100% - 60px);}
#content .link_box .con:hover .big {color:#3687d2;}
#content .link_box .con .txt {position: relative; z-index: 10;}
#content .link_box .x_btn {color: #fff; border: 1px solid #fff; margin-top: 30px; width: 300px;}
#content .link_box .x_btn .btn_item01, #content .link_box .x_btn .btn_item02 {border: 1px solid #fff;}
#content .link_box .x_btn:hover {background-color: #fff; color: #000;}
#content .link_box .x_btn .arrow::before,#content .link_box .x_btn .arrow::after {background-color: #000;}
#content .box01 {background: url("img/content/box01_bg.jpg")top left repeat; margin-top: 50px;}
#content .box01 .title {background: url("img/content/box01_title_bg.jpg")top left repeat; padding: 20px 0; position: relative; overflow: hidden;}
#content .box01 .title .min {font-size: 16px; line-height: 1;}
#content .box01 .title h2 {font-size: 30px; line-height: 1; margin-top: 10px;}
#content .box01 .title::before {content: ''; width: 250px; height: 100px; background: #184a78; position: absolute; top: 0; left: -40px; transform: skewX(40deg);}
#content .box01 .title::after {content: ''; width: 250px; height: 100px; background: #184a78; position: absolute; top: 0; right: -40px; transform: skewX(-40deg);}
#content .box01 .inner {margin-top: 50px; padding: 0 50px; font-size: 16px; line-height: 2;}
#content .box01 .inner .img01 {margin-right: 50px;}
#content .box01 .inner .img02 {margin-left: 50px;}
#content .bnr01 {background: url("img/content/bnr01_bg.jpg")top left no-repeat; padding: 70px 0 70px 50px; position: relative; border: 3px solid #3687d2; overflow: hidden; margin-top: 50px;}
#content .bnr01 .txt01,#content .bnr01 .txt02 {font-size: 50px; line-height: 1; background: #fff; padding: 10px; display: table;}
#content .bnr01 .txt02 {margin-top: 20px;}
#content .bnr01 .txt03 {background: url("img/content/bnr01_bg02.jpg")top left repeat; padding: 20px 80px 20px 50px; transform: skewX(-40deg); position: absolute; bottom: 0; right: -50px;}
#content .bnr01 .txt03 p {font-size: 45px; transform: skewX(40deg); line-height: 1;}
#content .box02 .title {background: url("img/content/box02_title_bg.jpg")top left repeat;}
#content .box02 .title::before,#content .box02 .title::after { background: #3687d2;}
#content .bnr02 {background: url("img/content/bnr02_bg.jpg")top left no-repeat; border: 3px solid #184a78;}
#content .bnr02 .txt03 {background: url("img/content/bnr02_bg02.jpg")top left repeat;}
#content .bnr03 {background: url("img/content/bnr03_bg.jpg")top left no-repeat;}
#content .bnr04 {background: url("img/content/bnr04_bg.jpg")top left no-repeat;}
#content .end {background: url("img/content/end_bg.jpg")center center no-repeat; padding: 75px; margin-top: 50px;}
#content .end .txt01 {font-size: 25px; line-height: 1; background: #fff; border-radius: 25px; display: table; margin: auto; padding: 10px 20px;}
#content .end .txt02 {font-size: 38px; line-height: 1; margin-top: 50px;}
#content .end .txt03 {font-size: 65px; line-height: 1; margin: 20px 0;}
#content .end .txt04 {font-size: 21px; line-height: 1;}
#content .end .logo {margin: auto; margin-top: 50px;}

/*blog_news*/
#blog_news .blog_list {margin-top: 40px;}
#blog_news .blog_list .item {font-size: 16px; padding: 20px 0; border-bottom: 2px solid #000;}
#blog_news .blog_list .item:nth-of-type(1) {margin-top: 0; transition-delay: 1s;}
#blog_news .blog_list .item:nth-of-type(2) {transition-delay: 1.1s;}
#blog_news .blog_list .item:nth-of-type(3) {transition-delay: 1.2s;}
#blog_news .blog_list .item:nth-of-type(4) {transition-delay: 1.3s;}
#blog_news .blog_list .item:nth-of-type(5) {transition-delay: 1.4s;}
#blog_news .blog_list .item:nth-of-type(6) {transition-delay: 1.5s;}
#blog_news .blog_list h3 {margin-top: 15px;}
#blog_news .blog_list .time {padding-right: 25px; border-right: 1px solid #000; margin-right: 25px;}
#single_blog .box01 {border: 2px solid #cfcfcf; padding: 50px;}
#single_blog .time {font-size: 16px; line-height: 1; border-right: 1px solid #000; padding-right: 20px; margin-right: 20px;}
#single_blog .tag {font-size: 16px; line-height: 1;}
#single_blog h2 {font-size: 16px; border-bottom: 1px solid #cfcfcf; padding-bottom: 20px; margin-top: 20px; font-weight: 500;}
#single_blog .text {font-size: 16px; line-height: 2; margin-top: 20px;}

/*works*/
#works .item {box-sizing: border-box; width: 280px; border-bottom: 2px solid #3687d2; padding-bottom: 20px; position: relative; transition-delay: 1s; margin-right: 26px;}
#works .item:nth-child(2) {transition-delay: 1.1s;}
#works .item:nth-child(3) {transition-delay: 1.2s;}
#works .item:nth-child(4) {transition-delay: 1.3s;}
#works .item:nth-child(5) {transition-delay: 1.4s;}
#works .item:nth-child(6) {transition-delay: 1.5s;}
#works .item:nth-child(7) {transition-delay: 1.6s;}
#works .item:nth-child(8) {transition-delay: 1.7s;}
#works .item:nth-child(4n) {margin-right: 0;}
#works .item:nth-child(n + 5) {margin-top: 60px;}
#works .img_box {position: relative; width: 100%; margin-bottom: 20px;}
#works h3 {font-size: 16px; line-height: 1.7;}
#works .tax_tag {font-size: 20px; line-height: 1; display: table; padding: 5px 10px; position: absolute; top: -16px; left: 5px; z-index: 10;}
#works .works_list {margin: 90px auto 80px;}
#works .works_list .item .img_box img {transform: translate(0px, 0px); transition-duration: .5s;}
#works .works_list .item .img_box {background: #3687d2;}
#works .works_list .item:hover img {transform: translate(-5px, -5px);}
#works .tag_box {margin-top: 80px;}
#works .tax {font-size: 20px; padding: 15px 0; width: 260px; line-height: 1;}
#works .img_item {width: 280px;}
#works .img_item .img {height: 200px; width: 100%;}
#works .img_item img {height: 100%; width: 100%; object-fit: cover;}
#single_works {padding-bottom: 80px;}
#single_works h2 {display: table; margin: auto; font-size: 30px; background: #3687d2; padding: 10px;}
#single_works .txt01 {font-size: 16px; line-height: 1; margin-top: 30px;}
#single_works .works_box a {width: 373px; margin-right: 40px; height: 280px;}
#single_works .works_box a img {width: 100%; height: 100%;}
#single_works .works_box a:nth-of-type(3n) {margin-right: 0;}
#single_works .works_box a:nth-of-type(n + 4) {margin-top: 40px;}
#single_works .case_item .txt {border: 3px solid #cfcfcf; padding: 50px;}
#single_works h3 {font-size: 16px; line-height: 1; padding: 5px; background: #000; display: table;}
#single_works .p {margin-top: 20px; font-size: 16px; line-height: 2;}

/*archives-works-tax*/
#archives-works-tax .item {box-sizing: border-box; width: 280px; border-bottom: 2px solid #3687d2; padding-bottom: 20px; position: relative; transition-delay: 1s; margin-right: 26px;}
#archives-works-tax .item:nth-child(2) {transition-delay: 1.1s;}
#archives-works-tax .item:nth-child(3) {transition-delay: 1.2s;}
#archives-works-tax .item:nth-child(4) {transition-delay: 1.3s;}
#archives-works-tax .item:nth-child(5) {transition-delay: 1.4s;}
#archives-works-tax .item:nth-child(6) {transition-delay: 1.5s;}
#archives-works-tax .item:nth-child(7) {transition-delay: 1.6s;}
#archives-works-tax .item:nth-child(8) {transition-delay: 1.7s;}
#archives-works-tax .item:nth-child(4n) {margin-right: 0;}
#archives-works-tax .item:nth-child(n + 5) {margin-top: 60px;}
#archives-works-tax .img_box {position: relative; width: 100%; margin-bottom: 20px;}
#archives-works-tax h3 {font-size: 16px; line-height: 1.7;}
#archives-works-tax .tax_tag {font-size: 20px; line-height: 1; display: table; padding: 5px 10px; position: absolute; top: -16px; left: 5px; z-index: 10;}
#archives-works-tax .tag_box {margin-top: 80px;}
#archives-works-tax .tax {font-size: 20px; padding: 15px 0; width: 260px; line-height: 1;}
#archives-works-tax .works_list {margin: 90px auto 80px;}
#archives-works-tax .works_list .item .img_box img {transform: translate(0px, 0px); transition-duration: .5s;}
#archives-works-tax .works_list .item .img_box {background: #3687d2;}
#archives-works-tax .works_list .item:hover img {transform: translate(-5px, -5px);}
#archives-works-tax .img_item {width: 280px;}
#archives-works-tax .img_item .img_box {height: 200px; width: 100%;}
#archives-works-tax .img_item img {height: 100%; width: 100%; object-fit: cover;}

/*contact*/
#contact .txt01 {font-size: 18px; line-height: 1; margin-top: 60px;}
#contact .tel {font-size: 40px; line-height: 1; margin: 5px auto 60px;}
#contact .tel span {font-size: 70px;}
#contact table {width: 100%; margin: auto; border: 1px solid #b7b7b7; margin-top: 80px;}
#contact .form_btn {box-sizing: border-box; width: 400px; height: 60px;font-size: 18px; line-height: 1; border: none; display: block; font-weight: bold; cursor: pointer; color: #fff; margin: 60px auto; background: url("img/contact/arrow.svg")center left 10px no-repeat; background-color: #000;}
#contact tr th,#contact tr td {vertical-align: middle; padding: 30px 20px; border-bottom: 1px solid #b7b7b7;}
#contact .essential {position: absolute; right: 25px; background: #fff; width: 60px; font-size: 15px; height: 25px; display: flex; align-items: center; justify-content: center; line-height: 1; color: #3687d2; top: 0; bottom: 0; margin: auto;}
#contact tr th {width: 300px; position: relative; box-sizing: border-box; vertical-align: middle; font-size: 18px; line-height: 1; padding: 30px 20px; background: #3687d2; color: #fff;}
#contact td input, #contact textarea {width: 100%; outline: none; font-size: 16px; padding: 10px; box-sizing: border-box; font-weight: 500;font-family: 'Noto Sans JP', sans-serif, "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif, -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Noto Sans Japanese", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", Arial, Meiryo, sans-serif; background: #eee; border: none;}
#contact textarea {line-height: 1.5;}
#contact td input {height: inherit; height: 40px; padding: 5px;}
.wpcf7 form.sent .wpcf7-response-output {display: none;}
.wpcf7 .ajax-loader {display: none;}
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output {border: none; color: red;}
.wpcf7-not-valid-tip {color: red!important; font-weight: 500!important;}
.wpcf7-spinner,.wpcf7-spinner::before {display: none;}
#contact .inner table:nth-child(2) th,#contact .inner table:nth-child(2) td {display: block;}
#contact .inner table tr:nth-child(1) th,#contact .inner table tr:nth-child(1) td {padding-top: 0;}
#contact .inner table:nth-child(2) th {padding-bottom: 30px; line-height: 1;}
#contact textarea {height: 150px;}
#contact .wpcf7 .ajax-loader {display: none;}
#contact .thanks {font-size: 16px; line-height: 2; margin-top: 80px;}



