.h2_left_residence_blog{font-family:YakuHanMP, "Noto Serif", "Hiragino Mincho ProN", eatYuM, "Sawarabi Mincho", Meiryo, serif}.h2_left_residence_blog .subtitle{letter-spacing:0px}.h2_left_residence_blog .headding_wrap{font-size:2rem}.h2_left_residence_blog .subtitle_wrap,.h2_left_residence_blog .editable_wrap{font-size:1.2rem}.h2_left_residence_blog .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:2rem}@media only screen and (min-width: 768px){.h2_left_residence_blog .headding_wrap{font-size:3.5rem}.h2_left_residence_blog .subtitle_wrap,.h2_left_residence_blog .editable_wrap{font-size:1.5rem}.h2_left_residence_blog .spacer-item_wrap:nth-child(1) .editable_wrap{font-size:3.5rem}}
.blog_list{padding:4rem 0}.blog_list .section_inner{position:relative}.blog_list .main-column{margin-bottom:5rem}.blog_list_h3{text-align:center;font-size:1.5rem;margin-bottom:2rem;font-weight:normal}.blog_list_article{max-width:315px;margin:auto}.blog_list .article{border-bottom:1px solid #e9e8e8;margin-bottom:2.5rem;padding-bottom:1.5rem}.blog_list .article-thumb{margin-bottom:1.5rem}.blog_list .article-category{font-size:1.2rem;position:relative}.blog_list .article-category .category-color{position:absolute;width:30px;height:10px;background-color:#ff5721;left:-40px;top:50%;margin-top:-5px}.blog_list .article h1{font-size:1.7rem;font-weight:normal}.blog_list .article-date{font-size:1.1rem}.blog_list .article-link{display:none}.blog_list .article footer{padding-left:1rem}.blog_list .side-column{max-width:315px;margin:auto}.blog_list .side-column h4{font-size:1.5rem;font-weight:normal;padding-bottom:1rem;border-bottom:1px solid #e9e8e8}.blog_list .side-column_item{margin-bottom:5rem;padding-bottom:1rem}.blog_list .side-column_item.banner .duplicatable{padding-top:2rem}.blog_list .side-column_item.banner .duplicatable-content:nth-child(n+2){margin-top:1rem}.blog_list .side-column_item.archive .year{padding-top:2rem}.blog_list .side-column_item.archive .year>li{font-size:1.5rem}.blog_list .side-column_item.archive .year>li>a{display:block;width:100%;padding:2rem 1rem;position:relative}.blog_list .side-column_item.archive .year>li>a:after{content:"";border-top:1px solid #666;border-right:1px solid #666;width:8px;height:8px;transform:rotate(135deg);position:absolute;right:10px;top:50%;margin-top:-.8rem;transition:transform .3s}.blog_list .side-column_item.archive .year>li.open a:after{transform:rotate(-45deg);margin-top:-.5rem}.blog_list .side-column_item.archive .month{font-size:0;padding:0 1rem;border-top:1px solid #e9e8e8}.blog_list .side-column_item.archive .month li{font-size:1.4rem;display:inline-block;width:50%;padding:1rem;text-align:center;border-bottom:1px solid #e9e8e8}.blog_list .side-column_item.archive .month li:nth-child(even){border-left:1px solid #e9e8e8}.blog_list .side-column_item.archive .month li:nth-last-child(-n+2){border-bottom:none}.blog_list .side-column_item.archive .month li:last-child{border-bottom:1px solid #e9e8e8}.blog_list .side-column_item.category li{border-bottom:1px solid #e9e8e8}.blog_list .side-column_item.category a{position:relative;padding:2rem;display:block}.blog_list .side-column_item.category .category-color{position:absolute;width:14px;height:6px;background-color:#ff5721;left:0;top:50%;margin-top:-3px}.blog_list .side-column_item.tag ul{padding:2rem 0}.blog_list .side-column_item.tag li{display:inline-block;margin:0 1rem 1rem 0}.blog_list .side-column_item.tag a{font-size:1.4rem;padding:0 1.2rem;border:1px solid #e9e8e8;border-radius:3px;display:block;line-height:1.7;color:#999}.blog_list .pagination{text-align:center}.blog_list .pagination li{display:inline-block;padding:0 1rem;font-weight:bold}@media only screen and (min-width: 768px){.blog_list .section_inner{min-height:700px}.blog_list .column-container{display:flex}.blog_list .main-column{width:100%}.blog_list_article{max-width:none}.blog_list .article-category span:before{content:"";position:absolute;width:100vw;height:1px;top:5px;left:-100vw;background-color:inherit;display:block}.blog_list .article-link{display:block}.blog_list .side-column{width:270px;flex-shrink:0;margin:0 0 0 5rem}.blog_list .side-column_item{margin-bottom:4rem}.blog_list .side-column_item.archive .month{padding:0 0 1rem 2rem;border-top:none}.blog_list .side-column_item.archive .month li{width:100%;padding:0 0 1rem 0;border-bottom:none;text-align:left}.blog_list .side-column_item.archive .month li:nth-child(even){border-left:none}}
.footer_logo_under .footer-nav{display:flex;justify-content:space-between;padding:4.5rem 15px;max-width:990px;margin:0 auto}.footer_logo_under .nav-side .duplicatable-container{max-height:180px;display:flex;flex-direction:column;flex-wrap:wrap}.footer_logo_under .nav-side .duplicatable-content{width:180px;margin-top:5px;margin-right:10px}.footer_logo_under .contact-side .footer-info{text-align:center}.footer_logo_under .contact-side .letter{min-width:200px;max-width:320px}.footer_logo_under .contact-side .tel{font-size:2.5rem}.footer_logo_under .contact-side .tel .tel-small{font-size:1.5rem}.footer_logo_under .contact-side .section_btn{margin-top:15px}.footer_logo_under .footer-icon{padding:3rem 0 0;position:relative;z-index:1}.footer_logo_under .footer-icon_bg{position:absolute;width:100%;height:100%;top:0;left:0;z-index:-1}.footer_logo_under .footer-icon_inner{display:flex;justify-content:space-between;max-width:990px;margin:0 auto;padding:0 15px}.footer_logo_under .footer-icon .logo{width:200px;text-align:center}.footer_logo_under .footer-icon img{width:auto;max-width:100%}.footer_logo_under .sns-side{display:flex;align-items:center}.footer_logo_under .sns-side .duplicatable-container{display:flex;align-items:center;justify-content:center}.footer_logo_under .sns-side .duplicatable-content{padding:0 1rem;width:60px}.footer_logo_under .copy{text-align:center;padding:2rem 15px;max-width:990px;margin:0 auto}@media only screen and (max-width: 1024px){.footer_logo_under .footer-nav{flex-direction:column;justify-content:center;align-items:center;padding:4.5rem 15px}.footer_logo_under .nav-side{display:none;max-width:400px;text-align:center;margin-bottom:20px}.footer_logo_under .nav-side .duplicatable-container{max-height:none}.footer_logo_under .footer-icon_inner{flex-direction:column;align-items:center}.footer_logo_under .logo-side{padding:20px 0}.footer_logo_under .sns-side{padding:20px 0}}
@charset "UTF-8";#section-wrapper{background-color:#fff}#section-wrapper .headding{    font-family: YakuHanMP, 'Noto Serif', 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, serif;
    line-height: ;
    letter-spacing: em;
}#section-wrapper .subtitle{    font-family: YakuHanMP, 'Noto Serif', 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, serif;
    line-height: ;
    letter-spacing: em;
}#section-wrapper .letter{    font-family: YakuHanMP, 'Noto Serif', 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, serif;
    line-height: ;
    letter-spacing: em;
}@media only screen and (min-width:769px){}#loading{position:fixed;top:0;width:100%;height:100%;background:rgba(0,0,0,0.5);z-index:9999;display:none}#loading .loading_inner{width:100%;height:90px;position:absolute;top:50%}#loading .loading_inner .loader_animation,#loading .loading_inner .loader_animation:before,#loading .loading_inner .loader_animation:after{border-radius:50%;width:2.4rem;height:2.4rem;-webkit-animation-fill-mode:both;animation-fill-mode:both;-webkit-animation:load7 1.3s infinite ease-in-out;animation:load7 1.3s infinite ease-in-out}#loading .loading_inner .loader_animation{color:#fff;font-size:12px;margin:10px auto;position:relative;top:-30px;text-indent:-9999rem;-webkit-transform:translateZ(0);transform:translateZ(0);-webkit-animation-delay:-0.16s;animation-delay:-0.16s}#loading .loading_inner .loader_animation:before,#loading .loading_inner .loader_animation:after{content:'';position:absolute;top:0}#loading .loading_inner .loader_animation:before{left:-3.4rem;-webkit-animation-delay:-0.32s;animation-delay:-0.32s}#loading .loading_inner .loader_animation:after{left:3.4rem}@-webkit-keyframes load7{0%,80%,100%{box-shadow:0 2.45rem 0 -1.25rem}40%{box-shadow:0 2.45rem 0 0}}@keyframes load7{0%,80%,100%{box-shadow:0 2.45rem 0 -1.25rem}40%{box-shadow:0 2.45rem 0 0}}#loading .circle{position:fixed;top:50%;left:50%;width:50px;height:50px;margin:-25px 0 0 -25px;border-radius:50%;border:8px solid #f00;border-right-color:transparent;-webkit-animation:spin .8s linear infinite;animation:spin .8s linear infinite}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg);opacity:.2}50%{-webkit-transform:rotate(180deg);transform:rotate(180deg);opacity:1.0}100%{-webkit-transform:rotate(360deg);transform:rotate(360deg);opacity:.2}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg);opacity:.2}50%{-webkit-transform:rotate(180deg);transform:rotate(180deg);opacity:1.0}100%{-webkit-transform:rotate(360deg);transform:rotate(360deg);opacity:.2}}

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

  --ff-base: 'Bodoni Moda', 'Shippori Mincho', serif;

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

  --underline-height: 4px;
}

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

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




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

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

