.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-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}}

/* =============================================== */
/***** 全体 *****/
/* =============================================== */
/* 英語用 */
.font-en {
  /* 欧文フォントを先に書き、後ろに日本語フォントを予備で置く */
  font-family: 'Quicksand', 'Zen Maru Gothic', sans-serif !important; 
}

/* 日本語用 */
.font-ja {
  font-family: 'Zen Maru Gothic', 'Noto Sans JP', sans-serif !important;
}

.section_btn {
  padding: 0;
}


/* =============================================== */
/***** フォント *****/
/* =============================================== */
.h2_section .section_h2,
.h2_center .subtitle {
  font-weight: 500;
}
/*** フォントサイズ ***/
@media only screen and (max-width: 768px) {
  /* .h2_section .section_h2 {
    font-size: 2.5rem !important;
  } */
  .h2_center .subtitle {
    font-size: 1.5rem !important;
  }
  .half_slanted_line .section_h3 {
    font-size: 28px !important;
    text-align: center;
  }
  .subtitle .font {
    font-size: 15px !important;
  }
}
.blog_unity .blog-side .blog_title {
  font-weight: bold;
  color: #fff;
}
@media only screen and (max-width: 1024px) {
  .blog_unity .blog-side .blog_title {
    font-size: 16px;
  }
  .blog_unity .blog-side .blog_meta {
    font-size: 15px !important;
  }
}
.blog_unity .blog-side .date,
.blog_unity .blog-side .category {
  font-size: 1em;
  font-weight: bold;
  color: #fff;
}


/* =============================================== */
/***** FV *****/
/* =============================================== */
/* テキストを囲む親要素の調整 */
.mainvisual_mountain .section_inner {
  /* 必要に応じて位置調整 */
  display: flex;
  align-items: center; /* 上下中央揃え */
  justify-content: flex-start; /* 左寄せ */
  padding: 10% 10%; /* 画面端からの余白 */
}
/* メインの黒い帯エリア */
.mainvisual_mountain .catch {
  position: relative;
  display: inline-block; /* 文字量に合わせて幅を調整 */
  padding: 40px 60px; /* 黒帯の内側の余白 */
  z-index: 1; /* 背景より手前に表示 */
}
/* 黒い帯（斜め背景）の生成 */
.mainvisual_mountain .catch::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;

  /* サブカラー：黒（少し透過させて馴染ませる） */
  background-color: rgba(10, 10, 10, 0.85);

  /* アメリカンな斜めカット（-20度傾ける） */
  transform: skewX(-20deg);

  /* アクセント：赤（左端のボーダーライン） */
  border-left: 8px solid #D32F2F; 

  /* メイン：水色（右下のドロップシャドウ風装飾） */
  box-shadow: 15px 15px 0px rgba(0, 160, 233, 0.4);

  z-index: -1; /* 文字の後ろへ */
}

@media (max-width: 768px) {
  .mainvisual_mountain .catch {
    position: relative;
    display: inline-block;
    padding: 0;
    z-index: 1;
  }
  .mainvisual_mountain .catch {
    width: 90%;
    padding: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    z-index: 1;
  }
}


/* =============================================== */
/***** 各ページのFV *****/
/* =============================================== */
.h1_text .section_h1 {
  font-size: 1em !important;
}
.h1_center_generic01,
.h1_text .text-side,
.h1_text .text,
.h1_center_generic03,
#section-wrapper > *:nth-child(2) .animation {
  text-align: start;
  color: #fff;
  font-size: 2rem;
  font-weight: bold;
}

#section-wrapper #section_695035 .section_h2 {
    font-size: clamp(4rem, 5vw, 5.2rem);
  font-weight: bold !important;
}
/* 1. テキスト本体を、下線を配置するための基準点にします */
.section_h2 {
  position: relative;
  display: inline-block; /* レイアウトを安定させる */
  z-index: 1;            /* テキストが下線より手前に来るように */
  padding: 0 0.1em;      /* 左右に少し余白を持たせると綺麗に見える（任意） */
}

