.h1_center{text-align:center}.h1_center .headding_wrap,.h1_center .headding{font-size:3.5rem}.h1_center .subtitle_wrap{letter-spacing:0.15em;margin-top:.5rem}.h1_center .subtitle{font-size:inherit}.h1_center .editable_wrap{margin-top:2rem}
.title_line_wide_reversible .section_inner{text-align:left;padding:0 2.5rem}.title_line_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_line_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_line_wide_reversible .headding_wrap,.title_line_wide_reversible .headding{font-size:2.5rem}.title_line_wide_reversible .subtitle_wrap,.title_line_wide_reversible .subtitle{font-size:1.1rem;text-align:center}.title_line_wide_reversible .text-box{margin-top:50px}.title_line_wide_reversible .text-box .editable_wrap{font-size:1.6rem;color:#000}.title_line_wide_reversible .text-box .editable_wrap_title{text-align:center;font-size:2rem;color:#333;font-weight:bold}@media only screen and (min-width: 768px){.title_line_wide_reversible .section_h3{text-align:left}.title_line_wide_reversible .section_inner{display:flex;gap:15px}.title_line_wide_reversible.reverse .section_inner{flex-direction:row-reverse}.title_line_wide_reversible.reverse .title-box{padding-right:0;padding-left:2rem}.title_line_wide_reversible.reverse .section_btn{float:left}.title_line_wide_reversible .title-box{width:35%;padding-right:2rem}.title_line_wide_reversible .text-box{width:65%}.title_line_wide_reversible .text-box .spacer-item_wrap{width:100%}.title_line_wide_reversible .headding_wrap,.title_line_wide_reversible .headding{font-size:3rem}.title_line_wide_reversible .subtitle_wrap,.title_line_wide_reversible .subtitle{font-size:1.6rem;text-align:left}.title_line_wide_reversible .text-box .editable_wrap{font-size:1.5rem}.title_line_wide_reversible .text-box .editable_wrap_title{text-align:left}.title_line_wide_reversible .section_btn{float:right}.title_line_wide_reversible .section_btn a{font-family:YakuHanJP, Lato, 'Droid Sans', 'Noto Sans Japanese', 'Hiragino Kaku Gothic ProN', eatYuG, Meiryo, sans-serif}}
.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}}
#content-wrapper #section-wrapper .two_images_rounded{padding-bottom:50px}#content-wrapper #section-wrapper .two_images_rounded .section_inner{max-width:1200px;margin:0 auto}#content-wrapper #section-wrapper .two_images_rounded .duplicatable-content_inner{display:flex;text-align:left;padding-bottom:200px}#content-wrapper #section-wrapper .two_images_rounded .image-side,#content-wrapper #section-wrapper .two_images_rounded .text-side{width:50%;height:50%}#content-wrapper #section-wrapper .two_images_rounded .image-side_inner{display:flex;gap:32px;height:100%;padding-top:0}#content-wrapper #section-wrapper .two_images_rounded .image-frame_wrap .left-img{margin-top:80px}#content-wrapper #section-wrapper .two_images_rounded .text-side{display:flex;align-items:center}#content-wrapper #section-wrapper .two_images_rounded .text-side_inner{max-width:85%;margin:0 auto}#content-wrapper #section-wrapper .two_images_rounded .headding_wrap{margin:50px 0 80px}#content-wrapper #section-wrapper .two_images_rounded .headding_wrap,#content-wrapper #section-wrapper .two_images_rounded .section_h3{font-size:26px;font-family:游ゴシック体, YakuHanJP, “Noto Sans JP”, “Helvetica Neue”, Lato, “Droid Sans”, “Hiragino Kaku Gothic ProN”, eatYuG, Meiryo, sans-serif}#content-wrapper #section-wrapper .two_images_rounded .letter{font-size:16px}#content-wrapper #section-wrapper .two_images_rounded .image-side_inner{width:100%;font-size:0}#content-wrapper #section-wrapper .two_images_rounded .image-side_inner .image-frame_wrap{position:relative;width:calc(100% / 2);padding-top:70%;max-width:284px;height:460px}#content-wrapper #section-wrapper .two_images_rounded .image-side_inner .image-frame-bg{position:absolute !important;top:0;right:0;bottom:0;left:0;margin:auto;max-width:284px;height:460px}#content-wrapper #section-wrapper .two_images_rounded .image-side_inner .image-frame-bg .frame-image{border-radius:20px}#content-wrapper #section-wrapper .two_images_rounded .left-frame-wrap::before{position:absolute;top:160px;right:0;bottom:0;left:0;margin:auto;width:100%}#content-wrapper #section-wrapper .two_images_rounded .left-frame-wrap .edit-btns{top:65% !important}#content-wrapper #section-wrapper .two_images_rounded .editable_wrap{font-size:16px}@media only screen and (max-width: 1024px){#content-wrapper #section-wrapper .two_images_rounded .section_inner{max-width:100%;padding:0 64px}#content-wrapper #section-wrapper .two_images_rounded .duplicatable-content_inner{gap:48px;padding-bottom:80px}#content-wrapper #section-wrapper .two_images_rounded .image-side_inner{width:100%;height:77vh;position:relative}#content-wrapper #section-wrapper .two_images_rounded .image-side_inner .image-frame_wrap{padding-top:100%;width:100%;max-width:368px}#content-wrapper #section-wrapper .two_images_rounded .image-side_inner .image-frame-bg{max-width:368px;height:597px;top:145px}#content-wrapper #section-wrapper .two_images_rounded .image-frame_wrap .left-img{margin-top:0}#content-wrapper #section-wrapper .two_images_rounded .image-side .second-img{position:absolute;top:0px}#content-wrapper #section-wrapper .two_images_rounded .left-img,#content-wrapper #section-wrapper .two_images_rounded .right-img{position:absolute;width:100%;opacity:0;animation:change-img-anim 8s infinite}#content-wrapper #section-wrapper .two_images_rounded .left-img{animation-delay:0s}#content-wrapper #section-wrapper .two_images_rounded .right-img{animation-delay:4s}@keyframes change-img-anim{0%{opacity:0}50%{opacity:1}100%{opacity:0}}}@media only screen and (max-width: 767px){#content-wrapper #section-wrapper .two_images_rounded .section_inner{padding:10px}#content-wrapper #section-wrapper .two_images_rounded .image-side_inner{height:85vh}#content-wrapper #section-wrapper .two_images_rounded .duplicatable-content_inner{padding:0}}@media only screen and (max-width: 480px){#content-wrapper #section-wrapper .two_images_rounded .section_inner{padding:35px 32px 0}#content-wrapper #section-wrapper .two_images_rounded .duplicatable-content_inner{flex-direction:column;gap:0}#content-wrapper #section-wrapper .two_images_rounded .text-side,#content-wrapper #section-wrapper .two_images_rounded .image-side{width:100%}#content-wrapper #section-wrapper .two_images_rounded .text-side{margin-bottom:48px}#content-wrapper #section-wrapper .two_images_rounded .image-side_inner{height:80vh}#content-wrapper #section-wrapper .two_images_rounded .headding_wrap,#content-wrapper #section-wrapper .two_images_rounded .section_h3{font-size:20px}#content-wrapper #section-wrapper .two_images_rounded .headding_wrap{margin:0px 0 48px}#content-wrapper #section-wrapper .two_images_rounded .editable_wrap{font-size:16px}#content-wrapper #section-wrapper .two_images_rounded .image-side_inner .image-frame_wrap{max-width:100%;height:505px}}@media screen and (max-width: 380px){#content-wrapper #section-wrapper .two_images_rounded .image-side_inner{height:105vh}}
.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}}
#content-wrapper #section-wrapper .three_cards_dot_separator{padding-top:80px}#content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-container{display:flex;flex-wrap:wrap;justify-content:center;padding:0 2rem}#content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content{width:33.33333%;border-right:2px dotted #ccc;padding:32px;margin-bottom:60px}#content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content:last-child{border-right:none}#content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content:nth-of-type(3n){border-right:none}#content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content:nth-child(1){border-right:2px dotted #ccc}#content-wrapper #section-wrapper .three_cards_dot_separator .section_inner{max-width:1000px}#content-wrapper #section-wrapper .three_cards_dot_separator .text-side{text-align:left;padding:2rem 0;position:relative;z-index:1}#content-wrapper #section-wrapper .three_cards_dot_separator .text-side .headding{font-size:24px;letter-spacing:.2rem;font-family:Hiragino Kaku Gothic ProN, W6;text-align:center;margin-bottom:64px}#content-wrapper #section-wrapper .three_cards_dot_separator .text-side .headding_wrap{margin-bottom:1rem}#content-wrapper #section-wrapper .three_cards_dot_separator .text-side .text_wrap{font-size:16px}#content-wrapper #section-wrapper .three_cards_dot_separator .editable.letter{font-size:16px;color:#334137}#content-wrapper #section-wrapper .three_cards_dot_separator .letter_wrap_basic{font-size:16px;font-family:游ゴシック体, Medium}#content-wrapper #section-wrapper .three_cards_dot_separator .image-side{width:30%;margin:0 auto;padding-top:2.25vw;position:relative;z-index:1}#content-wrapper #section-wrapper .three_cards_dot_separator .image-side .frame-image{padding-top:100%}@media only screen and (max-width: 1024px){#content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-container{padding:0 0.5rem}#content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content{width:32%;padding:1rem 0;padding:64px 32px}#content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content:last-child{padding-bottom:0}#content-wrapper #section-wrapper .three_cards_dot_separator .text-side .headding{line-height:32px}#content-wrapper #section-wrapper .three_cards_dot_separator h3{margin:15px 0}}@media only screen and (max-width: 767px){#content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content{width:100%;border-right:none;border-bottom:2px dotted #ccc;padding:0}#content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content:nth-child(1){border-right:none}#content-wrapper #section-wrapper .three_cards_dot_separator .text-side{margin-top:0}}@media only screen and (max-width: 480px){#content-wrapper #section-wrapper .three_cards_dot_separator .section_inner{padding:0 32px}#content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content{margin-bottom:50px}#content-wrapper #section-wrapper .three_cards_dot_separator .letter_wrap_basic{font-size:16px;margin-bottom:48px}#content-wrapper #section-wrapper .three_cards_dot_separator .text-side{margin-top:0}#content-wrapper #section-wrapper .three_cards_dot_separator .text-side .headding{margin-bottom:40px}}
.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}}
.table_light{font-size:1.5rem}.table_light .duplicatable-container{border-top:1px solid rgba(0,0,0,0.5)}.table_light .table_wrap{text-align:left}.table_light .table_wrap .duplicatable-content{width:100%}.table_light .table_wrap .tr{width:100%;border-bottom:1px solid rgba(0,0,0,0.5)}.table_light .table_wrap .tr .th,.table_light .table_wrap .tr .td{padding:2rem 1rem;vertical-align:middle;white-space:normal}.table_light .table_wrap .tr .th{background-color:rgba(0,0,0,0.1)}@media only screen and (min-width: 768px){.table_light .table_wrap{width:100%}.table_light .table_wrap .duplicatable-content{display:table}.table_light .table_wrap .tr{display:table}.table_light .table_wrap .tr .th,.table_light .table_wrap .tr .td{display:table-cell}.table_light .table_wrap .tr .th{width:30%}.table_light .table_wrap .tr .td{width:70%;max-width:350px}}
.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}}
.eat_cms .time_text:after{left:-39px !important}.time_table{color:#333;background:#e5f3fb}.time_table .duplicatable-container{position:relative;padding:40px 0}.time_table .duplicatable-container:after{z-index:1;position:absolute;top:0;bottom:0;left:0;display:block;width:2px;background:#333;content:""}.time_table .duplicatable-container>.duplicatable-content{position:relative;padding:0 30px;z-index:4}.time_table .duplicatable-container-nest .duplicatable-content:last-child{padding-bottom:14px}.time_table .time_text{position:relative;margin:0 0 20px;padding:10px 20px 10px 30px;font-size:2.2rem;line-height:1;letter-spacing:0.2rem}.time_table .time_text:after{position:absolute;z-index:2;left:-37px;display:block;width:16px;height:16px;border:2px solid #111;border-radius:16px;background:#fff;content:""}.time_table .time_text:before{position:absolute;right:-30px;left:-8px;bottom:0;display:block;height:2px;background:#333;content:""}.time_table .description_container{background:#fff;padding:3rem;letter-spacing:0.1rem;margin:0 0 3rem}.time_table .description_text{font-size:1.6rem;letter-spacing:.2rem}.time_table .image-side{margin:2.5rem 0 0 0;position:relative;z-index:1}.time_table .image-side .frame-image{padding-top:51.2%}@media only screen and (max-width: 767px){.time_table .duplicatable-container>.duplicatable-content{padding-right:0px}.time_table .time_text{font-size:1.8rem}.time_table .description_text{font-size:1.4rem}}
.time_table_image_rounded{color:#333;padding:30px 0}.time_table_image_rounded .section_inner{max-width:890px;margin:0 auto;counter-reset:number 0;position:relative}.time_table_image_rounded .duplicatable-content_inner{position:relative}.time_table_image_rounded .duplicatable-content_inner::before{content:"";position:absolute;top:22px;left:-6px;background:radial-gradient(circle farthest-side, #ccc, #ccc 30%, transparent 30%, transparent);background-size:20px 20px;content:'';display:inline-block;height:100%;width:20px}.time_table_image_rounded .duplicatable-content{position:relative;margin-bottom:73px;border:none !important}.time_table_image_rounded .duplicatable-content:last-child{padding-bottom:14px}.time_table_image_rounded .duplicatable-content::before{content:'';position:absolute;display:inline-block;bottom:0px;left:55%;width:500px;width:95%;height:3px;-webkit-transform:translateX(-50%);transform:translateX(-50%);background-color:#ccc}.time_table_image_rounded .duplicatable-content:last-child::before{display:none}.time_table_image_rounded .duplicatable-content::after{content:'';position:absolute;top:100%;left:55%;transform:translateX(-50%);border-top:33px solid #ccc;border-right:47px solid transparent;border-left:47px solid transparent}.time_table_image_rounded .duplicatable-content:last-child::after{display:none}.time_table_image_rounded .content_container{position:relative}.time_table_image_rounded .content_container::before{counter-increment:number 1;content:counter(number);position:absolute;top:-7px;left:-28px;font-size:32px;font-family:ヒラギノ角ゴ StdN;width:63px;height:63px;background-color:#ccc;border-radius:50%;display:flex;justify-content:center;align-items:center;color:#fff}.time_table_image_rounded .description_container{display:flex;position:relative;padding:0 0 64px;margin:0 0 0px 80px;letter-spacing:0.1rem;gap:80px}.time_table_image_rounded .description_container .time_table_txt{width:50%}.time_table_image_rounded .description_text{font-family:游ゴシック体, YakuHanJP, “Noto Sans JP”, “Helvetica Neue”, Lato, “Droid Sans”, “Hiragino Kaku Gothic ProN”, eatYuG, Meiryo, sans-serif;font-size:16px;letter-spacing:.2rem}.time_table_image_rounded h4{font-family:游ゴシック体, YakuHanJP, “Noto Sans JP”, “Helvetica Neue”, Lato, “Droid Sans”, “Hiragino Kaku Gothic ProN”, eatYuG, Meiryo, sans-serif;font-size:26px;font-weight:bold;margin-bottom:48px}.time_table_image_rounded .image-side{width:50%}.time_table_image_rounded .image-side .image-frame-bg{height:auto}.time_table_image_rounded .image-side .frame-image{padding-top:66%;border-radius:16px}@media only screen and (max-width: 1024px){.time_table_image_rounded .section_inner{width:100%}.time_table_image_rounded .duplicatable-content:last-child{margin-bottom:0}.time_table_image_rounded .duplicatable-content::before{left:57.5%;width:500px;width:85%}.time_table_image_rounded .duplicatable-content_inner::before{left:36px}.time_table_image_rounded .description_container{padding:0 0 48px;margin-left:40px;flex-direction:column;gap:0}.time_table_image_rounded .description_container::before{left:50%;border-top:30px solid #ccc;border-right:40px solid transparent;border-left:40px solid transparent}.time_table_image_rounded .description_container .time_table_txt,.time_table_image_rounded .description_container .image-side{width:100%}.time_table_image_rounded .content_container{width:90%;margin-left:auto}.time_table_image_rounded .content_container::before{left:-9.1%}.time_table_image_rounded .image-side .frame-image{padding-top:50%}.time_table_image_rounded h4{margin-bottom:3%}.time_table_image_rounded .description_text{margin-bottom:48px}}@media only screen and (max-width: 767px){.time_table_image_rounded .section_inner{width:85%}.time_table_image_rounded .duplicatable-content_inner::before{left:-16px}.time_table_image_rounded .content_container{width:100%}.time_table_image_rounded .content_container::before{left:-38px}.time_table_image_rounded .description_container{margin-left:64px}}@media only screen and (max-width: 480px){.time_table_image_rounded .section_inner{width:100%;padding:0 24px}.time_table_image_rounded .description_container{padding:0 0 32px;margin:0 0 48px 64px}.time_table_image_rounded .description_container::before{border-top:20px solid #ccc;border-right:30px solid transparent;border-left:30px solid transparent}.time_table_image_rounded .duplicatable-content::before{height:3px;bottom:0;left:60%}.time_table_image_rounded .duplicatable-content::after{left:60%;border-top:22px solid #ccc;border-right:32px solid transparent;border-left:32px solid transparent}.time_table_image_rounded .duplicatable-content_inner::before{top:10px;left:10px;height:97%}.time_table_image_rounded h4{font-size:24px}.time_table_image_rounded .description_text{font-size:16px;margin-bottom:24px}.time_table_image_rounded .content_container::before{font-size:24px;width:50px;height:50px;top:-4px;left:-5px}}
.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}}
.contact_policy .intro{margin-bottom:2rem}.contact_policy .intro .headding_wrap{text-align:center}.contact_policy .intro .section_h3{font-size:3rem}.contact_policy .text-side{background-color:#fefefe;border:1px solid #dedede;position:relative}.contact_policy .text-side .overlay{height:100%;width:100%;background-color:rgba(222,222,222,0.6);position:absolute;top:0;left:0}.contact_policy .text-side .show_btn{display:inline-block;background-color:#efefef;border:1px solid #ccc;padding:1rem;position:absolute;top:50%;left:50%;transform:translate(-50%, -50%)}.contact_policy .text-side .text_wrap{font-size:inherit;padding:1rem;height:200px;overflow-y:scroll}
.check_before_contact .intro{margin-bottom:2rem}.check_before_contact .intro .headding_wrap{text-align:center}.check_before_contact .intro .section_h3{font-size:3rem}.check_before_contact .text-side{background-color:#fefefe;border:1px solid #dedede;position:relative}.check_before_contact .text-side .overlay{height:100%;width:100%;background-color:rgba(222,222,222,0.6);position:absolute;top:0;left:0}.check_before_contact .text-side .show_btn{display:inline-block;background-color:#efefef;border:1px solid #ccc;padding:1rem;position:absolute;top:50%;left:50%;transform:translate(-50%, -50%)}.check_before_contact .text-side .text_wrap{font-size:inherit;padding:1rem;height:200px;overflow-y:scroll}
.formapps .form_area .form-item .awesomplete{display:block;width:100%;padding:0 !important}.form_area .awesomplete li mark{display:inline-block;padding:0 0 0 0.5rem;background:#f2f2f2;border-radius:0.3em}.form_area .awesomplete>ul{box-shadow:unset;overflow:hidden}.form_area .awesomplete>ul>li{color:#333}.form_area .awesomplete>ul>li::after{content:"";position:absolute;left:0;right:0;bottom:0;margin:auto;width:100%;height:2px;background-color:#ccc;transition:transform 0.2s;transform:scaleX(0)}.form_area .awesomplete>ul>li:first-child{border-radius:0.3em 0.3em 0 0}.form_area .awesomplete>ul>li:last-child{border-radius:0 0 0.3em 0.3em}.form_area .awesomplete>ul>li:hover{background-color:#f2f2f2}.form_area .awesomplete>ul>li:hover mark{background-color:#f2f2f2}.form_area .awesomplete>ul>li:hover::after{transform:scaleX(1)}
.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}}
body:not(.eat_cms) .block_link.u_none-hover{pointer-events:none}.eat_cms .information_half_wide .info-wrapper{margin-bottom:80px}.information_half_wide.reverse .info-wrapper{flex-direction:row-reverse}@media only screen and (max-width: 1024px){.information_half_wide.reverse .info-wrapper{flex-direction:column-reverse}}.information_half_wide .info-wrapper{display:flex;height:480px}.information_half_wide .link-side{width:50%;position:relative}.information_half_wide .link-side .duplicatable{width:100%;height:100%}.information_half_wide .link-side .duplicatable-container{width:100%;height:100%;display:flex;flex-direction:column}.information_half_wide .link-side .duplicatable-content{width:100%;height:25%;flex-grow:1}.information_half_wide .link-side_inner{position:relative;width:100%;height:100%;border-top:1px solid #151E2F}.information_half_wide .link-side_bg{position:absolute;top:0;left:0;width:100%;height:100%}.information_half_wide .link-side_text{padding:0 60px;position:absolute;top:50%;transform:translateY(-50%);color:#151E2F}.information_half_wide .link-side .headding_wrap,.information_half_wide .link-side .section_h3{font-size:3.2rem}.information_half_wide .link-side .letter_wrap,.information_half_wide .link-side .letter{font-size:1.8rem}.information_half_wide .contact-side{width:50%;position:relative}.information_half_wide .contact-side_inner{width:100%;height:100%}.information_half_wide .contact-side_bg{position:absolute;top:0;left:0;width:100%;height:100%}.information_half_wide .contact-side_text{text-align:center;font-size:4rem;position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);color:#151E2F;width:90%}.information_half_wide .contact-side .letter{font-weight:bold}.information_half_wide .contact-side .microcopy_wrap{font-size:1.5rem}.information_half_wide .contact-side .microcopy{font-size:1.5rem}.information_half_wide .editable{min-width:100px}@media only screen and (max-width: 1024px){.information_half_wide .info-wrapper{flex-direction:column}.information_half_wide .link-side{width:100%;height:50%}.information_half_wide .link-side .duplicatable-container{flex-direction:row;flex-wrap:wrap}.information_half_wide .link-side .duplicatable-content{width:50%;height:auto}.information_half_wide .link-side .duplicatable-content:nth-child(2n) .link-side_inner{border-left:1px solid #151E2F}.information_half_wide .link-side .headding_wrap,.information_half_wide .link-side .section_h3{font-size:2rem}.information_half_wide .link-side .letter_wrap,.information_half_wide .link-side .letter{font-size:1.5rem}.information_half_wide .link-side_text{padding:0 8px;text-align:center;left:50%;transform:translate(-50%, -50%);width:100%}.information_half_wide .contact-side{width:100%;height:50%}.information_half_wide .contact-side_text{font-size:2.5rem}}
#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: 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}}

body {
     color:#1d1d1d;
     font-size:15px;
    font-weight:400;
  font-family: "Noto Sans JP", sans-serif;
}

    .fit_card_two_image .text-side .spacer-item_wrap:nth-child(4) .editable_wrap, .fit_card_two_image .text-side .subtitle, .fit_card_two_image .text-side .subtitle_wrap {
        font-size: 1.5rem;
    }

#content-wrapper #section-wrapper .two_images_rounded .headding_wrap, #content-wrapper #section-wrapper .two_images_rounded .section_h3,
#section-wrapper .headding,
#section-wrapper .subtitle,
#section-wrapper .letter {
  font-family: "Noto Sans JP", sans-serif;
}

.title_line_wide_reversible .text-box .editable_wrap_title {
     color:#1d1d1d;
}

/* =============================================== */
/***** フォント設定 *****/
/* =============================================== */
/* 英語用のフォント設定 */
.font-en {
  font-family: 'Noto Sans JP', 'Noto Sans' !important;
}
/* 日本語用のフォント設定 */
/*
.font-ja,
body {
  font-family: 'Noto Sans JP', 'Noto Sans' !important;
}
*/
/* ============================================== */
/***** 背景画像 *****/
/* ============================================== */
#section-wrapper::before {
  content: "";
  width: 100%;
  height: 100%;
  background: url(https://d1i7na1hjknxjq.cloudfront.net/uploads/storage/image/file/474122/optimized_NVTuaTQvsh4vyGvZFY5Dmg.jpg) no-repeat left top / cover;
  position: fixed;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: .7;
}
.title_line_wide_reversible,
.table_light_builder_company,
.formapps.formapps_border_light {
  background-color: transparent !important;
}
#section_665666, #section_665673 {
  background-color: #1d1d1d;
}