/* 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-color: var(--color-accent);
    position: absolute;
    left: 0;
    bottom: 0;
    transition: transform .35s ease;
    transform: scale(0, 1);
    transform-origin: left center;
  }

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

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

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

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

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

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

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

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

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

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

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


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


/* ==================================================================================================================
   表（テーブル）
================================================================================================================== */
/* th 背景色 */
.th.editable.letter {
  background-color: var(--color-main) !important;
}
/* 会社概要テーブル 左列見出し文字色 */
.table_light_generic .th.editable.letter,
.table_border_light .table_wrap .tr .th.editable.letter {
  color: var(--color-white) !important;
  font-weight: 700 !important;
}
/* 横線 */
.table_border_light .table_wrap .tr {
    width: 100%;
    border-bottom: 1px solid var(--color-main);
}

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

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

/*FV背景カバー*/
.mainvisual_mountain .section-image_bg.bg-cover {
  background-color: var(--color-sub) !important;
  opacity: .6;
}

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

/*FVタイトル*/
.mainvisual_mountain .catch .catch_text,
.mainvisual_mountain .catch .catch_text span {
    font-size: 60px !important;
    text-shadow: 0px 0px 4px var(--color-sub);
}
/*1024px以下：FVタイトルサイズ*/
@media only screen and (max-width: 1024px) {
  .mainvisual_mountain .catch .catch_text,
  .mainvisual_mountain .catch .catch_text span {
    font-size: 44px !important;
  }
}
/*767px以下：FVタイトルサイズ*/
@media only screen and (max-width: 767px) {
  .mainvisual_mountain .catch .catch_text,
  .mainvisual_mountain .catch .catch_text span {
    font-size: 27px !important;
  }
}


