.mainvisual_desk_generic{position:relative;height:100vh}.mainvisual_desk_generic .section_inner{height:100%;width:100%;position:absolute;top:0}.mainvisual_desk_generic .image-side{position:absolute;top:0;height:100%;width:100%}.mainvisual_desk_generic .swiper-wrapper{height:100%}.mainvisual_desk_generic .swiper-slide{height:100%;position:relative;overflow:hidden}.mainvisual_desk_generic .swiper-slide img{height:100vh;width:auto;max-width:none;position:absolute;top:50%;left:50%;transform:translate(-50%, -50%)}.mainvisual_desk_generic .catch{width:100%;text-align:center;padding:0 1.5rem;position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);line-height:1.4;z-index:1;font-family:"Josefin Sans";color:#fff}.mainvisual_desk_generic .catch_text{font-size:4rem;margin-bottom:2rem;line-height:1;text-shadow:0.5px 0.5px 5px #666}.mainvisual_desk_generic .catch_subtext{font-size:1.7rem;letter-spacing:.1em;font-family:YakuHanMP,"Times New Roman","Yu Mincho",YuMincho,"Hiragino Mincho ProN","Sawarabi Mincho",Meiryo,serif;text-shadow:0.5px 0.5px 5px #666}.mainvisual_desk_generic .headding_wrap{font-size:4.2rem}.mainvisual_desk_generic .subtitle_wrap{font-size:1.7rem}.mainvisual_desk_generic .one_page_scroll_btn{position:absolute;z-index:1;bottom:0;left:50%;transform:translate(-50%, 0);text-transform:uppercase;background-color:transparent;width:60px;height:auto;text-align:center;font-size:1rem;padding-bottom:4rem;cursor:pointer;overflow:hidden;letter-spacing:.2em}.mainvisual_desk_generic .one_page_scroll_btn span{transform:translate(0, 0);width:1px;height:35px;position:absolute;top:auto;left:50%;bottom:0;display:block}@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_desk_generic .swiper-pagination{width:auto;position:absolute;right:10px;left:auto}.mainvisual_desk_generic .swiper-pagination-bullet{opacity:1;background:#fff;width:6px;height:6px;margin:0 7px;vertical-align:middle}.mainvisual_desk_generic .swiper-pagination-bullet-active{background:transparent;border:2px solid #fff;width:12px;height:12px}@media only screen and (min-width: 768px){.mainvisual_desk_generic .catch_text{font-size:8rem}.mainvisual_desk_generic .catch_subtext{font-size:3rem}}@media only screen and (min-width: 1025px){.mainvisual_desk_generic .swiper-slide img{width:120%;height:auto}.mainvisual_desk_generic .catch_text{font-size:8rem}.mainvisual_desk_generic .catch_subtext{font-size:3rem;letter-spacing:.2em}.mainvisual_desk_generic .one_page_scroll_btn{padding-bottom:7rem}.mainvisual_desk_generic .one_page_scroll_btn span{height:60px;animation:down 3s ease-in;animation-iteration-count:infinite}.mainvisual_desk_generic .headding_wrap{font-size:14rem}.mainvisual_desk_generic .subtitle_wrap{font-size:2rem}}
.infomation_all_generic{text-align:center;font-size:1.4rem}.infomation_all_generic .section_inner{color:#fff}.infomation_all_generic .letter,.infomation_all_generic .editable_wrap{letter-spacing:.7px;font-size:1.4rem}.infomation_all_generic .info-side{font-size:1.2rem}.infomation_all_generic .info-side .tel-linker{font-size:2rem}.infomation_all_generic .section_btn{margin:3rem auto 0}.infomation_all_generic .section_btn .linker{font-size:1.5rem}.infomation_all_generic .section_btn a{background-color:#E4A947}.infomation_all_generic .headding_wrap,.infomation_all_generic .section_h3{font-size:3rem;color:#fff}.infomation_all_generic .subtitle_wrap,.infomation_all_generic .subtitle{font-size:1.5rem}.infomation_all_generic .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:3rem}.infomation_all_generic .spacer-item_wrap:nth-child(2) .editable_wrap{font-size:1.5rem}@media only screen and (min-width: 768px){.infomation_all_generic .info-side{display:flex;justify-content:center}.infomation_all_generic .section_btn{margin:0 0 0 5rem}}
#footer-section{z-index:3}@media only screen and (max-width: 768px){.jobs #footer-section .detail-side{display:none}}.footer-block .footer_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: 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 .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}}

/* ==================================================================================================================
   テーマ変数（色・フォント・共通サイズ）
   → 色替えやブランド変更はここだけ触ればOK
================================================================================================================== */
:root {
  --color-main: #49b06e;
  --color-main-B: #3b5cb8;
  --color-sub: #d9ffe6;
  --color-sub-B: #e9f0ff;
  --color-accent: #243972;
  --color-white: #ffffff;
  --color-text: #1a1a1a;
  --color-bg: #e9e9e9;
  --shadow-weak: rgba(0, 0, 0, .5);

  --ff-base: 'Noto Sans JP', sans-serif;

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

  --underline-height: 4px;
}

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

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

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

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

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

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






/* ==================================================================================================================
   ボタン
================================================================================================================== */
.section_btn a {
  background: var(--color-main) !important;
  border: none;
  color: #fff;
  text-align: center;
  text-decoration: none;
  outline: none;
  position: relative;
  z-index: 2;
  border-radius: 4px;
  font-weight: bold;
  overflow: hidden;
}

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

/* スライドレイヤ */
.section_name .section_btn a:not(#page_top_icon):after {
  position: absolute;
  z-index: -1;
  display: block;
  content: '';
  pointer-events: none;
  top: 0;
  left: 97%;
  width: 120%;
  height: 100%;
  transform: skewX(-40deg);
  background-color: var(--color-main-B);
  box-sizing: border-box;
  transition: all .3s;
}

/* ホバー */
.section_btn a:hover { opacity: 1; }
.section_btn a:hover::before { right: 3.3rem; }
.section_name .section_btn a:not(#page_top_icon):hover:after { left: -10%; }

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

/* ==================================================================================================================
   表（テーブル）
================================================================================================================== */
/* th 背景色 */
#section_678391 .th.editable.letter {
  background-color: var(--color-sub-B) !important;
}
/*コスモテック ページ*/
#section_679143 .th.editable.letter,
#section_679146 .th.editable.letter {
  background-color: var(--color-sub-B) !important;
}
/*ファイネル ページ*/
#section_679136 .th.editable.letter,
#section_679155 .th.editable.letter {
  background-color: var(--color-sub) !important;
}

