@charset "UTF-8";
/* TOP
------------------------------------------*/
.home div#mv .ovh { padding-top: 37px; padding-bottom: 162px; }

.mv-box { width: calc(100% - 100px); border-radius: 20px; margin: 0 auto; background: url("../img/main/mv-bg.png") no-repeat left bottom; background-size: cover; position: relative; min-height: 878px; padding-top: 70px; box-sizing: border-box; }
.mv-box .mv-img { position: absolute; top: -37px; width: 814px; left: calc(50% + 204px); }

.mv-cont { width: 700px; position: relative; left: calc(50% - 650px); }

.ovh { overflow: hidden; }

ul.mv-feat.flex { align-items: center; margin-bottom: 15px; }
ul.mv-feat.flex > li { font-weight: 800; font-size: 22px; margin-right: 48px; position: relative; line-height: 32px; }
ul.mv-feat.flex > li:after { content: ""; background: url("../img/main/kakeru.svg") no-repeat; width: 27px; height: 27px; background-size: contain; position: absolute; left: calc(100% + 12px); top: 2px; }
ul.mv-feat.flex > li:last-child { margin-right: 0; }
ul.mv-feat.flex > li:last-child:after { content: none; }

.mv-copy { color: #05004E; font-weight: 800; font-size: 50px; line-height: 1.41; margin-bottom: 25px; }
.mv-copy span.dot01 { background: url("../img/main/dot01.svg") no-repeat left 8px top; }
.mv-copy span.dot02 { background: url("../img/main/dot02.svg") no-repeat center top; }

ul.mv-do.flex > li { margin-right: 10px; font-size: 22px; font-weight: 800; border-radius: 5px; padding: 9px 14px 10px 14px; background: #FECF00; line-height: 30px; }
ul.mv-do.flex > li:nth-child(2n) { background: #0D0485; color: #fff; }

.mv-cont02 { width: 700px; display: flex; flex-wrap: wrap; position: relative; left: calc(50% - 650px); position: relative; z-index: 5; }
.mv-cont02 .mv-sb { width: 150px; margin-right: 30px; margin-top: -30px; position: relative; }
.mv-cont02 .mv-sb img { display: block; position: relative; }
.mv-cont02 .mv-sb img.sb-in { opacity: 0.6; }
.mv-cont02 .mv-sb img.sb-in-text { position: absolute; left: 0; top: 0; width: 150px; z-index: 2; }
.mv-cont02 .mv-sb:before { content: ""; width: 100%; height: 100%; position: absolute; -webkit-backdrop-filter: blur(5px); backdrop-filter: blur(5px); border-radius: 100%; left: 0; bottom: 0; }
.mv-cont02 .mv-data01 { width: calc(100% - 180px); display: flex; flex-wrap: wrap; justify-content: space-between; margin-top: 40px; }
.mv-cont02 .mv-data01 .box { font-weight: 800; text-align: center; }
.mv-cont02 .mv-data01 .box .tit { font-size: 18px; color: #fff; border-radius: 30px; padding: 3px 9px; background: #2B92E8; }
.mv-cont02 .mv-data01 .box .text { font-size: 20px; }

div.belt-slider { margin-top: 50px; }
div.belt-slider .slick-list { overflow: visible; }
div.belt-slider div.b-slide { margin-right: 30px; }

section#top-news { margin-top: -62px; position: relative; z-index: 3; }

.slider01 .slick-track { display: flex; flex-wrap: wrap; }
.slider01 article.blog-art { margin-right: 46px; height: auto !important; }

button.slick-arrow { opacity: 1; z-index: 2; transition: 0.3s !important; width: 70px; height: 70px; box-sizing: border-box; transition: 0s; border: none; top: 90px; transform: translateY(0); }

button.slick-prev.slick-arrow { background: url("../img/common/slide-arrow01.svg") no-repeat center #BCBCBC; left: -70px; border-radius: 10px 0 0 10px; }

button.slick-next.slick-arrow { background: url("../img/common/slide-arrow02.svg") no-repeat center #BCBCBC; right: -70px; border-radius: 0 10px 10px 0; }

button.slick-arrow:before { content: none; }

button.slick-prev.slick-arrow:hover, button.slick-prev.slick-arrow.slick-disabled { background-color: #0D0485; }

button.slick-next.slick-arrow:hover, button.slick-next.slick-arrow.slick-disabled { background-color: #0D0485; }

button.slick-arrow.slick-disabled { background-color: transparent; }

article.blog-art { width: 336px; }
article.blog-art a { display: block; text-decoration: none; }
article.blog-art a .img { border-radius: 5px; border: solid 1px #ECECEC; margin-bottom: 20px; overflow: hidden; }
article.blog-art a .img .in-img { padding-top: 75%; border-radius: 4px; transition: 0.3s; }
article.blog-art a .cont .a-date { font-size: 13px; margin: 0 0 10px; }
article.blog-art a .cont h3.tit { width: 100%; font-weight: 500; line-height: 1.71; display: -webkit-box; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
article.blog-art a .cont .infos.flex { margin-top: 10px; }
article.blog-art a:hover .img .in-img { transform: scale(1.1); }

.infos.flex { width: calc(100% + 10px); margin: -10px 0 0 -10px; }
.infos.flex > div { font-size: 13px; color: #fff; line-height: 20px; border-radius: 2px; background: #727171; padding: 5px; margin: 10px 0 0 10px; }

section#servic-sec { padding-top: 226px; padding-bottom: 150px; margin-top: -75px; background: url("../img/top/top-bg01.svg") no-repeat top right calc(50% + 770px), url("../img/top/top-bg02.svg") no-repeat bottom left calc(50% + 660px); }
section#servic-sec .titles01 { margin-bottom: 80px; }

.service-list01.flex { margin-top: -90px; }
.service-list01.flex > div.serviceBox { margin: 90px 100px 0 0; position: relative; }
.service-list01.flex > div.serviceBox:nth-child(2n) { margin-right: 0; }
.service-list01.flex > div.serviceBox.service01 { left: 140px; }
.service-list01.flex > div.serviceBox.service02 { left: 140px; top: -100px; }
.service-list01.flex > div.serviceBox.service04 { top: -100px; }

.serviceBox { width: 430px; height: 691px; background: url("../img/top/service-bg-h.svg") no-repeat center; }
.serviceBox a { display: block; position: relative; text-decoration: none; width: 430px; height: 691px; box-sizing: border-box; padding-top: 290px; }
.serviceBox a > div, .serviceBox a .tit { position: relative; z-index: 2; }
.serviceBox a .tit { width: 234px; text-align: center; transform: rotateZ(-30deg); position: absolute; left: -29px; top: 13px; font-size: 26px; font-weight: 800; }
.serviceBox a .img { position: absolute; top: -81px; left: 0; }
.serviceBox a .img img { opacity: 1; }
.serviceBox a .num { color: #ffff; font-size: 18px; position: relative; z-index: 2; font-weight: 800; position: absolute; left: 47px; top: 194px; transform: rotateZ(30deg); }
.serviceBox a .sub-copy { color: #fff; font-size: 22px; position: relative; z-index: 2; padding: 0 40px; text-align: center; font-weight: 800; line-height: 1.6; margin-bottom: 20px; }
.serviceBox a > .text { color: #fff; position: relative; z-index: 2; text-align: center; padding: 0 40px; }
.serviceBox a .service-btn { color: #fff; position: absolute; z-index: 2; display: block; text-align: center; width: 80px; height: 42px; left: 0; right: 0; margin: 0 auto; bottom: 50px; }
.serviceBox a .service-btn img { opacity: 1; display: block; }
.serviceBox a .service-btn span.arrow { width: 18px; display: block; margin: 10px auto 0; }
.serviceBox a:before { content: ""; width: 100%; height: 100%; position: absolute; left: 0; top: 0; background: url("../img/top/service-bg.svg") no-repeat center; transition: 0.3s; }
.serviceBox a:hover:before { opacity: 0; }

section#works-sec { position: relative; overflow: hidden; }
section#works-sec > .bg { width: calc(50% + 650px); height: 100%; background: url("../img/top/tit-bg01.png") no-repeat left top #EAF2F9; background-size: 377px; border-radius: 15px 0 0 15px; position: absolute; top: 0; right: 0; }
section#works-sec .titles01 { margin-bottom: 90px; }
section#works-sec .wrap { position: relative; z-index: 2; width: 1175px; left: -38px; box-sizing: border-box; padding: 0 0 60px 30px; }

.works-list01 .slick-list { overflow: visible; }
.works-list01 .slick-track { display: flex; flex-wrap: wrap; }
.works-list01 article.works-art { margin-right: 70px; opacity: 0; pointer-events: none; height: auto !important; }
.works-list01 article.works-art.slick-active { opacity: 1; pointer-events: auto; }
.works-list01 article.works-art.slick-active + article.works-art { opacity: 1; pointer-events: auto; }
.works-list01 article.works-art.slick-active + article.works-art + article.works-art { opacity: 1; pointer-events: auto; }
.works-list01 button.slick-arrow { opacity: 1; z-index: 2; transition: 0.3s !important; width: 70px; height: 70px; box-sizing: border-box; transition: 0s; border: none; top: -130px; transform: translateY(0); }
.works-list01 button.slick-prev.slick-arrow { background: url("../img/common/slide-arrow03.svg") no-repeat center #fff; left: calc(50% + 664px); border-radius: 10px 0 0 10px; }
.works-list01 button.slick-next.slick-arrow { background: url("../img/common/slide-arrow04.svg") no-repeat center #fff; right: auto; left: calc(50% + 739px); border-radius: 0 10px 10px 0; }
.works-list01 button.slick-arrow:before { content: none; }
.works-list01 button.slick-prev.slick-arrow:hover, .works-list01 button.slick-prev.slick-arrow.slick-disabled { background-image: url("../img/common/slide-arrow01.svg"); background-color: #404040; }
.works-list01 button.slick-next.slick-arrow:hover, .works-list01 button.slick-next.slick-arrow.slick-disabled { background-image: url("../img/common/slide-arrow02.svg"); background-color: #404040; }
.works-list01 button.slick-arrow.slick-disabled { background-color: transparent; }
.works-list01 ul.slick-dots { text-align: left; bottom: auto; display: flex; width: 833px; left: 362px; right: auto; top: -93px; }
.works-list01 ul.slick-dots li { width: calc(100% / 8); height: 4px; margin: 0; }
.works-list01 ul.slick-dots li.slick-active { padding: 0; }
.works-list01 ul.slick-dots li.slick-active button { background: #404040; }
.works-list01 ul.slick-dots button { width: 100%; height: 4px; background: #DCE3E9; padding: 0; }
.works-list01 ul.slick-dots button:before { content: none; }

article.works-art { width: 336px; }
article.works-art a { position: relative; display: block; text-decoration: none; }
article.works-art a .a-date { font-size: 13px; position: absolute; transform: rotateZ(90deg); left: -5px; top: 2px; transform-origin: left top; }
article.works-art a .img { overflow: hidden; margin-bottom: 20px; position: relative; border-radius: 5px; }
article.works-art a .img .cate { position: absolute; left: 0; top: 0; padding: 7px 9px; color: #fff; font-size: 13px; background: #05004E; border-radius: 5px 0 5px 0; z-index: 2; line-height: 22px; }
article.works-art a .img .in-img { padding-top: 75%; border-radius: 5px; transition: 0.3s; }
article.works-art a h3.tit { margin-bottom: 20px; width: 100%; line-height: 31px; display: -webkit-box; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; font-weight: 800; }
article.works-art a:hover .img .in-img { transform: scale(1.1); }

.w-data dl { margin-bottom: 15px; align-items: center; justify-content: space-between; }
.w-data dl dt { width: 49px; height: 41px; text-align: center; line-height: 41px; background: #2B92E8; color: #fff; border-radius: 5px; font-size: 13px; }
.w-data dl dd { width: calc(100% - 59px); line-height: 22px; font-size: 13px; }
.w-data dl:last-child { margin-bottom: 0; }

.more-btn01 { width: 90px; height: 100%; position: absolute; z-index: 5; right: 0; top: 0; }
.more-btn01 a { display: block; height: 100%; border-radius: 10px 0 0 10px; color: #fff; background: rgba(0, 0, 0, 0.5); -webkit-backdrop-filter: blur(5px) brightness(0.5); backdrop-filter: blur(5px) brightness(0.5); display: flex; flex-wrap: wrap; justify-content: center; align-items: center; text-decoration: none; }
.more-btn01 a .in01 { width: 20px; padding: 0 5px 13px; background: url("../img/common/btn-arow-white.svg") no-repeat center bottom; line-height: 20px; }
.more-btn01 a:hover { background: #0D0485; }

section#range-sec { padding: 120px 0; border-radius: 50px; background: url("../img/top/range-bg.png") no-repeat center; background-size: cover; color: #fff; margin-bottom: -40px; position: relative; z-index: 2; margin-top: 150px; }
section#range-sec .titles01 { margin-bottom: 76px; }
section#range-sec .wrap { width: 1300px; }

h4.titles02.tth { margin-bottom: 0; }

.bikou-text01 > p { position: relative; padding-left: 18px; }
.bikou-text01 > p:before { content: "※"; position: absolute; left: 0; top: 0; }

div.range-list01.flex { margin-top: -76px; justify-content: space-between; }
div.range-list01.flex > div.box { box-sizing: border-box; border-radius: 10px; background: rgba(5, 0, 78, 0.7); padding: 40px; position: relative; margin-top: 76px; }
div.range-list01.flex > div.box > .tit { position: absolute; bottom: 100%; left: 33px; border-radius: 10px 10px 0 0; font-size: 18px; font-weight: 800; line-height: 31px; padding: 5px 15px; background: rgba(5, 0, 78, 0.7); }
div.range-list01.flex > div.box > .tit .r-left { width: 10px; height: 10px; overflow: hidden; position: absolute; right: 100%; bottom: 0; }
div.range-list01.flex > div.box > .tit .r-left:before { content: ""; width: 20px; height: 20px; border-radius: 100%; box-shadow: 10px 10px 0 0 rgba(5, 0, 78, 0.7); position: absolute; bottom: 0; right: 0; }
div.range-list01.flex > div.box > .tit .r-right { width: 10px; height: 10px; overflow: hidden; position: absolute; left: 100%; bottom: 0; }
div.range-list01.flex > div.box > .tit .r-right:before { content: ""; width: 20px; height: 20px; border-radius: 100%; box-shadow: -10px 10px 0 0 rgba(5, 0, 78, 0.7); position: absolute; bottom: 0; left: 0; }
div.range-list01.flex > div.box .inner > .inBox { padding-bottom: 20px; border-bottom: solid 1px #3D3A67; margin-bottom: 20px; }
div.range-list01.flex > div.box .inner > .inBox:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
div.range-list01.flex > div.box .inner .img { margin: 20px auto 0; text-align: center; }
div.range-list01.flex > div.box.box01 { width: 41.23%; }
div.range-list01.flex > div.box.box02 { width: 27.07%; }
div.range-list01.flex > div.box.box03 { width: 27.07%; }
div.range-list01.flex > div.box.box04 { width: calc(50% - 15px); }
div.range-list01.flex > div.box.box05 { width: calc(50% - 15px); }

section#about-sec { padding: 196px 0 513px; background: linear-gradient(180deg, white 0%, #f6fafd 49%, #eaf2f9 100%); }
section#about-sec .wrap { box-sizing: border-box; padding-right: 690px; width: 1300px; margin-bottom: 65px; }
section#about-sec .wrap .movie { position: absolute; right: 0; top: 102px; width: 620px; height: 348px; }
section#about-sec .wrap .movie iframe { width: 100%; height: 100%; border-radius: 10px; }
section#about-sec .wrap .btn01 { margin-top: 38px; }

section#reason-sec { background: url("../img/top/reason-bg.png") no-repeat center top; padding: 226px 0 160px; box-sizing: border-box; height: 882px; color: #fff; margin-top: -424px; margin-bottom: -399px; z-index: 3; position: relative; }
section#reason-sec .wrap { width: 1150px; }
section#reason-sec .service-btn { text-align: center; }
section#reason-sec .service-btn a { color: #fff; }
section#reason-sec .service-btn a > span.text { display: block; }
section#reason-sec .service-btn a span.arrow { display: inline-block; position: relative; top: -5px; }
section#reason-sec .service-btn a span.arrow img { display: block; }
section#reason-sec .service-btn a:hover { text-decoration: underline; }

.titles01.type03 { width: 36px; position: absolute; left: 0; right: 0; top: -65px; margin: 0 auto; }
.titles01.type03 > span { display: block; width: 36px; text-align: center; line-height: 1.16; padding-top: 16px; }

.reason-list01.flex { justify-content: space-between; margin-top: -30px; }
.reason-list01.flex > div.box { width: 467px; display: flex; flex-wrap: wrap; align-items: center; flex-direction: row-reverse; justify-content: space-between; margin-top: 30px; }
.reason-list01.flex > div.box .img { width: 267px; }
.reason-list01.flex > div.box .text { width: calc(100% - 287px); text-align: right; font-size: 18px; font-weight: 800; line-height: 31px; }
.reason-list01.flex > div.box:nth-child(2n) { flex-direction: row; }
.reason-list01.flex > div.box:nth-child(2n) .text { text-align: left; }

section#onestop-sec { padding-top: 535px; position: relative; z-index: 2; background: url("../img/top/onestop-bg.svg") no-repeat center top; margin-bottom: -182px; }
section#onestop-sec .wrap { display: flex; flex-wrap: wrap; justify-content: space-between; }
section#onestop-sec .wrap .left { width: 563px; }
section#onestop-sec .wrap .right { width: 467px; margin-top: -44px; }
section#onestop-sec .wrap .bottom { width: 100%; margin-top: 100px; }
section#onestop-sec .wrap .bottom > h3.tit { text-align: center; margin-bottom: 30px; line-height: 38px; font-weight: 800; font-size: 22px; }
section#onestop-sec .wrap .btn01 { margin: 60px auto 0; }

.subBox { margin-top: 40px; padding-top: 40px; border-top: solid 1px #B7C2CB; }

.titles02.type02 { background-image: url("../img/common/tit-ico03.svg"); }

ul.dot-list01 > li { position: relative; padding-left: 15px; }
ul.dot-list01 > li:before { content: "・"; position: absolute; left: 0; top: 0; }

.ico-setsumei { text-align: right; margin-bottom: 10px; }

.onestop-ico { width: 1158px; margin-left: -29px; }

section#facility-sec { padding: 518px 0 303px; background: url("../img/top/top-bg03.svg") no-repeat top right calc(50% + 710px), url("../img/top/top-bg04.svg") no-repeat bottom right calc(50% + 710px); overflow: hidden; }
section#facility-sec .wrap { box-sizing: border-box; padding-right: 669px; }
section#facility-sec .wrap .img { position: absolute; left: 500px; top: -286px; width: 820px; }
section#facility-sec .wrap .btn01 { margin-top: 60px; }

.copy { font-weight: 800; margin-bottom: 30px; font-size: 22px; }

div#seq-box { padding: 83px 0 150px; }

.seq-cont { display: flex; flex-wrap: wrap; align-items: center; color: #fff; border-radius: 10px; background: linear-gradient(267deg, #2782da 0%, #0b107c 100%); width: 100%; box-sizing: border-box; padding: 20px 60px 23px; }
.seq-cont .img { width: 327px; margin-right: 22px; }
.seq-cont .cont { width: calc(100% - 349px); }
.seq-cont .cont .tit { font-size: 22px; margin-bottom: 30px; }

/*　02 樹脂切削加工
----------------------------------*/
div#umv { height: 220px; background: url("../img/main/umv.jpg") no-repeat center; display: flex; flex-wrap: wrap; width: 100%; justify-content: center; align-items: center; }

.mv-tit { font-weight: 800; font-size: 45px; line-height: 1.4; }

section#p02Box01 { padding: 80px 0 150px; }
section#p02Box01 .twin-cont01.flex { margin-bottom: 40px; }
section#p02Box01 .copy { line-height: 1.6; }

.twin-cont01.flex { justify-content: space-between; }
.twin-cont01.flex > div.left { width: 514px; }
.twin-cont01.flex > div.right { width: 538px; }

.tri-box01.flex { border: solid 1px #2B92E8; box-sizing: border-box; border-radius: 10px; }
.tri-box01.flex > div.box { width: 366px; box-sizing: border-box; border-right: solid 1px #D5EBFF; line-height: 1.6; }
.tri-box01.flex > div.box .bikou-text01 { margin-top: 10px; }
.tri-box01.flex > div.box .tit { background: #2B92E8; color: #fff; padding: 10px 20px; line-height: 1.6; position: relative; }
.tri-box01.flex > div.box .tit:after { content: ""; width: 1px; height: 100%; background: #fff; position: absolute; right: -1px; top: 0; z-index: 2; }
.tri-box01.flex > div.box .cont { padding: 20px; }
.tri-box01.flex > div.box .cont .num-text .num { font-weight: 800; font-size: 24px; }
.tri-box01.flex > div.box:first-child .tit { border-radius: 8px 0 0 0; }
.tri-box01.flex > div.box:nth-child(3n) { border-right: none; }
.tri-box01.flex > div.box:nth-child(3n) .tit { border-radius: 0 8px 0 0; }
.tri-box01.flex > div.box:nth-child(3n) .tit:after { content: none; }

dl.in-dl01.flex dt { font-weight: 800; }

div#p02Box02 { padding: 150px 0; background: #EAF2F9; }
div#p02Box02 ul.links.flex { width: 1100px; margin: 0 auto 100px; }

ul.links.flex > li { margin-right: 10px; width: 212px; height: 70px; display: table; margin-right: 10px; }
ul.links.flex > li a { display: table-cell; text-align: left; vertical-align: middle; border: solid 1px #FECF00; background: #FECF00; color: #404040; position: relative; padding-right: 40px; line-height: 1.3; padding-left: 20px; border-radius: 10px; text-decoration: none; }
ul.links.flex > li a .arrow { position: absolute; right: 20px; top: 50%; transform: translateY(-50%); z-index: 2; }
ul.links.flex > li a .arrow img { display: block; opacity: 1; }
ul.links.flex > li a:hover { border-color: #404040; background: #fff; }
ul.links.flex > li:last-child { margin-right: 0; }

section.p02-2-1 { padding: 0 0 120px; background: url("../img/p02/bg01.svg") no-repeat right calc(50% + 660px) bottom 48px; }
section.p02-2-1 .tit-head.flex .text { width: 550px; }

.tit-head.flex { margin-bottom: 40px; justify-content: space-between; }
.tit-head.flex .titles01 { margin-bottom: 0; }

.mate-list.flex { margin-top: -20px; }
.mate-list.flex .mateBox { width: 266px; margin: 20px 12px 0 0; background: #fff; padding: 20px; border-radius: 5px; box-sizing: border-box; line-height: 1.6; }
.mate-list.flex .mateBox .img { margin-bottom: 20px; }
.mate-list.flex .mateBox h3.tit { font-weight: 800; line-height: 1.6; margin-bottom: 10px; }
.mate-list.flex .mateBox .cont .inBox { margin-bottom: 10px; }
.mate-list.flex .mateBox .cont .inBox:last-child { margin-bottom: 0; }
.mate-list.flex .mateBox:nth-child(4n) { margin-right: 0; }

.sub02 { color: #2B92E8; font-size: 14px; border-bottom: solid 1px #2B92E8; margin-bottom: 6px; }

section.p02-2-2 { padding-bottom: 126px; background: url("../img/p02/bg02.svg") no-repeat bottom left calc(50% + 660px); }

.method-list01.flex { margin-top: -25px; }
.method-list01.flex .methodBox { width: 350px; margin: 25px 25px 0 0; background: #fff; line-height: 1.6; border-radius: 5px; }
.method-list01.flex .methodBox .img img { border-radius: 5px 5px 0 0; }
.method-list01.flex .methodBox .cont { padding: 20px; }
.method-list01.flex .methodBox .cont .tit { font-weight: 800; font-size: 24px; margin-bottom: 10px; }
.method-list01.flex .methodBox:nth-child(3n) { margin-right: 0; }

section.u-works { position: relative; padding-bottom: 60px; overflow: hidden; }
section.u-works .bg { position: absolute; right: 0; top: 100px; height: calc(100% - 100px); width: calc(50% + 610px); background: #fff; border-radius: 20px 0 0 20px; }
section.u-works .bg:before { content: ""; height: 100px; width: calc(100% - 100px); background: #fff; position: absolute; right: 0; bottom: 100%; }
section.u-works .wrap { z-index: 5; }
section.u-works .btn01 { margin-top: 60px; }

.titles01.kado { margin-bottom: 56px; }
.titles01.kado > span { padding-right: 50px; padding-bottom: 34px; background-color: #EAF2F9; box-sizing: border-box; height: 100px; position: relative; }
.titles01.kado > span .r-top { width: 20px; height: 20px; overflow: hidden; position: absolute; left: 100%; top: 0; }
.titles01.kado > span .r-top:before { content: ""; width: 40px; height: 40px; border-radius: 100%; box-shadow: -20px -20px 0 0 #EAF2F9; position: absolute; top: 0; left: 0; }
.titles01.kado > span .r-bottom { width: 20px; height: 20px; overflow: hidden; position: absolute; right: 0; bottom: 0; }
.titles01.kado > span .r-bottom:before { content: ""; width: 40px; height: 40px; border-radius: 100%; box-shadow: 20px 20px 0 0 #fff; position: absolute; bottom: 0; right: 0; }

.works-list02.flex { box-sizing: border-box; padding-left: 26px; }
.works-list02.flex .slick-list { overflow: visible; }
.works-list02.flex .slick-track { display: flex; flex-wrap: wrap; }
.works-list02.flex article.works-art { margin-right: 70px; opacity: 0; pointer-events: none; height: auto !important; }
.works-list02.flex article.works-art.slick-active { opacity: 1; pointer-events: auto; }
.works-list02.flex article.works-art.slick-active + article.works-art { opacity: 1; pointer-events: auto; }
.works-list02.flex article.works-art.slick-active + article.works-art + article.works-art { opacity: 1; pointer-events: auto; }
.works-list02.flex button.slick-arrow { opacity: 1; z-index: 2; transition: 0.3s !important; width: 70px; height: 70px; box-sizing: border-box; transition: 0s; border: none; top: auto; transform: translateY(0); bottom: -130px; border: solid 1px #EAF2F9; }
.works-list02.flex button.slick-prev.slick-arrow { background: url("../img/p02/slide-arrow01.svg") no-repeat center #EAF2F9; left: 975px; border-radius: 10px 0 0 10px; }
.works-list02.flex button.slick-next.slick-arrow { background: url("../img/p02/slide-arrow02.svg") no-repeat center #EAF2F9; right: auto; left: 1050px; border-radius: 0 10px 10px 0; }
.works-list02.flex button.slick-arrow:before { content: none; }
.works-list02.flex button.slick-prev.slick-arrow:hover, .works-list02.flex button.slick-prev.slick-arrow.slick-disabled { background-color: #fff; border-color: #404040; }
.works-list02.flex button.slick-next.slick-arrow:hover, .works-list02.flex button.slick-next.slick-arrow.slick-disabled { background-color: #fff; border-color: #404040; }
.works-list02.flex button.slick-arrow.slick-disabled { background-color: transparent; }

section.p02-2-4 { padding: 120px 0; }
section.p02-2-4 .tit-head.flex { margin-bottom: 60px; }
section.p02-2-4 .tit-head.flex > .text { width: 484px; }
section.p02-2-4 .twin-cont01.flex { margin-bottom: 40px; }
section.p02-2-4 .twin-cont01.flex .left { width: 554px; }
section.p02-2-4 .twin-cont01.flex .right { width: 496px; }

.TBL02 { line-height: 1.6; }
.TBL02 table { border-collapse: separate; border-spacing: 0; }
.TBL02 th, .TBL02 td { box-sizing: border-box; }
.TBL02 thead th { background: #2B92E8; color: #fff; padding: 10px 20px; border-right: solid 1px #fff; }
.TBL02 thead th.col03 { border-right-color: #2B92E8; }
.TBL02 thead .col01 { border-radius: 10px 0 0 0; }
.TBL02 thead .col03 { border-radius: 0 10px 0 0; }
.TBL02 tbody td { background: #fff; border-bottom: solid 1px #E3ECFD; border-right: solid 1px #E3ECFD; padding: 20px; }
.TBL02 tbody td.col01 { border-left: solid 1px #2B92E8; }
.TBL02 tbody td.col03 { border-right-color: #2B92E8; }
.TBL02 tbody tr:last-child td { border-bottom: solid 1px #2B92E8; }
.TBL02 tbody tr:last-child td.col01 { border-radius: 0 0 0 10px; }
.TBL02 tbody tr:last-child td.col03 { border-radius: 0 0 10px 0; }
.TBL02 .col01 { width: 380px; }
.TBL02 .col02 { width: 360px; }
.TBL02 .col03 { width: 360px; }

section.u-column { position: relative; }
section.u-column .btn01 { margin: 60px auto 0; }

.news-list02.flex button.slick-arrow { opacity: 1; z-index: 2; transition: 0.3s !important; width: 70px; height: 70px; box-sizing: border-box; transition: 0s; border: none; top: -110px; transform: translateY(0); border: solid 1px #fff; }
.news-list02.flex button.slick-prev.slick-arrow { background: url("../img/p02/slide-arrow01.svg") no-repeat center #fff; left: auto; right: 80px; border-radius: 10px 0 0 10px; }
.news-list02.flex button.slick-next.slick-arrow { background: url("../img/p02/slide-arrow02.svg") no-repeat center #fff; right: 0; left: auto; border-radius: 0 10px 10px 0; }
.news-list02.flex button.slick-arrow:before { content: none; }
.news-list02.flex button.slick-prev.slick-arrow:hover, .news-list02.flex button.slick-prev.slick-arrow.slick-disabled { background-color: #fff; border-color: #404040; }
.news-list02.flex button.slick-next.slick-arrow:hover, .news-list02.flex button.slick-next.slick-arrow.slick-disabled { background-color: #fff; border-color: #404040; }
.news-list02.flex button.slick-arrow.slick-disabled { background-color: transparent; }

/*　03 治具の設計製作
----------------------------------*/
section#p03Box01 { padding: 80px 0 150px; background: url("../img/p02/bg02.svg") no-repeat bottom left calc(50% + 660px); }

section#p03Box02 { padding: 150px 0; background: linear-gradient(90deg, #2782da 0%, #0b107c 100%); }
section#p03Box02 .tit-head.flex { color: #fff; align-items: flex-end; }
section#p03Box02 .tit-head.flex > .text { width: 880px; }

div.typeBox { margin-bottom: 20px; line-height: 1.6; border-radius: 5px; background: #fff; border: solid 1px #fff; }
div.typeBox .opcl-cont { display: none; }
div.typeBox .opcl-cont .text { padding: 25px 30px; }

div.typeBox:last-child { margin-bottom: 0; }

div.typeBox.on { border-color: #0D0485; }
div.typeBox.on h3.type-tit { color: #fff; background: #0D0485; border-radius: 4px 4px 0 0; }
div.typeBox.on h3.type-tit .num { color: #0D0485; }
div.typeBox.on h3.type-tit .num:before { background: #fff; }
div.typeBox.on h3.type-tit span.opcl-ico:before { background: #fff; }
div.typeBox.on h3.type-tit span.opcl-ico:after { background: #fff; transition: 0.3s; opacity: 0; transform: rotateZ(-90deg); }

h3.type-tit { padding: 18px 60px 18px 82px; position: relative; background: #fff; border-radius: 5px; font-weight: 800; font-size: 24px; cursor: pointer; }
h3.type-tit .num { width: 46px; height: 46px; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; position: absolute; left: 20px; top: 14px; z-index: 2; color: #fff; font-size: 16px; }
h3.type-tit .num > span { display: inline-block; position: relative; z-index: 2; }
h3.type-tit .num:before { content: ""; width: 32px; height: 32px; border-radius: 1px; position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto; background: #0D0485; transform: rotateZ(45deg); }
h3.type-tit span.opcl-ico { width: 30px; height: 30px; position: absolute; z-index: 2; right: 20px; top: 50%; transform: translateY(-50%); }
h3.type-tit span.opcl-ico:before { content: ""; width: 18px; height: 2px; background: #0D0485; transition: 0.3s; left: 0; right: 0; top: 0; bottom: 0; margin: auto; border-radius: 2px; position: absolute; }
h3.type-tit span.opcl-ico:after { content: ""; width: 2px; height: 18px; background: #0D0485; transition: 0.3s; left: 0; right: 0; top: 0; bottom: 0; margin: auto; border-radius: 2px; position: absolute; }

section#p03Box03 { padding: 150px 0; background: url("../img/p03/bg02.svg") no-repeat bottom right calc(50% + 660px); }
section#p03Box03 .titles01 { margin-bottom: 52px; }

div.flowBox { width: 254px; position: relative; background: #EAF2F9; line-height: 1.6; margin-right: 28px; }
div.flowBox .num { position: absolute; left: 0; right: 0; top: -12px; width: 52px; height: 24px; border-radius: 20px; color: #fff; text-align: center; font-size: 14px; font-weight: 800; background: #2B92E8; margin: 0 auto; z-index: 2; }
div.flowBox .cont { padding: 20px; }
div.flowBox .cont > .tit { font-weight: 800; font-size: 18px; margin-bottom: 10px; }

div.flowBox:after { content: ""; width: 0; height: 0; border-left: solid 10px #2B92E8; border-top: solid 8px transparent; border-bottom: solid 8px transparent; position: absolute; top: 0; bottom: 0; left: calc(100% + 9px); margin: auto 0; }

div.flowBox:last-child { margin-right: 0; }

div.flowBox:last-child:after { content: none; }

.p03-bg-wrap01 { padding: 150px 0; background: #EAF2F9; }

section#p03Box04 { padding: 150px 0; }

div.canBox { padding-bottom: 50px; margin-bottom: 50px; border-bottom: solid 1px #B7C2CB; width: 100%; display: flex; flex-wrap: wrap; justify-content: space-between; }
div.canBox .img { width: 288px; border-radius: 10px; position: relative; }
div.canBox .img .num { width: 46px; height: 46px; background: #0D0485; color: #fff; line-height: 46px; text-align: center; border-radius: 10px 0 10px 0; font-size: 18px; font-weight: 800; position: absolute; left: 0; top: 0; z-index: 2; }
div.canBox .cont { width: calc(100% - 328px); }
div.canBox .cont .copy { margin-bottom: 10px; }
div.canBox .cont .copy .blue, div.canBox .cont .copy .yellow { font-size: 26px; }

div.canBox:last-child { padding-bottom: 0; margin-bottom: 0; border-bottom: none; }

/*　04 追加工
----------------------------------*/
section#p04Box01 { padding: 80px 0 150px; background: url("../img/p04/bg01.svg") no-repeat bottom left calc(50% + 660px); }
section#p04Box01 .twin-cont01.flex { margin-bottom: 63px; }

.blueBox { background: #EAF2F9; border-radius: 10px; padding: 1px 20px 30px; }
.blueBox .tit { line-height: 45px; color: #fff; margin: -24px 0 30px; font-size: 18px; font-weight: 800; }
.blueBox .tit > span { display: inline-block; height: 45px; border-radius: 40px; padding: 0 20px; background: #2B92E8; }

ul.check-list01.flex { margin-top: -14px; }
ul.check-list01.flex > li { margin: 14px 20px 0 0; box-sizing: border-box; padding-left: 28px; background: url("../img/p04/ico-check.svg") no-repeat left top 1px; line-height: 1.6; min-width: 460px; }
ul.check-list01.flex > li:nth-child(2n) { margin-right: 0; }

section#p04Box02 { padding: 150px 0; background: linear-gradient(90deg, #2782da 0%, #0b107c 100%); }
section#p04Box02 .tit-head.flex { color: #fff; align-items: flex-end; margin-bottom: 40px; }
section#p04Box02 .tit-head.flex > .text { width: 844px; }

.cont-list.flex { width: 1102px; }
.cont-list.flex .box { background: #fff; width: 268px; margin-right: 10px; box-sizing: border-box; border-radius: 10px; padding: 30px 20px; margin-right: 10px; }
.cont-list.flex .box:nth-child(4n) { margin-right: 0; }

.num-tit { margin-bottom: 10px; align-items: center; display: flex; flex-wrap: wrap; align-items: center; }
.num-tit .num { font-size: 14px; font-weight: 800; background: #0D0485; border-radius: 5px; color: #fff; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; margin-right: 10px; width: 36px; height: 36px; }
.num-tit .text { width: calc(100% - 46px); font-size: 20px; font-weight: 800; color: #0D0485; }

.p04-bg-wrap01 { padding: 150px 0; background: url("../img/p04/bg02.svg") no-repeat bottom 18px right calc(50% + 660px); }
.p04-bg-wrap01 section.u-works .titles01.kado > span { background-color: #fff; }
.p04-bg-wrap01 section.u-works .titles01.kado > span .r-top:before { box-shadow: -20px -20px 0 0 #fff; }
.p04-bg-wrap01 section.u-works .titles01.kado > span .r-bottom:before { box-shadow: 20px 20px 0 0 #EAF2F9; }
.p04-bg-wrap01 section.u-works .bg { background: #EAF2F9; }
.p04-bg-wrap01 section.u-works .bg:before { background: #EAF2F9; }
.p04-bg-wrap01 .works-list02.flex button.slick-prev.slick-arrow { background-color: #fff; }
.p04-bg-wrap01 .works-list02.flex button.slick-next.slick-arrow { background-color: #fff; }

/*　05 試作・小ロット対応
----------------------------------*/
section#p05Box01 { padding: 80px 0 150px; background: url("../img/p04/bg01.svg") no-repeat bottom left calc(50% + 660px); }
section#p05Box01 h2.copy { font-size: 32px; font-weight: 800; line-height: 1.45; margin-bottom: 30px; }
section#p05Box01 .blueBox { margin-top: 80px; padding: 1px 30px 30px; }
section#p05Box01 .blueBox .tit > span { min-width: 330px; box-sizing: border-box; text-align: center; }
section#p05Box01 .blueBox .inner01.flex { justify-content: space-between; align-items: center; }
section#p05Box01 .blueBox .inner01.flex ul.check-list01.flex { display: block; margin-top: 0; width: 588px; }
section#p05Box01 .blueBox .inner01.flex ul.check-list01.flex > li { font-size: 20px; width: 100%; margin: 0 0 20px; background-position: left top 4px; }
section#p05Box01 .blueBox .inner01.flex ul.check-list01.flex > li .blue { font-weight: 800; }
section#p05Box01 .blueBox .inner01.flex ul.check-list01.flex > li:last-child { margin-bottom: 0; }

section#p05Box02 { padding: 150px 0; background: #EAF2F9; }
section#p05Box02 .titles01 { text-align: center; background-position: center top; margin-bottom: 30px; }
section#p05Box02 .copy { text-align: center; margin-bottom: 50px; }
section#p05Box02 .wrap > .text { width: 900px; margin: 0 auto; }

.sceneBox { position: relative; background: #fff; padding: 85px 40px 40px; border-radius: 10px; margin-top: 70px; }
.sceneBox .ang-tit { background: #0D0485; border-radius: 10px 0 10px 0; font-weight: 800; font-size: 18px; padding: 10px 12px; line-height: 1.4; }
.sceneBox .inner.flex .box { width: 320px; margin-right: 30px; background: #EAF2F9; }
.sceneBox .inner.flex .box .cont { padding: 20px; }
.sceneBox .inner.flex .box .cont .tit { font-weight: 800; line-height: 1.6; font-size: 18px; margin-bottom: 10px; }
.sceneBox .inner.flex .box:nth-child(3n) { margin-right: 0; }

ul.dot-list02 > li { position: relative; padding-left: 14px; line-height: 1.6; margin-bottom: 6px; }
ul.dot-list02 > li:last-child { margin-bottom: 0; }
ul.dot-list02 > li:before { content: ""; width: 6px; height: 6px; border-radius: 100%; background: #0D0485; position: absolute; left: 0; top: 10px; }

section#p05Box03 { background: linear-gradient(90deg, #2782da 0%, #0b107c 100%); padding: 150px 0; }
section#p05Box03 .titles01 { color: #fff; }

.type-list.faq-list div.typeBox .opcl-cont .text { position: relative; padding-left: 60px; }
.type-list.faq-list div.typeBox .opcl-cont .text:before { content: "A"; color: #0D0485; font-weight: 800; position: absolute; left: 40px; top: 21px; font-size: 20px; }

/*　06 事例紹介
----------------------------------*/
section#p06Box01 { padding: 80px 0 150px; background: url("../img/p04/bg01.svg") no-repeat top 35px left calc(50% + 660px); }
section#p06Box01 .twin-cont01.flex { margin-bottom: 40px; }
section#p06Box01 .twin-cont01.flex > .left { width: 380px; }
section#p06Box01 .twin-cont01.flex > .right { width: 690px; }

.trou-box { background: #EAF2F9; border-radius: 10px; padding: 1px 80px 40px; position: relative; box-sizing: border-box; margin-left: -80px; width: 1260px; margin-bottom: 100px; }
.trou-box .tit { text-align: center; font-weight: 800; font-size: 32px; margin: -24px auto 40px; line-height: 1.45; }

.trou-box:after { content: ""; width: 0; height: 0; border-top: solid 40px #EAF2F9; border-left: solid 70px transparent; border-right: solid 70px transparent; position: absolute; left: 0; right: 0; top: 100%; margin: 0 auto; }

.check-list06.flex { margin-top: -20px; justify-content: space-between; }
.check-list06.flex > div.box { width: 540px; box-sizing: border-box; margin-top: 20px; border-radius: 5px; padding: 16px 14px; background: #fff; line-height: 1.6; font-size: 20px; }
.check-list06.flex > div.box > p { padding-left: 28px; background: url("../img/p04/ico-check.svg") no-repeat left top 5px; }
.check-list06.flex > div.box > p .blue { font-weight: 800; }

section#p06Box02 { padding: 150px 0; color: #fff; background: linear-gradient(90deg, #2782da 0%, #0b107c 100%); }

section#p06Box03 { padding: 150px 0; background: url("../img/p04/bg02.svg") no-repeat bottom 150px right calc(50% + 660px); }

.method-list01.range-list06.flex .methodBox { border-radius: 5px; background: #EAF2F9; }

/*　07 設備紹介
----------------------------------*/
div#p07Box01 { padding: 80px 0 150px; }
div#p07Box01 .wrap .copy { font-size: 32px; line-height: 1.45; margin-bottom: 30px; }

.faci-list { margin-top: 85px; }
.faci-list .titles04 { border-bottom: solid 1px #DADADA; padding-bottom: 16px; font-size: 26px; margin-bottom: 40px; background-position: left top 10px; line-height: 1.45; }

section.faciSec { margin-bottom: 80px; }

section.faciSec:last-child { margin-bottom: 0; }

article.faci-art { border: solid 1px #0D0485; border-radius: 5px; margin-bottom: 30px; }
article.faci-art > h3 { background: #0D0485; border-radius: 4px 4px 0 0; color: #fff; line-height: 1.45; padding: 10px 20px; font-size: 22px; }
article.faci-art .inner.flex { justify-content: space-between; flex-direction: row-reverse; box-sizing: border-box; padding: 40px; }
article.faci-art .inner.flex .img { width: 460px; }
article.faci-art .inner.flex .img .in-img { padding-top: 75.21%; border-radius: 5px; }
article.faci-art .inner.flex .eqTBL { width: 530px; }

article.faci-art:last-child { margin-bottom: 0; }

.eqTBL tr:first-child th, .eqTBL tr:first-child td { padding-top: 0; }
.eqTBL tr:last-child th, .eqTBL tr:last-child td { padding-bottom: 0; }
.eqTBL tr:last-child th:before { content: none; }
.eqTBL th, .eqTBL td { box-sizing: border-box; position: relative; padding: 20px 0; line-height: 1.6; vertical-align: top; }
.eqTBL th:before { content: ""; height: 1px; width: 530px; position: absolute; z-index: 2; left: 0; bottom: 0; background-image: radial-gradient(circle, #707070 1px, transparent 1px), radial-gradient(circle, #707070 1px, transparent 1px); background-position: left bottom, left top; background-repeat: repeat-x, repeat-y; background-size: 6px 2px, 2px 6px; }
.eqTBL th { width: 124px; font-weight: 800; color: #0D0485; }

div#p07Box02 { padding: 150px 0; background: #EAF2F9; }

section.faciSec02 { margin-bottom: 80px; }

section.faciSec02:last-child { margin-bottom: 0; }

.TBL07 { border-radius: 10px; border: solid 1px #2B92E8; }
.TBL07 .col01 { width: 336px; }
.TBL07 .col02 { width: 336px; }
.TBL07 .col03 { width: 336px; }
.TBL07 .col04 { width: 90px; }
.TBL07 th, .TBL07 td { box-sizing: border-box; }
.TBL07 table { border-collapse: separate; border-spacing: 0; }
.TBL07 thead th { background: #2B92E8; color: #fff; padding: 10px 20px; font-weight: 700; border-right: solid 1px #fff; }
.TBL07 thead th.col01 { border-radius: 8px 0 0 0; }
.TBL07 thead th.col04 { border-radius: 0 8px 0 0; border-right: none; text-align: center; }
.TBL07 tbody th, .TBL07 tbody td { padding: 20px; border-bottom: solid 1px #E3ECFD; }
.TBL07 tbody th { background: #CEE0F0; border-right: solid 1px #fff; }
.TBL07 tbody td { background: #fff; border-right: solid 1px #E3ECFD; }
.TBL07 tbody td.col04 { border-right: none; text-align: center; }
.TBL07 tbody tr:last-child th, .TBL07 tbody tr:last-child td { border-bottom: none; }
.TBL07 tbody tr:last-child th.col01 { border-radius: 0 0 0 8px; }
.TBL07 tbody tr:last-child td.col04 { border-radius: 0 0 8px 0; }

/*　08 モロトについて
----------------------------------*/
section#p08Box01 { padding: 80px 0 150px; background: url("../img/p02/bg02.svg") no-repeat top 92px left calc(50% + 660px); }
section#p08Box01 .twin-cont01.flex .left { width: 520px; }
section#p08Box01 .twin-cont01.flex .left .copy { line-height: 1.45; font-size: 32px; margin-bottom: 30px; }
section#p08Box01 .twin-cont01.flex .left > .text > p { margin-bottom: 20px; }
section#p08Box01 .twin-cont01.flex .left > .text > p:last-child { margin-bottom: 0; }
section#p08Box01 .twin-cont01.flex .right { width: 510px; }

ul.com-state.flex { margin-bottom: 20px; }
ul.com-state.flex > li { margin-right: 10px; border-radius: 5px; background: #FECF00; padding: 14px 20px; line-height: 1.3; font-weight: 800; }
ul.com-state.flex > li:last-child { margin-right: 0; }

section#p08Box02 { padding: 150px 0; background: linear-gradient(90deg, #2782da 0%, #0b107c 100%); }
section#p08Box02 .copy { color: #fff; line-height: 1.45; font-size: 32px; margin-bottom: 60px; }

.solu-list.flex { margin-top: -40px; justify-content: space-between; }
.solu-list.flex .soluBox { background: #fff; width: 530px; display: flex; flex-wrap: wrap; align-items: center; margin-top: 40px; border-radius: 5px; }
.solu-list.flex .soluBox .ico { width: 116px; background: #0D0485; color: #fff; display: flex; flex-wrap: wrap; align-items: center; text-align: center; justify-content: center; line-height: 1.3; font-weight: 800; height: 130px; border-radius: 5px 0 0 5px; }
.solu-list.flex .soluBox .ico img { display: block; }
.solu-list.flex .soluBox > .cont { width: calc(100% - 116px); box-sizing: border-box; padding: 10px 20px; }

section#p08Box03 { padding: 150px 0; background: #EAF2F9; }
section#p08Box03 .titles01 { margin-bottom: 60px; }

div.reasonBox { margin-bottom: 30px; display: flex; flex-wrap: wrap; flex-direction: row-reverse; box-sizing: border-box; border-radius: 10px; width: 100%; padding: 40px; justify-content: space-between; background: #fff; }
div.reasonBox .img { width: 462px; }
div.reasonBox .cont { width: 520px; }
div.reasonBox .cont .num { font-size: 14px; font-weight: 800; color: #2B92E8; margin-bottom: 10px; }
div.reasonBox .cont .tit { font-size: 28px; font-weight: 800; line-height: 1.6; margin-bottom: 10px; }
div.reasonBox .cont .btn01 { margin-top: 20px; }

div.reasonBox:nth-child(2n) { flex-direction: row; }

div.reasonBox:last-child { margin-bottom: 0; }

.sub03 { font-weight: 800; font-size: 18px; color: #0D0485; margin-bottom: 20px; }

/*　09 事例紹介
----------------------------------*/
div#two-content { justify-content: space-between; flex-direction: row; }

div#two-main { width: 772px; }

div#two-side { width: 298px; }

.case-list-all { margin-top: -30px; width: 100%; display: flex; flex-wrap: wrap; }
.case-list-all article.works-art.works-art02 { margin: 30px 20px 0 0; width: 376px; }
.case-list-all article.works-art.works-art02:nth-child(2n) { margin-right: 0; }

article.works-art a:hover .img .in-img { transform: scale(1.1); }

article.works-art.works-art02 a { height: 100%; text-decoration: none; box-sizing: border-box; background: #EAF2F9; border-radius: 10px; padding: 20px; }
article.works-art.works-art02 a .a-date { position: relative; transform: none; left: auto; top: auto; margin-bottom: 10px; }

/*詳細*/
div#p09sBox01 { padding: 100px 0 120px; }
div#p09sBox01 div#two-content { flex-direction: row; }
div#p09sBox01 .blog-text { margin-top: 40px; }

article.singleBox01 .infos.flex { width: calc(100% + 10px); margin-left: -10px; margin-top: -10px; align-items: center; margin-bottom: 10px; }
article.singleBox01 .infos.flex > div { margin: 10px 0 0 10px; line-height: 32px; }
article.singleBox01 .infos.flex .cate { color: #fff; border: solid 1px #05004E; border-radius: 5px; font-size: 14px; padding: 0 7px; background: #05004E; }
article.singleBox01 .infos.flex .w-date { font-size: 14px; background: none; padding: 0; color: #404040; margin-right: 10px; }
article.singleBox01 .w-data { margin-top: 40px; line-height: 1.6; }
article.singleBox01 .w-data dl.flex { justify-content: space-between; padding-bottom: 20px; margin-bottom: 20px; align-items: flex-start; background-image: radial-gradient(circle, rgba(112, 112, 112, 0.5) 1px, transparent 1px); background-position: left bottom; background-repeat: repeat-x; background-size: 8px 2px; }
article.singleBox01 .w-data dl.flex dt { width: 100px; color: #0D0485; font-weight: 800; padding: 0; background: none; height: auto; text-align: left; font-size: 16px; height: auto; line-height: 1.6; }
article.singleBox01 .w-data dl.flex dd { width: calc(100% - 100px); font-size: 16px; }
article.singleBox01 .w-data dl.flex:last-child { margin-bottom: 0; }

.kadaiBox, .teianBox { margin-top: 40px; }
.kadaiBox .greenBox, .teianBox .greenBox { padding: 30px; border-radius: 5px; }

article.singleBox01-case h2.titles02 { margin-bottom: 10px; border-bottom: none; }

.sub-tit { font-weight: 700; color: #34A02B; margin-bottom: 10px; }

h1.ws-tit { font-weight: 700; font-size: 22px; line-height: 1.4; margin-bottom: 20px; }

.wh3 { margin-bottom: 10px; font-weight: 700; font-size: 24px; }

.wh4 { margin-bottom: 10px; font-weight: 700; font-size: 20px; }

.wh5 { margin-bottom: 10px; font-weight: 700; font-size: 18px; }

.blog-text p:first-child { margin-top: 0; }
.blog-text p:first-child img { margin-top: 0; }
.blog-text img:first-child { margin-top: 0; }
.blog-text img[class*="wp-image-"] { margin: 20px 0; }
.blog-text iframe { max-width: 100%; }
.blog-text div { max-width: 100%; }
.blog-text a { max-width: 100%; }

.works-cont01.flex { justify-content: space-between; align-items: flex-start; }
.works-cont01.flex .gallery-main { width: 544px; }
.works-cont01.flex .gallery-main button.slick-prev.slick-arrow { border-radius: 2px !important; width: 30px; height: 50px; background: url("../img/p09/slide-arrow01.svg") no-repeat center #EAF2F9; top: 200px; transform: translateY(-50%); left: 0; right: auto; border: none; }
.works-cont01.flex .gallery-main button.slick-next.slick-arrow { border-radius: 2px !important; width: 30px; height: 50px; background: url("../img/p09/slide-arrow02.svg") no-repeat center #EAF2F9; top: 200px; transform: translateY(-50%); right: 0; left: auto; border: none; }
.works-cont01.flex .gallery-main button.slick-arrow:hover { opacity: 0.7; }
.works-cont01.flex .gallery-thumb.flex { width: 206px; margin-top: -10px; justify-content: space-between; }
.works-cont01.flex .gallery-thumb.flex .slick-track { transform: none !important; width: 100% !important; display: flex; flex-wrap: wrap; }

.g-main .cap { line-height: 1.4; margin-top: 10px; }

.g-main-img a { position: relative; text-decoration: none; display: block; border-radius: 5px; }
.g-main-img a .in-img { padding-top: 73.52%; border-radius: 5px; }

.g-thumb { width: 98px; position: relative; margin-top: 10px; margin-right: 10px; cursor: pointer; transition: 0.3s; border-radius: 5px; }
.g-thumb .in-img { padding-top: 73.46%; border-radius: 5px; }

.g-thumb:before { content: ""; width: 100%; height: 100%; border-radius: 5px; background: rgba(0, 0, 0, 0.5); position: absolute; left: 0; top: 0; z-index: 2; opacity: 0; }

.g-thumb:hover, .g-thumb.slick-current:before { opacity: 1; }

.g-thumb:nth-child(2n) { margin-right: 0; }

.w-repeat { margin-top: 40px; }
.w-repeat .w-repeatBox { margin-bottom: 40px; }
.w-repeat .w-repeatBox:last-child { margin-bottom: 0; }
.w-repeat .titles03 { font-size: 24px; }
.w-repeat .titles03:before { top: 19px; }

.wt-text01 { margin-bottom: 40px; }

.bfafBox.flex { margin-bottom: 20px; }

.wt-text01:last-child, .bfafBox.flex:last-child { margin-bottom: 0; }

.bfafBox.flex { justify-content: center; }
.bfafBox.flex .ang-tit { display: none; }
.bfafBox.flex > div.img { width: 360px; margin-right: 52px; position: relative; }
.bfafBox.flex > div.img .in-img { padding-top: 70%; border-radius: 5px; }
.bfafBox.flex > div.img:last-child { margin-right: 0; }

.bfafBox.flex.bfaf .ang-tit { display: block; line-height: 1.6; font-size: 14px; font-weight: 400; padding: 0 10px; color: #fff; background: #4B4E4D; line-height: 24px; position: absolute; left: 0; top: 0; border-radius: 5px 0 5px 0; }
.bfafBox.flex.bfaf .af .ang-tit { background: #2B92E8; }
.bfafBox.flex.bfaf > div.img.bf:before { content: ""; width: 0; height: 0; border-left: solid 16px #2B92E8; border-top: solid 12px transparent; border-bottom: solid 12px transparent; position: absolute; top: 0; bottom: 0; margin: auto 0; left: calc(100% + 20px); }

.sideBox { margin-bottom: 20px; position: relative; box-sizing: border-box; padding: 29px; border: solid 1px #0D0485; border-radius: 10px; }
.sideBox > h2.tit { position: relative; font-weight: 700; padding-left: 20px; margin-bottom: 20px; font-size: 18px; line-height: 1.6; }
.sideBox > h2.tit:before { content: ""; width: 10px; height: 10px; background: #34A02B; border-radius: 1px; position: absolute; left: 0; top: 11px; }
.sideBox ul.side-list > li { height: 54px; width: 100%; margin-bottom: 10px; display: table; }
.sideBox ul.side-list > li a { text-decoration: none; font-weight: 500; display: table-cell; line-height: 1.2; padding: 5px 40px 5px 20px; background: #EAF2F9; position: relative; text-align: left; vertical-align: middle; border-radius: 40px; }
.sideBox ul.side-list > li a .arrow { position: absolute; right: 20px; top: 50%; transform: translateY(-50%); z-index: 2; }
.sideBox ul.side-list > li a .arrow img { display: block; opacity: 1; }
.sideBox ul.side-list > li a:hover { background-color: #0D0485; color: #fff; }
.sideBox ul.side-list > li a:hover .arrow img { filter: brightness(0) saturate(100%) invert(100%) sepia(100%) saturate(0%) hue-rotate(305deg) brightness(103%) contrast(103%); }
.sideBox ul.side-list li.side-li:hover .parent_side-wrap > a { background-color: #0D0485; color: #fff; }
.sideBox ul.side-list li.side-li:hover .parent_side-wrap span.opcl2:before { background: #fff; }
.sideBox ul.side-list li.side-li:hover .parent_side-wrap span.opcl2:after { background: #fff; }
.sideBox ul.side-list li.side-li.r_current > a { pointer-events: none; background-color: #0D0485; color: #fff; }
.sideBox ul.side-list li.side-li.r_current > a .arrow img { filter: brightness(0) saturate(100%) invert(100%) sepia(100%) saturate(0%) hue-rotate(305deg) brightness(103%) contrast(103%); }
.sideBox ul.side-list li.side-li.r_current .parent_side-wrap > a { pointer-events: none; background-color: #0D0485; color: #fff; }
.sideBox ul.side-list li.side-li.r_current .parent_side-wrap span.opcl2:before { background: #fff; }
.sideBox ul.side-list li.side-li.r_current .parent_side-wrap span.opcl2:after { background: #fff; }
.sideBox ul.side-list > li:last-child { margin-bottom: 0; }
.sideBox ul.side-list li.side-li.parent_li { display: block; height: auto; }

.sideBox:last-child { margin-bottom: 0; }

.parent_side-wrap { position: relative; width: 100%; height: 54px; display: table; }
.parent_side-wrap span.opcl2 { width: 30px; height: 30px; position: absolute; z-index: 2; right: 13px; top: 50%; transform: translateY(-50%); cursor: pointer; }
.parent_side-wrap span.opcl2:before { content: ""; width: 14px; height: 2px; background: #404040; border-radius: 2px; position: absolute; right: 8px; top: calc(50% - 1px); transition: 0.3s; }
.parent_side-wrap span.opcl2:after { content: ""; width: 2px; height: 14px; background: #404040; border-radius: 2px; position: absolute; right: calc(50% - 1px); top: 8px; transition: 0.3s; }

.parent_side-wrap.on > a { pointer-events: none !important; background-color: #0D0485 !important; color: #fff !important; }
.parent_side-wrap.on span.opcl2:before { background: #fff; }
.parent_side-wrap.on span.opcl2:after { transform: translateZ(90deg); opacity: 0; background: #fff; }

ul.side-child { padding-top: 20px; padding-left: 40px; padding-bottom: 10px; display: none; }
ul.side-child li.side-li { margin-bottom: 10px; }
ul.side-child li.side-li a { background: none; padding: 0 20px 0 0; display: block; line-height: 26px; }
ul.side-child li.side-li a .arrow { right: 0; }
ul.side-child li.side-li a:hover { background: none !important; color: #0D0485 !important; }
ul.side-child li.side-li a:hover .arrow img { filter: brightness(0) saturate(100%) invert(17%) sepia(46%) saturate(3044%) hue-rotate(231deg) brightness(87%) contrast(142%); }
ul.side-child li.side-li.r_current a { background: none !important; color: #0D0485 !important; }
ul.side-child li.side-li.r_current a .arrow img { filter: brightness(0) saturate(100%) invert(17%) sepia(46%) saturate(3044%) hue-rotate(231deg) brightness(87%) contrast(142%) !important; }
ul.side-child li.side-li:last-child { margin-bottom: 0; }

select#archives-dropdown-2 { padding: 5px 32px 5px 20px; background: url("../img/p09/select-arrow02.svg") no-repeat center right 20px #EAF2F9; border-radius: 40px; border: none; height: 54px; color: #404040; box-sizing: border-box; width: 100%; }

select { cursor: pointer; }

.ang-tit { position: absolute; left: -2px; top: -2px; z-index: 2; color: #fff; font-weight: 500; font-size: 16px; border-radius: 5px 0 5px 0; padding: 10px 16px; background: #0D0485; line-height: 1; }

div.witerBox { position: relative; padding: 55px 38px 38px; margin-top: 80px; border: solid 2px #0D0485; border-radius: 10px; }
div.witerBox .inner { position: relative; padding-left: 120px; min-height: 100px; }
div.witerBox .inner h2 { font-size: 20px; line-height: 1.4; }
div.witerBox .inner .wr-detail { line-height: 1.6; }
div.witerBox .inner .img { position: absolute; left: 0; top: 0; width: 100px; }
div.witerBox .inner .img .in-img { border-radius: 100%; padding-top: 100%; }

.witer-tits.flex { margin-bottom: 10px; align-items: center; line-height: 1.6; }
.witer-tits.flex > h2 { margin-right: 14px; line-height: 1.6; }

.w-post { font-weight: 700; color: #0D0485; }

/*ページャー*/
div#pager00 { text-align: center; }

div#pager00 .wp-pagenavi { margin-top: 50px; }

.wp-pagenavi > span, .wp-pagenavi > a { display: inline-block; margin: 2px; text-decoration: none; width: 48px; height: 48px; text-align: center; line-height: 46px; font-size: 14px; font-weight: 700; color: #0D0485; box-sizing: border-box; border-radius: 5px; border: solid 1px #0D0485; }

.wp-pagenavi a.page { position: relative; }

.wp-pagenavi span.extend { background: none; color: #0D0485; box-shadow: none; border: none; }

.wp-pagenavi > a:hover { color: #fff; background-color: #0D0485; }

.wp-pagenavi a.previouspostslink { color: transparent; background: url("../img/p09/arrow01.svg") no-repeat center #fff; margin-left: 0; }

.wp-pagenavi a.nextpostslink { color: transparent; background: url("../img/p09/arrow02.svg") no-repeat center #fff; margin-right: 0; }

.wp-pagenavi span.current { color: #fff; background: #0D0485; }

.wp-pagenavi a.first { border: solid 1px #0D0485; background: url("../img/p11/arrow01.svg") no-repeat center #fff; color: transparent; display: none; }

.wp-pagenavi a.last { border: solid 1px #0D0485; background: url("../img/p11/arrow04.svg") no-repeat center #fff; color: transparent; display: none; }

.wp-pagenavi a.previouspostslink:hover { background-color: #0D0485; color: transparent !important; background-image: url("../img/p09/arrow01h.svg"); }

.wp-pagenavi a.nextpostslink:hover { background-color: #0D0485; color: transparent !important; background-image: url("../img/p09/arrow02h.svg"); }

.wp-pagenavi a.first:hover { background-color: #0D0485; color: transparent; background-image: url("../img/p12/arrow01h.svg"); }

.wp-pagenavi a.last:hover { background-color: #0D0485; color: transparent; background-image: url("../img/p12/arrow04h.svg"); }

.wp-pagenavi span.pages { display: none; }

.post-navigation ul { margin-top: 80px; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; }
.post-navigation ul > li { margin-right: 10px; width: 160px; height: 48px; display: table; }
.post-navigation ul > li a { text-decoration: none; display: table-cell; text-align: center; vertical-align: middle; color: #fff; background: #0D0485; border-radius: 5px; border: solid 2px #0D0485; font-weight: 700; }
.post-navigation ul > li:last-child { margin-right: 0; }
.post-navigation ul li.kara { opacity: 0; pointer-events: none; }
.post-navigation ul li.prev.kara { opacity: 0; pointer-events: none; }
.post-navigation ul li.next.kara { opacity: 0; pointer-events: none; }
.post-navigation ul li.prev a { background: url("../img/p09/arrow01.svg") no-repeat top calc(50% + 1px) left 30px #fff; color: #0D0485; padding-left: 20px; }
.post-navigation ul li.prev a:hover { opacity: 0.7; }
.post-navigation ul li.next a { background: url("../img/p09/arrow02.svg") no-repeat top calc(50% + 1px) right 30px #fff; color: #0D0485; padding-right: 20px; }
.post-navigation ul li.next a:hover { opacity: 0.7; }
.post-navigation ul li.blog-back { display: table; }
.post-navigation ul li.blog-back > a { display: table-cell; text-align: center; vertical-align: middle; text-decoration: none; background: #0D0485; color: #fff; -weight: 700; }
.post-navigation ul li.blog-back > a:hover { background: #fff; color: #0D0485; }

/*　10 お知らせ
----------------------------------*/
.news-list-all { display: flex; flex-wrap: wrap; justify-content: space-between; justify-content: space-between; margin-top: -30px; }
.news-list-all article.blog-art { width: 376px; margin: 30px 0 0; }
.news-list-all article.blog-art a { text-decoration: none; box-sizing: border-box; padding: 20px; background: #EAF2F9; border-radius: 10px; }

/*詳細*/
article.singleBox01 div#toc_container { width: 100% !important; margin-top: 50px; background: #EAF2F9 !important; border: none !important; margin-bottom: 20px !important; padding: 30px; border-radius: 10px; box-sizing: border-box; }
article.singleBox01 div#toc_container p.toc_title { text-align: left; font-weight: 700; font-size: 20px; line-height: 1.2; margin-bottom: 10px; color: #404040; }
article.singleBox01 div#toc_container ul.toc_list { margin-top: 0; }
article.singleBox01 div#toc_container ul.toc_list > li { margin: 0 0 8px; }
article.singleBox01 div#toc_container ul.toc_list > li a { display: inline-block; box-sizing: border-box; text-decoration: none; line-height: 1.4; font-weight: 500; font-size: 16px; }
article.singleBox01 div#toc_container ul.toc_list > li a span.toc_number { display: inline-block; min-width: 24px; text-align: center; line-height: 24px; height: 24px; color: #fff; border-radius: 5px; font-weight: 700; font-size: 16px; font-family: 'mont'; margin-right: 8px; background: #0D0485; position: relative; box-sizing: border-box; padding: 0 8px; }
article.singleBox01 div#toc_container ul.toc_list > li a:hover { text-decoration: underline; }
article.singleBox01 div#toc_container ul.toc_list > li ul { margin-top: 8px; }

ul.word_list.flex { width: calc(100% + 12px); margin: -10px 0 0 -12px; }
ul.word_list.flex > li { margin: 10px 0 0 12px; }
ul.word_list.flex > li a { font-weight: 500; font-size: 14px; }

.blog_word_box { margin-top: 50px; }
.blog_word_box > .tit { font-weight: 800; color: #2B92E8; margin-bottom: 14px; font-weight: 700; line-height: 1.2; font-size: 18px; }

/*　11 会社概要
----------------------------------*/
section#p11Box01 { padding: 80px 0 150px; background: url("../img/p02/bg02.svg") no-repeat bottom left calc(50% + 660px); }
section#p11Box01 ul.links.flex { margin-bottom: 150px; }
section#p11Box01 ul.links.flex > li { height: 50px; }

.p11-cont01.flex { justify-content: space-between; }
.p11-cont01.flex .cont { width: 720px; }
.p11-cont01.flex .cont .copy { font-size: 24px; margin-bottom: 40px; line-height: 1.6; }
.p11-cont01.flex .cont > .text > p { margin-bottom: 20px; }
.p11-cont01.flex .cont > .text > p:last-child { margin-bottom: 0; }
.p11-cont01.flex .imgs { width: 330px; }
.p11-cont01.flex .imgs .img { margin-bottom: 10px; }

.p11-names > span { margin-right: 15px; }
.p11-names > span:last-child { margin-right: 0; }

section#p11Box02 { padding: 150px 0; background: linear-gradient(90deg, #2782da 0%, #0b107c 100%); }

div.rine-cont { background: #fff; border-radius: 10px; padding: 80px 117px 80px 223px; position: relative; }
div.rine-cont .titles01.type03 { right: auto; left: 117px; top: 80px; bottom: auto; margin: 0; }

.rine-list > div.box { margin-bottom: 20px; font-size: 20px; display: flex; flex-wrap: wrap; align-items: flex-start; justify-content: space-between; }
.rine-list > div.box span.num { width: 32px; height: 32px; color: #fff; background: #0D0485; border-radius: 5px; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; font-size: 14px; font-weight: 800; }
.rine-list > div.box span.text { width: calc(100% - 42px); line-height: 1.6; }
.rine-list > div.box:last-child { margin-bottom: 0; }

section#p11Box03 { padding: 150px 0; }
section#p11Box03 .TBL11 { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: flex-start; }
section#p11Box03 .TBL11 > table { width: 520px; }

.TBL11 tr:first-child th, .TBL11 tr:first-child td { padding-top: 0; }
.TBL11 th, .TBL11 td { box-sizing: border-box; padding: 25px 0; line-height: 1.6; vertical-align: top; }
.TBL11 th { border-bottom: solid 1px #2B92E8; font-weight: 800; color: #2B92E8; }
.TBL11 td { border-bottom: solid 1px #DADADA; }

section#p11Box04 { padding: 150px 0; }
section#p11Box04 .wrap { box-sizing: border-box; padding-left: 129px; }
section#p11Box04 .titles01.type03 { right: auto; left: 0; top: 0; bottom: auto; margin: 0; }

.historyBox { padding-bottom: 40px; position: relative; width: 100%; display: flex; flex-wrap: wrap; box-sizing: border-box; padding-left: 34px; }
.historyBox .age { width: 100px; color: #0D0485; font-weight: 800; line-height: 1.2; font-size: 18px; }
.historyBox .age .big { font-size: 32px; }
.historyBox .cont { width: calc(100% - 100px); }
.historyBox .cont dl.flex { margin-bottom: 20px; }
.historyBox .cont dl.flex dt { width: 100px; box-sizing: border-box; padding-left: 10px; font-weight: 800; line-height: 1.2; font-size: 18px; color: #0D0485; }
.historyBox .cont dl.flex dt .big { font-size: 32px; }
.historyBox .cont dl.flex dd { width: calc(100% - 100px); padding-top: 10px; }
.historyBox .cont dl.flex:last-child { margin-bottom: 0; }

.historyBox:before { content: ""; width: 1px; height: 100%; background: #B5D9F7; position: absolute; left: 7px; top: 20px; }

.historyBox:after { content: ""; width: 15px; height: 15px; border-radius: 100%; background: #2B92E8; position: absolute; left: 0; top: 14px; }

.historyBox:last-child:before { content: none; }

section#p11Box05 { padding: 150px 0; background: #EAF2F9; }

.p11-cont05.flex { justify-content: space-between; }
.p11-cont05.flex > .left { width: 434px; }
.p11-cont05.flex > .left .text01 { margin-bottom: 30px; line-height: 26px; padding-left: 32px; background: url("../img/p11/ico01.svg") no-repeat left top; margin-bottom: 30px; }
.p11-cont05.flex > .right { width: 610px; min-height: 390px; }
.p11-cont05.flex > .right iframe { width: 100%; height: 100%; }

.access-list { line-height: 1.6; }
.access-list .box { margin-bottom: 30px; }
.access-list .box:last-child { margin-bottom: 0; }

h3.ac-tit { font-weight: 700; padding-left: 32px; background: url("../img/p11/ico02.svg") no-repeat left top; margin-bottom: 10px; }

.box02 h3.ac-tit { background-image: url("../img/p11/ico03.svg"); }

/*　12 お問い合わせ
----------------------------------*/
div#p12Box01 { padding: 80px 0 150px; }
div#p12Box01 .copy { text-align: center; margin-bottom: 30px; font-size: 24px; line-height: 1.4; }
div#p12Box01 .copy .big { font-size: 32px; }

.p12-cont01.flex { border: solid 1px #2B92E8; border-radius: 10px; align-items: center; }
.p12-cont01.flex > .box01 { width: 288px; height: 122px; color: #fff; background: #2B92E8; justify-content: center; align-items: center; display: flex; flex-wrap: wrap; font-size: 22px; font-weight: 800; border-radius: 8px 0 0 8px; }
.p12-cont01.flex > .box02 { width: calc(100% - 288px); position: relative; padding: 10px 30px; box-sizing: border-box; }
.p12-cont01.flex > .box02 ul.check-list01.flex > li { min-width: 0; }
.p12-cont01.flex > .box02 .nado { position: absolute; right: 30px; bottom: 10px; line-height: 1.6; }

.p12-texBox { border: solid 1px #0D0485; background: #EAF2F9; border-radius: 10px; margin-top: 40px; }
.p12-texBox .tit { text-align: center; color: #fff; background: #0D0485; font-size: 24px; line-height: 1.6; padding: 10px; border-radius: 8px 8px 0 0; font-weight: 800; }
.p12-texBox .inner.flex { box-sizing: border-box; padding: 40px; justify-content: center; align-items: center; }
.p12-texBox .inner.flex .tel-set.tel-set01 { margin-right: 29px; }
.p12-texBox .inner.flex .tel-set.tel-set01 .bh { display: none; }
.p12-texBox .inner.flex .tel-num a { font-size: 40px; padding-left: 40px; background-size: 30px; }
.p12-texBox .inner.flex .text02 { line-height: 1.6; }
.p12-texBox .inner.flex .bikou-text { font-size: 16px; margin-top: 0; }

div#p12Box02 { padding: 150px 0; background: #EAF2F9; }
div#p12Box02 h2.titles01 { text-align: center; }
div#p12Box02 h2.titles01 span { padding-top: 42px; background: url("../img/p12/ico-mail.svg") no-repeat center top; }

.contact-text01 { width: 720px; margin: 0 auto 40px; }
.contact-text01 > p { padding-left: 18px; position: relative; position: relative; }
.contact-text01 > p:before { content: "※"; position: absolute; left: 0; top: 0; }

.form-box { border-radius: 10px; background: #fff; padding: 60px; }

/*フォーム*/
.file-bikou { font-size: 14px; }

ul.contact-state { display: flex; flex-wrap: wrap; justify-content: space-between; margin: 40px auto 35px; width: 100%; max-width: 720px; position: relative; z-index: 2; }

ul.contact-state > li { display: table; width: 29.02%; height: 60px; position: relative; }

ul.contact-state > li > span { display: table-cell; text-align: center; vertical-align: middle; color: #0d0485; font-size: 18px; font-weight: 700; background: #fff; border-radius: 5px; border: solid 1px #0d0485; }
ul.contact-state > li > span span.num { margin-right: 6px; }

ul.contact-state > li.state01 { margin-left: 0; }

ul.contact-state > li.state01 > span { background: #0d0485; color: #fff; }

ul.contact-state.contact-state02 > li.state02 > span { background: #0d0485; color: #fff; }

ul.contact-state.contact-state02 { display: flex; flex-wrap: wrap; justify-content: space-between; }

ul.contact-state:before { content: ""; width: 100%; height: 1px; background: #0d0485; position: absolute; left: 0; top: 50%; }

a.green { text-decoration: underline; }

a.green:hover { text-decoration: none; }

.contactTBL th, .contactTBL td { display: block; box-sizing: border-box; font-size: 16px; padding: 20px 0; color: #000000; line-height: 1.2; }
.contactTBL th { padding-bottom: 15px; }
.contactTBL td { padding-top: 0; }
.contactTBL .wpcf7-list-item { margin-left: 0; display: block; margin-bottom: 10px; margin-right: 25px; }
.contactTBL input[type="checkbox"], .contactTBL input[type="radio"] { transform-origin: left center; transform: scale(1.5); margin-right: 8px; }

span.hissu { display: inline-block; color: #fff; padding: 3px 4px; background: #0d0485; margin-right: 4px; box-sizing: border-box; font-size: 14px; font-weight: 700; border-radius: 2px; }

span.nini { display: inline-block; padding: 3px 4px; margin-right: 8px; font-size: 14px; font-weight: 700; color: #0d0485; border: solid 1px #0d0485; border-radius: 2px; }

input.wpcf7-number, input.wpcf7-date, input.wpcf7-text { box-sizing: border-box; height: 38px; border: solid 1px #B3B3B3; padding: 3px 16px; font-size: 16px; background: #fff; width: 100%; border-radius: 2px; }

input.wpcf7-date { padding: 3px 16px; }

select.wpcf7-select { width: auto; }

select { border-radius: 2px; }

textarea.wpcf7-textarea { box-sizing: border-box; height: 160px; border: solid 1px #B3B3B3; padding: 5px 10px; font-size: 16px; background: #fff; width: 100%; border-radius: 2px; }

ul.form-address-list > li { margin-bottom: 20px; }
ul.form-address-list > li .cap { font-weight: 400; margin-bottom: 12px; line-height: 1; }
ul.form-address-list > li select.wpcf7-form-control.wpcf7-select { width: 200px; }
ul.form-address-list > li:first-child .inp { display: flex; flex-wrap: wrap; align-items: center; }
ul.form-address-list > li:first-child .inp span.form-bikou { margin-left: 8px; }
ul.form-address-list > li:last-child { margin-bottom: 0; }

input.com-name, input.busho-name, input#your-name, input#your-kana { width: 512px; }

.cours-area { margin-top: 5px; }

input.wpcf7-text.tel01, input#zip { width: 140px; }

select#pref3 { width: auto; }

span.form-bikou { display: block; }

.form-ex { line-height: 1.4; margin-top: 16px; font-weight: 500; }

ul.address-list > li { margin-bottom: 30px; }
ul.address-list > li:last-child { margin-bottom: 0; }
ul.address-list .th { font-size: 14px; margin-bottom: 5px; }

.contactArea .codedropz-upload-container { padding: 0; }

.contactArea .codedropz-upload-handler { border: solid 1px #B3B3B3; border-radius: 2px; background: url("../img/p12/ico-file.svg") no-repeat center top 42px #fff; padding: 74px 30px 40px; }

.contactArea .codedropz-upload-inner { color: #1C1C1C; line-height: 1.5; font-size: 16px; font-weight: 500; }

.contactArea .codedropz-upload-inner h3 { font-size: 16px; font-weight: 500; margin: 0; }

a.cd-upload-btn { width: 140px; height: 40px; display: inline-block; line-height: 35px; background: #D9D9D9; border: none; border-radius: 0; padding-top: 3px; font-size: 16px; margin-top: 8px; color: #000000; }

a.cd-upload-btn:hover { opacity: 0.7; }

.form-bikou { font-size: 14px; font-weight: 500; line-height: 26px; }

.contact-submit.flex { margin-top: 30px; justify-content: center; flex-direction: row-reverse; position: relative; }

.contact-submit.flex > p { width: 100%; text-align: center; margin-top: 30px; }

.inb { display: inline-block; }

.in-cont { margin-bottom: 8px; display: flex; flex-wrap: wrap; align-items: center; }
.in-cont > span { margin-right: 9px; }
.in-cont > span.line01 { width: 55px; }

input.wpcf7-form-control.wpcf7-text.text-num01 { width: 60px; text-align: right; }

.form-btn { width: 360px; position: relative; }

.form-btn input[type="submit"], .form-btn input[type="button"] { transition: 0.3s; border: none; color: #fff; width: 100%; height: 70px; font-size: 16px; font-weight: 500; position: relative; z-index: 3; background: url("../img/p12/arrow01.svg") no-repeat center right 24px, #404040; border-radius: 10px; border: none; padding: 0 30px; text-align: center; border: solid 1px #404040; }

.form-btn.form-btn02 { margin-right: 10px; }

.form-btn.form-btn02 input[type="submit"], .form-btn.form-btn02 input[type="button"] { background: url("../img/p12/arrow02.svg") no-repeat center left 20px, #404040; text-align: center; }

.form-btn input { transition: 0.3s; cursor: pointer; }

.form-btn input:hover { background-color: #fff; color: #404040; }

.form-btn.form-btn03 input[type="submit"], .form-btn.form-btn03 input[type="button"] { text-align: center; }

span.zip-mark { margin-right: 10px; font-size: 14px; }

span.zip-bikou { margin-left: 15px; font-size: 13px; }

.zip_list > div { margin-bottom: 10px; }
.zip_list > div:last-child { margin-bottom: 0; }
.zip_list .zip00.zip02 > div { margin-bottom: 10px; }
.zip_list .zip00.zip02 > div:last-child { margin-bottom: 0; }

.wpcf7-spinner { position: absolute !important; top: -10px !important; }

p.check-text { margin-bottom: 30px; }

/*入力内容確認時にフォーム上部へスクロールするがナビゲーションが追従の場合フォームとナビゲーションが重なるのでそのためのオフセット設定*/
form.wpcf7-form { padding-top: 120px; margin-top: -120px; }

.wpcf7c-conf { background-color: #e8f0fe !important; }

input:-webkit-autofill, input:-internal-autofill-selected { -webkit-appearance: none; -webkit-box-shadow: 0 0 0px 1000px #e8f0fe inset !important; box-shadow: 0 0 0px 1000px #e8f0fe inset !important; }

::placeholder { font-size: 16px; color: #B2B2B2; line-height: 1.5; }

.wpcf7-checkbox input[type="checkbox"] { display: none; }
.wpcf7-checkbox span.wpcf7-list-item-label { display: inline-block; padding-left: 24px; background: url("../img/p12/ico-c.svg") no-repeat left top 3px; padding-bottom: 2px; cursor: pointer; }
.wpcf7-checkbox input[type="checkbox"]:checked ~ span.wpcf7-list-item-label { background-image: url("../img/p12/ico-cr.svg"); }

.wpcf7-radio input[type="radio"] { display: none; }
.wpcf7-radio span.wpcf7-list-item-label { display: inline-block; padding-left: 24px; background: url("../img/p12/ico-r.svg") no-repeat left top 0; padding-bottom: 2px; cursor: pointer; }
.wpcf7-radio input[type="radio"]:checked ~ span.wpcf7-list-item-label { background-image: url("../img/p12/ico-rc.svg"); }

/*確認画面*/
.contactArea.che { background: #eee; padding: 30px; }
.contactArea.che .pop-btn.opcl-btn.on { pointer-events: none; }
.contactArea.che .opcl-wrap { display: block !important; }
.contactArea.che div.opcl-inBox { padding-top: 20px; }

.contactArea.che .contactTBL tr { border-bottom: solid 1px #000; }

.contactArea.che .contactTBL th, .contactArea.che .contactTBL td { padding-top: 5px; padding-bottom: 5px; vertical-align: middle; }

.contactArea.che .dnd-upload-status .dnd-upload-details .remove-file, .contactArea.che .codedropz-upload-handler, .contactArea.che .bikou-text01, .contactArea.che span.dnd-progress-bar, .contactArea.che input[type=checkbox] { display: none; }

.contactArea.che input[type=checkbox] ~ span.wpcf7-list-item-label { display: none; }

.contactArea.che input[type=checkbox]:checked ~ span.wpcf7-list-item-label { display: inline-block; font-weight: 700; }

.contactArea.che input[type=radio] { display: none; }

.contactArea.che input[type=radio] ~ span.wpcf7-list-item-label { display: none; }

.contactArea.che input[type=radio]:checked ~ span.wpcf7-list-item-label { display: inline-block; font-weight: 700; }

.contactArea.che textarea.wpcf7-textarea, .contactArea.che input.wpcf7-number, .contactArea.che input.wpcf7-date, .contactArea.che input.wpcf7-text, .contactArea.che select { font-weight: 700; }

select { box-sizing: border-box; height: 38px; border: solid 1px #B3B3B3; padding: 3px 30px 3px 16px; font-size: 16px; background: #fff; width: auto; background: url(../img/p12/select-arrow.svg) no-repeat center right 17px #fff; width: auto; -webkit-appearance: none; appearance: none; width: 100%; font-weight: 500; border-radius: 2px; }

/*　thanksページ等
----------------------------------*/
div#p100Box01 { padding: 90px 0 120px; }
div#p100Box01 .btn01 { margin: 50px auto 0; }

.pp-title01 { font-size: 22px; border-bottom: solid 2px; margin-bottom: 25px; padding-bottom: 10px; }

.pp-title02:first-child { margin-top: 0; }

.pp-title02 { font-size: 18px; padding-left: 15px; position: relative; color: #05004E; margin-top: 50px; }

.pp-title02:before { content: ""; width: 5px; height: 65%; background: #05004E; position: absolute; left: 0; top: 0; bottom: 0; margin: auto 0; }

/*ブラウザごと
----------------------------------*/
.tokushu div.gnav ul.flex > li { margin-left: 15px; }
.tokushu div.gnav ul.flex > li:first-child { margin-left: 0; }
.tokushu div.gnav ul.flex > li > a, .tokushu div.gnav ul.flex > li > .dr-tit { font-size: 12px; }
.tokushu ul.fead-feat > li { font-size: 12px; }
.tokushu .serviceBox a .service-btn { width: 130px; }
.tokushu aside.aside01 > div.cont ul.fead-feat > li { font-size: 13px; margin-right: 10px; }
.tokushu aside.aside01 > div.cont ul.fead-feat > li:last-child { margin-right: 0; }
.tokushu div#fnav > div { margin-right: 20px; }
.tokushu div#fnav > div:last-child { margin-right: 0; }

/*デバイス幅
----------------------------------*/
@media screen and (min-width: 0px) and (max-width: 1750px) { .works-list01 ul.slick-dots { width: 733px; }
  .works-list01 button.slick-prev.slick-arrow { left: calc(50% + 564px); }
  .works-list01 button.slick-next.slick-arrow { left: calc(50% + 639px); } }
@media screen and (min-width: 0px) and (max-width: 1550px) { .works-list01 ul.slick-dots { width: 613px; }
  .works-list01 button.slick-prev.slick-arrow { left: calc(50% + 444px); }
  .works-list01 button.slick-next.slick-arrow { left: calc(50% + 519px); } }
@media screen and (min-width: 0px) and (max-width: 1480px) { .mv-cont { left: 70px; }
  .mv-cont02 { left: 70px; }
  .works-list01 ul.slick-dots { width: 483px; }
  .works-list01 button.slick-prev.slick-arrow { left: calc(50% + 314px); }
  .works-list01 button.slick-next.slick-arrow { left: calc(50% + 389px); }
  aside.aside01 > div.cont > .inner { margin: auto; } }
@media screen and (min-width: 0px) and (max-width: 1330px) { section#works-sec > .bg { width: calc(50% + 550px); }
  section#works-sec .wrap { width: 1100px; left: 0; padding-left: 50px; }
  .works-list01 ul.slick-dots { left: 333px; }
  section#range-sec .wrap { width: 1100px; }
  section#about-sec .wrap { width: 1100px; }
  div#scr { transform-origin: right bottom; transform: scale(0.7); } }