/* 2. ::after疑似要素で、ずらした下線（帯）を作成します */
.section_h2::after {
  content: '';
  position: absolute;
  
  /* ▼▼▼ 下線のスタイル ▼▼▼ */
  background-color: #9E3532; /* 線の色 */
  width: 110%;
  height: 24px;               /* 線の太さ */
  
  /* ▼▼▼ ここで線をずらして文字に重ねる ▼▼▼ */
  /* bottomで垂直位置を調整。em単位で文字サイズに連動させる */
  bottom: 0.25em; 
  transform: translateX(-50%);
  left: 50%;
 
  z-index: -1;             /* テキストの背面に配置 */
}
#section_643734 .section_h2::after {
  display: none;
}

.section_h3,
.section_h3 * {
  font-weight: bold !important;
}

.title_space .section_inner .editable_wrap {
  font-size: 2.5em !important;
  color: #35383d !important;
}
.title_line_wide .headding_wrap {
  font-size: 3em !important;
}

.h2_center .subtitle {
  font-size: 1.4em !important;
}
.h2_center .subtitle *,
.half_wide_limited_height .spacer-item_wrap:nth-child(2) .editable_wrap {
  font-size: 1em !important;
  font-weight: bold !important;
  /* color: #3598E6; */
}


/* =============================================== */
/***** 各ページのFV *****/
/* =============================================== */
/* 1. 背景画像がある親要素 */
.h1_left {
  position: relative; /* 基準点の設定 */
  z-index: 0;         /* 重なり順の基準を作成 */
}
/* 2. 黒いベール（疑似要素）を作成 */
.h1_left::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #000; /* 黒色 */
  opacity: 0.5;           /* 透け具合（数字を大きくすると濃くなります） */
  z-index: 1;             /* 背景画像(z-indexなし)より手前 */
}
/* 3. 文字が入っている要素を最前面へ */
.h1_left .section_inner {
  position: relative; /* z-indexを効かせるために必要 */
  z-index: 2;         /* ベール(1)より手前に表示 */
}


/* =============================================== */
/***** ヘッダー *****/
/* =============================================== */
header.logo_side .header_logo span {
  font-size: 2.5rem !important;
  font-weight: bold;
}

#section-wrapper {
  position: relative;
  z-index: 1; 
}

/* PC用ナビゲーション */

@media (min-width:1025px) {
/*
#global-nav .gnav_pc .gnav_items {
  display: flex;
  flex-wrap: nowrap;
  white-space: nowrap;
  align-items: center;
}
*/
#global-nav .gnav_items li a {
  font-weight: 700; /* ページ名を太字に */
        font-size: 1.6rem;
  position: relative; /* ::after疑似要素の基準点にする */
  text-decoration: none; /* 元の下線を消す */
  padding-bottom: 8px; /* 下線を引くスペースを確保 */
}
/* アンダーラインの本体（初期状態は非表示） */
#global-nav .gnav_items li a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px; /* 線の太さ */
  background-color: #2756AE; /* 線の色 */

  /* アニメーションの設定 */
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease-out;
}
/* 滞在ページの下線を「常に表示」させるための専用ルール */
#global-nav .gnav_items li.current a::after {
  transform: scaleX(1); /* 幅を100%にする */
  transform-origin: left; /* アニメーションの起点を左に */
}
/* ホバー時に下線を表示させるための専用ルール */
#global-nav .gnav_items li a:hover::after {
  transform: scaleX(1); /* 幅を100%にする */
  transform-origin: left; /* アニメーションの起点を左に */
}
/* 滞在ページのスタイル */
#global-nav .gnav_items li.current a,
#global-nav .gnav_items li a:hover {
  color: #2756AE;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 4px;
}
#global-nav .gnav_items li.current a::after,
#global-nav .gnav_items li a:hover::after {
  transform: scaleX(1); /* アンダーラインを幅100%で表示 */
}
}
/* ヘッダーお問い合わせボタン */
#global-nav .gnav_accordion_wide .gnav_pc .gnav_items li:not(.gnav-submenu):last-child {
  background: #9E3532 !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;
}
/* SP用ナビゲーション */
#global-nav .gnav_sp .gnav_items {
    text-align: center;
}
#global-nav .gnav_accordion_wide .hamburger_top, #global-nav .gnav_accordion_wide .hamburger_mid, #global-nav .gnav_accordion_wide .hamburger_btm {
  background-color: #fff;
}
@media (min-width: 1025px) {
  #global-nav .gnav_sp .gnav_items li:last-child a {
    margin-top: 0.8em;
    background: #9E3532 !important;
    color: #FFFFFF !important;
  }
}


