/* works-page */
.works-page .cate-area{ width: 100%; list-style: none; text-align: left; margin: 40px auto 0; display: flex; justify-content: center; align-items: stretch;}
.works-page .cate-area li{ width: calc(100% / 3); padding: 4px 8px; line-height: 1.2; display: flex; justify-content: center; align-items: center;}
.works-page .cate-area li::after{ content: ""; width: 1px; height: 80%; background-color: var(--color_black); top: 0; right: 0; bottom: 0; margin: auto; position: absolute;}
.works-page .cate-area li:last-child::after{ display: none;}
.works-page .cate-area li br{ display: inline;}
.works-page .cate-area a{ font-size: 12px;}

.works-page .woaks-area{ width: 100%; list-style: none; margin: 20px auto 0; padding: 0 0; box-sizing: border-box;}
.works-page .woaks-area li{ width: calc(100% - 20px);}
.works-page .woaks-area li .wrap{ padding: 40px 10px; display: block;}
.works-page .woaks-area li .wrap img{ max-width: 300px; margin: 0 auto 0; display: block;}
.works-page .woaks-area li .wrap .text-box{ width: 100%; max-width: 340px; margin: 20px auto 0;}
.works-page .woaks-area li .wrap .text-box .item-box{ width: 100%; margin-top: 0;}
.works-page .woaks-area li .wrap .text-box .item-box:nth-child(n + 2){ margin-top: 20px;}
.works-page .woaks-area li .wrap .text-box .item-box .item-title{ padding: 4px 20px; font-size: 12px;}
.works-page .woaks-area li .wrap .text-box .item-box .ml20{ margin-left: 0;}
.works-page .woaks-area li .wrap .text-box .item-box p{ font-size: 14px;}
.works-page .woaks-area li .wrap .text-box .item-box p.title{ font-size: 18px;}
.works-page .woaks-area li .wrap .text-box .item-box p.title span{ font-size: 14px;}

/* about-page */
.about .about-page{ padding: 180px 0 0;}
.about .about-page .about-area{ margin: 40px auto 0;}
.about .about-page .about-area .wrap{ padding: 0 10px; display: block;}
.about .about-page .about-area .wrap .left{ width: 100%; padding: 20px 10px; display: block;}
.about .about-page .about-area .wrap .right{ width: 100%; padding: 20px 10px; display: block;}
.about .about-page .about-area .wrap:last-child .left{ border-bottom: 1px solid; padding: 20px 10px;}
.about .about-page .about-area .wrap .item-title{ width: auto; max-width: auto; display: inline-block; padding: 4px 20px; font-size: 12px; margin: 0 0 0 0;}
.about .about-page .about-area .wrap .item-detail{ font-size: 16px;}
.about .about-page .about-area .wrap .item-detail p{ font-size: 16px;}

.about .slogan-area{ padding: 40px 10px;}
.about .slogan-area .htitle p.en{ font-size: clamp(30px, 4vw, 50px); color: var(--color_white); mix-blend-mode: difference;}
.about .slogan-area .htitle p.jp{ color: var(--color_black); background-color: var(--color_white); mix-blend-mode: difference;}
.about .slogan-area .wrap{ width: 100%; max-width: 1200px; margin: 40px auto 0;}
.about .slogan-area .wrap h2{ line-height: 2.2;}

.about .service-area{ width: 100%; padding: 0 0 0; box-sizing: border-box;}
.about .service-area .wrap ul{ width: 100%; height: auto; list-style: none;}
.about .service-area .wrap ul li:nth-child(1){ border-top: 1px solid var(--color_white);}
.about .service-area .wrap ul li:last-child{ border-bottom: 0px none;}
.about .service-area .wrap ul li .left-box p:nth-child(2){ font-size: 12px;}
.about .service-area .wrap ul li .right-box p{ font-size: 12px; text-align: left; margin-top: 20px;}
.about .service-area .wrap ul li.active{ display: block; padding: 20px 10px;}
.about .service-area .wrap ul li.active{ height: auto; opacity: 1; padding: 20px 10px; background: var(--color_black);}

.about .message-area{ padding: 120px 10px 0; overflow: hidden}
.about .message-area .wrap{ padding: 20px;}
.about .message-area .wrap::after{ top: -71px; right: -13px;}
.about .message-area .wrap .circle{ width: 160px; top: -80px;}