/* ============================================== */
/***** FV *****/
/* ============================================== */
/*** スクロール ***/
.mainvisual_standard .one_page_scroll_btn {
  color: #FFA836;
  font-weight: 400;
}
.mainvisual_standard .one_page_scroll_btn span {
  background-color: #FFA836;
}

.mainvisual_standard {
  /* ::after 疑似要素を配置するための基準点として必要 */
  position: relative;
}
/*** テキストの位置 ***/
.mainvisual_standard .catch {
 width: fit-content;
    top: auto;
    bottom: 3em;
    left: 5%;
    transform: none;
}

@media only screen and (min-width: 768px) {
  /* 波型を生成するための疑似要素 */
  .mainvisual_standard::after {
    content: '';
    position: absolute;
    bottom: 0; /* セクションの下端に配置 */
    left: 0;
    width: 100%; /* 幅は常に100% */
        height: 32em;
    background-color: #F8FCFC; /* 波の色 */

    /* --- ここから下が波型を生成するマスク処理 --- */
  
    /* * 上部が波型で、下が塗りつぶされた形状のSVGをマスクとして使用
         * fill='%23000000' は黒（不透明）
   */
    -webkit-mask-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 100' preserveAspectRatio='none'%3e%3cpath d='M0,50 C360,0 1080,100 1440,50 L1440,100 L0,100 Z' fill='%23000000'%3e%3c/path%3e%3c/svg%3e");
    mask-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 100' preserveAspectRatio='none'%3e%3cpath d='M0,50 C360,0 1080,100 1440,50 L1440,100 L0,100 Z' fill='%23000000'%3e%3c/path%3e%3c/svg%3e");

    /* マスクを要素全体 (width: 100%, height: 100px) に引き伸ばす */
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;

    /* マスクは繰り返さない */
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
  }
}
@media only screen and (max-width: 768px) {
  /* 波型を生成するための疑似要素 */
  .mainvisual_standard::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 400px; /* 波の高さ (適宜調整してください) */
    background-color: #F8FCFC; /* 波の色 */

    -webkit-mask-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 100' preserveAspectRatio='none'%3e%3cpath d='M0,50 C360,25 1080,75 1440,50 L1440,100 L0,100 Z' fill='%23000000'%3e%3c/path%3e%3c/svg%3e");
    mask-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 100' preserveAspectRatio='none'%3e%3cpath d='M0,50 C360,25 1080,75 1440,50 L1440,100 L0,100 Z' fill='%23000000'%3e%3c/path%3e%3c/svg%3e");

    /* マスクの共通設定 */
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
  }
}

