.mainvisual_right_slider{position:relative;height:100vh;font-family:YakuHanMP, 'Playfair Display', 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, serif}.mainvisual_right_slider .section_inner{height:85vh;width:85%;float:right;transform:none;position:relative}.mainvisual_right_slider .image-side{overflow:hidden;top:60px;position:absolute;height:100%;width:100%}.mainvisual_right_slider .text-side_bg{position:absolute;width:70%;height:118%;background-color:#f2ede9;left:-18%}.mainvisual_right_slider .swiper-wrapper{height:100%}.mainvisual_right_slider .swiper-slide{height:100%;position:relative;overflow:hidden}.mainvisual_right_slider .swiper-slide img{height:100vh;max-width:none;width:auto;position:absolute;top:50%;left:50%;transform:translate(-50%, -50%)}.mainvisual_right_slider .catch{background-color:rgba(255,255,255,0.6);text-align:left;padding:1.5em;position:absolute;z-index:1;top:45%;left:-20%;line-height:1.6;color:#000}.mainvisual_right_slider .catch_text{font-size:2.1rem;letter-spacing:.2em}.mainvisual_right_slider .catch_subtext{font-size:2rem;letter-spacing:.1em}.mainvisual_right_slider .swiper-slide img{width:120%;height:auto}.mainvisual_right_slider .headding_wrap{font-size:2.1rem}.mainvisual_right_slider .subtitle_wrap{font-size:2rem}@keyframes down{0%{transform:translate(0, 0);height:60px}40%{transform:translate(0, 0);height:60px}80%{transform:translate(0, 60px);height:0}90%{transform:translate(0, -60px);height:0}100%{transform:translate(0, 0);height:60px}}.mainvisual_right_slider .swiper-pagination{width:auto;position:absolute;right:10px;left:auto}.mainvisual_right_slider .swiper-pagination-bullet{opacity:1;background:#fff;width:6px;height:6px;margin:0 7px;vertical-align:middle}.mainvisual_right_slider .swiper-pagination-bullet-active{background:transparent;border:2px solid #fff;width:12px;height:12px}@media only screen and (min-width: 1025px){.mainvisual_right_slider .catch{padding-left:100px;width:auto;transform:none}.mainvisual_right_slider .catch .headding_wrap,.mainvisual_right_slider .catch .heading{font-weight:bold}.mainvisual_right_slider .catch_text{font-size:4.2rem;margin-bottom:2rem}.mainvisual_right_slider .headding_wrap{font-size:4.2rem}}
.eat_cms .cta_fixed{padding:5rem 0 10rem}.eat_cms .cta_fixed .duplicatable-content{width:120px;margin:0 auto 15px}.eat_cms .cta_fixed::after{content:"レビュー画面もしくは公開画面で確認してください。\Aこのセクションは1ページにつき1つまでが望ましいです。";position:absolute;left:50%;bottom:0;width:100%;padding:2rem;background-color:#2C5DFF;font-size:1.6rem;text-align:center;color:#fff;transform:translateX(-50%);white-space:pre}body:not(.eat_cms) .cta_fixed{opacity:0;right:10px;padding:10px;border-radius:10px}body:not(.eat_cms) .cta_fixed .duplicatable-content:not(:last-child){margin-bottom:10px}body:not(.eat_cms) .cta_fixed .fixed_btn{width:50px}body:not(.eat_cms) .cta_fixed .image-frame div{display:flex}@media only screen and (max-width: 768px){body:not(.eat_cms) .cta_fixed{top:auto;right:5px;bottom:60px}body:not(.eat_cms) .cta_fixed .fixed_btn{width:40px}}.cta_fixed .duplicatable-container{display:flex;flex-direction:column}.cta_fixed .fixed_btn{text-align:center}.cta_fixed .image-frame{border-radius:10px;overflow:hidden}body:not(.eat_cms) section.fixed{z-index:2}body:not(.eat_cms) section.fixed .pos_fixed_section{animation:fadeFixedSection 0.3s ease-in forwards}body:not(.eat_cms) section.fixed .close_situation_bottom{animation:fadeOutFixedSection 0.3s ease-in forwards}body:not(.eat_cms) section.fixed .close_situation_top{animation:fadeOutFixedSection 0.3s ease-in forwards}@keyframes fadeFixedSection{0%{opacity:0}100%{opacity:1}}@keyframes fadeOutFixedSection{0%{opacity:1}100%{opacity:0}}
.title_all .text-side{max-width:850px;margin:auto;text-align:center}.title_all .text-side .text{text-align:left}.title_all .subtitle{letter-spacing:0}.title_all .editable_wrap,.title_all .headding_wrap{font-size:2.5rem}.title_all .subtitle_wrap{font-size:1.1rem}@media only screen and (min-width:768px){.title_all .text-side .text{text-align:center}.title_all .editable_wrap,.title_all .headding_wrap{font-size:3rem}.title_all .subtitle_wrap{font-size:1.6rem}}
.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}}
.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}}
.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}}
.h2_center .text-side{color:#fff;text-align:center}.h2_center .subtitle{letter-spacing:0px}.h2_center .headding_wrap{font-size:2rem}.h2_center .subtitle_wrap,.h2_center .editable_wrap{font-size:1.2rem}.h2_center .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:2rem}@media only screen and (min-width: 768px){.h2_center .headding_wrap{font-size:3.5rem}.h2_center .subtitle_wrap,.h2_center .editable_wrap{font-size:1.5rem}.h2_center .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:3.5rem}}
.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}
.fit_card_two{text-align:center}.fit_card_two .section_bg{position:absolute;height:100%;width:100%;top:0;left:0}.fit_card_two .image-side{position:relative}.fit_card_two .image-side_bg{width:100%}.fit_card_two .image-side_inner{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}.fit_card_two .image-side .image-frame-bg{padding-top:66%}.fit_card_two .image-side .frame-image{position:absolute!important;top:0;right:0;bottom:0;left:0;margin:auto}.fit_card_two .image-side_text{width:90%;color:#fff;z-index:2;margin-top:-1rem;padding:5rem 0;position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}.fit_card_two .image-side .headding_wrap,.fit_card_two .image-side .spacer-item_wrap:nth-child(1) .editable_wrap,.fit_card_two .image-side_text .title{font-size:3rem}.fit_card_two .image-side .editable_wrap{font-size:1.5rem}.fit_card_two .text-side{position:relative;width:90%;max-width:990px;margin:-2rem auto 0}.fit_card_two .text-side_content{margin-bottom:3rem;position:relative;padding:0 1.5rem 2.5rem}.fit_card_two .text-side_content:nth-child(2){margin-bottom:0}.fit_card_two .text-side_bg{position:absolute;height:100%;width:100%;top:0;left:0}.fit_card_two .text-side_inner{position:relative;z-index:2;max-width:310px;margin:auto}.fit_card_two .text-side .headding_wrap,.fit_card_two .text-side .section_h3{font-size:2.5rem}.fit_card_two .text-side .subtitle,.fit_card_two .text-side .subtitle_wrap{font-size:1.1rem}.fit_card_two .text-side .spacer-item_wrap:nth-child(3) .editable_wrap{font-size:2.5rem}.fit_card_two .text-side .spacer-item_wrap:nth-child(4) .editable_wrap{font-size:1.1rem}.fit_card_two .section_btn{position:relative}@media only screen and (min-width:768px){.fit_card_two .image-side .image-frame-bg{padding-top:38%}.fit_card_two .image-side_text{font-size:3rem;margin-top:-2.5rem}.fit_card_two .image-side .headding_wrap,.fit_card_two .image-side .spacer-item_wrap:nth-child(1) .editable_wrap,.fit_card_two .image-side_text .title{font-size:6rem}.fit_card_two .text-side{margin:-5rem auto 0;display:-ms-flexbox;display:flex;height:100%}.fit_card_two .text-side_content{width:49%;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:justify;justify-content:space-between;margin-bottom:0}.fit_card_two .text-side_content:nth-child(2){margin-left:2%}.fit_card_two .text-side_inner{max-width:340px;width:100%;height:100%}.fit_card_two .text-side .spacer-item_wrap:nth-child(4) .editable_wrap,.fit_card_two .text-side .subtitle,.fit_card_two .text-side .subtitle_wrap{font-size:1.2rem}}
.half_limited_height .image-side{position:relative}.half_limited_height .image-side_inner{padding-top:66%}.half_limited_height .image-side .image-frame-bg{position:absolute !important;top:0;right:0;bottom:0;left:0;margin:auto}.half_limited_height .text-side{position:relative}.half_limited_height .text-side_inner{width:100%;position:relative;z-index:2;max-width:280px;margin:auto}.half_limited_height .headding_wrap,.half_limited_height .section_h3{font-size:3rem}.half_limited_height .subtitle{font-size:1.1rem}.half_limited_height .editable_wrap{font-size:1.5rem}.half_limited_height .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:3rem}.half_limited_height .spacer-item_wrap:nth-child(2) .editable_wrap{font-size:1.1rem}@media only screen and (min-width: 768px){.half_limited_height .duplicatable-content_inner{display:flex}.half_limited_height .duplicatable-content:nth-child(even) .duplicatable-content_inner{flex-direction:row-reverse}.half_limited_height .duplicatable-content:nth-child(even) .text-side{padding:0 5rem 0 1.5rem}.half_limited_height .image-side,.half_limited_height .text-side{width:50%}.half_limited_height .image-side{max-height:330px}.half_limited_height .image-side_inner{height:100%}.half_limited_height .text-side{display:flex;align-items:center;flex-direction:column;padding:0 1.5rem 0 5rem}.half_limited_height .text-side .spacer-content{width:100%}.half_limited_height .text-side_inner{max-width:500px}.half_limited_height .section_btn{margin-left:0}.half_limited_height.reverse .duplicatable-content_inner{flex-direction:row-reverse}.half_limited_height.reverse .duplicatable-content:nth-child(even) .duplicatable-content_inner{flex-direction:row}.half_limited_height.reverse .duplicatable-content:nth-child(even) .text-side{padding:0 1.5rem 0 5rem}.half_limited_height.reverse .text-side{padding:0 5rem 0 1.5rem}.half_limited_height .section_h3,.half_limited_height .headding_wrap{font-size:3.5rem}.half_limited_height .subtitle{font-size:1.2rem}.half_limited_height .editable_wrap{font-size:1.5rem}.half_limited_height .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:3.5rem}.half_limited_height .spacer-item_wrap:nth-child(2) .editable_wrap{font-size:1.2rem}}
.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}}
body:not(.eat_cms) .block_link.u_none-hover{pointer-events:none}body:not(.eat_cms) .information_card .info-side_tel-text{pointer-events:none}.information_card .information_card-content{display:flex;justify-content:space-between}.information_card .text-side{width:40%}.information_card .text-side .headding_wrap,.information_card .text-side .section_h2{font-size:6.4rem;font-weight:bold}.information_card .text-side .subtitle_wrap,.information_card .text-side .subtitle{font-size:1.8rem}.information_card .text-side .letter_wrap{margin-top:30px;font-size:1.6rem}.information_card .text-side .letter{font-size:1.6rem}.information_card .info-side{width:50%;display:flex;flex-direction:column;gap:20px}.information_card .info-side_content-inner{position:relative;padding:50px 20px;display:flex;justify-content:center;align-items:center;width:100%;border:1px solid #333}.information_card .info-side-bg{position:absolute;width:100%;height:100%}.information_card .info-side .info-side_mail-text,.information_card .info-side .info-side_tel-text{position:relative;text-align:center;z-index:2}.information_card .info-side .headding_wrap,.information_card .info-side .section_h3{font-size:2rem}.information_card .info-side .cta-text_wrap,.information_card .info-side .cta-text{font-size:3.3rem;font-weight:bold;margin-top:20px}.information_card .info-side .microcopy_wrap,.information_card .info-side .microcopy{font-size:1.4rem}.information_card .editable{min-width:100px}@media only screen and (max-width: 1024px){.information_card .information_card-content{flex-direction:column;align-items:center}.information_card .text-side{text-align:center;width:100%}.information_card .text-side .headding_wrap,.information_card .text-side .section_h2{font-size:4rem}.information_card .info-side{margin-top:20px;width:100%}.information_card .info-side .headding_wrap,.information_card .info-side .section_h3{font-size:1.8rem}.information_card .info-side .cta-text_wrap,.information_card .info-side .cta-text{font-size:2.2rem}}
#footer-section{z-index:3}@media only screen and (max-width: 768px){.jobs #footer-section .detail-side{display:none}}.footer-block .footer_tp_generic .detail-side{bottom:0;transition:bottom .5s}.footer_tp_generic{background-color:#fff;font-size:1.4rem}.footer_tp_generic .editable a{color:#666}.footer_tp_generic .footer-company{position:relative}.footer_tp_generic .footer-company::before{content:"";position:absolute;top:0;left:50%;width:100%;height:1px;background-color:#ccc;transform:translateX(-50%)}.footer_tp_generic .logo-side{padding:2rem 0;text-align:center}.footer_tp_generic .logo{max-width:200px;margin:0 auto 2rem}.footer_tp_generic .logo img{width:auto;max-width:100%}.footer_tp_generic .logo div{display:inline}.footer_tp_generic .menu-side{display:none}.footer_tp_generic .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_tp_generic .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_tp_generic .detail-side_first .tel{line-height:1.4;letter-spacing:0}.footer_tp_generic .detail-side_first .tel a{position:absolute;width:100%;height:100%;top:0;left:0}.footer_tp_generic .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_tp_generic .detail-side_first .hour{font-size:1.2rem;display:none}.footer_tp_generic .detail-side_second{-ms-flex-positive:1;flex-grow:1}.footer_tp_generic .linker a{background-color:#E4A847}.footer_tp_generic .letter{letter-spacing:.1em}.footer_tp_generic .copy{border-top:1px solid #ccc;font-size:1.2rem;padding:2rem 0;text-align:center}.footer_tp_generic .sns-side{margin-bottom:2rem}.footer_tp_generic .sns-side .duplicatable-container{display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center}.footer_tp_generic .sns-side .duplicatable-content{max-width:70px;padding:0 1rem}.footer_tp_generic .section_btn a{white-space:nowrap}.footer_tp_generic .back-top{cursor:pointer;width:40px;height:40px;border-radius:20px;border:1px solid #E4A847;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_tp_generic .back-top .arrow:before{content:"▲";color:#E4A847}@media only screen and (min-width: 768px){.footer_tp_generic .footer-company{padding:3.5rem 0 2rem}.footer_tp_generic .footer-company_inner{display:flex;flex-wrap:wrap}.footer_tp_generic .logo{display:block;margin:0 auto}.footer_tp_generic .menu-block{order:3;width:100%}.footer_tp_generic .menu-side{display:block;padding:3rem 0 5rem}.footer_tp_generic .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_tp_generic .menu-side .duplicatable-content{width:auto;padding:0 1rem;font-size:1.4rem}.footer_tp_generic .logo-side{order:1;width:200px}.footer_tp_generic .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_tp_generic .detail-side_first{margin-bottom:4rem;font-size:1.8rem;text-align:right;display:block}.footer_tp_generic .detail-side_first .tel{font-size:2.2rem}.footer_tp_generic .detail-side_first .tel:after{content:none}.footer_tp_generic .detail-side_first .tel a{position:relative;pointer-events:none}.footer_tp_generic .detail-side_first .hour{display:block}.footer_tp_generic .detail-side_second{max-width:300px;margin-bottom:3rem}.footer_tp_generic .detail-side>div{margin-bottom:0;width:100%}.footer_tp_generic .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_tp_generic .sns-side{margin-bottom:0}.footer_tp_generic .sns-side .duplicatable-content{width:60px}.footer_tp_generic .section_btn{margin:auto 0 auto auto}.footer_tp_generic .back-top{bottom:80px}}@media only screen and (max-width: 768px){.footer_tp_generic .detail-side_first .tel{font-size:0 !important}.footer_tp_generic .detail-side_second .section_btn{max-width:none}.footer_tp_generic .detail-side_second .section_btn a{border-radius:0}}@media only screen and (min-width: 768px){_:-ms-lang(x)::-ms-backdrop,.footer_tp_generic .detail-side{align-items:center;margin:unset}_:-ms-lang(x)::-ms-backdrop,.footer_tp_generic .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: YakuHanJP, "Noto Sans", "Droid Sans", "Helvetica Neue", "Hiragino Kaku Gothic ProN", "Noto Sans Japanese", eatYuG, Meiryo, sans-serif;
    line-height: ;
    letter-spacing: em;
}#section-wrapper .letter{    font-family: YakuHanJP, "Noto Sans", "Droid Sans", "Helvetica Neue", "Hiragino Kaku Gothic ProN", "Noto Sans Japanese", eatYuG, Meiryo, sans-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}}