/* 横線 */
.table_light .duplicatable-container,
.table_light_generic .duplicatable-container {
  border-top: 1px solid var(--color-text) !important;
}
.table_light .table_wrap .tr,
.table_light_generic .table_wrap .tr {
  width: 100%;
  border-bottom: 1px solid var(--color-text) !important;
}
.table_border_light .table_wrap .tr .th {
  padding: 1rem;
}

/*SP時：見出し位置調整*/
@media only screen and (max-width: 767px) {
  #content-wrapper #section-wrapper .table_separated_border .th {
    padding: 20px 0px 20px 20px;
  }
}

/*消防設備保守・点検 ページ 表*/
.table_stripe_light .duplicatable-content:nth-child(odd) {
    background-color: rgba(233, 240, 255, .5);
}

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

/*FV背景カバー*/
.mainvisual_step_animation .section-image_bg.bg-cover {
  background: linear-gradient(145deg, var(--color-main) 5%, var(--color-main-B) 95%);
  opacity: .5;
}

/*FVタイトル*/
.mainvisual_step_animation .catch .catch_text,
.mainvisual_step_animation .catch .catch_text span {
    text-shadow: 3px 3px 1px var(--color-text);
}
/*956px以下：FVタイトルサイズ*/
@media only screen and (max-width: 956px) {
    .mainvisual_step_animation .catch .catch_text,
    .mainvisual_step_animation .catch .catch_text span {
        font-size: 36px !important;
    }
} 
/*490px以下：FVタイトルサイズ*/
@media only screen and (max-width: 490px) {
    .mainvisual_step_animation .catch .catch_text,
    .mainvisual_step_animation .catch .catch_text span {
        font-size: 28px !important;
    }
} 
/*678px以下の場合*/
/*FVタイトル 段落ちしないようにする*/
@media only screen and (max-width: 678px) {
  .mainvisual_step_animation .catch .catch_text p:last-child b:last-child::before {
    content: "\A" ;
    white-space: pre ;
  }
}


/* タイトル */
.h1_left.title_section .headding.section_h3.editable,
.h1_left.title_section .headding.section_h3.editable span {
  font-size: 48px;
  font-weight: 700; /* 600px → 600 に修正 */
  text-shadow: 4px 4px 0 var(--shadow-weak);
}