/* =============================================== */
/***** ヘッダー *****/
/* =============================================== */
#global-nav .gnav_pc .gnav_items li a {
  font-size: 1em;
  font-weight: 700;
  position: relative;
  text-decoration: none;
  padding-bottom: 8px; /* ● のためのスペース */
}
#global-nav .gnav_pc .gnav_items li a::after {
  content: "" !important;
  position: absolute;
  width: 6px;
  height: 6px;
  background: #FFA836;
  border-radius: 50%;

  bottom: 0;
  left: calc(50% - 3px); 

  /* アニメーション: 初期状態は透明 */
  opacity: 0; 
  transition: opacity 0.3s ease-out; /* opacity だけをアニメーション */
}
#global-nav .gnav_pc .gnav_items li a::after {
  content: "" !important;
  position: absolute;
  width: 6px;
  height: 6px;
  background: #FFA836;
  border-radius: 50%;
  bottom: 0;
  left: calc(50% - 3px);

  /* --- アニメーションの初期状態 --- */
  opacity: 0; /* 1. 初期状態は透明 */
  transform: translateY(-5px); /* 2. 初期状態は 5px 上 に移動 */

  /* 3. opacity と transform の両方を 0.3秒 かけて変化させる */
  transition: opacity 0.3s ease-out, transform 0.3s ease-out;
}
/* 滞在ページ (li.active) で ● を表示 */
/* ホバーで ● を表示 */
#global-nav .gnav_pc .gnav_items li.active a::after,
#global-nav .gnav_pc .gnav_items li a:hover::after {
  opacity: 1; /* 1. 表示状態は不透明 */
  transform: translateY(0); /* 2. 表示状態は Y軸0px (本来の位置) に戻す */
}
/* 滞在ページ・ホバー時の「文字色」のスタイル */
#global-nav .gnav_pc .gnav_items li.active a,
#global-nav .gnav_pc .gnav_items li a:hover {
  color: #FFA836 !important; /* !important でインラインスタイルを上書きします */
}
/* ヘッダーお問い合わせボタン */
#global-nav .gnav_accordion_wide .gnav_pc .gnav_items li:not(.gnav-submenu):last-child {
  background: #6AB659 !important;
}
#global-nav .gnav_accordion_wide .gnav_pc .gnav_items li:not(.gnav-submenu):last-child a {
  color: #fff !important;
}
#global-nav .gnav_accordion_wide .gnav_pc .gnav_items li:not(.gnav-submenu):last-child a:hover {
  opacity: 1 !important;
}
#global-nav .gnav_accordion_wide .gnav_pc .gnav_items li {
  padding: 0 1.6vw;
}