body {
  color: #fff;
}
#section-wrapper {
  background-color: #2D2D2D;
}

/* =============================================== */
/***** フォント設定 *****/
/* =============================================== */
/* 英語用のフォント設定 */
.font-en {
  font-family: 'Sans Serif' !important;
}
/* 日本語用のフォント設定 */
.font-ja,
body {
  font-family: 'Zen Kaku Gothic New', 'Noto Sans JP', 'Noto Sans' !important;
}

/* ============================================== */
/***** テキスト全般 *****/
/* ============================================== */
div.editable.letter:not(
  .title_line_wide .text-box .text.editable.letter,
  .three_cards_title_shift .text-side .subtitle_wrap *
) {
  font-size: 15px;
}
@media only screen and (min-width: 768px) {
    span.font-en:not( .section_h3 span.font-en, .information_card-content .editable_wrap span.font-en ) {
    font-size: 20px !important;
    font-weight: bold;
    color: #0078ed;
  }
.page-blog #section-wrapper .blog_posts_contetnts .post_item_link .notice {
    color: #fff;
}
}

/* ============================================== */
/***** 背景画像 *****/
/* ============================================== */
#section-wrapper::before {
  content: "";
  width: 100%;
  height: 100%;
  background: url(https://d1i7na1hjknxjq.cloudfront.net/uploads/storage/image/file/481973/optimized_DnpN-OYcM1fi2EDkc2V6_Q.png) no-repeat left top / cover;
  position: fixed;
  left: 0;
  top: 0;
  pointer-events: none;
}
/*.title_line_wide_reversible,
.table_light_builder_company,
.formapps.formapps_border_light {
  background-color: transparent !important;
}*/

