.mainvisual_shift{width:100vw;height:100vh}.mainvisual_shift .section_inner{display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-end;align-items:flex-start;height:100vh}.mainvisual_shift .catch{position:absolute;left:40px;bottom:100px;text-align:left}.mainvisual_shift .catch .catch_text{color:#fff;font-size:16.4rem;line-height:.8292682927;margin-bottom:24px;letter-spacing:0.03em}.mainvisual_shift .catch .catch_subtext{max-width:500px;color:#fff;font-size:28px;line-height:2;letter-spacing:.13em;display:flex;font-weight:700}.mainvisual_shift .catch .catch_subtext:after{background-color:currentColor;content:"";display:block;height:1px;margin-left:13px;position:relative;top:28px;width:80px}.mainvisual_shift .headding_wrap{font-size:16.4rem;overflow:hidden;padding:10px 0}@media only screen and (max-width: 1024px){.mainvisual_shift .catch{width:95%}.mainvisual_shift .catch .catch_text{font-size:7.1rem}.mainvisual_shift .catch .catch_subtext{width:100%;font-size:2rem;max-width:fit-content}.mainvisual_shift .catch .catch_subtext:after{top:2rem}.mainvisual_shift .headding_wrap{font-size:7.1rem}}@media only screen and (max-width: 767px){.mainvisual_shift .catch{left:20px}.mainvisual_shift .catch .catch_subtext{font-size:1.3rem}.mainvisual_shift .catch .catch_subtext:after{width:40px;top:1.3rem}}@media only screen and (max-width: 480px){.mainvisual_shift .catch .catch_text{font-size:6rem}.mainvisual_shift .headding_wrap{font-size:6rem}}
.iphone .h2_bgfix,.ipad .h2_bgfix{background-attachment:scroll;background-size:100% auto;background-repeat:no-repeat}@media only screen and (max-width: 480px){.iphone .h2_bgfix,.ipad .h2_bgfix{background-size:auto 100%}}.h2_bgfix .text-side{color:#fff;text-align:center}.h2_bgfix .section_h2{margin-bottom:.3rem}.h2_bgfix .image-frame-bg{height:1px;width:100px;margin:0 auto 1.5rem}.h2_bgfix .headding_wrap,.h2_bgfix .section_h2{font-size:2.8rem}.h2_bgfix .subtitle_wrap,.h2_bgfix .subtitle,.h2_bgfix .editable_wrap{font-size:1.2rem;letter-spacing:0px}.h2_bgfix .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:2.8rem}@media only screen and (min-width: 768px){.h2_bgfix{background-attachment:fixed}.h2_bgfix .headding_wrap,.h2_bgfix .section_h2{font-size:5rem}.h2_bgfix .subtitle_wrap,.h2_bgfix .subtitle,.h2_bgfix .editable_wrap{font-size:1.5rem}.h2_bgfix .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:5rem}}
.blog_unity .content-wrap{display:grid;grid-template-columns:330px 1fr;grid-template-rows:92px 92px;column-gap:50px;row-gap:30px}.blog_unity .text-side{grid-row:1 / 2;grid-column:1 / 2;margin-left:5px}.blog_unity .text-side .section_h3{font-size:30px}.blog_unity .text-side .subtitle{font-size:15px}.blog_unity .section_btn{grid-row:2 / 3;grid-column:1 / 2;margin:0}.blog_unity .blog-side-wrap{position:relative;width:100%;height:100%;grid-row:1 / 4;grid-column:2 / 3}.blog_unity .blog-side{position:relative}.blog_unity .blog-side .article_template{border-bottom:1px dotted #ccc}.blog_unity .blog-side .article_template+.article_template{margin-top:1rem}.blog_unity .blog-side .blog_content{display:flex;gap:40px;padding:0 15px 15px;position:relative}.blog_unity .blog-side .blog_content:hover .more_read:after{margin-left:.5rem}.blog_unity .blog-side .blog_image-wrap{width:200px;height:120px;border-radius:20px;border:1px solid #e6e6e6;overflow:hidden;flex-shrink:0}.blog_unity .blog-side .blog_image{width:100%;height:100%;background-image:url("//s1.crcn.jp/images/noimage.jpg");background-position:center;background-repeat:no-repeat;background-size:cover}.blog_unity .blog-side .text_wrap{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;flex-wrap:wrap;gap:15px}.blog_unity .blog-side .blog_meta{display:flex;gap:15px;font-size:14px}.blog_unity .blog-side .date{font-size:.8em}.blog_unity .blog-side .category{font-size:.8em;text-align:center;color:#fff;background-color:#3e9bc4;padding:0 0.5rem;margin-left:auto;max-width:140px;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.blog_unity .blog-side .blog_title{width:100%;font-size:20px;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.blog_unity .blog-side .more_read{font-size:.8em;margin:.5rem 0 0 auto;position:absolute;bottom:15px;right:0}.blog_unity .blog-side .more_read:before{content:'→';margin-left:10px}.blog_unity .blog-side .more_read:after{content:'more';display:inline-block;margin-left:1rem;transition:margin-left .3s ease-in-out}@media only screen and (max-width: 1024px){.blog_unity .content-wrap{display:block}.blog_unity .text-side{margin-bottom:30px;margin-left:30px}.blog_unity .section_btn{margin:0 auto}.blog_unity .blog-side-wrap{margin-bottom:30px}.blog_unity .blog-side .blog_content{gap:20px}.blog_unity .blog-side .blog_image-wrap{width:150px;height:90px;border-radius:15px}.blog_unity .blog-side .blog_title{font-size:16px}.blog_unity .blog-side .blog_meta{font-size:12px}}@media only screen and (max-width: 767px){.blog_unity .blog-side .blog_meta{gap:0;flex-direction:column-reverse}.blog_unity .blog-side .category{margin-left:0}}@media only screen and (max-width: 480px){.blog_unity .text-side .section_h3{font-size:25px}.blog_unity .blog-side .blog_content{padding:0 0 15px}.blog_unity .blog-side .text_wrap{gap:5px}.blog_unity .blog-side .blog_image-wrap{width:100px;height:60px;border-radius:10px}.blog_unity .more_read.letter::after{display:none}}
.banner_image{text-align:center}.banner_image.width-limit .section_inner{max-width:800px;margin:0 auto}.banner_image .section_inner{position:relative}.banner_image .section-content{height:180px;margin-top:20px}.banner_image .text-side{position:relative;width:100%;height:100%;top:0;display:flex;align-items:center;justify-content:center}.banner_image .text-side .image-frame{width:100%;max-width:80px;margin:0 auto}.banner_image .text-side .image-frame img{width:100%}.banner_image .text-side_bg{position:absolute;height:100%;width:100%;top:0;left:0}.banner_image .text-side_inner{position:absolute}.banner_image .text-side .editable{min-width:100px}.banner_image .text-side .section_h3{font-size:3rem;font-weight:bold;color:#fff}.banner_image .text-side .letter{color:#fff}@media only screen and (max-width: 767px){.banner_image .section-content{height:150px}.banner_image .text-side .section_h3{font-size:2rem}}body:not(.eat_cms) .block_link.none-events{pointer-events:none}
.half_out_of_position .image-side{position:relative}.half_out_of_position .image-side .frame-image{padding-top:66%}.half_out_of_position .text-side{width:94%;text-align:center;margin:-3rem auto 0;padding:1.5rem 1.5rem 3rem;box-shadow:0 5px 15px rgba(0,0,0,0.1);position:relative;z-index:1}.half_out_of_position .text-side_bg{height:100%;width:100%;opacity:.8;position:absolute;top:0;left:0;z-index:-1}.half_out_of_position .text-side_bg .image-frame-bg{background-color:#fff}.half_out_of_position .text-side .headding_wrap,.half_out_of_position .text-side .headding{font-size:2.5rem}.half_out_of_position .text-side .subtitle_wrap{margin-top:.5rem}.half_out_of_position .text-side .editable_wrap{margin-top:1rem}.half_out_of_position .text-side .section_btn{margin:3rem auto 0}.half_out_of_position .duplicatable-content+.duplicatable-content{margin-top:3rem}@media only screen and (min-width: 768px){.half_out_of_position .duplicatable-content_inner{display:flex;align-items:stretch}.half_out_of_position .image-side{width:55%;margin:0 -5% 0 0}.half_out_of_position .image-side .frame-image{padding-top:0}.half_out_of_position .text-side{width:55%;text-align:left;margin:5rem 0 5rem -5%;padding:3rem 5rem 3.5rem}.half_out_of_position .text-side .section_btn{margin:3rem 0 auto}.half_out_of_position .duplicatable-content+.duplicatable-content{margin-top:5rem}.half_out_of_position .duplicatable-content:nth-child(2n) .duplicatable-content_inner{flex-direction:row-reverse}.half_out_of_position .duplicatable-content:nth-child(2n) .duplicatable-content_inner .text-side{margin:5rem -5% 5rem 0}.half_out_of_position .duplicatable-content:nth-child(2n) .duplicatable-content_inner .image-side{margin:0 0 0 -5%}.half_out_of_position.reverse .duplicatable-content_inner{flex-direction:row-reverse}.half_out_of_position.reverse .duplicatable-content_inner .text-side{margin:5rem -5% 5rem 0}.half_out_of_position.reverse .duplicatable-content_inner .image-side{margin:0 0 0 -5%}.half_out_of_position.reverse .duplicatable-content:nth-child(2n) .duplicatable-content_inner{flex-direction:row}.half_out_of_position.reverse .duplicatable-content:nth-child(2n) .duplicatable-content_inner .text-side{margin:5rem 0 5rem -5%}.half_out_of_position.reverse .duplicatable-content:nth-child(2n) .duplicatable-content_inner .image-side{margin:0 -5% 0 0}}
.card_one{text-align:center}.card_one .section-content_inner{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column}.card_one .image-side{width:100%}.card_one .image-side .image-frame-bg{padding-top:66%;position:relative}.card_one .image-side .frame-image{position:absolute!important;top:0;right:0;bottom:0;left:0;margin:auto;width:100%;height:100%}.card_one .text-side{position:relative;padding:0 1.5rem 4.4rem}.card_one .text-side_bg{position:absolute;height:100%;width:100%;top:0;left:0}.card_one .text-side_inner{position:relative;max-width:280px;margin:auto;z-index:2}.card_one .section_btn{position:relative}.card_one .headding_wrap,.card_one .section_h3{font-size:2.3rem}.card_one .subtitle{font-size:1.1rem;letter-spacing:1px}.card_one .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:2.3rem}.card_one .spacer-item_wrap:nth-child(2) .editable_wrap{font-size:1.1rem}@media only screen and (min-width:768px){.card_one .text-side_inner{max-width:850px}.card_one .image-side .image-frame-bg{padding-top:50%}.card_one .headding_wrap,.card_one .section_h3{font-size:3rem}.card_one .subtitle{font-size:1.2rem}.card_one .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:3rem}.card_one .spacer-item_wrap:nth-child(2) .editable_wrap{font-size:1.2rem}}
.new_standard_content_two .duplicatable-content+.duplicatable-content{margin-top:3rem}.new_standard_content_two .image-side{position:relative}.new_standard_content_two .image-side .image-frame{width:100%;padding-top:66%}.new_standard_content_two .image-side img{height:100%;width:100%;position:absolute;top:0;left:0;object-fit:cover;object-position:50% 50%}.new_standard_content_two .text-side{position:relative;padding:2rem 2rem 3rem}.new_standard_content_two .text-side_bg{height:100%;width:100%;position:absolute;top:0;left:0}.new_standard_content_two .text-side_inner{position:relative;text-align:center}.new_standard_content_two .text-side .headding_wrap,.new_standard_content_two .text-side .headding{font-size:2.5rem}.new_standard_content_two .text-side .subtitle_wrap{margin-top:.5rem}.new_standard_content_two .text-side .editable_wrap{margin-top:1.5rem}.new_standard_content_two .text-side .section_btn{margin-top:3rem}@media only screen and (min-width: 768px){.new_standard_content_two .duplicatable-container{display:flex;flex-wrap:wrap}.new_standard_content_two .duplicatable-content{width:48.5%}.new_standard_content_two .duplicatable-content+.duplicatable-content{margin-top:0}.new_standard_content_two .duplicatable-content:nth-child(2n){margin-left:3%}.new_standard_content_two .duplicatable-content:nth-child(n+3){margin-top:3%}.new_standard_content_two .text-side{padding:3rem 3.5rem 3.5rem}}
.title_sub{font-family:"YakuHanMP, Vollkorn, 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, sans-serif"}.title_sub .section_h3{font-family:YakuHanMP, Vollkorn, "Hiragino Mincho ProN", eatYuM, "Sawarabi Mincho", Meiryo, sans-serif}.title_sub .text-side{max-width:850px;margin:auto;text-align:center}.title_sub .subtitle{letter-spacing:0px}.title_sub .headding_wrap,.title_sub .editable_wrap{font-size:2.5rem}.title_sub .subtitle_wrap{font-size:1.1rem}@media only screen and (min-width: 768px){.title_sub .headding_wrap,.title_sub .editable_wrap{font-size:3rem}.title_sub .subtitle_wrap{font-size:1.6rem}}
.portfolio_standerd .portfolio_list{position:relative;z-index:1}.portfolio_standerd li{border-bottom:1px solid #ccc;margin-bottom:3rem;padding-bottom:2rem}.portfolio_standerd li .image-wrap{margin-bottom:1rem}.portfolio_standerd li .image-wrap .portfolio_image{padding-top:66%;background-image:url("//s1.crcn.jp/images/noimage.jpg");background-position:center;background-repeat:no-repeat;background-size:cover;overflow:hidden;position:relative}.portfolio_standerd li .image-wrap .portfolio_image img{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);width:130%;height:auto}.portfolio_standerd li .image-wrap a{display:block}.portfolio_standerd li .portfolio_text .text_wrap{text-align:left;margin-bottom:0;padding:0}.portfolio_standerd li .portfolio_text .text_wrap h4{font-size:1.7rem;font-weight:200;margin-bottom:1rem;line-height:1.5}.portfolio_standerd li .portfolio_text .text_wrap p{color:#bababa}.portfolio_standerd li .portfolio_text .text_wrap .date{font-size:1.2rem;margin-bottom:.5rem}.portfolio_standerd li .category{font-size:1.4rem;position:relative}.portfolio_standerd li .category .category-color{position:absolute;width:15px;height:5px;left:0;background-color:#ff5721;top:50%;margin-top:-2.5px}.portfolio_standerd .section_btn{width:90%;max-width:300px}.portfolio_standerd .dummy_blog_text{background-color:rgba(255,255,255,0.9);color:#333;transition:opactiy .2s ease}.portfolio_standerd .dummy_blog_text:hover{background-color:rgba(255,255,255,0.5)}@media only screen and (min-width: 768px){.portfolio_standerd{text-align:left}.portfolio_standerd .portfolio_articles,.portfolio_standerd .dummy_form_area{text-align:center;font-size:0}.portfolio_standerd .article{display:flex;flex-flow:row wrap;justify-content:center}.portfolio_standerd li{vertical-align:top;width:31.333%;margin-left:3%}.portfolio_standerd li:nth-child(3n+1){margin-left:0}}
.btn .section_btn a{background-color:#2C5DFF}
.title_simple_wide_reversible .section_inner{padding:0 2.5rem}.title_simple_wide_reversible .text-side{text-align:left}.title_simple_wide_reversible .subtitle{letter-spacing:0px;color:#000;font-family:YakuHanJP, Lato, 'Droid Sans', 'Noto Sans Japanese', 'Hiragino Kaku Gothic ProN', eatYuG, Meiryo, sans-serif}.title_simple_wide_reversible .section_h3{font-family:YakuHanMP, 'Playfair Display', 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, serif;word-wrap:break-word;font-weight:bold;letter-spacing:1.8px;font-size:3.6rem;text-align:center}.title_simple_wide_reversible .headding_wrap,.title_simple_wide_reversible .headding{font-size:2.5rem}.title_simple_wide_reversible .subtitle_wrap,.title_simple_wide_reversible .subtitle{font-size:1.1rem;text-align:center}.title_simple_wide_reversible .text-box{position:relative;margin-top:50px;padding:3rem;border:1px solid #333}.title_simple_wide_reversible .text-box_bg{position:absolute;height:100%;width:100%;top:0;left:0}.title_simple_wide_reversible .text-box .editable_wrap{font-size:1.6rem;color:#000}.title_simple_wide_reversible .text-box .editable_wrap_title{text-align:center;font-size:2rem;color:#333;font-weight:bold}.title_simple_wide_reversible .text-box .spacer-item_wrap{position:relative}@media only screen and (min-width: 768px){.title_simple_wide_reversible .section_h3{text-align:left}.title_simple_wide_reversible .text-side{display:flex}.title_simple_wide_reversible.reverse .text-side{flex-direction:row-reverse;gap:20px}.title_simple_wide_reversible .title-box{width:45%;padding-right:2rem}.title_simple_wide_reversible.reverse .title-box{padding-left:2rem;padding-right:0}.title_simple_wide_reversible .text-box{margin-top:15rem;width:55%}.title_simple_wide_reversible .text-box .spacer-item_wrap{width:100%}.title_simple_wide_reversible .headding_wrap,.title_simple_wide_reversible .headding{font-size:6rem}.title_simple_wide_reversible .subtitle_wrap,.title_simple_wide_reversible .subtitle{font-size:1.6rem;text-align:left}.title_simple_wide_reversible .text-box .editable_wrap{font-size:1.5rem}.title_simple_wide_reversible .text-box .editable_wrap_title{text-align:left}.title_simple_wide_reversible .section_btn a{font-family:YakuHanJP, Lato, 'Droid Sans', 'Noto Sans Japanese', 'Hiragino Kaku Gothic ProN', eatYuG, Meiryo, sans-serif}}
.title_backcolor .section_inner{width:100%;max-width:1024px}.title_backcolor .duplicatable-content{width:100%}.title_backcolor .duplicatable-content:not(:last-child){margin-bottom:80px}.title_backcolor .image-side{text-align:center}.title_backcolor .image-side .image-frame{width:100%}.title_backcolor .image-side .image-frame img{object-fit:cover;height:480px}.title_backcolor .text-side{position:relative;margin:-40px 0 0;padding:0 40px;text-align:left}.title_backcolor .text-side .headding_wrap,.title_backcolor .text-side .subtitle_wrap{display:inline-block;padding:4px 20px;background:#0072C3}.title_backcolor .text-side .headding_wrap{margin-bottom:10px}.title_backcolor .text-side .headding_wrap .headding{color:#fff;font-size:30px;line-height:1.8;letter-spacing:4px}.title_backcolor .text-side .subtitle_wrap{margin-bottom:30px}.title_backcolor .text-side .subtitle_wrap .subtitle{color:#fff;font-size:20px;line-height:1.8;letter-spacing:4px}.title_backcolor .text-side .text_wrap .text{color:#333;font-size:16px;line-height:1.8;letter-spacing:0.3px}@media only screen and (max-width: 1024px){.title_backcolor .section_inner{padding:0}.title_backcolor .image-side .image-frame{position:relative;padding-top:60%}.title_backcolor .image-side .image-frame img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}}@media only screen and (max-width: 767px){.title_backcolor .duplicatable-content:not(:last-child){margin-bottom:20px}.title_backcolor .section_inner{padding:0 20px}.title_backcolor .text-side{padding:0 20px}.title_backcolor .text-side .headding_wrap .headding{font-size:17px;line-height:1.48}.title_backcolor .text-side .subtitle_wrap{margin-bottom:20px}.title_backcolor .text-side .subtitle_wrap .subtitle{font-size:15px}.title_backcolor .text-side .text_wrap .text{font-size:14px}}
.standard_content_dup .duplicatable-container{display:flex;flex-wrap:wrap;justify-content:center}.standard_content_dup .duplicatable-content{width:100%}.standard_content_dup .duplicatable-content:not(:last-child){margin-bottom:3rem}@media only screen and (min-width: 768px){.standard_content_dup .duplicatable-content{width:32%}.standard_content_dup .duplicatable-content:not(:last-child){margin-bottom:0}.standard_content_dup .duplicatable-content:not(:nth-child(3n)):not(:last-child){margin-right:2%}.standard_content_dup .duplicatable-content:not(:nth-child(-n+3)){margin-top:3rem}}.standard_content_dup .duplicatable-content .image-side{margin-bottom:2rem}.standard_content_dup .duplicatable-content .image-side .frame-image{padding-top:66%}.standard_content_dup .text-side{text-align:center}.standard_content_dup .text-side .headding_wrap,.standard_content_dup .text-side .headding{font-size:2.5rem}.standard_content_dup .text-side .headding_wrap{margin-bottom:1rem}.standard_content_dup .text-side .subtitle_wrap,.standard_content_dup .text-side .subtitle{font-size:1.4rem}.standard_content_dup .text-side .subtitle_wrap{margin-bottom:1.5rem}.standard_content_dup .text-side .text_wrap{margin-bottom:3rem}
.fit_card_one{text-align:center}.fit_card_one .section_bg{position:absolute;height:100%;width:100%;top:0;left:0}.fit_card_one .image-side{position:relative}.fit_card_one .image-side_bg{width:100%}.fit_card_one .image-side_inner{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}.fit_card_one .image-side .image-frame-bg{padding-top:66%}.fit_card_one .image-side .frame-image{position:absolute!important;top:0;right:0;bottom:0;left:0;margin:auto}.fit_card_one .image-side_text{width:90%;margin-top:-1rem;font-family:YakuHanMP,"Times New Roman","Yu Mincho",YuMincho,"Hiragino Mincho ProN","Sawarabi Mincho",Meiryo,serif;color:#fff;z-index:2;padding:5rem 0;position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}.fit_card_one .image-side_text .title{font-size:3rem}.fit_card_one .image-side_text .title span{font-size:1.6rem;display:block;line-height:1}.fit_card_one .image-side .headding_wrap,.fit_card_one .image-side .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:3rem}.fit_card_one .image-side .editable_wrap{font-size:1.5rem}.fit_card_one .text-side{position:relative;width:90%;max-width:990px;margin:-2rem auto 0}.fit_card_one .text-side_bg{position:absolute;height:100%;width:100%;top:0;left:0}.fit_card_one .text-side_inner{position:relative;z-index:2;max-width:310px;margin:auto;padding:0 1.5rem}.fit_card_one .text-side .headding_wrap,.fit_card_one .text-side .section_h3{font-size:2.5rem}.fit_card_one .text-side .spacer-item_wrap:nth-child(2) .editable_wrap,.fit_card_one .text-side .subtitle,.fit_card_one .text-side .subtitle_wrap{font-size:1.1rem}@media only screen and (min-width:768px){.fit_card_one .image-side .image-frame-bg{padding-top:38%}.fit_card_one .image-side_text{font-size:3rem;margin-top:-2.5rem}.fit_card_one .image-side_text .title{font-size:6rem}.fit_card_one .image-side_text .title span{font-size:3rem}.fit_card_one .image-side .headding_wrap,.fit_card_one .image-side .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:6rem}.fit_card_one .text-side{margin:-5rem auto 0}.fit_card_one .text-side_inner{max-width:850px}.fit_card_one .text-side .spacer-item_wrap:nth-child(2) .editable_wrap,.fit_card_one .text-side .subtitle,.fit_card_one .text-side .subtitle_wrap{font-size:1.2rem}.fit_card_one .section_h3{font-size:3rem}}
.block_vertical_two{text-align:center}.block_vertical_two .duplicatable-content{font-size:1.4rem}.block_vertical_two .duplicatable-content_inner{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column}.block_vertical_two .image-side_inner{width:100%;font-size:0}.block_vertical_two .image-side_inner .image-frame_wrap{position:relative;width:50%;display:inline-block;padding-top:84%;height:100%}.block_vertical_two .image-side_inner .image-frame_wrap:nth-child(1){border-right:3px solid transparent}.block_vertical_two .image-side_inner .image-frame_wrap:nth-child(2){border-left:3px solid transparent}.block_vertical_two .image-side_inner .image-frame-bg{position:absolute!important;top:0;right:0;bottom:0;left:0;margin:auto;width:100%;height:100%}.block_vertical_two .text-side{padding:0 1.5rem;position:relative}.block_vertical_two .text-side_inner{width:100%;position:relative;max-width:270px;margin:auto;z-index:2}.block_vertical_two .headding_wrap,.block_vertical_two .section_h3{font-size:2.3rem}.block_vertical_two .subtitle{color:#9b4b32;font-size:1.1rem;letter-spacing:0}.block_vertical_two .editable_wrap{font-size:1.5rem}.block_vertical_two .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:2.3rem}.block_vertical_two .spacer-item_wrap:nth-child(2) .editable_wrap{font-size:1.1rem}@media only screen and (min-width:768px){.block_vertical_two .duplicatable-content{font-size:1.5rem}.block_vertical_two .duplicatable-content_inner{display:-ms-flexbox;display:flex;-ms-flex-direction:row-reverse;flex-direction:row-reverse;text-align:left}.block_vertical_two .duplicatable-content:nth-child(even) .duplicatable-content_inner{-ms-flex-direction:row;flex-direction:row}.block_vertical_two .image-side,.block_vertical_two .text-side{width:50%}.block_vertical_two .image-side_inner{height:100%;padding-top:0}.block_vertical_two .text-side{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}.block_vertical_two .text-side_inner{max-width:410px}.block_vertical_two .section_btn{margin-left:0}.block_vertical_two.reverse .duplicatable-content_inner{-ms-flex-direction:row;flex-direction:row}.block_vertical_two.reverse .duplicatable-content:nth-child(even) .duplicatable-content_inner{-ms-flex-direction:row-reverse;flex-direction:row-reverse}.block_vertical_two .headding_wrap,.block_vertical_two .section_h3{font-size:2.5rem}.block_vertical_two .subtitle{font-size:1.2rem}.block_vertical_two .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:2.5rem}.block_vertical_two .spacer-item_wrap:nth-child(2) .editable_wrap{font-size:1.2rem}}
.standard_content_text_two .duplicatable-container{display:flex;gap:30px;justify-content:center;flex-wrap:wrap}.standard_content_text_two .duplicatable-content{width:calc((100% - 30px) / 2)}.standard_content_text_two .text-box{width:100%;border:1px solid #000;border-radius:5px;padding:50px 20px;position:relative;display:flex;justify-content:center;overflow:hidden}.standard_content_text_two .text-box_bg{width:100%;height:100%;position:absolute;top:0;left:0}.standard_content_text_two .text-box_inner{position:relative;display:flex;flex-direction:column;gap:15px;justify-content:center;align-items:center;text-align:center;max-width:330px;width:100%}.standard_content_text_two .text-box-headding_wrap{width:100%}.standard_content_text_two .text-box .section_btn{margin-top:20px}.standard_content_text_two .headding{font-size:25px}.standard_content_text_two .letter{font-size:16px;width:100%}@media only screen and (max-width: 767px){.standard_content_text_two .duplicatable-container{flex-direction:column;align-items:center}.standard_content_text_two .duplicatable-content{width:100%}}
.new_catchcopy_simple .text-wrap{max-width:750px;margin:auto;padding:3rem 1.5rem;box-shadow:0 5px 10px rgba(0,0,0,0.1);position:relative;z-index:0}.new_catchcopy_simple .image-side_bg{height:100%;width:100%;position:absolute;top:0;left:0;opacity:0.9;z-index:-1}.new_catchcopy_simple .text-side{text-align:center}.new_catchcopy_simple .text-side .headding_wrap,.new_catchcopy_simple .text-side .headding{font-size:2.5rem}.new_catchcopy_simple .text-side .subtitle_wrap{margin-top:0.5rem}.new_catchcopy_simple .text-side .editable_wrap{margin-top:1.5rem}.new_catchcopy_simple .text-side .section_btn{margin-top:3rem}
.api_map_text{text-align:center}.api_map_text .map_area{padding-top:100%;position:relative;overflow:hidden}.api_map_text .map_area iframe{position:absolute;top:0;left:0}.api_map_text .image-side{position:relative;margin-bottom:2rem}.api_map_text .overlay{display:none}.api_map_text_wide .map_area{padding-top:57%}.api_map_text .headding_wrap,.api_map_text .section_h3{font-size:3rem}.api_map_text .editable_wrap,.api_map_text .spacer-item_wrap:nth-child(1) .editable_wrap,.api_map_text .subtitle,.api_map_text .subtitle_wrap{font-size:1.5rem}.api_map_text .spacer-item_wrap:nth-child(2) .editable_wrap{font-size:3rem}@media only screen and (min-width:768px){.api_map_text{text-align:left}.api_map_text .section_inner{display:-ms-flexbox;display:flex}.api_map_text .image-side,.api_map_text .text-side{width:50%}.api_map_text .image-side{margin-bottom:0}.api_map_text .text-side{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;-ms-flex-direction:column;flex-direction:column;padding:0 1.5rem 0 5rem}.api_map_text .text-side_inner{width:100%;max-width:400px;padding:2rem 0}.api_map_text .text-side .spacer{width:100%}.api_map_text .section_btn{margin-left:0}.api_map_text.reverse .section_inner{-ms-flex-direction:row-reverse;flex-direction:row-reverse}.api_map_text_wide .map_area{height:100%;padding-top:82%}.api_map_text .headding_wrap,.api_map_text .section_h3,.api_map_text .spacer-item_wrap:nth-child(2) .editable_wrap{font-size:3.5rem}}
.infomation_all_generic{text-align:center;font-size:1.4rem}.infomation_all_generic .section_inner{color:#fff}.infomation_all_generic .letter,.infomation_all_generic .editable_wrap{letter-spacing:.7px;font-size:1.4rem}.infomation_all_generic .info-side{font-size:1.2rem}.infomation_all_generic .info-side .tel-linker{font-size:2rem}.infomation_all_generic .section_btn{margin:3rem auto 0}.infomation_all_generic .section_btn .linker{font-size:1.5rem}.infomation_all_generic .section_btn a{background-color:#E4A947}.infomation_all_generic .headding_wrap,.infomation_all_generic .section_h3{font-size:3rem;color:#fff}.infomation_all_generic .subtitle_wrap,.infomation_all_generic .subtitle{font-size:1.5rem}.infomation_all_generic .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:3rem}.infomation_all_generic .spacer-item_wrap:nth-child(2) .editable_wrap{font-size:1.5rem}@media only screen and (min-width: 768px){.infomation_all_generic .info-side{display:flex;justify-content:center}.infomation_all_generic .section_btn{margin:0 0 0 5rem}}
#footer-section{z-index:3}@media only screen and (max-width: 768px){.jobs #footer-section .detail-side{display:none}}.footer-block .footer_menu_center .detail-side{bottom:0;transition:bottom .5s}.footer_menu_center{background-color:#fff;font-size:1.4rem}.footer_menu_center .footer-company{position:relative}.footer_menu_center .footer-company::before{content:"";position:absolute;top:0;left:50%;width:100%;height:1px;background-color:#ccc;transform:translateX(-50%)}.footer_menu_center .logo-side{padding:2rem 0;text-align:center}.footer_menu_center .logo{max-width:120px;margin:0 auto 2rem}.footer_menu_center .logo img{width:auto;max-width:100%}.footer_menu_center .logo div{display:inline}.footer_menu_center .menu-side{display:none}.footer_menu_center .detail-side{text-align:center;font-size:1.4rem;display:-ms-flexbox;display:flex;-ms-flex-direction:row-reverse;flex-direction:row-reverse;background-color:#fff;position:fixed;bottom:-100%;left:0;width:100%;transition:bottom .8s .2s}.footer_menu_center .detail-side_first{width:80px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;position:relative}.footer_menu_center .detail-side_first .tel{line-height:1.4;letter-spacing:0}.footer_menu_center .detail-side_first .tel a{position:absolute;width:100%;height:100%;top:0;left:0}.footer_menu_center .detail-side_first .tel:after{content:"phone";font-family:"Material Icons";font-size:3.6rem;font-weight:400;font-style:normal;display:inline-block;line-height:1;text-transform:none;letter-spacing:normal;word-wrap:normal;white-space:nowrap;direction:ltr;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;-moz-osx-font-smoothing:grayscale;-webkit-font-feature-settings:"liga";font-feature-settings:"liga"}.footer_menu_center .detail-side_first .hour{font-size:1.2rem;display:none}.footer_menu_center .detail-side_second{-ms-flex-positive:1;flex-grow:1}.footer_menu_center .letter{letter-spacing:.1em}.footer_menu_center .copy{border-top:1px solid #ccc;font-size:1.2rem;padding:2rem 0;text-align:center}.footer_menu_center .sns-side{margin-bottom:2rem}.footer_menu_center .sns-side .duplicatable-container{display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center}.footer_menu_center .sns-side .duplicatable-content{max-width:70px;padding:0 1rem}.footer_menu_center .section_btn a{white-space:nowrap}.footer_menu_center .back-top{cursor:pointer;width:40px;height:40px;border-radius:20px;border:1px solid #f44336;position:absolute;bottom:10px;right:10px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}.footer_menu_center .back-top .arrow:before{content:"▲";color:#f44336}@media only screen and (min-width: 768px){.footer_menu_center .footer-company{padding:3.5rem 0 2rem}.footer_menu_center .footer-company_inner{display:flex;flex-wrap:wrap}.footer_menu_center .logo{display:block;margin:0 auto}.footer_menu_center .menu-block{order:3;width:100%}.footer_menu_center .menu-side{display:block;padding:3rem 0 5rem}.footer_menu_center .menu-side .duplicatable-container{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;text-align:center;-ms-flex-pack:end;justify-content:center}.footer_menu_center .menu-side .duplicatable-content{width:auto;padding:0 1rem;font-size:1.4rem}.footer_menu_center .logo-side{order:1;width:200px}.footer_menu_center .detail-side{order:2;-ms-flex-direction:row;flex-direction:row;-ms-flex-pack:justify;justify-content:space-between;text-align:left;margin:auto 0 auto auto;width:calc(100% - 220px);position:static;background-color:transparent}.footer_menu_center .detail-side_first{margin-bottom:4rem;font-size:1.8rem;text-align:right;display:block}.footer_menu_center .detail-side_first .tel{font-size:2.2rem}.footer_menu_center .detail-side_first .tel:after{content:none}.footer_menu_center .detail-side_first .tel a{position:relative;pointer-events:none}.footer_menu_center .detail-side_first .hour{display:block}.footer_menu_center .detail-side_second{max-width:300px;margin-bottom:3rem}.footer_menu_center .detail-side>div{margin-bottom:0;width:100%}.footer_menu_center .copy{padding:1.5rem 0;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between;-ms-flex-align:center;align-items:center}.footer_menu_center .sns-side{margin-bottom:0}.footer_menu_center .sns-side .duplicatable-content{width:60px}.footer_menu_center .section_btn{margin:auto 0 auto auto}.footer_menu_center .back-top{bottom:80px}}@media only screen and (max-width: 768px){.footer_menu_center .detail-side_first .tel{font-size:0 !important}.footer_menu_center .detail-side_second .section_btn{max-width:none}.footer_menu_center .detail-side_second .section_btn a{border-radius:0}}@media only screen and (min-width: 768px){_:-ms-lang(x)::-ms-backdrop,.footer_menu_center .detail-side{align-items:center;margin:unset}_:-ms-lang(x)::-ms-backdrop,.footer_menu_center .detail-side_second{margin-left:2rem}}@media only screen and (max-width: 768px){_::-webkit-full-page-media,_:future,:root .detail-side_first{text-align:center}_::-webkit-full-page-media,_:future,:root .tel.letter.editable{display:grid}}
@charset "UTF-8";#section-wrapper{background-color:#fff}#section-wrapper .headding{    font-family: YakuHanMP, 'Noto Serif', 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, serif;
    line-height: ;
    letter-spacing: em;
}#section-wrapper .subtitle{    font-family: YakuHanMP, 'Noto Serif', 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, serif;
    line-height: ;
    letter-spacing: em;
}#section-wrapper .letter{    font-family: YakuHanMP, 'Noto Serif', 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, serif;
    line-height: ;
    letter-spacing: em;
}@media only screen and (min-width:769px){}#loading{position:fixed;top:0;width:100%;height:100%;background:rgba(0,0,0,0.5);z-index:9999;display:none}#loading .loading_inner{width:100%;height:90px;position:absolute;top:50%}#loading .loading_inner .loader_animation,#loading .loading_inner .loader_animation:before,#loading .loading_inner .loader_animation:after{border-radius:50%;width:2.4rem;height:2.4rem;-webkit-animation-fill-mode:both;animation-fill-mode:both;-webkit-animation:load7 1.3s infinite ease-in-out;animation:load7 1.3s infinite ease-in-out}#loading .loading_inner .loader_animation{color:#fff;font-size:12px;margin:10px auto;position:relative;top:-30px;text-indent:-9999rem;-webkit-transform:translateZ(0);transform:translateZ(0);-webkit-animation-delay:-0.16s;animation-delay:-0.16s}#loading .loading_inner .loader_animation:before,#loading .loading_inner .loader_animation:after{content:'';position:absolute;top:0}#loading .loading_inner .loader_animation:before{left:-3.4rem;-webkit-animation-delay:-0.32s;animation-delay:-0.32s}#loading .loading_inner .loader_animation:after{left:3.4rem}@-webkit-keyframes load7{0%,80%,100%{box-shadow:0 2.45rem 0 -1.25rem}40%{box-shadow:0 2.45rem 0 0}}@keyframes load7{0%,80%,100%{box-shadow:0 2.45rem 0 -1.25rem}40%{box-shadow:0 2.45rem 0 0}}#loading .circle{position:fixed;top:50%;left:50%;width:50px;height:50px;margin:-25px 0 0 -25px;border-radius:50%;border:8px solid #f00;border-right-color:transparent;-webkit-animation:spin .8s linear infinite;animation:spin .8s linear infinite}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg);opacity:.2}50%{-webkit-transform:rotate(180deg);transform:rotate(180deg);opacity:1.0}100%{-webkit-transform:rotate(360deg);transform:rotate(360deg);opacity:.2}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg);opacity:.2}50%{-webkit-transform:rotate(180deg);transform:rotate(180deg);opacity:1.0}100%{-webkit-transform:rotate(360deg);transform:rotate(360deg);opacity:.2}}

/* ==================================================================================================================
   テーマ変数（色・フォント・共通サイズ）
   → 色替えやブランド変更はここだけ触ればOK
================================================================================================================== */
:root {
  --color-main: #ff2c2c;
  --color-sub: #ffe4e1;
  --color-accent: #ecb846;
  --color-white: #ffffff;
  --color-black: #000;
  --color-text: #1a1a1a;
  --color-bg: #f2f2f2;
  --shadow-weak: rgba(38, 2, 2, .5);

  --ff-base: 'DM Serif Display', 'Noto serif JP', serif;

  --fz-h1: 52px;
  --fz-h2: 44px;
  --fz-h3: 22px; /* モバイルの基準にも使う */
  --fz-body: 15px;

  --underline-height: 4px;
}

/* ==================================================================================================================
   共通（フォント・見出し・本文）
================================================================================================================== */
/* フォント指定（対象は元コード準拠） */
h1, h2, h3, body, a, div,
#section-wrapper .subtitle,
#section-wrapper .headding,
#section-wrapper .letter {
  font-family: var(--ff-base) !important;
  font-weight: 900;
}

/* 本文フォント */
.letter.editable {
  font-size: var(--fz-body);
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: 0.03em !important;
}
/* 767px以下：本文フォント */
@media screen and (max-width: 767px) {
  .letter.editable {
    font-size: 15px;
  }
}

/* 見出し（PC基準） */
h1, h1 font, h1 span, h1 b { font-size: var(--fz-h1); font-weight: 800; }
#section-wrapper .section_h2,#section-wrapper .section_h2 font,#section-wrapper .section_h2 span,#section-wrapper .section_h2 b { font-size: var(--fz-h2); font-weight: 800; line-height: 1; }
#section-wrapper h3,#section-wrapper h3 font,#section-wrapper h3 span,#section-wrapper h3 b { font-weight: 600; } /* サイズはモバイル側で指定 */
.section_h3 { line-height: 1.25; }

/* 767px以下：見出しサイズ調整 */
@media screen and (max-width: 767px) {
  h1, h1 font, h1 span, h1 b { font-size: 36px; font-weight: 800; }
#section-wrapper .section_  h2,#section-wrapper .section_h2 font,#section-wrapper .section_h2 span,#section-wrapper .section_h2 b { font-size: 30px; font-weight: 800; }
#section-wrapper h3,#section-wrapper h3 font,#section-wrapper h3 span,#section-wrapper h3 b { font-size: var(--fz-h3); font-weight: 800; }
}

.h2_section .subtitle,
.h2_section .subtitle font,
.subtitle.editable,
.subtitle.editable font {
    font-size: 18px;
}

/* ==================================================================================================================
   最背景
================================================================================================================== */
#section-wrapper:before {
  content: "";
  position: fixed;
  background:url(https://d1i7na1hjknxjq.cloudfront.net/uploads/storage/image/file/496934/optimized_dKf0dIyLzVmK_rzvCXAJTw.jpg) no-repeat center / cover; 
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  opacity: .05;
 }




/* ==================================================================================================================
   gnav（ヘッダー／ナビ）
================================================================================================================== */
/* ページ名リンクの余白・サイズ */
.gnav-wrap .gnav .gnav_items li a {
  padding: 6px 1.2rem;
  font-size: var(--fz-body);
}

/* 問い合わせボタン（最後の li） */
.gnav_items li:last-child:not(.gnav-submenu) {
  color: var(--color-white) !important;
  font-weight: 900;
  background: var(--color-main)!important;
  border: 1px solid var(--color-white);
}

/* 1024px以下：問い合わせボタン背景は透明 */
@media screen and (max-width: 1024px) {
  #global-nav .header_logo img {
    width: 140px; /* 元コードにあった別サイズも尊重 */
    height: auto;
    padding-top: 9px;
    border: none;
  }
  .gnav_items li:last-child:not(.gnav-submenu) {
    background-color: transparent !important;
  }
}

/* ページリンクの文字色 */
.gnav_items li a {
  color: var(--color-text)!important;
  font-weight: 900;
}

/*1024px以下：ページリンクスタイル調整*/
.gnav-wrap .gnav_sp .drawer-nav li a {
  border-bottom: solid 1px var(--color-text);
  color: #fff !important;
  font-weight: 900;
}

/* 1025px以上：アンダーライン演出＋hover色変更 */
@media only screen and (min-width: 1025px) {
  .gnav_items li a {
    position: relative;
    font-weight: 900 !important;
    height: 100%;
    display: flex;
    align-items: center;
    font-size: var(--fz-body);
  }

  /* 下線（初期は非表示：scaleX(0)） */
  .gnav_items li a::before,
  .gnav_items .active > a::before,
  .gnav_items .visit  > a::before {
    content: "";
    width: 100%;
    height: var(--underline-height);
    background-color: var(--color-main);
    position: absolute;
    left: 0;
    bottom: 0;
    transition: transform .35s ease;
    transform: scale(0, 1);
    transform-origin: left center;
  }

  /* hover／active／visit で下線表示＆文字色変更 */
  .gnav_items li a:hover,
  .gnav_items .active > a,
  .gnav_items .visit  > a {
    opacity: 1;
    text-decoration: none !important;
  }

  .gnav_items li.active > a::before,
  .gnav_items li.visit  > a::before,
  .gnav_items li > a:hover::before {
    transform: scale(1, 1);
  }
}

/* 1025px以上：最後の li（問い合わせ）には下線を出さない */
@media only screen and (min-width: 1025px) {
  .gnav_items li:last-child a::before {
    transform: scale(0, 1) !important;
  }
}

/*ブラウザ幅を縮めても2段にならないようにする*/
@media only screen and (max-width: 1060px) {
  .gnav_items li {
    padding: 0 20px!important;
  }
}

/* ハンバーガーメニューの色 */
.hamburger_top.drawer-hamburger-icon,
.hamburger_mid.drawer-hamburger-icon,
.hamburger_btm.drawer-hamburger-icon {
  background-color: var(--color-text)!important;
}




/* ==================================================================================================================
   ボタン
================================================================================================================== */
.section_btn a {
  color: var(--color-white) !important;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: .1em !important;
  background-color: var(--color-white)!important;
  border: 1px solid var(--color-white)!important;
  border-radius: 6px !important;
  position: relative;
  transition: .3s;
  z-index: 0;
}

/* 矢印（右） */
.section_btn a::before {
  content: "";
  width: 1rem;
  height: 1rem;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  position: absolute;
  top: calc(50% - 0.5px);
  right: 1.8rem;
  transform-origin: center;
  transform: rotate(45deg) translateY(-50%);
  transition: .3s;
}

/* 背面レイヤ（ホバーでフェード） */
.section_btn a::after {
  content: '';
  position: absolute;
  inset: 0;
  background-color: var(--color-main)!important;
  z-index: -1;
  transition: .3s;
  border-radius: 4px !important;
}

/* ホバー */
.section_btn a:hover {
  color: var(--color-main) !important;
  border: 1px solid var(--color-main)!important;
  opacity: 1;
}

.section_btn a:hover::before { right: 1.3rem;   border-top: 2px solid var(--color-main); border-right: 2px solid var(--color-main); }
.section_btn a:hover::after { opacity: 0; }

.multiple_btn .section_inner .section_btn .linker a { font-size: 16px; }


/*ご依頼の方へ 対応エリアの…ボタン サイズ調整*/
@media only screen and (min-width: 768px) {
    #section_702850 .section_btn {
        max-width: 314px;
    }
}


/* ==================================================================================================================
   表（テーブル）
================================================================================================================== */
/* th 背景色 */
.th.editable.letter {
  background-color: var(--color-main) !important;
}

/* 横線 */
.table_border_light .table_wrap .tr {
    width: 100%;
    border-bottom: 1px solid var(--color-main);
}

/*幅調整*/
.table_border_light .table_wrap .tr .th {
    padding: 1rem 1rem 1rem;
}

/* ==================================================================================================================
   FV / H1 セクション（余白・被せ等）
================================================================================================================== */
/* 1025px以上：余白解除 */
@media only screen and (min-width: 1025px) {
  #section_705152 .content,
  .content:has(.h1_left.title_section) {
    padding: 0 !important;
  }
}

/*FV背景カバー*/
.mainvisual_shift .section-image_bg.bg-cover {
  background-color: var(--shadow-weak);
  opacity: .3;
  mix-blend-mode: multiply;
}

/*FVサブタイトル（上）*/
.mainvisual_shift .catch_head {
  font-size: 25px;
  border-bottom: 1px solid var(--color-white);
}
@media only screen and (max-width: 858px) {
  .mainvisual_shift .catch_head {
    font-size: 18px;
  }
}

/*FVサブタイトル（上） 背景帯*/
.mainvisual_shift .catch .catch_subtext {
    background-color: red;
    border-radius: 6px;
    padding: 0px 14px;
    margin-bottom: 20px;
}

/*FVタイトル*/
.mainvisual_shift  .catch .catch_text,
.mainvisual_shift .catch .catch_text span {
    font-size: 120px !important;
    text-shadow: 4px 4px 0px var(--shadow-weak);
}
/*1024px以下：FVタイトルサイズ*/
@media only screen and (max-width: 1024px) {
  .mainvisual_shift .catch .catch_text,
  .mainvisual_shift .catch .catch_text span {
    font-size: 100px !important;
  }
}
/*767px以下：FVタイトルサイズ*/
@media only screen and (max-width: 767px) {
  .mainvisual_shift .catch .catch_text,
  .mainvisual_shift .catch .catch_text span {
    font-size: 54px !important;
  }
}


/*FVサブタイトル*/
.mainvisual_shift .catch .catch_subtext {
    font-size: 28px;
    text-shadow: 2px 2px 0px var(--shadow-weak);
}
@media only screen and (max-width: 1024px) {
    .mainvisual_shift .catch .catch_subtext {
        font-size: 18px;
    }
}


/*ページトップタイトル背景カバー
.h1_left.title_section .section-image_bg.bg-cover {
  background-color: rgba(27, 28, 37, .7);
}
*/

/* タイトル */
.h1_left.title_section .headding.section_h3.editable,
.h1_left.title_section .headding.section_h3.editable span,
.h1_left.title_section .headding.section_h3.editable font {
  font-size: 60px;
  font-weight: 700; /* 600px → 600 に修正 */
  text-shadow: 4px 4px 0px var(--shadow-weak);
}
/* 767px以下：タイトルサイズ調整 */
@media screen and (max-width: 767px) {
  .h1_left.title_section .headding.section_h3.editable,
  .h1_left.title_section .headding.section_h3.editable span,
  .h1_left.title_section .headding.section_h3.editable font {
    font-size: 52px;
  }
}

/*サブタイトル*/
.h1_left.title_section .subtitle.editable,
.h1_left.title_section .subtitle.editable span,
.h1_left.title_section .subtitle.editable font {
  font-size: 28px;
  font-weight: 700; /* 600px → 600 に修正 */
  text-shadow: 2px 2px 0px var(--shadow-weak);
}



/* ==================================================================================================================
   ページトップ 下セクションと字頭をそろえる
================================================================================================================== */
/*下セクションと字頭をそろえる*/
@media only screen and (min-width: 768px) {
    .h1_left.title_section .section_inner {
        margin: 0 0 0 40px;
    }
}
@media only screen and (min-width: 768px) {
    .half_wide_limited_height .text-side {
        padding: 0 20px 0 40px!important;
    }
}
@media only screen and (min-width: 768px) {
    .half_wide_limited_height .text-side_inner {
        max-width: 50vw;
    }
}



/* ==================================================================================================================
   画像角丸
================================================================================================================== */
.frame-image,
.image-frame-bg,
.new_standard_content_two .image-side img,
.unevenness_opposite .image-side .image-frame img {
  border-radius: 6px!important;
}

.title_circle .image-frame-bg {
  border-radius: 50%!important;
}

/* ==================================================================================================================
   ハーフセクション（左タイトル、右テキストエリア）
================================================================================================================== */
/*上揃え*/
@media only screen and (min-width: 768px) {
    .title_simple_wide_reversible .text-box {
        margin-top: 58px;
    }
}

/*角丸*/
.title_simple_wide_reversible .text-box .image-frame-bg {
  border-radius: 8px;
}

/*枠線*/
.title_simple_wide_reversible .text-box {
  border: 1px solid var(--color-main);
  border-radius: 8px;
}

/* ==================================================================================================================
   ハーフセクション（左右画像、テキスト）
================================================================================================================== */
/*SP時：テキスト幅調整*/
@media only screen and (max-width: 768px) {
  .half .text-side_inner {
    max-width: 345px;
  }
}

/* ==================================================================================================================
   ハーフセクション（背景斜め）
================================================================================================================== */
.half_wide_circle_basisdesign .duplicatable-content::before {
  background-color: var(--color-main);
}

/* ==================================================================================================================
   上画像下テキスト カードセクション
================================================================================================================== */
.standard_content_dup .duplicatable-content {
  background-color: var(--color-white);
  border-radius: 6px;
}

/* ==================================================================================================================
   ハーフセクション（ずらし画像背景）
================================================================================================================== */
.half_two_image_misaligned .image-side .image-frame-bg .frame-image::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: #000;
  opacity: .5;
  position: absolute;
  left: 0;
  top: 0;
}

/* ==================================================================================================================
   ハーフセクション（四角画像）
================================================================================================================== */
/*サブタイトル 帯*/
.half.rv_section.section_name.width-limit.color-bg .subtitle.editable span {
  background-color: var(--color-main);
  padding: 3px 10px;
  border-radius: 4px;
}

/* ==================================================================================================================
   全面背景画像、下カードセクション
================================================================================================================== */
/*背景カバー*/
.fit_card_one .image-side_bg .frame-image::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(255, 255, 255, .8);
}

/*テキストサイズ調整*/
.fit_card_one .editable.headding.title span {
  font-size: 60px;
}
@media only screen and (max-width: 768px) {
  .fit_card_one .editable.headding.title span {
        font-size: clamp(40px, 9vw, 46px);
  }
}

/*カード 角丸*/
.fit_card_one .image-frame-bg {
  border-radius: 6px;
}

/* ==================================================================================================================
   全背景前面センターテキストセクション
================================================================================================================== */
/*背景カバー*/
.h2_bgfix.h2_section .section-image_bg.bg-cover {
  background-color: rgba(255, 44, 44, .8)
}

/* ==================================================================================================================
   テキストボックス：枠・角・影
================================================================================================================== */
/*枠線スタイル変更・角丸*/
.standard_content_text_dup .text-box,
.standard_content_text_two .text-box {
  border: 1px solid rgba(255, 44, 44, .2);
  border-radius: 6px !important;
  box-shadow: 8px 8px var(--shadow-weak);
}

/*==================================================================================================================
   POINTセクション
==================================================================================================================*/
/*背景円追加*/
.three_cards_title_sfiht .duplicatable-content_inner::before {
    content: '';
    position: absolute;
    width: 300px;
    height: 300px;
    background-color: var(--color-main);
    border-radius: 50%;
    top: 50%;
    left: 60%;
    z-index: -1;
}
@media screen and (max-width: 1024px) {
    .three_cards_title_sfiht .duplicatable-content_inner::before {
        width: 200px;
        height: 200px;
        top: 50%;
    }
}

.duplicatable-content:nth-child(1) .duplicatable-content_inner::before,
.duplicatable-content:nth-child(2) .duplicatable-content_inner::before,
.duplicatable-content:nth-child(3) .duplicatable-content_inner::before,
.duplicatable-content:nth-child(4) .duplicatable-content_inner::before,
.duplicatable-content:nth-child(5) .duplicatable-content_inner::before {
    transform: translate(-60%, -50%) rotate(0deg);
}



/*テキスト スタイル調整
.three_cards_title_sfiht .text-side .headding {
  text-shadow: .3rem .3rem var(--color-main);
}
*/

/*SP時：テキスト幅調整*/
@media only screen and (max-width: 1024px) {
    .three_cards_title_sfiht .duplicatable-container {
      max-width: 60%!important;
      margin: auto;
    }
.three_cards_title_sfiht .duplicatable-content {
        width: 100%;
        margin-bottom: 5rem;
}
}
@media only screen and (max-width: 767px) {
    .three_cards_title_sfiht .duplicatable-content {
      width: 60%;
      margin: auto;
    }
}

/*間隔調整*/
.three_cards_title_sfiht .text-side {
    margin-top: -2.7rem;
}
@media only screen and (max-width: 1024px) {
    .three_cards_title_sfiht .text-side {
        margin-top: -6.6rem;
    }
}


/* ==================================================================================================================
   テキストセクション（サブタイトル、タイトル）
================================================================================================================== */
/*サブタイトル 背景帯*/
.sub_title .subtitle_wrap .subtitle span {
    background-color: var(--color-main);
    padding: 3px 10px;
    border-radius: 4px;
}


/*==================================================================================================================
   下部ページリンク
==================================================================================================================*/
/*背景カバー*/
.square_four_images_with_text .image-frame-bg {
  position: relative;
}
.square_four_images_with_text .image-frame-bg:after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-color: rgba(38, 2, 2, .5);
  border-radius: 6px!important;
}

/*テキスト位置調整*/
.square_four_images_with_text .text-side {
    margin-top: 20px;
}

/* ==================================================================================================================
   円・サークル画像セクション
================================================================================================================== */
/*テキストサイズ調整*/
.circle-box .duplicatable-content .name {
    font-size: 18px !important;
}

/*背景カバー*/
.circle-box_link.color-bg .image-frame.center-icon.top-icon.circle-image::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(255, 44, 44, .5);
  z-index: 1;
}

/* ==================================================================================================================
   タイトル帯セクション
================================================================================================================== */
/*帯 スタイル調整*/
.title_backcolor .text-side .headding_wrap,
.title_backcolor .text-side .subtitle_wrap {
    background: var(--color-main);
}

/* ==================================================================================================================
   アイコンカード：枠・角・影
================================================================================================================== */
/*枠線スタイル調整*/
.card_icon .card_icon-item {
  border: 1px solid rgba(255, 44, 44, .2);
  border-radius: 6px !important;
  box-shadow: .2rem .2rem 8px var(--shadow-weak);
}

/*見出し 位置調整*/
.card_icon .text-side {
  top: -8px;
}


/* ==================================================================================================================
   アイコンセクション
================================================================================================================== */
/*PC時：上2つ下2つ配置*/
@media only screen and (min-width: 768px) {
  #content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content {
    width: 45%;
    border-right: none;
  }
  #content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content:nth-child(3) {
    border-right: 2px dotted #ccc;
  }
}