/* =============================================== */
/***** フッター *****/
/* =============================================== */
.footer_tp_generic .footer-company::before {
  dispaly: none;
}
.footer_tp_generic .editable a {
  color: #fff;
}
.footer_tp_generic {
  background-color: #0E1219 !important;
}

/* =============================================== */
/***** TOPに戻るボタン *****/
/* =============================================== */
/* ボタン本体 (通常時) */
.footer_tp_generic .back-top {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 45px;
  height: 45px;
  border-radius: 50%; /* 正円にする */
  background-color: #9E3532; /* 背景色を黄に */
  border: 1px solid #9E3532; /* 枠線を黄に */
  cursor: pointer;
  transition: background-color 0.3s, color 0.3s; /* 変化を滑らかに */
}
.footer_tp_generic .back-top .arrow::before {
  border: 1px solid #9E3532;
  content: "▲";
  color: #ffffff;
}
::before, ::after {
  text-decoration: inherit;
  vertical-align: inherit;
}


/* =============================================== */
/***** ボタン *****/
/* =============================================== */
#content-wrapper #section-wrapper .linker::after {
  position: absolute;
  opacity: 1 !important;
  z-index: 10;
}
#content-wrapper #section-wrapper .linker .btn-hide {
  z-index: 1 !important;
}

/* ボタン全体の基本設定 */
.section_btn {
  padding: 0;
  width: 100%;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.15em;
}

/* aタグのスタイリング */
.section_btn .linker a {
  /* 重要：疑似要素を配置するための基準となります */
  position: relative;
  
  /* ボタンの見た目を整えます */
  display: block;
  min-width: 200px;
  width: 100%;
  max-height: fit-content;
  min-height: fit-content;
  box-sizing: border-box; /* paddingを含めて幅100%になるように調整 */
  padding: 1em 2em; /* 内側の余白 */
  text-decoration: none; /* 下線を削除 */
  overflow: hidden;      /* はみ出した要素を隠します（スライドアニメーションに必須） */
  z-index: 1;            /* テキストが背景より手前に来るようにします */

  background: #3E83C4 !important;
  color: #FFFFFF !important;
  border: 3px solid #9E3532 !important;
  border-radius: 0; /* ホバー時の角丸を維持 */
  
  /* アニメーションを滑らかにします */
  transition: color 0.4s ease-out;
}

/* ホバー時のスライド背景 */
.section_btn .linker a::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  
  background: #9E3532;
  
  /* 最初はボタンの左外側に配置しておきます */
  transform: translateX(-101%);
  transition: transform 0.4s ease-out; /* アニメーションを設定 */
  z-index: 1; /* テキストの背面に配置 */
  border-radius: 0; /* ホバー時の角丸を維持 */
}

/* 右向きの矢印 */
.section_btn .linker a::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 1.2em; /* ボタンの右からの位置 */
  
  /* 縦方向中央に配置 */
  transform: translateY(-50%);
  
  /* 三角形を作成 */
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 8px; /* 上下6px, 左8px の線で三角形を作る */
  
  /* ご指定の矢印の色 */
  border-color: transparent transparent transparent #EE9B00;
  
  transition: right 0.3s ease-out; /* ホバー時のアニメーション */
}

/* ホバー時のアクション */
.section_btn .linker a:hover::before {
  /* 隠れていた背景をスライドインさせます */
  transform: translateX(0);
  z-index: -1;
}
.section_btn .linker a:hover::after {
  /* ホバー時に少し矢印が右に動くアニメーション（任意） */
  right: 1.2em;
}
.section_btn .linker a:hover {
  opacity: 1 !important;
}


/* =============================================== */
/***** ページ最下部（ページ遷移） *****/
/* =============================================== */
.vertical_icon_dup {
  background-color: transparent !important;
}

@media only screen and (min-width: 1025px) {
  .width-limit .section_inner {
    max-width: 1080px;
  }
}
.vertical_icon_dup .duplicatable-content_inner {
  padding-top: 100%;
}
.vertical_icon_dup .duplicatable-content {
  padding: 8px;
}