/* ============================================== */
/***** FV *****/
/* ============================================== */
.mainvisual_mountain .catch_text,
.mainvisual_mountain .catch_subtext {
  font-weight: bold;
}

/* ============================================== */
/***** MV *****/
/* ============================================== */
/* 指定されたセクションID内の背景エリアをターゲットにします */
.h1_section {
  /* インラインスタイルの background-image: none を上書きするために !important を使用 */
  background-image: linear-gradient(
    115deg,                      /* ラインの角度（約115度） */
    transparent 30%,             /* 左側の余白 */
    rgba(255, 255, 255, 0.05) 25%, /* 1本目のライン開始（白の5%透明度） */
    rgba(255, 255, 255, 0.05) 42%, /* 1本目のライン終了 */
    transparent 42%,             /* ライン間の隙間開始 */
    transparent 45%,             /* ライン間の隙間終了 */
    rgba(255, 255, 255, 0.05) 45%, /* 2本目のライン開始 */
    rgba(255, 255, 255, 0.05) 47%, /* 2本目のライン終了 */
    transparent 47%              /* 右側の余白 */
  ) !important;

  /* ベースの黒色は既存の設定を引き継ぎますが、念のため指定 */
  background-color: rgb(23, 23, 23) !important; 
}

/* ============================================== */
/***** ヘッダー *****/
/* ============================================== */
.gnav_items * {
  color: #fff !important;
}
#global-nav .gnav_accordion_icon_builder .hamburger_top, #global-nav .gnav_accordion_icon_builder .hamburger_mid, #global-nav .gnav_accordion_icon_builder .hamburger_btm {
  display: inline-block;
  height: 3px;
  width: 100%;
  background-color: #fff;
  transition: opacity 0.1s, transform 0.3s;
}
#global-nav .gnav_accordion_icon_builder .gnav_pc .logo_side {
  height: 100%;
  flex: 0 0 auto;
  margin: 0 32px;
  padding: 2rem 0 !important;
}
/*** SP ***/
#global-nav .gnav_accordion_icon_builder .gnav_sp .logo_side img {
  height: 100%;
  width: auto;
  padding: 10px 0;
}
#global-nav .gnav_accordion_two_cta .gnav_sp .gnav-editable-contents .gnav-btn {
  width: 60%;
  color: #fff !important;
  margin-top: 12px;
  margin-left: 0;
  height: 40px;
  border-radius: 4px;
}
html.scroll-locked #global-nav .hamburger-box .gnav_bg {
  border-radius: 4px !important;
}

