.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: 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: 'Roboto', sans-serif !important;
  /* color: #3598E6; */
}
/* 日本語用のフォント設定 */
.font-ja {
  font-family: 'Noto Sans JP', sans-serif !important;
}

/* =============================================== */
/* 固定背景ロゴとコンテンツラッパー */
/* =============================================== */
body::before {
    content: '';
    position: fixed;
    top: 0; left: 0;
    width: 120%; height: 120%;
    background-image: url('https://d1i7na1hjknxjq.cloudfront.net/uploads/storage/image/file/460334/optimized_kPuPEvUvp9n7JVFplwIjSg.png');
    background-position: left 95%;
    background-repeat: no-repeat;
    background-size: 100vmin;
    opacity: 0.1;
    z-index: 1;
    pointer-events: none;
}
/* デフォルトの背景色を削除 */
#section-wrapper {
    position: relative;
    z-index: 2; /* コンテンツは階層「2」 */
    background-color: transparent;
}
.footer_tp_generic {
    background-color: transparent !important;
}


/* =============================================== */
/***** FV *****/
/* =============================================== */
section:first-of-type .content {
  padding: 0;
}
/* --- PC向けのスタイル --- */
section:first-of-type .mainvisual_desk_generic.image-bg {
  /* 画像のサイズをコンテナの幅に対して87%に設定（高さは自動調整） */
  background-size: 87% !important;
  backgroud-color: #FFFFFF;
  
  /* 画像を右上に配置 */
  background-position: top right !important;
  
  /* 画像がタイル状に繰り返されるのを防ぐ */
  background-repeat: no-repeat !important;
}

/* テキストブロックのコンテナ要素 */
.catch.text-side {
  bottom: 60%;
  left: 55%;
  box-sizing: border-box;
}

/* 見出しテキストの調整 */
.catch_text {
  font-size: 2.5rem;
  font-weight: bold;
  margin-bottom: 0.5em;
  padding: 0.32em 0.5em 0.3em 0.35em;
  width: fit-content;
  background-color: rgba(255, 255, 255);
  text-shadow: none !important;
  text-align: left !important;
  white-space: nowrap;
}

/* サブテキストの調整 */
.catch_subtext {
  font-size: 1.4rem;
  padding: 0.32em 1.2em 0.3em 1.2em;
  width: fit-content;
  background-color: rgba(255, 255, 255);
  text-shadow: none !important;
  text-align: left !important;
  white-space: nowrap;
}

/* FVにあるスクロールボタン */
.mainvisual_desk_generic .one_page_scroll_btn {
  /* --- 位置と基本設定 --- */
  position: absolute;
  z-index: 1;
  bottom: 3%;
  left: 50%;
  transform: translateX(-50%); /* Y軸のtransformは不要なためXのみに修正 */
  cursor: pointer;
  width: auto;

  /* --- テキストスタイル --- */
  color: #ffffff;
  font-size: 1.5rem;
  font-weight: 500;
  letter-spacing: .2em;
  text-transform: uppercase;
  
  /* --- 縦線を入れるための余白と準備 --- */
  padding-bottom: 4rem; /* 縦線を表示するスペース */

display:none;/* 非表示中 */
}
/* 縦線を作成するための疑似要素（::after） */
.mainvisual_desk_generic .one_page_scroll_btn::after {
  content: ''; /* 疑似要素には必須 */
  position: absolute;
  
  /* 縦線の見た目 */
  width: 1px; /* 線の太さ */
  height: 3rem; /* 線の長さ */
  background-color: #ffffff;

  /* 縦線の位置（テキストの真下に配置） */
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  
  /* 縦線のアニメーションを設定 */
  animation: scroll-down 1.5s ease-in-out infinite;
}
/* 縦線を動かすためのアニメーションを定義 */
@keyframes scroll-down {
  0% {
    transform: translate(-50%, -1rem); /* 少し上に移動した状態から開始 */
    opacity: 0;
  }
  50% {
    opacity: 1; /* アニメーションの中間で表示 */
  }
  100% {
    transform: translate(-50%, 0); /* 定位置に移動して消える */
    opacity: 0;
  }
}