/* SP用ナビゲーション */
#global-nav .gnav_accordion_icon .gnav_sp .logo_side {
  height: 60px;
  flex: 1 0 0;
  padding: 0.5rem 0;
  margin: 10px;
}
@media only screen and (max-width: 768px) {
  .gnav_draewr .logo_side {
    height: 60px;
    flex: 1 0 0;
    padding: 1.5rem 0 !important;
  }
}
#global-nav .gnav_accordion_wide .gnav_sp .logo_side img {
  height: 100%;
  width: 100%;
}
#global-nav .gnav_sp .gnav_items {
  text-align: center;
}
#global-nav .gnav_accordion_wide .gnav_sp .gnav_items a {
  width: fit-content;
}
.sidebar-box .gnav_items li:last-child a {
  background-color: #6AB659 !important; /* 緑色の背景 */
  color: #ffffff !important; /* 文字色を白に */
  border-radius: 1rem;
  padding: 10px 20px;
  display: block;
  text-align: center; /* テキストを中央揃えに */
  margin: 10px auto; /* 上下に10px */
}

/* =============================================== */
/***** フッター *****/
/* =============================================== */
div.footer-company::before {
  display: none;
}
.footer_tp_generic {
  background-color: #6AB659;
}
@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;
}

/* =============================================== */
/***** TOPに戻るボタン *****/
/* =============================================== */
/* ボタン本体 (通常時) */
.footer_tp_generic .back-top {
  cursor: pointer;
  width: 50px;
  height: 50px;
  border-radius: 25px;
  border: 2px solid #FFA836;
  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: #FFA836;
  font-size: 1.8rem !important;
}
::before, ::after {
  text-decoration: inherit;
  vertical-align: inherit;
}

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

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

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

  /* (補足: ボタンとして機能させるため、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%;

  /* スライドの色 = ホバー時の背景色 (オレンジ #FFA836) */
  background: #FFA836 !important;
  border: 3px solid #fff !important;
  border-radius: 1rem;

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

  /* アニメーションの速度とイージング */
  transition: transform 0.3s 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: 1px 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, #FFA836 0%, #FFA836 100%);
  background-repeat: no-repeat;
  background-size: 0% 100%; /* ホバーで横幅100%に広げる */
  background-position: left top;

  border: 3px solid #FFA836 !important;
  border-radius: 1rem;
  color: #1d1d1d !important;
  letter-spacing: 0.2rem;
  font-size: 16px;
  font-weight: bold;
  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.36s;
  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 3px 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 .section_h2 {
  font-weight: 600;
}
/* 見出し下のラインを追加 */
.h2_center .subtitle_wrap::after {
  content: ""; /* 疑似要素に必須 */
  display: block; /* ブロック要素として表示 */
  width: 100px;
  height: 3px; /* 線の太さ */
  background-color: #FFA836;
  margin: 20px auto 0; /* 上に20pxの余白・左右中央揃え */
}