#global-nav .gnav_accordion_icon_builder .gnav_pc .nav_side {
  display: flex;
  /* flex-direction: unset; */
  align-items: flex-end;
  gap: 5px;
}
#global-nav .gnav_accordion_icon_builder .gnav_pc {
  padding: 0;
}
#global-nav .gnav_accordion_icon_builder .gnav_pc .gnav_items {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  height: 100%;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.gnav-editable-contents .gnav-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 120px;
  height: 40px;
  color: #fff;
  background-color: #005CB5;
  border-radius: 0;
  font-size: 15px;
  line-height: initial;
  margin-left: 0;
  margin-right: 1rem;
  font-weight: bold;
  border-radius: 4px;
  border: 1px solid #000;
}
.gnav-editable-contents .gnav-btn:last-child {
    background-image: linear-gradient(90deg, rgb(215 184 73), rgb(149 92 0));
}

/* --- 下線本体 (疑似要素) --- */
/* 1. リンクの基準位置設定
   HTMLの階層構造に合わせて詳細に指定し、優先度を高めています */
#global-nav .gnav_accordion_two_cta .gnav_pc .gnav_items li a,
.sidebar-box .gnav_items li a {
  position: relative !important; /* 下線の配置基準にするために必須 */
  display: inline-block !important; /* 高さを認識させる */
  text-decoration: none !important;
  padding-bottom: 5px !important;   /* 文字と下線の間の余白 */
  transition: opacity 0.3s;
}
/* 2. 下線（疑似要素）の初期状態 */
#global-nav .gnav_accordion_two_cta .gnav_pc .gnav_items li a::after,
.sidebar-box .gnav_items li a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px; /* 下線の太さ */
  background-color: transparent; /* 最初は透明 */
  transition: background-color 0.3s ease;
  z-index: 10; /* 他の要素に隠れないように前面へ */
}
/* 3. ホバー時 ＆ 現在ページ(active) で下線を表示
   HTMLにある .active クラスに反応するように設定 */