/* ==================================================================================================================
   チェックボックスあしらい
================================================================================================================== */
/*アイコン非表示*/
#section_705082 .card_icon .image-side {
    display: none;
}

/*チェックボックス 左側余白*/
#section_705082 .section_inner .editable_wrap .editable.letter span {
    margin-bottom: .3rem;
    padding-left: 2.7rem;
    position: relative;
}
/*チェックボックス チェックの部分*/
#section_705082 .section_inner .editable_wrap .editable.letter span::before {
    content: "";
    position: absolute;
    top: 6px;
    left: 7px;
    -webkit-transform: rotate(50deg);
    -ms-transform: rotate(50deg);
    transform: rotate(50deg);
    width: 6px;
    height: 11px;
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    z-index: 1;
}
/*チェックボックス 四角の部分*/
#section_705082 .section_inner .editable_wrap .editable.letter span::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 0;
    width: 20px;
    height: 20px;
    background-color: var(--color-main);
    border-radius: 0;
}

/*チェックボックステキスト 中央揃え*/
#section_705082 .section_inner .editable_wrap {
  width: 97%;
  margin-left: auto;
  margin-right: auto;
}



/* ==================================================================================================================
   お問い合わせ
================================================================================================================== */
/*767px以下の場合*/
@media only screen and (max-width: 767px) {
  /*タイトル テキストサイズ調整*/
  .contact_policy.width-limit .section_h3.headding.editable span,
  .check_before_contact.width-limit .section_h3.headding.editable span {
    font-size: 24px;
  }
}
/*送信ボタンスタイル変更*/
.section_btn input {
    color: var(--color-white)!important;
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: .1em !important;
    background: var(--color-main)!important;
    border: 1px solid var(--color-white);
    border-radius: 6px !important;
    position: relative;
    transition: .3s!important;
    z-index: 0;
}
/*#### お問い合わせフォーム ####*/
/*お問い合わせフォーム テキスト調整*/
#section_704657 label,
#section_704657 input,
#section_704657 textarea,
#section_704657 select {
  font-weight: 700;
  color: var(--color-text);
}