.title_line_wide_reversible .editable_wrap.headding_wrap {
  position: relative; /* 疑似要素(::before)の基準点となります */
  z-index: 1; /* テキストが背後の円に隠れないようにします */
}
.title_line_wide_reversible .editable_wrap.headding_wrap::before {
  content: ""; /* 疑似要素に必須 */
  display: block;
  background-color: #D4E5D0;
  width: 180px; 
  height: 180px;
  border-radius: 50%;
  position: absolute;
  top: 20%;
  left: 10%;
  transform: translate(-50%, -50%);
  z-index: -1; 
}

.half_text_scroll .image-side {
  position: relative;
}
@media only screen and (min-width: 767px) {
  .half_text_scroll .duplicatable-content:nth-child(odd) .image-side::after {
    content: "";
    display: block;
    background-color: #D4E5D0;
    width: 80px; 
    height: 80px;
    border-radius: 50%;
    position: absolute;
    bottom: -10%; 
    left: 20%;
    transform: translate(-50%, -50%);
    z-index: 1;
  }
  .half_text_scroll .duplicatable-content:nth-child(even) .image-side::after {
    content: "";
    display: block;
    background-color: #D4E5D0;
    width: 80px; 
    height: 80px;
    border-radius: 50%;
    position: absolute;
    bottom: -10%; 
    right: 5%;
    transform: translate(-50%, -50%);
    z-index: 1;
  }
}
@media only screen and (max-width: 768px) {
  .half_text_scroll .duplicatable-content .image-side::after {
    content: "";
    display: block;
    background-color: #D4E5D0;
    width: 60px; 
    height: 60px;
    border-radius: 50%;
    position: absolute;
    bottom: -10%; 
    left: 32%;
    transform: translate(-50%, -50%);
    z-index: 1;
  }
}
.half_text_scroll .image-side-name,
.half_text_scroll .image-side-position {
  position: relative;
  z-index: 2;
}