#global-nav .gnav_accordion_two_cta .gnav_pc .gnav_items li a:hover::after,
#global-nav .gnav_accordion_two_cta .gnav_pc .gnav_items li.active a::after,
.sidebar-box .gnav_items li a:hover::after,
.sidebar-box .gnav_items li.active a::after {
  background-color: #005CB5 !important; /* 青色を表示 */
  opacity: 1 !important;
}

/* =============================================== */
/***** フッター *****/
/* =============================================== */
/*** 電話番号（色が変わらないのでCSSで変更） ***/
.footer_tp_generic .editable a {
  color: #fff;
}

div.footer-company::before {
  display: none;
}
#footer-section .section-image_bg {
  background-color: #000;
}
@media only screen and (min-width: 1025px) {
  .footer_tp_generic .section_inner {
    max-width: 1200px;
  }
}
@media only screen and (min-width: 768px) {
  .footer_tp_generic .copy {
    justify-content: center;
  }
}
.footer_tp_generic .copy {
  font-size: 1.5rem;
  font-weight: bold;
}

/*** SP ***/
.footer_tp_generic .detail-side {
  background-color: #0c0c0c;
}

/* =============================================== */
/***** TOPに戻るボタン *****/
/* =============================================== */
/* ボタン本体 (通常時) */
.footer_tp_generic .back-top {
  cursor: pointer;
  width: 50px;
  height: 50px;
  border-radius: 4px;
  border: 2px solid #000;
  background-color: #fff;
  position: absolute;
  right: 30px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.footer_tp_generic .back-top .arrow:before {
  content: "▲";
  color: #000;
  font-size: 1.8rem !important;
}
::before, ::after {
  text-decoration: inherit;
  vertical-align: inherit;
}

/* =============================================== */
/***** ボタン *****/
/* =============================================== */
.section_btn a,
.linker a {
  /* 適応させたいコードのデザイン */
  background-color: #fff !important; /* 白背景 */
  border: 2px solid #005CB5 !important; /* 黒枠線 */
  color: #005CB5 !important; /* 黒文字 */
  letter-spacing: 0.2rem;
  font-size: 16px;
  font-weight: 600; 

  /* アニメーションに必要なプロパティを追加 */
  overflow: hidden; /* スライド要素をボタン内に隠す */
  position: relative; /* スライド要素の位置基準 */
  z-index: 1; /* スライド要素 (z-index: -1) の上にボタンのコンテンツを表示 */

  /* ★ トランジションで文字色がスムーズに変わるようにすると、より自然です */
  transition: color 0.5s; 

  /* (補足: ボタンとして機能させるため、displayやpadding, text-decorationなども追加すると良い) */
  /* display: inline-block;
  padding: 10px 20px;
  text-decoration: none;
  text-align: center;
  cursor: pointer; */
}
/* スライドアニメーションの要素 (a::after) */
.section_btn a::after,
.linker a::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;

  /* スライドの色 = ホバー時の背景色 (黒 #1D1D1D) 
  background: #005CB5 !important;
  border: 2px solid #fff !important;
*/

  /* 初期状態: スケールを0にして見えないようにする (左上を基点に横方向のみ0) */
  transform: scale(0, 1); 
  transform-origin: left top;

  /* アニメーションの速度とイージング */
  transition: transform 0.5s cubic-bezier(0.45, 0, 0.55, 1); 

  /* 最背面に配置 */
  z-index: -1;
}
/* ホバー時のデザイン (a:hover) */
.section_btn a:hover,
.linker a:hover {
  /* ホバー時は文字色を白 (スライドの色とコントラストを出す) に変更 */
  /* 背景色・枠線は:afterがカバーするので、ここで指定は不要です */
  color: #fff !important;
  /* 枠線は白にしたい場合 (任意) */
  border: 2px solid #fff;
  opacity: 1;
}
/* ホバー時にスライド要素を拡大 (a:hover::after) */
.section_btn a:hover::after,
.linker a:hover::after {
  /* 最終状態: スケールを1にして全体を表示 */
  transform: scale(1, 1);
}

/*** お問い合わせ：送信ボタン ***/
.formapps .section_btn {
  /* 親要素をボタンラッパーとして使う場合の予備指定（必要なら有効化） */
  position: relative;
  display: inline-block; /* ボタン幅を内包する */
  overflow: hidden; /* 背景がはみ出さないようにする */
}
.formapps .section_btn input {
  /* ベーススタイル（見た目は従来と同等に） */
  background-color: #fff; /* 背景はグラデで制御するため透明に */
  background-image: linear-gradient(90deg, #005CB5 0%, #005CB5 100%);
  background-repeat: no-repeat;
  background-size: 0% 100%; /* ホバーで横幅100%に広げる */
  background-position: left top;

  border: 2px solid #005CB5 !important;
  color: #005CB5 !important;
  letter-spacing: 0.2rem;
  font-size: 16px;
  font-weight: 600;
  padding: 0.7rem 1.2rem; /* 適宜調整 */
  cursor: pointer;

  /* レイヤー順とアニメーション */
  position: relative;
  z-index: 1; /* 背景（bg）より前にテキストを出す */
  transition: background-size 0.5s cubic-bezier(0.45, 0, 0.55, 1), color 0.22s;
  appearance: none; /* 標準プロパティ（互換性のため先に記述） */
  -webkit-appearance: none; /* ブラウザ標準の見た目を抑制（必要に応じて） */
}
.formapps .section_btn input:hover,
.formapps .section_btn input:focus {
  background-size: 100% 100%; /* 横方向にスライドして塗りつぶす */
  color: #fff !important;
  /* 内側に白いボーダーを追加（ホバー時の内側枠） */
  box-shadow: inset 0 0 0 1px rgba(255,255,255,1);
}
/* アクセシビリティ: キーボードでフォーカスしたときは内側白枠＋外側リングを表示 */
.formapps .section_btn input:focus {
  outline: none;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,1), 0 0 0 3px rgba(27, 117, 211, 0.12);
}