/* ==================================================================================================================
   サンクスページ
================================================================================================================== */
.thanks_page .catch_text.headding,
.thanks_page .catch_text.headding span {
  font-size: 32px;
  font-weight: 600;
  text-align: center;
  padding-left: 0 !important;
  color: var(--color-text) !important;
}
.thanks_page .catch_subtext {
  font-size: 18px !important;
  font-weight: 600;
  padding-bottom: 3rem !important;
  color: var(--color-main) !important;
}
/* 上下線削除＋背景白 */
.thanks_page .catch {
  border: 0 !important;
  padding: 5%;
  background-color: var(--color-white);
  /* 元コードの二重指定（border:none）を統合 */
}
/* セクション背景（灰） */
.thanks_page { background-color: #F1F1F1; }

/* ドロップシャドウ削除 */
.catch_text { text-shadow: 0 0 0 rgba(0,0,0,0); }

/* 768px以下：見出し・本文サイズ調整 */
@media screen and (max-width: 768px) {
  .thanks_page .catch_text.headding,
  .thanks_page .catch_text.headding span { font-size: 24px; }
  .thanks_page .catch_subtext { padding-bottom: 3rem !important; }
}

/* ==================================================================================================================
ブログ・施工事例
================================================================================================================== */
/*ご依頼・ご相談 テキストカラー*/
.blog_posts .banner_text ._color_,
.showcase_chart .banner_text ._color_ {
  color: var(--color-main) !important;
}

/*お問い合わせはこちら ボタン*/
.banner_text .banner_link,
.blog_posts .banner_text .banner_link,
.showcase_chart .banner_text .banner_link {
  background-color: var(--color-main)!important;
  border-radius: 0!important;
}

.blog_posts .banner_text .banner_link,
.showcase_chart .banner_text .banner_link {
  font-weight: 600;
}

/*背景カバー*/
.width-limit.showcase_outer.letter::before,
.wrapper.blog_posts.letter.blog_posts_index::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-color: rgba(255, 255, 255, .8);
  z-index: -1;
}