.vertical_icon_dup .text-side .frame-image {
  position: relative; /* 疑似要素の基準点にするため */
}
.vertical_icon_dup .text-side .frame-image::before {
  content: "";          /* これがないと表示されません */
  position: absolute;   /* 親要素に重ねる設定 */
  top: 0;
  left: 0;
  width: 100%;          /* 親要素いっぱいに広げる */
  height: 100%;         /* 親要素いっぱいに広げる */
  background-color: #000;
  opacity: 0.6;
  display: block;
  z-index: 1;           /* 必要に応じて重なり順を指定 */
}
@media only screen and (max-width: 768px) {
  .vertical_icon_dup .text-side .image-frame img {
    width: 80%;
  }
}


/* =============================================== */
/***** HOME *****/
/* =============================================== */
/*** キャッチコピー ***/
.h2_line .image-frame-bg {
  background-color: #EE9B00 !important;
    height: 2px;
    width: 100px;
    margin: 0 auto 1.5rem;
    display: none;
}

/*** ブログ ***/
.blog_unity .section_inner {
    /* 画像の色味に合わせた濃いネイビー */
    background-color: #000;
    
    /* これが外枠の太さになります */
    padding: 3rem; 
    margin: 0 auto;
}
/* --- Blogセクション：理想のデザイン（額縁＋グリッド） --- */
/* 1. 外側の「太い黒枠（額縁）」を作る */
.blog_unity .section_inner {
    /* これが外側の黒い太枠の幅になります */
    padding: 20px; 
    
    /* 背景を黒にして、サイト背景となじませつつ枠感を出す */
    background-color: #000000;
    
    /* 横幅の制限（画面いっぱいに広がらないように） */
    max-width: 1200px;
    margin: 0 auto;
    
    /* ボックスサイズの計算方法を統一 */
    box-sizing: border-box;
}
/* 2. 内側の「青い枠線」とレイアウト */
.blog_unity .content-wrap {
    /* 青い外枠線 */
    border: 2px solid #1e50a2;
    
    /* グリッドレイアウト（左カラム | 右カラム） */
    display: grid;
    /* 左側:320px固定 | 右側:残り全部 */
    grid-template-columns: 320px 1fr;
    /* 上段:自動 | 下段:残り全部（ボタンを下へ押しやるため） */
    grid-template-rows: auto 1fr;
    
    /* 背景は黒 */
    background-color: #000000;
    
    /* 余白リセット */
    padding: 0;
    width: 100%;
}
/* 3. 左上：Blogタイトル */
.blog_unity .text-side {
    /* 配置：左列・上段 */
    grid-column: 1 / 2;
    grid-row: 1 / 2;
    
    padding: 40px 30px 10px; /* 上・左右・下の余白 */
}
/* 4. 左下：ボタン */
.blog_unity .section_btn {
    /* 配置：左列・下段 */
    grid-column: 1 / 2;
    grid-row: 2 / 3;
    
    /* ボタンをエリアの「底」に配置する */
    align-self: end;
    
    padding: 10px 30px 40px; /* 上・左右・下の余白 */
}
/* ボタンの幅調整 */
.blog_unity .section_btn .linker a {
    width: 100%;
    display: block;
    box-sizing: border-box;
    text-align: center;
}
/* 5. 右側：記事エリア（縦線で区切る） */
.blog_unity .blog-side-wrap {
    /* 配置：右列（上から下までぶち抜き） */
    grid-column: 2 / 3;
    grid-row: 1 / 3;

    padding: 40px;
    
    /* 中身の上下中央揃え */
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%; /* 高さ確保 */
}
/* --- スマホ表示時の調整（SP） --- */
@media screen and (max-width: 768px) {
    .blog_unity .section_inner {
        padding: 10px; /* スマホでは額縁を少し細く */
    }
    .blog_unity .content-wrap {
        display: block; /* 縦積みに戻す */
    }    
    .blog_unity .text-side,
    .blog_unity .section_btn {
        padding: 20px 20px 10px;
    }    
    .blog_unity .section_btn {
        padding-bottom: 20px;
    }    
    .blog_unity .blog-side-wrap {
        border-left: none;
        border-top: 2px solid #1e50a2; /* 縦線を横線に変更 */
        padding: 30px 20px;
    }
}