/* =============================================== */
/***** セクションタイトル *****/
/* =============================================== */
.h2_center {
  background-image: none !important;
}
/* 見出し下のラインを追加 */
.h2_center .text-side .spacer-item_wrap:first-child::after {
  content: ""; /* 疑似要素に必須 */
  display: block; /* ブロック要素として表示 */
  width: 100px;
  height: 3px; /* 線の太さ */
  background-image: linear-gradient(
    135deg,
    #005CB5,
    #1d1d1d
  );
  margin: 20px auto 0; /* 上に20pxの余白・左右中央揃え */
}

@media only screen and (max-width: 768px) {
  .h2_center .text-side .section_h2 {
    font-size: 2.5rem !important;
  }
}

/* =============================================== */
/***** TOP *****/
/* =============================================== */
/*** お知らせ, 新しい仲間大募集 ***/
.blog_unity,
.fit_card_two {
  background-color: transparent !important;
}
.fit_card_two .text-side_content .text-side_bg .image-frame-bg {
  border-radius: 1rem;
}
/* 画像が表示されている要素に対して、基準位置を設定します */
.fit_card_two .image-frame-bg .frame-image {
    position: relative;
    z-index: 0;
}
/* 画像の上に黒い膜（ベール）を作成して重ねます */
.fit_card_two .image-frame-bg .frame-image::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.3); /* 黒色の30%透明 */
    z-index: 1;
    pointer-events: none; /* クリックなどを透過させる設定 */
}
.fit_card_two .image-side_text .title {
  font-weight: bold;
}

/*** お問い合わせ（会社概要も含む） ***/
.information_card .info-side_content-inner {
  position: relative;
  padding: 50px 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  border: none;
}
.information_card .info-side_content-inner .image-frame-bg {
  border-radius: 1rem;
}