/*FVサブタイトル*/
.mainvisual_mountain .catch .catch_subtext {
    font-size: 27px;
    text-shadow: 0px 0px 4px var(--color-sub);
}
@media only screen and (max-width: 1024px) {
    .mainvisual_mountain .catch .catch_subtext {
        font-size: 18px;
    }
}


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

/* タイトル 下線 */
.h1_left.title_section .headding.section_h3.editable {
  border-bottom: 1px solid var(--color-white)!important;
}

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

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


/*各見出し サブタイトル位置調整*/
.h2_section .subtitle {
    padding-top: 14px;
}





/* ==================================================================================================================
   見出し左あしらいセクション
================================================================================================================== */
.simple_text_content .simple_text_title.editable.headding::before {
    background-color: var(--color-accent);
}

/*==================================================================================================================
   ハーフセクション
==================================================================================================================*/
/*サブタイトル サイズ調整*/
.half_fit_image.rv_section .subtitle.editable {
  font-size: 18px;
}

/*左線 点線*/
.half_fit_image.rv_section .section_h3.editable.headding {
  padding: 0.1rem 1rem;
  border-left: 2px solid var(--color-accent);
}

  /*SP時：テキストの幅を広げる*/
@media screen and (max-width:767px) {
  .half_limited_height .text-side_inner,
  .half_fit_image.rv_section .text-side_inner,
  .half_wide_limited_height .text-side_inner,
  .half .text-side_inner {
    max-width: 90%!important;
  }
}
.half .text-side_inner {
  max-width: max-content;
}