/*** Guide ***/
  .half_fit_image.reverse .text-side_inner {
    background-color: #000;
    padding: 3rem;
    position: relative; /* ★重要：これが無いと枠線が配置できません */
  }

  /* 青いラインの実装部分 */
  .half_fit_image.reverse .text-side_inner::after {
    content: "";
    display: block;
    position: absolute;
    /* 黒背景の端からどれくらい内側に線を引くか（10px～15pxあたりが綺麗です） */
    top: 10px;
    bottom: 10px;
    left: 10px;
    right: 10px;
    /* 線の設定：青色・実線・太さ */
    border: 2px solid #1e50a2; /*
    /* ボタンなどをクリックできるように、線自体へのクリック判定を無効化 */
    pointer-events: none; 
  }

@media only screen and (min-width: 768px) {
  /* 既存の記述に "position: relative;" を追加します */

  .half_fit_image .text-side_inner {
    max-width: 540px;
    margin-left: 0;
  }
  .half_fit_image.reverse .text-side_inner .spacer-item_wrap {
    padding: 2rem;
  }
}

.square_four_images_with_text .section_inner {
  max-width: 1440px;
  margin: 0 auto;
}
.square_four_images_with_text .image-frame-bg {
  padding-top: 60%;
}
.square_four_images_with_text .image-frame-bg:after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: rgba(51, 51, 51, 0.54);
}

/*** お問い合わせ ***/
.information_card .info-side_content-inner {
  position: relative;
  padding: 50px 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  border: 3px solid #9E3532;
  border-radius: 0;
  background-color: #fff;
}


/* =============================================== */
/***** 一建について *****/
/* =============================================== */
/*** 代表挨拶 ***/
@media only screen and (max-width: 768px) {
  .half_limited_height .text-side_inner {
    width: 100%;
    position: relative;
    z-index: 2;
    max-width: 320px;
    margin: auto;
  }
}

/*** 一建が選ばれる理由 ***/
@media only screen and (min-width: 768px) {
  .title_simple_wide_reversible .text-side {
    align-items: center;
  }
}
@media only screen and (min-width: 768px) {
  .title_simple_wide_reversible .text-box, .title_line_wide_reversible .text-box, .standard_content_text_dup .duplicatable-content {
    margin-top: 0;
  }
}
.title_simple_wide_reversible .text-box, .title_line_wide_reversible .text-box {
  padding: 4rem 3.5rem 4.5rem;
  background-color: #EE9B00;
  border: 3px solid #9E3532;
  border-radius: 0;
  box-shadow: .7rem .7rem 0 rgba(0, 0, 0, .03);
}
.title_simple_wide_reversible .section_inner {
  padding: 0;
}

/*** 数字で見る一建 ***/
@media only screen and (min-width: 768px) {
  .circle-box_link .duplicatable-content {
    width: 50%;
  }
}
.circle-box_link .duplicatable-content {
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
}
@media only screen and (min-width: 768px) {
  .circle-box_link .circle_wrap {
    max-width: 40rem;
  }
}
.circle-box_link .image_wrap .circle-image::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: #000;
  opacity: .2;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  pointer-events: none;
}
@media (min-width: 768px) {
  .circle-box_link .image_wrap .image_text {
    color: #fff !important;
    font-size: 3.2rem;
    text-shadow: .2rem .2rem 0 rgba(0, 0, 0, .15);
    z-index: 2;
  }
}
@media (max-width: 768px) {
  .circle-box_link .image_wrap .image_text {
    color: #fff !important;
    font-size: 2rem;
    text-shadow: .2rem .2rem 0 rgba(0, 0, 0, .15);
    z-index: 2;
  }
  .circle-box_link .text-wrap .editable.letter {
    font-size: 15px !important;
    text-align: center;
  }
}
.circle-box_link .duplicatable-content {
  width: 50%;
  padding: 1%;
  margin: 0 auto 2rem;
  text-align: center;
  display: inline-block;
  vertical-align: top;
  font-size: 1.6rem;
}