/* =============================================== */
/***** ページ下部のページリスト *****/
/* =============================================== */
.information_half_wide .link-side_inner {
  position: relative;
  width: 100%;
  height: 100%;
  border-top: none;
  border-bottom: 3px solid #FFA836;
  background-color: #F9F5EF;
}
.information_half_wide .contact-side_inner .image-frame-bg {
    background-color: #ffa836 !important;
}

/* =============================================== */
/***** TOP *****/
/* =============================================== */
.half_fit_image:not(
  #section_668836 .half_fit_image,
  #section_668844 .half_fit_image,
  #section_668867 .half_fit_image,
  #section_668868 .half_fit_image,
  #section_668869 .half_fit_image,
  #section_668870 .half_fit_image,
),
.standard_content_text_dup {
  background-color: transparent !important;
}

.standard_content_text_dup .text-box,
.standard_content_text_two .text-box {
  width: 100%;
  border: none;
  border-radius: 2rem;
  padding: 50px 20px;
  position: relative;
  display: flex;
  justify-content: center;
  overflow: hidden;
  background-color: #fff;
}
.fit_card_two_image .image-frame-bg {
  border-radius: 2rem;
  background-color: #fff !important;
}

.fit_card_two_image .image-side_bg .frame-image {
  position: relative;
}
.fit_card_two_image .image-side_bg .frame-image::after {
  content: ''; 
  
  /* 親要素(.frame-image)の全域に広げる */
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(249, 245, 239, 0.5);
}