/* news-page */
.news-page .cate-area{ width: 100%; list-style: none; text-align: left; margin: 0 auto 0; display: flex; justify-content: center; align-items: stretch;}
.news-page .cate-area li{ width: calc(100% / 4); padding: 4px 8px; line-height: 1.2; display: flex; justify-content: center; align-items: center;}
.news-page .cate-area li::after{ content: ""; width: 1px; height: 80%; background-color: var(--color_white); top: 0; right: 0; bottom: 0; margin: auto; position: absolute;}
.news-page .cate-area li:last-child::after{ display: none;}
.news-page .cate-area li br{ display: inline;}
.news-page .cate-area a{ font-size: 12px; color: var(--color_white);}

/* recruit-page */
.recruit-page .wrap{ padding: 0 10px;}
.recruit-page .wrap > p{ color: var(--color_black); mix-blend-mode: normal;}
.recruit-page .wrap > p br.forSP{ display: none;}
.recruit-area .tab-wrap{ padding: 40px 10px 0;}
.recruit-area .tab-wrap .tab-container .tab{ max-width: 127px; padding: 10px;}
.recruit-area .tab-wrap .tab-container .tab:nth-child(1){ margin-right: 2px;}
.recruit-area .tab-wrap .tab-container .tab p{ font-size: 10px;}
.recruit-area .tab-wrap .content-container{ position: relative; top: -40px; z-index: 0;}
.recruit-area .tab-wrap .content-container .content.show{ padding: 40px 10px 40px;}
.recruit-area .tab-wrap .content-container .content .box{ display: block; padding: 20px 10px;}
.recruit-area .tab-wrap .content-container .content .box .item-title{ width: auto; max-width: auto; display: inline-block; padding: 2px 10px; box-sizing: border-box; background-color: var(--color_white); font-size: 12px; margin: 0 0 0 0;}
.recruit-area .tab-wrap .content-container .content .box .item-detail{ font-size: 16px; padding-top: 3px;}
.recruit-area .tab-wrap .content-container .content .box .item-detail p{ font-size: 16px;}
.entry-area{ padding: 0 0 0;}
.entry-area .wrap{ padding: 0 10px;}

/* contact-page */
.contact-area.wrap{ padding: 0 10px;}
.thankyou p{ font-size: 14px; padding: 20px;}

/* service-page */
.service .service-page{ overflow: hidden; padding: 180px 10px 0; margin-top: 0;}
.service .service-page.service-area .wrap{ padding: 0;}
.service .service-page .cms-area .wrap{ padding: 0 10px;}
.service .service-page .cms-area .wrap .text-box p{ font-size: clamp(12px, 2vw, 18px);}
.service .service-page .cms-area .wrap .text-box h2{ font-size: clamp(40px, 4vw, 70px);}
.service .service-page .cms-area .wrap .text-box h2 p{ font-size: clamp(16px, 3vw, 20px);}
.service .service-page .cms-area .wrap .text-box p.copy-text{ margin-top: 20px; text-align: left;}
.service .service-page .cms-area .wrap .text-box p.copy-text br{ display: none;}
.service .service-page .cms-area .wrap-swiper{ padding: 0 10px; box-sizing: border-box;}
.service .service-page .cms-area .swiper{ margin-top: 40px;}
.service .service-page .cms-area .swiper-slide{ padding: 30px 20px;}
.service .service-page .cms-area .swiper-slide .text{ height: 100%;}
.service .service-page .cms-area .swiper-slide .text h3{ padding: 10px 0; max-width: calc(100% - 70px); margin: auto;}
.service .service-page .cms-area .swiper-slide .text p{ margin-top: 20px;}
.service .service-page .pager-area{ margin: 10px 0 0;}