/* ==================================================================================================================
   ハーフセクション（画像下タイトル、テキスト）
================================================================================================================== */
.half_text_scroll .duplicatable-content_inner {
  background-color: var(--color-white);
}

/* ==================================================================================================================
   ハーフセクション（左タイトル、右テキスト）
================================================================================================================== */
/*あしらい 左線*/
@media only screen and (min-width: 768px) {
    .title_line_wide_reversible .text-box {
        border-left: 1px solid var(--color-sub);
        padding-left: 20px;
    }
}

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

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

/* ==================================================================================================================
   背景 ＋ カードセクション
================================================================================================================== */
/*背景カバー*/
.fit_card_three_image .image-side_bg .frame-image::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(27, 28, 37, .7);
}

/* ==================================================================================================================
   アイコンカード：枠・角・影
================================================================================================================== */
/*枠線スタイル調整*/
.card_icon .card_icon-item {
  border-radius: 0 !important;
}

/*PC時：常に上3下2*/
@media only screen and (min-width: 1686px) {
  .card_icon .card_icon-wrapper {
    max-width: 1240px;
    margin: auto;
  }
}

/* ==================================================================================================================
   画像 ＋ ボタンセクション
================================================================================================================== */
.tree_image_btn .frame-image.lazyloaded::before {
  position: absolute;
  content: "";
  background-color: rgba(27, 28, 37, .7);
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

/* ==================================================================================================================
   テキストボックス：枠・角・影
================================================================================================================== */
/*枠線スタイル変更・角丸*/
.standard_content_text_dup .text-box,
.standard_content_text_two .text-box {
  border: 1px solid var(--color-white);
  border-radius: 0 !important;
}
.information_card .info-side_content:first-child .info-side_content-inner,
.information_card .info-side_content:last-child .info-side_content-inner {
  border: 6px solid var(--color-white)!important;
  border-radius: 0 !important;
}

/*サブタイトル位置調整*/
.information_card .info-side .cta-text_wrap {
  margin-top: -20px!important;
  margin-bottom: 20px;
}

/* ==================================================================================================================
   数字円流れセクション
================================================================================================================== */
/*数字 スタイル調整*/
.new_list_box .text-side .number_wrap {
  color: var(--color-text);
  background-color: var(--color-white);
}

/*数字円とタイトルの位置を揃える*/
@media only screen and (min-width: 768px) {
    .new_list_box .text-side .title_wrap {
        margin-bottom: 1.5rem;
    }
}


/* ==================================================================================================================
   背景円、矢印セクション
================================================================================================================== */
/*背景要素削除*/
.title_line_wide_light .section-animation-wrap .element-1,
.title_line_wide_light .section-animation-wrap .element-2,
.title_line_wide_light .section-animation-wrap .element-3,
.title_line_wide_light .section-animation-wrap .element-4,
.title_line_wide_light .section-animation-wrap .element-5 {
  display: none;
}

/*背景円追加・スタイル調整*/
.title_line_wide .title-box::before {
    content: "";
    width: 17rem;
    height: 17rem;
    background-color: var(--color-accent);
    position: absolute;
    left: 46%;
    top: 40%;
    transform: translate(-50%, -50%);
    pointer-events: none;
    opacity: 0.25;
    z-index: -1;
    border-radius: 10rem;
}
@media only screen and (max-width: 767px) {
    .title_line_wide .title-box::before {
        width: 15rem;
        height: 15rem;
        left: 50%;
        top: 60%;
    }
}

/* ==================================================================================================================
   1日の流れセクション
================================================================================================================== */
/*縦線*/
.time_table .duplicatable-container:after {
    background: var(--color-sub);
}

/*横線*/
.time_table .time_text:before {
    background: var(--color-sub);
}

/*円、丸*/
.time_table .time_text:after {
    border: 2px solid var(--color-sub);
    background: var(--color-white);
}

/*==================================================================================================================
   POINTセクション
==================================================================================================================*/
/*テキストサイズ調整*/
.three_cards_title_sfiht .text-side .headding {
    font-size: 36px;
}

/*左縦線*/
.three_cards_title_sfiht .text-side {
    border-left: 1px solid var(--color-black);
    border-top: 1px solid var(--color-black);
    margin: 10px 0;
    padding: 20px;
}

/* ==================================================================================================================
   リストセクション（上画像下テキストエリア）
================================================================================================================== */
/*PC時：枠線追加、余白調整*/
@media only screen and (min-width: 768px) {
    #section_702798 .standard_content_dup .duplicatable-content,
    #section_702804 .standard_content_dup .duplicatable-content {
        padding: 10px;
        border: 1px solid var(--color-sub);
    }
    #section_702803 .standard_content_dup .duplicatable-content {
        padding: 10px;
        border: 1px solid var(--color-white);
    }
}





/* ==================================================================================================================
   下部ページリンクセクション（横長）
================================================================================================================== */
/*背景カバー*/
.wide_block_link_flex .image-frame-bg::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(27, 28, 37, .7);
}


/* ==================================================================================================================
   HOME
================================================================================================================== */
/*キャッチコピー*/
#section_702883 .section_h1.editable.headding font {
  font-size: 40px;
}

/*767px以下の場合*/
@media only screen and (max-width: 767px) {
  #section_702883 .section_h1.editable.headding font {
    font-size: 28px;
  }
}

/* ==================================================================================================================
   お問い合わせ
================================================================================================================== */
/*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-sub)!important;
    border: 1px solid var(--color-white);
    border-radius: 0 !important;
    position: relative;
    transition: .3s!important;
    z-index: 0;
}
/*#### お問い合わせフォーム ####*/
/*お問い合わせフォーム テキスト調整*/
#section_702542 label,
#section_702542 input,
#section_702542 textarea,
#section_702542 select {
  font-weight: 700;
  color: var(--color-text);
}

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

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

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

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

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

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

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

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

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

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

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

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