/*** お問い合わせ ***/
.information_card .info-side_content-inner {
  border: none;
  border-radius: 2rem;
    background-color: #ffa836;
}

/* =============================================== */
/***** 菊文建設について *****/
/* =============================================== */
#section_668800 .h2_center {
  background-image: none !important;
}

.new_standard_content_two .duplicatable-content_inner {
  background-color: #fff;
  border-radius: 2rem;
}
.new_standard_content_two .image-side img {
  border-radius: 2rem 2rem 0 0;
}

/* =============================================== */
/***** 民間土木工事 *****/
/* =============================================== */
.circle_picture .section_inner .image-frame-bg {
  border-radius: 2rem;
}

/* =============================================== */
/***** 採用情報 *****/
/* =============================================== */
@media only screen and (min-width: 767px) {
  #content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content:nth-child(1),
  #content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content {
    width: 40%;
    border-right: none;
    padding: 32px;
    margin: 0 4rem;
    margin-bottom: 0;
  }
  #content-wrapper #section-wrapper .three_cards_dot_separator .image-side {
    width: 25%;
    margin: 0 auto;
    padding-top: 2.25vw;
    position: relative;
    z-index: 1;
  }
  #content-wrapper #section-wrapper .three_cards_dot_separator .duplicatable-content {
    border-right: none;
  }
}