/* ▼▼▼ 768px以下の画面で適用されるスタイル ▼▼▼ */
@media screen and (max-width: 768px) {
  
  /* --- 背景画像の調整 --- */
  section:first-of-type .mainvisual_desk_generic.image-bg {
    /* 画像でコンテナ全体を覆うように変更 */
    background-size: cover !important;
    /* 画像の中央が表示されるように配置を変更 */
    background-position: center center !important;
  }
  
  /* --- テキストブロックの調整 --- */
  .catch.text-side {
    /* 左右の余白をなくし、中央に配置 */
    margin: 0;
    /* 幅を画面幅の90%に設定 */
    width: 90%;
    left: 50%;
    /* テキストを中央揃えに変更 */
    text-align: center;
    /* 上下の余白を少し縮める */
    padding: 0.3em 0.5em;
  }

  /* --- テキストの調整 --- */
  .catch_text,
  .catch_subtext {
    width: fit-content;
    /* 折り返しを許可する */
    white-space: normal;
    /* 中央揃えを強制 */
    text-align: center !important;
  }

  .catch_text {
    /* スマートフォン向けに文字サイズを少し小さくする */
    font-size: 1.8rem;
  }
  .catch_subtext {
    display: inline;
    font-size: 1rem;
  }
}
/* ▲▲▲ 768px以下の画面で適用されるスタイル ▲▲▲ */


/* =============================================== */
/***** ヘッダー *****/
/* =============================================== */
#section-wrapper {
  position: relative;
  z-index: 1; 
}

#global-nav {
  position: fixed;
  width: 100%;
  top: 0; left: 0;
  z-index: 1000;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}
#global-nav .gnav_bg {
  background-color: rgba(255, 255, 255, 0.8) !important;
  backdrop-filter: blur(10px) !important;
}

/* 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-size: 1em;
  font-weight: 700; /* ページ名を太字に */

  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: linear-gradient(to right, #2756AE, #3598E6) !important;
}
#global-nav .gnav_accordion_wide .gnav_pc .gnav_items li:not(.gnav-submenu):last-child a {
  color: #fff !important; /* 文字色を白に */
}
#global-nav .gnav_accordion_wide .gnav_pc .gnav_items li:not(.gnav-submenu):last-child a:hover {
  opacity: 1 !important;
}
#global-nav .gnav_accordion_wide .gnav_pc .gnav_items li{padding: 0 1.6vw;}
}
/* SP用ナビゲーション */
#global-nav .gnav_sp .gnav_items {
    text-align: center;
}
/*
@media (max-width: 768px) {
  #global-nav .gnav_sp .gnav_items li:last-child a {
    margin-top: 0.8em;
    background: linear-gradient(to right, #2756AE, #3598E6) !important;
    color: #FFFFFF !important;
  }
}
*/

/* =============================================== */
/***** フッター *****/
/* =============================================== */
.footer_tp_generic .footer-company::before, {
  display: none;
}
#section-wrapper div[class^="footer"] .copy {
    border-top: none;
}

@media only screen and (min-width: 768px) {
  .footer_tp_generic .menu-side {
    display: block;
    padding: 3rem 0 5rem;
    font-weight: bold;
    color: #35383d !important;
  }
}

/* サイトマップ */
@media only screen and (min-width: 1025px) {
  .width-limit .section_inner {
    padding: 0;
    max-width: 990px;
    margin: 0 auto;
    font-weight: bold;
  }
}


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



/* -------------------------------------
------------- 共通部分 --------------
------------------------------------- */
/* =============================================== */
/***** 各ページの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_h2,
.section_h2 * {
  font-size: 1.2em;
  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: #a1c4fd; /* 線の色 */
  width: 110%;
  height: 30px;               /* 線の太さ */
  
  /* ▼▼▼ ここで線をずらして文字に重ねる ▼▼▼ */
  /* 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; */
}

/* =============================================== */
/***** ボタン *****/
/* =============================================== */
/* ボタン全体の基本設定 */
.section_btn {
  /*padding: 20px 0;*/
  width: 100%;
  /*font-size: 1.4em;*/
  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 1.2em; /* 内側の余白 */
  text-decoration: none; /* 下線を削除 */
  overflow: hidden;      /* はみ出した要素を隠します（スライドアニメーションに必須） */
  z-index: 1;            /* テキストが背景より手前に来るようにします */

  /* background-colorからbackground(グラデーション)に変更 */
  background: linear-gradient(to right, #2756AE, #3598E6) !important;
  color: #FFFFFF !important;
  
  /* アニメーションを滑らかにします */
  transition: color 0.4s ease-out;
}

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

/* 右向きの矢印 */
.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 #E9D92D;
  
  transition: right 0.3s ease-out; /* ホバー時のアニメーション */
}

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