.service .comparison-area{ padding: 40px 0 0;}
.service .comparison-area .wrap{ width: calc(100% - 10px); padding: 20px 10px; display: block;}
.service .comparison-area .wrap .left{ max-width: 100%;}
.service .comparison-area .wrap .left .htitle{ width: 100%;}
.service .comparison-area .wrap .left .htitle p{ font-size: 16px; margin-top: 30px; text-align: left;}
.service .comparison-area .wrap .left .htitle p br{ display: none;}
.service .comparison-area .wrap .right{ width: 100%; max-width: 490px; display: block; margin: 50px auto 0;}
.service .comparison-area .wrap .right .cms-box{ width: 100%; max-width: 100%;}
.service .comparison-area .wrap .right .cms-box:nth-child(1){ margin-right: 0; margin-bottom: 40px;}
.service .comparison-area .wrap .right .cms-box:nth-child(1)::before{ height: 27px; top: -30px; font-size: 16px;}
.service .comparison-area .wrap .right .cms-box:nth-child(1)::after{ width: 60px; bottom: -50px; right: 0; left: 0; font-size: 20px;}
.service .comparison-area .wrap .right .cms-box:nth-child(2){ background-color: var(--color_black);}
.service .comparison-area .wrap .right .cms .title{ width: 100%;}
.service .comparison-area .wrap .right .cms .title p{ font-size: 14px;}
.service .comparison-area .wrap .right .cms .title h3{ font-size: 24px;}
.service .comparison-area .wrap .right .cms .content{ width: 100%; margin-top: 20px;}
.service .comparison-area .wrap .right .cms .content p br.forSP{ display: inline;}

.service .faq-area{ width: calc(100% - 20px); margin: 40px auto 0; padding: 40px 20px;}
.service .faq-area .wrap .accordion-faq .accordion-header{ font-size: 14px; padding: 15px 30px 15px 40px;}
.service .faq-area .wrap .accordion-faq .accordion-header:before{ font-size: 15px; width: 30px; top: 11px; left: 0;}
.service .accordion-faq .accordion-header .i_box{ top: 15px; right: 0; width: 20px; margin-top: 0;}
.service .accordion-faq .accordion-header .i_box .one_i{ width: 14px; height: 14px;}
.service .accordion-faq .accordion-header .i_box .one_i:before,
.service .accordion-faq .accordion-header .i_box .one_i:after{ width: 14px; height: 2px; top: 6px; left: 0;}
.service .accordion-faq .accordion-header .i_box .one_i:before{ width: 2px; height: 14px; top: 0; left: 6px;}
.service .accordion-faq .accordion-inner{ padding: 10px 0px;}
.service .accordion-faq .accordion-inner .accordion-box{ padding: 0 0 15px;}
.service .accordion-faq .accordion-inner p{ padding-left: 40px;}
.service .accordion-faq .accordion-inner p:before{ font-size: 15px; width: 30px; top: -3px; left: 0; }

body.service .loader .wrap .box{ max-width: 100%; padding: 0 30px; box-sizing: border-box;}
body.service .loader .wrap .box .en{ font-size: clamp(15px, 2vw, 60px);}
body.service .loader .wrap .box .jp{ font-size: clamp(12px, 2vw, 30px); margin: 20px 0 0;}

/* bloglist-page */
.bloglist-page .cate-area{ width: 100%; list-style: none; text-align: left; margin: 40px auto 0; display: flex; justify-content: center; align-items: stretch;}
.bloglist-page .cate-area li{ width: calc(100% / 4); padding: 4px 8px; line-height: 1.2; display: flex; justify-content: center; align-items: center;}
.bloglist-page .cate-area li::after{ content: ""; width: 1px; height: 80%; background-color: var(--color_black); top: 0; right: 0; bottom: 0; margin: auto; position: absolute;}
.bloglist-page .cate-area li:last-child::after{ display: none;}
.bloglist-page .cate-area li br{ display: inline;}
.bloglist-page .cate-area a{ font-size: 12px;}

.bloglist-page .other-box{ width: calc(100% - 20px); margin: 20px auto 0; display: block;}
.bloglist-page .other-box::before{ width: 100%; order:1;}
.bloglist-page .other-box::after{ width: 100%;}
.bloglist-page .other-box a{ display: block; width: 100%; transition: 0.1s; margin: 30px 0 0;}
.bloglist-page .other-box a:nth-of-type(1){ margin-top: 0;}
.bloglist-page .other-box a:hover{ transform: none;}
.bloglist-page .other-box .bloglist-img{ width: 100%; aspect-ratio: 16 / 9; position: relative; border-radius: 24px; overflow: hidden; display: flex; justify-content: center; align-items: center;}
.bloglist-page .other-box a:hover .bloglist-img{ filter: grayscale(85%);}
.bloglist-page .other-box .bloglist-img img{ width: 100%; height: 100%; object-fit: cover; position: relative; opacity: .4;}
.bloglist-page .other-box .text-box{ width: 100%; padding: 10px; box-sizing: border-box; position: relative; z-index: 1; display: flex; justify-content: center; align-items: end;}
.bloglist-page .other-box .text-box .text--inner{ width: 100%;}
.bloglist-page .other-box .text-box .text--inner .cate{ font-size: 12px; font-weight: bold; font-family: var(--font_Lato); letter-spacing: 1.3px; color: var(--color_black); display: inline-block; position: absolute; top: -40px; left: 15px; background-color: var(--color_black); border-radius: 5px; padding: 3px 15px; box-sizing: border-box; color: var(--color_white);}