/* =============================================== */
/***** 広沢型枠とは *****/
/* =============================================== */
.half_slanted_line .text-side {
  background-color: #1d1d1d;
}
@media only screen and (min-width: 768px) {
  .half_slanted_line .text-side::after {
    background: -webkit-gradient(linear, right bottom, left top, color-stop(50%, transparent), color-stop(50.5%, #1d1d1d)) no-repeat top left / 100% 100%;
    background: -webkit-linear-gradient(bottom right, transparent 50%, #1d1d1d 50.5%) no-repeat top left / 100% 100%;
    background: linear-gradient(to top left, transparent 50%, #1d1d1d 50.5%) no-repeat top left / 100% 100%;
  }
}
@media only screen and (max-width: 768px) {
  .half_slanted_line .text-side::after {
    background: -webkit-gradient(linear, right bottom, left bottom, color-stop(50%, transparent), color-stop(50.5%, #1d1d1d)) no-repeat top left / 100% 100%;
    background: -webkit-linear-gradient(bottom right, transparent 50%, #1d1d1d 50.5%) no-repeat top left / 100% 100%;
    background: linear-gradient(to bottom left, transparent 50%, #1d1d1d 50.5%) no-repeat top left / 100% 100%;
  }
}

.title_line_vertical_writing {
  padding: 10rem 0;
  position: relative;
}

.standard_content_text_dup .text-box,
.standard_content_text_two .text-box {
  width: 100%;
  border: none;
  border-radius: 1rem;
  background-color: #1d1d1d;
  padding: 50px 20px;
  position: relative;
  display: flex;
  justify-content: center;
  overflow: hidden;
}

/* =============================================== */
/***** 事業内容 *****/
/* =============================================== */
.three_cards_title_sfiht .text-side {
  text-align: left;
  padding: 2rem;
  margin-top: 0;
  position: relative;
  z-index: 1;
  /*border: 2px solid #005CB5;*/
  border-radius: 1rem;
  background-color: #1d1d1d;
}

/* 1. 丸い画像の枠を基準位置に設定 */
#section_682639 .image-frame {
  position: relative !important;
  z-index: 0 !important;
  overflow: hidden !important;
}
/* 2. ドットなしのシンプルな黒いフィルターを作成 */
#section_682639 .image-frame::after {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;

  /* --- 変更点: ドット画像をなしにして、色のみ指定 --- */
  background-image: none !important; 
  
  /* 黒の不透明度（0.3 = 30%の濃さ） */
  /* 文字が見えにくい場合は、この数値を 0.4 や 0.5 に上げてください */
  background-color: rgba(0, 0, 0, 0.3) !important;

  /* 丸く切り抜く設定 */
  border-radius: 50% !important;
  
  z-index: 1 !important;
  pointer-events: none !important;
}
/* 3. 画像の上に重なるテキストを最前面へ */
#section_682639 .image_text {
  z-index: 2 !important;
  /* 文字に影をつけて、より読みやすくする（お好みで削除可） */
  text-shadow: 0 1px 3px rgba(0,0,0,0.8) !important;
}

/* =============================================== */
/***** 働く環境 *****/
/* =============================================== */
/*** メッセージ ***/
.title_line_wide_reversible {
  background-attachment: fixed;
}

/*** 先輩に聞く！ ***/
.alternating-backcolor .duplicatable-content:nth-child(odd) .dc-inner_bg .frame-image,
.alternating-backcolor .duplicatable-content .dc-inner_bg .frame-image {
  background-color: transparent;
}
/* 吹き出し本体（黒い箱） */
.alternating-backcolor .text-side {
    position: relative;       /* 矢印の基準位置 */
    background-color: #fff;   /* 背景：濃い黒 */
    padding: 30px;            /* 余白 */
    border-radius: 12px;      /* 角丸 */
    z-index: 1;
    width: 100%;              /* 幅を確保 */
    box-sizing: border-box;
}
/* 矢印（三角）の共通設定 */
.alternating-backcolor .text-side::before {
    content: "";
    position: absolute;
    top: 40px;                /* 矢印の高さ位置 */
    border-style: solid;
    width: 0;
    height: 0;
}
/* -------------------------------------------
   2. 【奇数番目】（1, 3, 5...個目）の設定
      配置：[画像] [テキスト] のまま
      矢印：左に出す
------------------------------------------- */
@media screen and (min-width: 768px) {
.alternating-backcolor .duplicatable-content:nth-child(odd) .duplicatable-content_inner {
    flex-direction: row; /* 通常の並び */
}
}
/* 矢印を左につける */
.alternating-backcolor .duplicatable-content:nth-child(odd) .text-side::before {
    left: -20px;
    border-width: 10px 20px 10px 0;
    border-color: transparent #fff transparent transparent;
}
/* レイアウト調整：画像とテキストの間の隙間 */
.alternating-backcolor .duplicatable-content:nth-child(odd) .text-side {
    margin-left: 20px; 
}
/* -------------------------------------------
   3. 【偶数番目】（2, 4, 6...個目）の設定
      配置：[テキスト] [画像] に反転させる
      矢印：右に出す
------------------------------------------- */
.alternating-backcolor .duplicatable-content:nth-child(even) .duplicatable-content_inner {
    flex-direction: row-reverse; /* ★ここで左右の配置を反転！ */
}
/* 矢印を右につける */
.alternating-backcolor .duplicatable-content:nth-child(even) .text-side::before {
    right: -20px;
    border-width: 10px 0 10px 20px;
    border-color: transparent transparent transparent #fff;
}
/* レイアウト調整：画像とテキストの間の隙間 */
.alternating-backcolor .duplicatable-content:nth-child(even) .text-side {
    margin-right: 20px; 
}
/* スマホ表示時の調整（スマホでは常に縦並び・画像上が自然なため） */
@media screen and (max-width: 767.9px) {
    .alternating-backcolor .duplicatable-content:nth-child(even) .duplicatable-content_inner {
        flex-direction: column; /* スマホなら縦並びに戻す */
    }
    /* スマホでは矢印を上に移動するなどの調整が必要な場合はここに追記 */
    .alternating-backcolor .text-side::before {
        display: none; /* スマホ等の狭い画面では矢印を消すのが無難 */
    }
    .alternating-backcolor .duplicatable-content:nth-child(odd) .text-side,
    .alternating-backcolor .duplicatable-content:nth-child(even) .text-side {
        margin-left: 0;
        margin-right: 0;
        margin-top: 20px;
    }
}
/*** 1日の流れ ***/
.table_stripe_light {
  background-color: transparent !important;
}

/* =============================================== */
/***** 採用情報 *****/
/* =============================================== */
.table_light,
.formapps {
  background-color: transparent !important;
}
.formapps .dummy_form_area .input_text input,
.formapps .dummy_form_area .input_text textarea,
.formapps .form_area .input_text input,
.formapps .form_area .input_text textarea {
  color: #fff;
}

/* =============================================== */
/***** 施工事例・新着情報 *****/
/* =============================================== */
/*** ヘッダーとページ内容の被り解消 ***/
@media only screen and (min-width: 1025px) {
  .fixed-wrapper {
    top: 120px !important;
    margin-bottom: 60px;
  }
}

.showcase_chart .banner_inner,
.blog_posts .banner_inner {
  padding: 2rem;
  text-align: center;
  background-color: #1d1d1d !important;
  box-shadow: none !important;
  border-radius: 1rem;
}
.showcase_chart .showcase_chart_title,
li.breadcrumb_item a,
.showcase_chart .post_popnews_title,
.showcase_chart .showcase_chart_sidebar_title,
.showcase_chart .banner_text,
.breadcrumb_item,
.blog_posts {
  color: #fff !important;
}
.showcase_chart .showcase_chart_popnews_item_title_wrap,
.blog_posts .blog_chart_popnews_item_title_wrap {
  justify-content: space-between;
  flex-direction: column-reverse;
}
.showcase_chart .showcase_chart_popnews_item_day,
.blog_posts .post_popnews_data {
  text-align: left !important;
}
@media (min-width: 767.9px) {
  .blog_posts .posts_title,
  .showcase_chart .showcase_chart_title {
    font-size: 36px !important;
    font-weight: 600 !important;
  }
  .showcase_chart .post_popnews_title,
  .showcase_chart .showcase_chart_sidebar_title {
    font-size: 24px !important;
  }
  h2.showcase_chart_item_title,
  h3.showcase_chart_popnews_item_title,
  h2.blog_post_title,
  h3.post_popnews_text {
    font-size: 20px !important;
    font-weight: bold;
  }
}
@media (max-width: 768px) {
  .blog_posts .posts_title,
  .showcase_chart .showcase_chart_title {
    font-size: 28px !important;
    font-weight: 600 !important;
  }
  .showcase_chart .post_popnews_title,
  .showcase_chart .showcase_chart_sidebar_title,
  .blog_posts .post_archives_title,
  .blog_posts .post_category_title,
  .blog_posts .post_popnews_title,
  .blog_posts .post_tag_title {
    font-size: 20px !important;
  }
  h2.showcase_chart_item_title,
  h3.showcase_chart_popnews_item_title,
  h2.blog_post_title,
  h3.post_popnews_text {
    font-size: 18px !important;
    font-weight: bold;
  }
  .showcase_chart .banner_text:nth-child(3),
  .blog_posts .banner_text:nth-child(3) {

    font-size: 15px !important;
  }
}

/*** ボタン ***/
.blog_posts .banner_text .banner_link,
.showcase_chart .banner_text .banner_link,
.banner_text .banner_link {
  /* 既存のスタイル */
  font-weight: 600;
  background: #fff !important;
  color: #005CB5 !important;
  border: 2px solid #005CB5;
  padding: 1rem 2rem !important;
  border-radius: 0.3rem;

  /* ★ アニメーション土台の追加 ★ */
  overflow: hidden; /* スライド要素をボタン内に隠す */
  position: relative; /* スライド要素の位置基準 */
  z-index: 1; /* スライド要素 (z-index: -1) の上にコンテンツを表示 */
  transition: color 0.5s; /* ホバー時に文字色がスムーズに変わるように */
}
/* スライドアニメーションの要素を定義 (全セレクタ共通) */
.blog_posts .banner_text .banner_link::after,
.showcase_chart .banner_text .banner_link::after,
.banner_text .banner_link::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;

  /* スライドの色 = ホバー時の背景色 */
  background: #005CB5;

  /* 初期状態: スケールを0にして見えないようにする (左上を基点に横方向のみ0) */
  transform: scale(0, 1); 
  transform-origin: left top;

  /* アニメーションの速度とイージング */
  transition: transform 0.5s cubic-bezier(0.45, 0, 0.55, 1); 

  /* 最背面に配置 */
  z-index: -1;
}
/* ホバー時のデザインとアニメーションの実行 (全セレクタ共通) */
.blog_posts .banner_text .banner_link:hover,
.showcase_chart .banner_text .banner_link:hover,
.banner_text .banner_link:hover {
  /* ホバー時は文字色と枠線を白に変更 */
  color: #fff !important;
  border-color: #fff;
  opacity: 1;
  /* background-color の変更は ::after が担うため不要 */
}

/* ホバー時にスライド要素を拡大 (アニメーション実行) */
.blog_posts .banner_text .banner_link:hover::after,
.showcase_chart .banner_text .banner_link:hover::after,
.banner_text .banner_link:hover::after {
  /* 最終状態: スケールを1にして全体を表示 */
  transform: scale(1, 1);
}

.blog_posts .banner_text ._color_,
.showcase_chart .banner_text ._color_,
.banner_text ._color_ {
  color: #0078ed !important;
}
.blog_posts .banner_text:nth-child(3),
.showcase_chart .banner_text:nth-child(3) {
  font-size: 15px !important;
  font-weight: 600;
}
/*** 新着情報 ***/
.breadcrumb_item {
  display: flex;
  place-items: center;
}
.blog_posts_index .blog_posts_sidebar {
  flex: 1 0 320px !important;
  margin: 0 0 0 84px;
}

/* =============================================== */
/***** 会社案内 *****/
/* =============================================== */
.table_light_generic {
  background-color: transparent !important;
}

/* =============================================== */
/***** e-thanks *****/
/* =============================================== */
@media only screen and (min-width: 1025px) {
  section:first-of-type .content {
    padding: 0;
  }
  .thanks_page .catch_text {
    padding: 4rem 0;
    font-size: 36px !important;
    font-weight: bold;
    color: #1d1d1d;
    text-align: center !important;
    letter-spacing: 0.1em
  }
}
.thanks_page {
  background-color: #F0F0F0;
}
.catch.text-side {
  margin: 0;
}
.thanks_page .catch {
  padding: 5%;
  background-color: #fff;
  border: 0.2rem;
  border: none !important;
}
.thanks_page .headding_wrap,
.thanks_page .subtitle_wrap {
  display: flex;
  justify-content: center;
}

.thanks_page .catch_text {
  font-weight: bold;
  color: #1d1d1d;
  text-align: center !important;
  letter-spacing: 0.1em
}
.thanks_page .subtitle_wrap .catch_subtext {
  color: #0078ed;
  font-weight: bold;
  text-align: center !important;
  letter-spacing: 0.1em
}

@media only screen and (max-width: 768px) {
  .thanks_contents .section_inner {
    padding: 20rem 3rem;
  }
}

/*20251224修正*/
/*btn----------------------*/
.section_btn a,
.linker a {
  /* 適応させたいコードのデザイン */
  background-color: #005CB5 !important; 
  border: 2px solid #fff !important; 
  color: #fff !important; 
}
.section_btn a:hover,
.linker a:hover {
  color: #005CB5 !important;
}
.section_btn a::after,
.linker a::after {
  background: #fff !important;
  border: 2px solid #005CB5 !important;
}
/*MV*/
.mainvisual_right_slider .text-side_bg {
  background: url(https://d1i7na1hjknxjq.cloudfront.net/uploads/storage/image/file/481981/optimized_CVjz4_yGUCDlrLEXuTDiJQ.jpg) no-repeat left top / cover;
}
.mainvisual_right_slider .text-side_bg .image-frame-bg{
background-color:transparent!important;
}

/* 20260213 修正 */
.form_area .form-item_title label {
    color: #fff;
}
.check_before_contact .text-side .show_btn {
    color: #000;
}
#section-wrapper .mainvisual_right_slider .catch {
    background-color: rgb(255 255 255 / 75%);
}
#global-nav .gnav_accordion_two_cta .gnav_sp .gnav-editable-contents .gnav-icon {
    margin-right: 25px;
}
#section-wrapper .blog_posts a,
#section-wrapper .blog_posts_body a,
#section-wrapper .blog_post_text,
#section-wrapper .blog_chart_popnews_item_title_wrap .blog_chart_popnews_item_category {
    color: #fff;
}
@media only screen and (min-width: 1025px) {
#section-wrapper .cta_fixed {
    top: 140px !important;
}
}