/* =============================================== */
/***** アイコンサイズ調整 *****/
/* =============================================== */
.card_icon .image-frame {
  width: 100%;
  height: auto;
}

/* =============================================== */
/***** ページ下部：Contact *****/
/* =============================================== */
.contact-side.section-content > a > div > div.contact-side_bg > div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #2756AE !important;
}
.information_half_wide .contact-side_text * {
  color: #FFFFFF !important;
}

.duplicatable-container .link-side_text,
.duplicatable-container .link-side_text * {
  color: #FFFFFF;
}


/* =============================================== */
/***** サンワ工務店について *****/
/* =============================================== */
#section_643735>div>div,
#section_642511>div>div,
#section_642512>div>div,
#section_642513>div>div {
  background-color: transparent !important;
}
#section_642511>div>div>div.section_inner>div.text-side>div.text-box.animation.animated.fadeInUpLittle.fadein-top>div:nth-child(1)>div.editable_wrap_title.letter_wrap.letter_wrap_basic>div,
#section_642512>div>div>div.section_inner>div.text-side>div.text-box.animation.animated.fadeInUpLittle.fadein-top>div:nth-child(1)>div.editable_wrap_title.letter_wrap.letter_wrap_basic>div,
#section_642513>div>div>div.section_inner>div.text-side>div.text-box.animation.animated.fadeInUpLittle.fadein-top>div:nth-child(1)>div.editable_wrap_title.letter_wrap.letter_wrap_basic>div {
  color: #2756AE !important;
}

#section_649795 > div > div,
#section_643734 > div > div,
#section_642487 > div > div {
  background: linear-gradient(90deg, #384480 0%, #2756AE 50%, #68ABDF 125%) !important;
  color: #FFFFFF !important;
}
.title_space .title_space_bg .editable_wrap {
  position: absolute;
  display: inline-block;
  font-size: 12em;
  color: #65B5F4;
  opacity: 0.1;
  line-height: 1;
  font-weight: 500;
}
@media only screen and (min-width: 768px) {
  .title_line_wide .title-box {
    width: 45%;
    padding-right: 4rem;  
  }
  .title_line_wide .text-box {
    width: 55%;
  }
}
.title_line_wide .section_h3 {
  width: fit-content;
  min-width: 100%;
  white-space: nowrap !important;
}

#section_642512 .title_line_wide .text-side {
  flex-direction: row-reverse;
}

#section_643735 .text-side *,
#section_642511 .text-side *,
#section_642512 .text-side *,
#section_642513 .text-side * {
  color: #35383d !important;
}

.section-animation-wrap .element-1 {
  border: 2px solid #2756AE !important;
  width: 320px !important;
  height: 320px !important;
}
#section_642512 .section-animation-wrap .element-1 {
  position: absolute;
  top: 0;
  left: calc(100% - 200px);
  border-radius: 50%;
  margin: 0;
}

.section-animation-wrap .element-2,
.section-animation-wrap .element-3,
.section-animation-wrap .element-4,
.section-animation-wrap .element-5 {
  display: none !important;
}


/* =============================================== */
/***** 採用情報 *****/
/* =============================================== */
@media only screen and (min-width: 1025px) {
  .width-limit .section_inner {
    padding: 0;
    max-width: 1200px;
    margin: 0 auto;
    font-weight: bold;
  }
  #section_649338 .three_cards_title_sfiht .text-side {
    text-align: center;
    padding: 2rem;
    margin-top: -5.7rem;
    position: relative;
    z-index: 1;

    display: flex;            /* Flexboxを有効化 */
    flex-direction: column;     /* アイテムを縦方向に並べる */
    justify-content: center;  /* 縦方向（主軸）の中央揃え */
  }

  #section_649338 .text-side .section_h3 {
    font-size: 2.5rem !important;
    white-space: nowrap;
  }
  #section_649338 .text-side .subtitle {
    font-size: 3rem !important;
  }
}
/* 見出し(POINTxx)とサブテキストの「座布団」の見た目を設定 */
#section_649338 .text-side .section_h3,
#section_649338 .text-side .subtitle {
  display: inline-block;    /* 背景を文字の幅に合わせる */
  background-color: #2756AE;  /* 座布団の色 */
  color: #FFFFFF;
  padding: 0.3em 0.8em;     /* テキストと帯の間の余白 */
  line-height: 1.5;         /* 行の高さを調整 */
}