.formapps .form_area .send_btn {
  display: flex;
}

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

/* =============================================== */
/***** テーブル *****/
/* =============================================== */
.table_light .table_wrap .tr .th,
.table_light_generic .table_wrap .tr .th {
  background-color: #F8F2E9;
}
.formapps .form_area .form-item_title label {
  color: #1d1d1d;
  font-weight: 400;
}

/* =============================================== */
/***** 施工事例・新着情報 *****/
/* =============================================== */
.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_inner,
.showcase_chart  .banner_inner {
  background-color: #F8F2E9 !important;
  box-shadow: none !important;
  border-radius: 1rem;
}

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

  /* ★ アニメーション土台の追加 ★ */
  overflow: hidden; /* スライド要素をボタン内に隠す */
  position: relative; /* スライド要素の位置基準 */
  z-index: 1; /* スライド要素 (z-index: -1) の上にコンテンツを表示 */
  transition: color 0.2s; /* ホバー時に文字色がスムーズに変わるように */
}
/* スライドアニメーションの要素を定義 (全セレクタ共通) */
.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: #FFA836;

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

  /* アニメーションの速度とイージング */
  transition: transform 0.2s 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: #6AB659 !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;
}

/* =============================================== */
/***** サイトマップ *****/
/* =============================================== */
.title_text_generic02 .text-side .text,
.title_text_generic02 .text-side .text * {
  text-align: center;
  font-size: 1.8rem !important;
  font-weight: 500 !important;
  line-height: 4.5rem;
}

/* =============================================== */
/***** 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: #F8F2E9;
}
.catch.text-side {
  margin: 0;
}
.thanks_page .catch {
  padding: 5%;
  background-color: #fff;
  border-radius: 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: #6AB659;
  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;
  }
}

/* =============================================== */
/***** その他 *****/
/* =============================================== */
.frame-image:not(
  .fit_card_two_image .image-side_bg .frame-image
) {
  border-radius: 2rem;
}
.card_three .text-side .image-frame-bg {
  border-radius: 0 0 2rem 2rem;
}
.card_four .image-side .frame-image,
.card_three .image-side .frame-image {
  border-radius: 2rem 2rem 0 0 !important;
}
.card_four .text-side .image-frame-bg {
  border-radius: 0 0 2rem 2rem !important;
}

@media only screen and (min-width: 767px) {
  .mainvisual_standard .catch_subtext {
    font-size: 20px;
  }
/*
  .fit_card_two_image .text-side .subtitle,
  .half_fit_image .subtitle,
  .subtitle,
  .subtitle * {
    font-size: 15px;
    font-weight: 400;
  }
*/
  .h1_center .headding {
    font-weight: 400;
  }
}
@media only screen and (max-width: 768px) {
/*
  .mainvisual_standard .catch_subtext,
  .subtitle,
  .font-ja:not(.blog_posts .posts_title, .showcase_chart .showcase_chart_title),
  .info-side_mail-text .section_h3 .font-ja,
  .info-side_content .section_h3 .font-ja {
    font-size: 15px !important;
  }
  .section_h2 .font-ja {
    font-size: 28px !important;
    font-weight: bold;
  }
  .section_h3,
  .section_h3 .font-ja:not(
    .info-side_mail-text .section_h3 .font-ja,
    .info-side_content .section_h3 .font-ja,
    .information_half_wide .section_h3 .font-ja,
    .card_four .section_h3 .font-ja
  ),
  .cta-text * {
    font-size: 24px !important;
    font-weight: bold;
  }
  .information_half_wide .section_h3 .font-ja {
    font-size: 20px;
  }
  .card_four .section_h3 .font-ja {
    font-size: 18px;
    font-weight: 600;
  }
*/
}

/*20251119修正*/
.title_line_wide_reversible .text-box {
    position: relative;
    z-index: 1;
}

#section_668898 .mainvisual_standard .catch_text {
    font-size: clamp(2.5rem, 4.5vw, 5rem) ;
}

.information_card .info-side .info-side_mail-text, .information_card .info-side .info-side_tel-text {
    color:#fefefe;
}

.information_card .info-side .cta-text_wrap, .information_card .info-side .cta-text {
    margin-top: 10px;
}

.information_half_wide .contact-side .letter {
    color: #fefefe;
}

@media only screen and (min-width: 768px) {
    .half_fit_image .subtitle {
        font-size: 1.5rem;
    }
}

@media only screen and (max-width: 1024px) {
    .information_half_wide .link-side .duplicatable-content:nth-child(2n) .link-side_inner {
        border-left: 3px solid #ffa836;
    }
}

@media (max-width:767.9px) {
.h2_section .section_h2,
.h2_center .section_h2,
.title_line_wide_reversible .headding,
.information_card .text-side .section_h2 {
        font-size: 3rem;
    }

.table_light_generic,
#content-wrapper #section-wrapper .two_images_rounded .letter,
.half_fit_image .subtitle,
.half .subtitle,
.information_card .text-side .letter,
.standard_content_text_two .letter,
.standard_content_text_dup .letter,
.title_line_wide_reversible .text-box .editable_wrap,
.h2_section .subtitle {
    font-size: 1.5rem;
}

#section_668898 .mainvisual_standard .catch_text {
    margin-bottom: 1rem;
}

#section_668898 .mainvisual_standard .catch_subtext {
    font-size: 1.5rem;
}
}