/*** 仕事のこだわり ***/
.title_line_wide .section_inner .section-animation-wrap > div:nth-child(n+2) {
  display: none !important;
}


/* =============================================== */
/***** 事業内容 *****/
/* =============================================== */
/*** 施工の流れ ***/
.flow_cards .number_wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  height: 2em;
  flex: 0 0 2em;
  color: #404040;
  font-size: 2rem;
  line-height: 1;
  background-color: #EE9B00;
  border-radius: 50%;
  position: relative;
  font-size: 2.2rem;
  width: 40px;
  height: 40px;
  border: none !important;
  margin: 0 auto;
}
.flow_cards .image-side .frame-image {
  border-bottom: 10px solid transparent;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-top: 10px solid #9E3532;
  width: 0;
  height: 0;
  margin: 0 auto;
}
@media (min-width:1025px) {
.flow_cards .duplicatable-content {
  counter-increment: section;
  display: flex;
  width: 20%;
  flex-direction: row;
  justify-content: space-between;
}
}
@media screen and (max-width: 560px) {
  .flow_cards .text_wrap {
    display: block !important;
  }
}
@media only screen and (max-width: 1024px) {
  .flow_cards .text_wrap {
    margin-top: 1.5rem;
  }
}
@media only screen and (max-width: 1024px) {
  .flow_cards .text_wrap .letter.editable {
    font-size: 15px !important;
  }
}

/*** 一建の施工品質 ***/
@media (min-width:768px) {
.three_cards_title_sfiht .duplicatable-content {
  width: 50%;
}
}
.three_cards_title_sfiht .image-side .frame-image {
  padding-top: 40%;
}
.three_cards_title_sfiht .text-side {
  margin-top: -6.5rem;
}

@media (min-width: 768px) {
  .image-frame:not(
    .footer_tp_generic .image-frame,
    .vertical_icon_dup .image-frame,
    .card_icon .image-frame,
    .width-limit.circle-box_link .image-frame,
    .images_loop_animation .image-frame),
  .frame-image:not(
    .standard_content_four .frame-image,
    .flow_cards .frame-image,
    .card_one .frame-image,
    .vertical_icon_dup .frame-image,
    .half_slanted_line .frame-image,
    .alternating-backcolor .frame-image,
    .title_simple_wide_reversible .frame-image,
    .half_out_of_position .text-side .frame-image,
    .information_card .frame-image) {
      box-shadow: 2rem 2rem 0 #9E3532;
  }
}
@media (max-width: 768px) {
  .image-frame:not(
    .footer_tp_generic .image-frame,
    .vertical_icon_dup .image-frame,
    .card_icon .image-frame,
    .width-limit.circle-box_link .image-frame,
    .images_loop_animation .image-frame),
  .frame-image:not(
    .standard_content_four .frame-image,
    .flow_cards .frame-image,
    .card_one .frame-image,
    .vertical_icon_dup .frame-image,
    .half_slanted_line .frame-image,
    .alternating-backcolor .frame-image,
    .title_simple_wide_reversible .frame-image,
    .half_out_of_position .text-side .frame-image,
    .information_card .frame-image) {
      box-shadow: 1rem 1rem 0 #9E3532;
  }
}