/* blog-page */
.blog-page .blog-area{ width: calc(100% - 20px);}
.blog-page .blog-area .main-img{ height: auto; aspect-ratio: 16 / 9;}
.blog-page .blog-area .date{ padding: 20px 10px 0;}
.blog-page .blog-area h1{ padding: 0 10px 20px;}
.blog-page .blog-area .text{ padding: 0 10px 60px;}
.blog-page .blog-area .text p{ font-size: 14px;}
.blog-page .blog-area .cate{ font-size: 14px; padding: 10px 20px;}
.blog-page .blog-area .main-img{ filter: grayscale(60%);}
.blog-page .blog-area .main-img .blur{ filter: blur(1px);}
.blog-page .blog-area .text-box .box{ padding: 20px 0;}
.blog-page .blog-area .text-box .box h2{ font-size: 16px; line-height: 1.4; padding: 10px 10px;}
/*.blog-page .blog-area .text-box .box h2::first-letter{ font-size: 22px;}*/
.blog-page .blog-area .text-box .box h2 + div > :nth-child(1){ margin-top: 5px;}
.blog-page .blog-area .text-box .box > div p{ font-size: 14px; word-break: break-word;}
.blog-page .blog-area .text-box .box > div h3{ font-size: 14px; line-height: 1.4;}
.blog-page .blog-area .text-box .box > div ol,
.blog-page .blog-area .text-box .box > div ul{ padding: 10px 20px 10px 30px;}
.blog-page .blog-area .text-box .box > div ol li,
.blog-page .blog-area .text-box .box > div ul li{ font-size: 14px; margin: 5px 0;}
.blog-page .blog-area .text-box .box > div pre{ width: 100%; padding: 30px 10px 10px; color: var(--color_white); font-size: 14px;}
.blog-page .blog-area .text-box .box > div pre::before{ top: 8px; left: 9px;}
.blog-page .blog-area .text-box .box > div table,
.blog-page .blog-area .text-box .box > div table tbody,
.blog-page .blog-area .text-box .box > div table tr,
.blog-page .blog-area .text-box .box > div table tr td{ border: solid 1px var(--color_white); font-size: 14px;}
.blog-page .blog-area .text-box .box > div table tr td{ padding: 5px;}
.blog-page .sns-box{ width: calc(100% - 20px);}
.blog-page .sns-box a:hover{}
.blog-page .sns-box .x-button{ display: block; width: 40px; aspect-ratio: 1 / 1; background-color: var(--color_gray); border-radius: 100px; background-image: url("/assets/images/logo-x.png"); background-size: 40%; background-repeat: no-repeat; background-position: center;}
.blog-page .sns-box .fb-button{ display: block; width: 40px; aspect-ratio: 1 / 1; border-radius: 100px; background-image: url("/assets/images/logo-fb.png"); background-size: 100%; background-repeat: no-repeat; background-position: center;}
.blog-page .sns-box .li-button{ display: block; width: 40px; aspect-ratio: 1 / 1; border-radius: 100px; background-image: url("/assets/images/logo-li.png"); background-size: 100%; background-repeat: no-repeat; background-position: center;}
.blog-page .pager-area p a{ font-size: 24px; font-weight: bold; font-family: var(--font_Lato); color: var(--color_black);}
@media screen and (max-width:600px){
	.blog-page .blog-area .text-box .box > div table{ display: block; overflow-y: auto; width: 100%; height: auto !important;}
	.blog-page .blog-area .text-box .box > div table tbody{ display: table; width: 600px; table-layout: fixed;}
}