/*サブタイトル*/
.h1_left.title_section .subtitle.editable,
.h1_left.title_section .subtitle.editable span {
  font-size: 18px;
  font-weight: 700; /* 600px → 600 に修正 */
}

/* 767px以下：タイトルサイズ調整 */
@media screen and (max-width: 767px) {
  .h1_left.title_section  .headding.section_h3.editable,
  .h1_left.title_section .headding.section_h3.editable span {
    font-size: 32px;
  }
}

/*背景カバー（一部）*/
#section_678404 .h1_left::before,
#section_678417 .h1_left::before,
#section_682079 .h1_left::before,
#section_682080 .h1_left::before,
#section_682081 .h1_left::before {
  content: "";
  width: 100%;
  height: 100%;
  background: linear-gradient(145deg, var(--color-main) 5%, var(--color-main-B) 95%);
  opacity: .6;
  position: absolute;
  left: 0;
  top: 0;
}

/*==================================================================================================================
   H2/H3セクション
==================================================================================================================*/
/*あしらい*/
.h2_center .section_h2.editable.headding::before,
.h2_center .section_h2.editable.headding::after {
  content: "";
  position: absolute;
  transform: translateY(-80%);
}

.h2_center .section_h2.editable.headding::before {
  left: 47%;
  top: 10%;
  width: 4rem;
  height: 4rem;
  border-radius: 30px;
  background-color: var(--color-main);
  opacity: .8;
  z-index: 2;
}

.h2_center .section_h2.editable.headding::after {
  left: 50%;
  top: 10%;
  height: 4rem;
  width: 4rem;
  background-color: var(--color-main-B);
  border-radius: 30px;
  opacity: .8;
}

/*SP時：あしらい位置・サイズ調整*/
@media screen and (max-width: 450px) {
  .h2_center .section_h2.editable.headding::before {
    left: 42%;
    top: 10%;
    width: 3rem;
    height: 3rem;
  }
  .h2_center .section_h2.editable.headding::after {
    left: 48%;
    top: 10%;
    height: 3rem;
    width: 3rem;
  }

  /*消防設備保守・点検 ページのみ 位置調整*/
  #section_679329 .h2_center .section_h2.editable.headding::before,
  #section_679329 .h2_center .section_h2.editable.headding::after {
    top: 4%;
  }
}



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

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

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

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

/* ==================================================================================================================
   テキストボックス枠あり
================================================================================================================== */
/*上下中央揃え*/
.standard_content_text_dup .duplicatable-container {
  align-items: center;
}

/*枠スタイル調整*/
.standard_content_text_dup .text-box,
.standard_content_text_two .text-box {
  border: none;
  border-radius: 4px;
}


/* ==================================================================================================================
   余白調整
================================================================================================================== */
/*SP時：余白調整*/
@media screen and (max-width: 767px) {
  .half_two_image_misaligned {
    padding: 0 0;
  }
}

/* ==================================================================================================================
   背景カバー
================================================================================================================== */
/*TOP ファイネル コスモテック 背景カバー*/
.half_two_image_misaligned.rv_section .half_two_fit_image_blockthreed_body .frame-image.lazyloaded::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(255, 255, 255, .2);
}

/*TOP 事業内容 背景カバー*/
.half_text_separate .frame-image.lazyloaded::before {
  content: "";
  width: 100%;
  height: 100%;
  background: linear-gradient(145deg, var(--color-main) 5%, var(--color-main-B) 95%);
  opacity: .6;
  position: absolute;
  left: 0;
  top: 0;
}

/* ==================================================================================================================
   アイコンサイズ調整
================================================================================================================== */
/*コスモテック ページ*/
.title_icon .image-frame {
    max-width: 240px;
}




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

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

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

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

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

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

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

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

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

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

/*アコーディオン 中央揃え*/
#global-nav .gnav_accordion_wide .gnav_pc .gnav_items li .dropdownSubMenu li {
    text-align: center;
}

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


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










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

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

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

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

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

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

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

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

/* 下部線 カラー調整*/
.footer_tp_generic .copy {
  border-top: 1px solid var(--color-main-B);
}

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

.standard_content_text_dup .duplicatable-content {
    align-self: stretch;
}

.standard_content_text_dup .text-box {
    align-self: stretch;
    height: 100%;
    align-items: flex-start;
}