/* =============================================== */
/***** ご依頼ガイド *****/
/* =============================================== */
/*** こんなお悩みありませんか？ ***/
.new_catchcopy_simple .text-side .editable_wrap .letter {
  line-height: 2.5 !important;
}
.new_catchcopy_simple .text-side .editable_wrap .letter > span,
.new_catchcopy_simple .text-side .editable_wrap .letter div > span {
  position: relative;
    display: block;
    padding-left: 2.5em;
}
.new_catchcopy_simple .text-side .editable_wrap .letter > span::before,
.new_catchcopy_simple .text-side .editable_wrap .letter div > span::before {
  content: '';
  position: absolute;
  top: .5ch;
  left: 0;
  width: 36px;
  height: 36px;
  background-image: url(https://d1i7na1hjknxjq.cloudfront.net/uploads/storage/image/file/489957/optimized_hHA0RsLKEQ2YXXvBHWIQBw.png);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}

/*** そのお悩み、一建がしっかり解決します ***/
.half_slanted_line .half_content {
    background-color: #fefefe;
}

/*** ご依頼の流れ ***/
.time_table_image_rounded .description_container .time_table_txt {
  width: 100%;
}
.time_table_image_rounded .description_container .image-side {
  display: none;
}
/* あしらい */
.time_table_image_rounded .duplicatable-content::before {
  background-color: #EE9B00;
}
.time_table_image_rounded .duplicatable-content::after {
  border-top: 33px solid #EE9B00;
  border-right: 47px solid transparent;
  border-left: 47px solid transparent;
}
.time_table_image_rounded .duplicatable-content_inner::before {
  position: absolute;
  top: 22px;
  left: -6px;
  background: radial-gradient(circle farthest-side, #9E3532, #9E3532 30%, transparent 30%, transparent);
  background-size: 20px 20px;
  content: '';
  display: inline-block;
  height: 100%;
  width: 20px;
}
.time_table_image_rounded .content_container::before {
  background-color: #3E83C4;
}

/*** 施工事例 ***/
.card_icon .image-frame-bg {
  background-color: #fff;
}


/* =============================================== */
/***** お問い合わせ *****/
/* =============================================== */
.formapps_border_light .form_area .form-item:not(.send_btn) div, .formapps_border_light .dummy_form_area .form-item:not(.send_btn) div {
  padding: 1rem;
  color: #000;
  font-weight: 600;
}


/* =============================================== */
/***** ブログ・施工事例 *****/
/* =============================================== */
.blog_posts .post_item .blog_post_day,
.blog_chart_popnews_item_category,
.blog_posts .post_popnews_data {
  color: #EE9B00 !important;
  font-weight: bold !important;
}
.breadcrumb_item,
.blog_posts .post_item .blog_post_title,
.blog_posts .post_item .post_category_name,
.blog_posts .post_item .blog_post_text,
.blog_posts .post_archives_title, .blog_posts .post_category_title, .blog_posts .post_popnews_title, .blog_posts .post_tag_title,
.blog_posts .post_archives_item, .blog_posts .post_category_item, .blog_posts .post_tag_item,
.blog_chart_popnews_item_category,
.blog_posts .post_popnews_text {
  color: #000 !important;
  font-weight: bold;
}
.breadcrumb_item,
.blog_posts .post_item .post_category_name,
.blog_chart_popnews_item_category,
.blog_posts .post_item .blog_post_day,
.blog_chart_popnews_item_category, .post_popnews_data,
.blog_posts .post_popnews_text,
.blog_posts .banner_text:nth-child(3) {
  font-size: 15px !important;
}
/*
.blog_posts .posts_title,
.showcase_chart .showcase_chart_title {
  font-size: 3em !important;
  font-weight: 600 !important;
}
*/
.blog_posts_sidebar,
.showcase_chart_sidebar {
  font-size: 110%;
}
.blog_posts .banner_text ._color_,
.showcase_chart .banner_text ._color_ {
  color: #3E83C4 !important;
}
.blog_posts .banner_text .banner_link,
.showcase_chart .banner_text .banner_link {
  font-size: 1.6rem;
  font-weight: 600;
  background: #3E83C4 !important;
  border-radius: 4px;
}
.blog_posts .banner_text:nth-child(3),
.showcase_chart .banner_text:nth-child(3) {
  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;
}


/* =============================================== */
/***** e-thanks *****/
/* =============================================== */
@media only screen and (min-width: 1025px) {
  section:first-of-type .content {
    padding: 0;
  }
}

.thanks_page {
  background-color: #eee;
}
.catch.text-side {
  margin: 0;
}
.thanks_page .catch {
  padding: 5%;
  background-color: #fff;
  border: none !important;
}
.thanks_page .headding_wrap,
.thanks_page .subtitle_wrap {
  display: flex;
  justify-content: center;
}

.thanks_page .catch_text {
  padding: 2rem 0;
  font-size: 5vw;
  font-weight: bold;
  color: #333;
  text-align: center !important;
  letter-spacing: 0.1em
}

.thanks_page .subtitle_wrap .catch_subtext {
  color: #3E83C4;
  font-weight: bold;
  text-align: center !important;
  letter-spacing: 0.1em
}

/* 20260123 修正 */
#section-wrapper .mainvisual_mountain .catch_text {
    font-size: clamp(2.2rem, 4.1vw, 6rem);
}
#section-wrapper .h2_section .section_h2 {
    font-size: clamp(3rem, 5vw, 4.5rem);
    font-weight: bold;
} 

.infomation_all {
    padding: 2% 0;
}

.vertical_icon_dup .spaceable.spaceable-top.spacer-item {
    padding-bottom: 10px !important;
}

.vertical_icon_dup .spacer-item_wrap:nth-child(2) .spaceable.spaceable-bottom.spacer-item,
.vertical_icon_dup .letter_wrap_basic .spaceable.spacer-item {
    display: none;
}

#global-nav .gnav_accordion_wide .gnav_pc .gnav_items li {
    padding: 0 10px;
}