/* =============================================== */
/***** 会社概要ページのテーブル *****/
/* =============================================== */
.table_light_generic .table_wrap .tr .th {
  background-color: rgba(39, 86, 174, 0.3);
}


/* =============================================== */
/***** ブログ・施工事例 *****/
/* =============================================== */
.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: #2756AE !important;
}
.blog_posts .banner_text .banner_link,
.showcase_chart .banner_text .banner_link {
  font-size: 1.6rem;
  font-weight: 600;
  background: linear-gradient(to right, #2756AE, #3598E6) !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;
}


/* =============================================== */
/***** サイトマップ *****/
/* =============================================== */
.footer_tp_generic .editable a,
.page-sitemap #section-wrapper .letter a {
  font-size: 1.2em !important;
  line-height: 3em;
}


/* =============================================== */
/***** e-thanks *****/
/* =============================================== */
.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: #2756AE;
  font-weight: bold;
  text-align: center !important;
  letter-spacing: 0.1em
}



@media screen and (max-width: 768px) {
  editable, editable *,
  .circle_picture .subtitle, .circle_picture .subtitle_wrap,
  .circle_picture .spacer-item_wrap:nth-child(4) .editable_wrap {
    font-size: 15px !important;
  }
  h3.section_h3.editable.headding {
    font-size: 1.1em !important;
  }
  .title_sub .subtitle_wrap {
    font-size: 0.9em;
  }
  #section_643657 div.subtitle.editable {
    font-size: 2.5em !important;
  }
  #section_643695 > div > div > div.section_inner.animation.animated.fadeInUpLittle.fadein-top > div > div.spacer-item_wrap > div.editable_wrap.headding_wrap > h3 > p > span {
    font-size: 1.1em !important;
  }
  #section_642453 > div > div > div.section_inner > div > div.link-side > div > div.duplicatable-container.animation-container > div:nth-child(2) > a > div > div.link-side_text > div.editable_wrap.headding_wrap > div > div > span {
    font-size: 1em !important;
  }
  div.subtitle.editable,
  div.editable.letter,
  div.editable.letter * {
    font-weight: 600;
  }
  .section_h2::after {
    display: none;
  }
  #section_642443 > div > div > div.section_inner > div > div.duplicatable-container > div:nth-child(1) > div.duplicatable-content_inner.animation.animated.fadeInUpLittle.fadein-top > div.text-side.section-content > div.text-side_inner > div:nth-child(1) > div.editable_wrap.headding_wrap > h3,
  #section_642443 > div > div > div.section_inner > div > div.duplicatable-container > div:nth-child(2) > div.duplicatable-content_inner.animation.animated.fadeInUpLittle.fadein-top > div.text-side.section-content > div.text-side_inner > div:nth-child(1) > div.editable_wrap.headding_wrap > h3,
  #section_642443 > div > div > div.section_inner > div > div.duplicatable-container > div:nth-child(3) > div.duplicatable-content_inner.animation.animated.fadeInUpLittle.fadein-top > div.text-side.section-content > div.text-side_inner > div:nth-child(1) > div.editable_wrap.headding_wrap > h3,
  #section_642443 > div > div > div.section_inner > div > div.duplicatable-container > div:nth-child(4) > div.duplicatable-content_inner.animation.animated.fadeInUpLittle.fadein-top > div.text-side.section-content > div.text-side_inner > div:nth-child(1) > div.editable_wrap.headding_wrap > h3 {
    font-size: 1em !important;
  }
  #section_642445 > div > div > div.section_inner > div > div.duplicatable-container > div > div.text-box > div.text-box_inner > div.text-box-headding_wrap > h3 {
    font-size: 1.8em !important;
  }
  .new_catchcopy_simple .text-side .headding_wrap, .new_catchcopy_simple .text-side .headding {
    font-size: 1.5em !important;
  }
  .block_circle .spacer-item_wrap:nth-child(2) .editable_wrap {
    font-size: 1em;
  }
  #section_649338 .text-side .subtitle {
    font-size: 2rem !important;
  }
}

@media screen and (max-width: 767.9px) {
.mainvisual_desk_generic .catch_text {font-size: .8em !important;}
.mainvisual_desk_generic .catch_subtext{display: inline-block !important;}
#content-wrapper #section-wrapper .table_separated_border .td ul{padding: 14px;}
}

.page-voice .h1_text .text{display:none;}
.title_space .letter_wrap .text_wrap:nth-child(1){display:none;}
.half_wide_limited_height .section_h3{font-size: 36px;}