/* ==================================================================================================================
   Footer
================================================================================================================== */
/* ロゴ画像 */
.footer_menu_center .logo img { width: 240px; }
.footer_menu_center .logo { max-width: 100%; }

/* 上部へ戻るボタン */
.footer_tp_generic .back-top {
  border: 1px solid var(--color-main) !important;
}
.footer_tp_generic .back-top .arrow:before {
  color: var(--color-main) !important;
}

/*ページリンク テキストスタイル調整*/
.editable a {
    color: var(--color-black);
}

.footer_menu_center .detail-side_first .tel a  {
    color: var(--color-main);
}

/* フッター上部線を削除 */
.footer_tp_generic .footer-company::before { content: none; }

/* 768px以上：TELサイズ／コピーライト中央 */
@media only screen and (min-width: 768px) {
  .tel.letter.editable span font { font-size: 24px; }
  .footer_tp_generic .copy { justify-content: center; }
}


/* 20260212 修正 */
#section-wrapper .section_h3 span {
    font-weight: 900;
}
.three_cards_title_sfiht .subtitle.editable font {
    font-size: 2.2rem;
}
#section-wrapper :is(.title_sub,.title_line_wide_reversible,.sub_title,.title_simple_wide_reversible,.api_map_text) .section_h3,
#section-wrapper :is(.title_sub,.title_line_wide_reversible,.sub_title,.title_simple_wide_reversible,.api_map_text) .section_h3 span,
#section-wrapper :is(.title_sub,.title_line_wide_reversible,.sub_title,.title_simple_wide_reversible,.api_map_text) .section_h3 font {
    font-size: clamp(3rem,5vw,4rem);
}
.sub_title .section_h3 {
    margin-top: 1rem;
}
@media only screen and (max-width: 767.9px) {
.three_cards_title_sfiht .duplicatable-container {
    max-width: 100% !important;
}
.three_cards_title_sfiht .duplicatable-content {
    width: 80%;
        margin-bottom: 5rem;
}
}
@media only screen and (max-width: 480px) {
.three_cards_title_sfiht .duplicatable-content {
    width: 90%;
}
   #section-wrapper .square_four_images_with_text .section_h3 {
        font-size: 1.5rem;
    }
}