#global-nav .gnav_accordion_wide .gnav_pc .gnav_items {
    margin-left: 2rem;
}
/*
 .standard_content_text_dup .duplicatable-content {
  outline: 1px solid #000;
    background-color: #EE9B00;
    border: 3px solid #9E3532;
    border-radius: 0;
    box-shadow: .7rem .7rem 0 rgba(0, 0, 0, .03);
    outline-offset: -10px;
}
*/

    #global-nav .gnav_accordion_wide .gnav_sp .logo_side img {
        max-width: 200px;
    }

.standard_content_text_dup .duplicatable-container {
    gap: 10px;
}

.standard_content_text_dup .text-box {
    border: 5px solid #9e3532;
    outline: 1px solid #000;
    outline-offset: -10px;
}

.standard_content_text_dup .text-box_bg {
    z-index: -1;
}

#section_695035 .information_card .info-side .cta-text_wrap, 
#section_695035 .information_card .info-side .cta-text {
        font-size: 1.5rem;
    }

#section-wrapper #section_695045 .h2_section .section_h2 {
    font-size: clamp(4rem, 5vw, 5.2rem);
}

    .title_simple_wide_reversible .headding_wrap, 
.title_simple_wide_reversible .headding {
        font-size: clamp(3rem, 4vw, 4rem);
    }

.unevenness_opposite .section_h3, .unevenness_opposite .headding_wrap {
    font-size: clamp(3rem, 4vw, 4rem);
}

#section-wrapper #section_695038 .h2_section .section_h2 {
    font-size: clamp(2.5rem, 5vw, 4.5rem);
}

@media only screen and (max-width: 767.9px) {
.section_h2::after {
    height: 16px;
    bottom: 0.15em;
}

.mainvisual_mountain .catch_head {
    font-size: 1.7rem;
}

.half_fit_image .text-side_inner {
    max-width: 350px;
    margin-top: 2rem;
}

.new_catchcopy_simple .text-side .editable_wrap .letter > span::before, 
.new_catchcopy_simple .text-side .editable_wrap .letter div > span::before {
    top: .2ch;
}

.new_catchcopy_simple .text-side .editable_wrap .letter {
    line-height: 2 !important;
}

.title_line_wide_reversible .section_inner {
    padding: 0 1.5rem;
}

#section_694791 .spaceable.spaceable-top.spacer-item {
    display: none;
}

.standard_content_text_dup .text-box {
    padding: 20px 20px;
}

.half_limited_height .headding_wrap, 
.half_limited_height .section_h3 {
    font-size: 2.5rem;
}
}
#section-wrapper #section_694397 .duplicatable-original .th.editable.letter,
#section-wrapper #section_694397 .duplicatable-original .td.editable.letter,
#section-wrapper #section_694397 .table_wrap .duplicatable-content .th.editable.letter,
#section-wrapper #section_694397 .table_wrap .duplicatable-content .td.editable.letter,
#section-wrapper #section_694397 .duplicatable-original .th.editable.letter *,
#section-wrapper #section_694397 .duplicatable-original .td.editable.letter *,
#section-wrapper #section_694397 .table_wrap .duplicatable-content .th.editable.letter *,
#section-wrapper #section_694397 .table_wrap .duplicatable-content .td.editable.letter * {
  color: #000 !important;
  font-family: 'Zen Maru Gothic', 'Noto Sans JP', sans-serif !important;
  font-weight: 700 !important;
}