.h1_center_builder{text-align:center}.h1_center_builder .headding_wrap,.h1_center_builder .headding{font-size:3.5rem}.h1_center_builder .subtitle_wrap{letter-spacing:0.15em;margin-top:.5rem}.h1_center_builder .subtitle{font-size:inherit}.h1_center_builder .editable_wrap{margin-top:2rem}
.contact_policy.contact_policy_builder .intro{margin-bottom:2rem}.contact_policy.contact_policy_builder .intro .headding_wrap{text-align:center}.contact_policy.contact_policy_builder .intro .section_h3{font-size:3rem}.contact_policy.contact_policy_builder .text-side{background-color:#fefefe;border:1px solid #dedede;position:relative}.contact_policy.contact_policy_builder .text-side .overlay{height:100%;width:100%;background-color:rgba(222,222,222,0.6);position:absolute;top:0;left:0}.contact_policy.contact_policy_builder .text-side .show_btn{display:inline-block;background-color:#efefef;border:1px solid #ccc;padding:1rem;position:absolute;top:50%;left:50%;transform:translate(-50%, -50%)}.contact_policy.contact_policy_builder .text-side .text_wrap{font-size:inherit;padding:1rem;height:200px;overflow-y:scroll}
.title_text .text-side{max-width:850px;margin:auto;text-align:center}.title_text .text-side .text{text-align:left}@media only screen and (min-width:768px){.title_text .text-side .text{text-align:center}}
.title_sub{font-family:"YakuHanMP, Vollkorn, 'Hiragino Mincho ProN', eatYuM, 'Sawarabi Mincho', Meiryo, sans-serif"}.title_sub .section_h3{font-family:YakuHanMP, Vollkorn, "Hiragino Mincho ProN", eatYuM, "Sawarabi Mincho", Meiryo, sans-serif}.title_sub .text-side{max-width:850px;margin:auto;text-align:center}.title_sub .subtitle{letter-spacing:0px}.title_sub .headding_wrap,.title_sub .editable_wrap{font-size:2.5rem}.title_sub .subtitle_wrap{font-size:1.1rem}@media only screen and (min-width: 768px){.title_sub .headding_wrap,.title_sub .editable_wrap{font-size:3rem}.title_sub .subtitle_wrap{font-size:1.6rem}}
.formapps .form_area .form-item .awesomplete{display:block;width:100%;padding:0 !important}.form_area .awesomplete li mark{display:inline-block;padding:0 0 0 0.5rem;background:#f2f2f2;border-radius:0.3em}.form_area .awesomplete>ul{box-shadow:unset;overflow:hidden}.form_area .awesomplete>ul>li{color:#333}.form_area .awesomplete>ul>li::after{content:"";position:absolute;left:0;right:0;bottom:0;margin:auto;width:100%;height:2px;background-color:#ccc;transition:transform 0.2s;transform:scaleX(0)}.form_area .awesomplete>ul>li:first-child{border-radius:0.3em 0.3em 0 0}.form_area .awesomplete>ul>li:last-child{border-radius:0 0 0.3em 0.3em}.form_area .awesomplete>ul>li:hover{background-color:#f2f2f2}.form_area .awesomplete>ul>li:hover mark{background-color:#f2f2f2}.form_area .awesomplete>ul>li:hover::after{transform:scaleX(1)}.formapps_border_light .form_area .form-item:not(.send_btn),.formapps_border_light .dummy_form_area .form-item:not(.send_btn){border-bottom:1px solid rgba(0,0,0,0.2)}.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}
#footer-section{z-index:3}@media only screen and (max-width: 768px){.jobs #footer-section .detail-side{display:none}}.footer-block .footer_menu_center_builder .detail-side{bottom:0;transition:bottom .5s}.footer_menu_center_builder{background-color:#fff;font-size:1.4rem}.footer_menu_center_builder .footer-company{position:relative}.footer_menu_center_builder .footer-company::before{content:"";position:absolute;top:0;left:50%;width:100%;height:1px;background-color:#ccc;transform:translateX(-50%)}.footer_menu_center_builder .logo-side{padding:2rem 0;text-align:center}.footer_menu_center_builder .logo{max-width:200px;margin:0 auto 2rem}.footer_menu_center_builder .logo img{width:auto;max-width:100%}.footer_menu_center_builder .logo div{display:inline}.footer_menu_center_builder .menu-side{display:none}.footer_menu_center_builder .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_menu_center_builder .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_menu_center_builder .detail-side_first .tel{line-height:1.4;letter-spacing:0}.footer_menu_center_builder .detail-side_first .tel a{position:absolute;width:100%;height:100%;top:0;left:0}.footer_menu_center_builder .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_menu_center_builder .detail-side_first .hour{font-size:1.2rem;display:none}.footer_menu_center_builder .detail-side_second{-ms-flex-positive:1;flex-grow:1}.footer_menu_center_builder .letter{letter-spacing:.1em}.footer_menu_center_builder .copy{border-top:1px solid #ccc;font-size:1.2rem;padding:2rem 0;text-align:center}.footer_menu_center_builder .sns-side{margin-bottom:2rem}.footer_menu_center_builder .sns-side .duplicatable-container{display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center}.footer_menu_center_builder .sns-side .duplicatable-content{max-width:70px;padding:0 1rem}.footer_menu_center_builder .section_btn a{white-space:nowrap}.footer_menu_center_builder .back-top{cursor:pointer;width:40px;height:40px;border-radius:20px;border:1px solid #f44336;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_menu_center_builder .back-top .arrow:before{content:"▲";color:#f44336}@media only screen and (min-width: 768px){.footer_menu_center_builder .footer-company{padding:3.5rem 0 2rem}.footer_menu_center_builder .footer-company_inner{display:flex;flex-wrap:wrap}.footer_menu_center_builder .logo{display:block;margin:0 auto}.footer_menu_center_builder .menu-block{order:3;width:100%}.footer_menu_center_builder .menu-side{display:block;padding:3rem 0 5rem}.footer_menu_center_builder .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_menu_center_builder .menu-side .duplicatable-content{width:auto;padding:0 1rem;font-size:1.4rem}.footer_menu_center_builder .logo-side{order:1;width:200px}.footer_menu_center_builder .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_menu_center_builder .detail-side_first{margin-bottom:4rem;font-size:1.8rem;text-align:right;display:block}.footer_menu_center_builder .detail-side_first .tel{font-size:2.2rem}.footer_menu_center_builder .detail-side_first .tel:after{content:none}.footer_menu_center_builder .detail-side_first .tel a{position:relative;pointer-events:none}.footer_menu_center_builder .detail-side_first .hour{display:block}.footer_menu_center_builder .detail-side_second{max-width:300px;margin-bottom:3rem}.footer_menu_center_builder .detail-side>div{margin-bottom:0;width:100%}.footer_menu_center_builder .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_menu_center_builder .sns-side{margin-bottom:0}.footer_menu_center_builder .sns-side .duplicatable-content{width:60px}.footer_menu_center_builder .section_btn{margin:auto 0 auto auto}.footer_menu_center_builder .back-top{bottom:80px}}@media only screen and (max-width: 768px){.footer_menu_center_builder .detail-side_first .tel{font-size:0 !important}.footer_menu_center_builder .detail-side_second .section_btn{max-width:none}.footer_menu_center_builder .detail-side_second .section_btn a{border-radius:0}}@media only screen and (min-width: 768px){_:-ms-lang(x)::-ms-backdrop,.footer_menu_center_builder .detail-side{align-items:center;margin:unset}_:-ms-lang(x)::-ms-backdrop,.footer_menu_center_builder .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: 'Noto Sans JP', 'Noto Sans', sans-serif !important;
  font-weight: bold;
}
*/
/* 日本語用のフォント設定 
.font-ja {
  font-family: 'Noto Sans JP', 'Noto Sans', sans-serif !important;
}
*/
/*20260109削除済み*/
body{
font-family: 'Noto Sans JP', 'Noto Sans', 'Meiryo', sans-serif !important;
}
#section-wrapper .headding{
font-family: 'Noto Sans JP', 'Noto Sans', 'Meiryo', sans-serif !important;
font-weight: bold;
}
#section-wrapper .letter{
font-family: 'Noto Sans JP', 'Noto Sans', 'Meiryo', sans-serif !important;
}
#section-wrapper .subtitle{
font-family: 'Noto Sans JP', 'Noto Sans', 'Meiryo', sans-serif !important;
font-weight: bold;
}
/* ============================================== */
/***** FV *****/
/* ============================================== */
@media only screen and (min-width: 1025px) {
  .mainvisual_responsive_slider {
    overflow: hidden;
    background-color: #E5E5E5 !important;
   /*border-left: 40px solid #E3872C;*/
  }
  .mainvisual_responsive_slider .image-side {
    position: absolute;
    transform: translateY(-50%);
    top: 50%;
    right: 0;
    height: 80%;
    width: 70%;
  }
/*
  .mainvisual_responsive_slider .catch {
    top: 70%;
    font-size: 2rem;
    /*text-shadow: 1px 1px 0 #E3872C;*/
    text-shadow: none
  }
*/
  .mainvisual_responsive_slider .catch_text {
    font-size: 8rem;
    text-shadow: 6px 4px 0 #1d1d1d;
  }
}
@media only screen and (max-width: 768px) {
  .mainvisual_responsive_slider .section_block {
    position: relative;
    height: 100vh;
  }
  .mainvisual_responsive_slider {
    overflow: hidden;
    background-color: #E5E5E5 !important;
    border-left: 30px solid #E3872C;
  }
  .mainvisual_responsive_slider .image-side {
    position: absolute;
    /*transform: translateY(-50%);*/
    top: 0;
    right: 0;
    height: 70%;
    width: 100%;
  }
/*
  .mainvisual_responsive_slider .catch {
    width: 100%;
    padding: 2rem 1.5rem 0;
    position: absolute;
    top: 75%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
    /*text-shadow: 1px 1px 0 #E3872C;*/
    text-shadow: none;
  }
*/
  .mainvisual_responsive_slider .catch .catch_head,
  .mainvisual_responsive_slider .catch .catch_subtext {
    font-size: 15px;
  }
  .mainvisual_responsive_slider .catch_text {
    text-shadow: 1px 1px 0 #1d1d1d;
    font-size: 36px;
  }
}
.flamingo-slider-pagination {
  display: none;
}

/* ============================================== */
/***** 背景画像 *****/
/* ============================================== */
#section-wrapper::before {
  content: "";
  width: 100%;
  height: 100%;
  background: url(https://d1i7na1hjknxjq.cloudfront.net/uploads/storage/image/file/472383/optimized_0ARGRlBENe0eNENujeHV5g.jpg) no-repeat left top / cover;
  position: fixed;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: .7;
}
.title_line_wide_reversible,
.table_light_builder_company,
.formapps.formapps_border_light {
  background-color: transparent !important;
}
#section_665666, #section_665673 {
  background-color: #1d1d1d;
}

/* ============================================== */
/***** ヘッダー *****/
/* ============================================== */
.gnav_bg.gnav_bg-color {
  background-color: rgba(29, 29, 29, 0.9) !Important;
}
.gnav_items * {
  color: #fff !important;
}
#global-nav .gnav_accordion_icon_builder .hamburger_top, #global-nav .gnav_accordion_icon_builder .hamburger_mid, #global-nav .gnav_accordion_icon_builder .hamburger_btm {
  display: inline-block;
  height: 3px;
  width: 100%;
  background-color: #fff;
  transition: opacity 0.1s, transform 0.3s;
}
#global-nav .gnav_accordion_icon_builder .gnav_pc .logo_side {
  height: 100%;
  flex: 0 0 auto;
  margin: 0 32px;
  padding: 2rem 0 !important;
}
#global-nav .gnav_accordion_icon_builder .gnav_sp .logo_side img {
  height: 100%;
  width: auto;
  padding: 10px 0;
}

#global-nav .gnav_accordion_icon_builder .gnav_pc .nav_side {
  display: flex;
  /* flex-direction: unset; */
  align-items: flex-end;
  gap: 5px;
}
#global-nav .gnav_accordion_icon_builder .gnav_pc {
  padding: 0;
}
#global-nav .gnav_accordion_icon_builder .gnav_pc .gnav_items {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  height: 100%;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.gnav-editable-contents .gnav-btn {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 120px;
    height: 50px;
    color: #FFF;
    background-color: #E3872C;
    border-radius: 0;
    font-size: 15px;
    line-height: initial;
    margin-left: 0;
}
.gnav-editable-contents .gnav-btn:last-child {
    background-color: #2C75E3;
  /* display: none; */
}
/* --- 下線本体 (疑似要素) --- */
#global-nav .gnav_accordion_icon_builder .gnav_pc .gnav_items li a::after,
.sidebar-box .gnav_items li a::after {
  content: ''; /* 疑似要素には必須 */
  position: absolute;
  bottom: 0; /* リンク要素の最下部に配置 */
  left: 0;
  width: 100%;
  height: 2px; /* 下線の太さ */
  background-color: transparent; /* 初期状態は透明 */
  transition: background-color 0.3s ease;
}
/* --- 2. ホバー時のスタイル --- */
#global-nav .gnav_accordion_icon_builder .gnav_pc .gnav_items li a:hover::after,
.sidebar-box .gnav_items li a:hover::after {
  background-color: #E3872C; /* ホバー時に下線の色を変更 */
  opacity: 1;
}
/* --- 3. 現在地のページのスタイル --- */
#global-nav .gnav_accordion_icon_builder .gnav_pc .gnav_items li.active a::after,
.sidebar-box .gnav_items li.active a::after {
  background-color: #E3872C; /* 現在地のページの下線の色 */
}

/*** SP版 ***/
.sidebar-box .gnav_items li a {
  position: relative; /* ::after擬似要素の基準位置となります */
  
  /* * display: block; を指定してリンク領域を広げ、
   * padding を調整すると、下線がより美しく表示されます（推奨）
   */
  display: block;
  padding-top: 10px;    /* 例: 上下の余白 */
  padding-bottom: 10px; /* 例: 下線との余白 */
}
/* (既存のままでOKですが、position: relative がないと機能しません) */
#global-nav .gnav_accordion_icon_builder .gnav_pc .gnav_items li a::after,
.sidebar-box .gnav_items li a::after {
  content: '';
  position: absolute;
  bottom: 0; /* aタグの最下部 (padding-bottom の内側) に配置 */
  left: 0;
  width: 100%;
  height: 2px;
  background-color: transparent;
  transition: background-color 0.3s ease;
}
.sidebar-box .gnav_items li a:hover::after {
  background-color: #E3872C;
  opacity: 1;
}
.sidebar-box .gnav_items li.active a::after {
  background-color: #E3872C;
}

/* =============================================== */
/***** フッター *****/
/* =============================================== */
div.footer-company::before {
  display: none;
}
#footer-section .section-image_bg {
  background-color: #F0F0F0;
}
@media only screen and (min-width: 1025px) {
  .footer_tp_generic .section_inner {
    max-width: 1200px;
  }
}
@media only screen and (min-width: 768px) {
  .footer_tp_generic .copy {
    justify-content: center;
  }
}
.footer_tp_generic .copy {
  font-size: 1.5rem;
  font-weight: bold;
}

/* =============================================== */
/***** TOPに戻るボタン *****/
/* =============================================== */
/* ボタン本体 (通常時) */
.footer_menu_center_builder .back-top {
  cursor: pointer;
  width: 40px;
  height: 40px;
  border-radius: 20px;
  border: 1px solid #E3872C;
  position: absolute;
  right: 30px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.footer_menu_center_builder .back-top .arrow:before {
  content: "▲";
  color: #E3872C;
}
::before, ::after {
  text-decoration: inherit;
  vertical-align: inherit;
}

/* =============================================== */
/***** h3 *****/
/* =============================================== */
.section_h3, .section_h3 * {
  font-weight: bold;
}
@media only screen and (min-width: 768px) {
  .section_h3 *,
  .section_h3:not(
    .half_wide_limited_height .section_inner .section_h3,
    .half_wide_limited_height .section_inner .section_h3 *,
    .title_backcolor .text-side .headding_wrap .headding,
    .title_backcolor .text-side .headding_wrap .headding *,
    .square_four_images_with_text .text-side .headding *) {
    font-size: 48px;
  }
  .title_backcolor .text-side .headding_wrap .section_h3 *,
  .square_four_images_with_text .text-side .headding * {
    font-size: 32px;
  }
}
@media only screen and (max-width: 768px) {
  .section_h3 *,
  .section_h3:not(
    .half_wide_limited_height .section_inner .section_h3,
    .half_wide_limited_height .section_inner .section_h3 *,
    .title_backcolor .text-side .headding_wrap .headding,
    .title_backcolor .text-side .headding_wrap .headding *,
    .square_four_images_with_text .text-side .headding *) {
    font-size: 32px !important;
  }
  .title_backcolor .text-side .headding_wrap .section_h3 * {
    font-size: 24px !important;
  }
  .square_four_images_with_text .text-side .headding *{
    font-size: 20px !important;
  }
}

/*** サブタイトル ***/
.text-side .subtitle .font-en,
.text-side .subtitle .font-ja:not(.flamingoSlide_app .mainvisual_responsive_slider .text-side .subtitle .font-ja),
.spacer-item_wrap .editable.subtitle *:not(.infomation_all .spacer-item_wrap .editable.subtitle font) {
  color: #fff !important;
  font-weight: bold;
  padding: 0.5rem 5rem;
  background-color: #E3872C;
}

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

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

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

  /* (補足: ボタンとして機能させるため、displayやpadding, text-decorationなども追加すると良い) */
  /* display: inline-block;
  padding: 10px 20px;
  text-decoration: none;
  text-align: center;
  cursor: pointer; */
}
/* スライドアニメーションの要素 (a::after) */
.section_btn a::after,
.linker a::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;

  /* スライドの色 = ホバー時の背景色 (黒 #1D1D1D) */
  background: #1D1D1D !important;
  border: 1px solid #fff !important;

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

  /* アニメーションの速度とイージング */
  transition: transform 0.2s cubic-bezier(0.45, 0, 0.55, 1); 

  /* 最背面に配置 */
  z-index: -1;
}
/* ホバー時のデザイン (a:hover) */
.section_btn a:hover,
.linker a:hover {
  /* ホバー時は文字色を白 (スライドの色とコントラストを出す) に変更 */
  /* 背景色・枠線は:afterがカバーするので、ここで指定は不要です */
  color: #fff !important;
  /* 枠線は白にしたい場合 (任意) */
  border: 1px solid #fff;
  opacity: 1;
}
/* ホバー時にスライド要素を拡大 (a:hover::after) */
.section_btn a:hover::after,
.linker a:hover::after {
  /* 最終状態: スケールを1にして全体を表示 */
  transform: scale(1, 1);
}

/*** お問い合わせ：送信ボタン ***/
.formapps .section_btn {
  /* 親要素をボタンラッパーとして使う場合の予備指定（必要なら有効化） */
  position: relative;
  display: inline-block; /* ボタン幅を内包する */
  overflow: hidden; /* 背景がはみ出さないようにする */
}
.formapps .section_btn input {
  /* ベーススタイル（見た目は従来と同等に） */
  background-color: #fff; /* 背景はグラデで制御するため透明に */
  background-image: linear-gradient(90deg, #1d1d1d 0%, #1d1d1d 100%);
  background-repeat: no-repeat;
  background-size: 0% 100%; /* ホバーで横幅100%に広げる */
  background-position: left top;

  border: 1px solid #1d1d1d !important;
  color: #1d1d1d !important;
  letter-spacing: 0.2rem;
  font-size: 16px;
  font-weight: 600;
  padding: 0.7rem 1.2rem; /* 適宜調整 */
  cursor: pointer;

  /* レイヤー順とアニメーション */
  position: relative;
  z-index: 1; /* 背景（bg）より前にテキストを出す */
  transition: background-size 0.22s cubic-bezier(0.45, 0, 0.55, 1), color 0.18s;
  appearance: none; /* 標準プロパティ（互換性のため先に記述） */
  -webkit-appearance: none; /* ブラウザ標準の見た目を抑制（必要に応じて） */
}
.formapps .section_btn input:hover,
.formapps .section_btn input:focus {
  background-size: 100% 100%; /* 横方向にスライドして塗りつぶす */
  color: #fff !important;
  /* 内側に白いボーダーを追加（ホバー時の内側枠） */
  box-shadow: inset 0 0 0 1px rgba(255,255,255,1);
}
/* アクセシビリティ: キーボードでフォーカスしたときは内側白枠＋外側リングを表示 */
.formapps .section_btn input:focus {
  outline: none;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,1), 0 0 0 3px rgba(27, 117, 211, 0.12);
}

/* =============================================== */
/***** グレースケール *****/
/* =============================================== */
.mainvisual_shift.section_name .section-image_bg.bg-cover {
    content: "";
    display: block;
    height: 100%;
    width: 100%;
    background-image: radial-gradient(rgba(0, 0, 0, .22) 20%, rgba(0, 0, 0, .12) 0), radial-gradient(rgba(0, 0, 0, .22) 20%, rgba(0, 0, 0, .12) 0);
    background-repeat: repeat;
    background-size: 3px 3px;
    background-color: rgba(0, 0, 0, 0.4);
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
}

/* 背景画像の上にオーバーレイをかけるためのスタイル */
.square_four_images_with_text .frame-image,
.h2_section:not(.page-case, .page-blog),
.circle-box_link .image-frame,
.h1_center_builder {
  position: relative; /* 疑似要素の基準位置にするため */
  z-index: 0;
}
.square_four_images_with_text .frame-image::before,
.h2_section:not(.page-case, .page-blog)::before,
.circle-box_link .image-frame::before,
.h1_center_builder::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: radial-gradient(rgba(0, 0, 0, .22) 20%, rgba(0, 0, 0, .12) 0), radial-gradient(rgba(0, 0, 0, .22) 20%, rgba(0, 0, 0, .12) 0);
  background-repeat: repeat;
  background-size: 3px 3px;
  background-color: rgba(0, 0, 0, 0.4);
  z-index: 1;
}
.square_four_images_with_text .frame-image .section_inner,
.h2_section .section_inner:not(.page-case, .page-blog),
.circle-box_link .image-frame .section_inner,
.h1_center_builder .section_inner {
  z-index: 2;
}


/* =============================================== */
/***** HOME *****/
/* =============================================== */
.half_two_image_misaligned {
  background-color: #1d1d1d !important;
}

.title_simple_wide_reversible .text-side .title-box {
  display: flex;
  flex-direction: column-reverse;
}
.title_simple_wide_reversible .text-side .title-box {
  display: flex;
  flex-direction: column-reverse;
  justify-content: flex-end;
}

.title_simple_wide_reversible .text-box {
    position: relative;
    margin-top: 50px;
    padding: 3rem;
    border: none;
}
/*.title_simple_wide_reversible .text-box .editable_wrap_title {
  font-size: 3rem;
}*/

.api_map_text .text-side_inner {
  /* 親要素をFlexコンテナとして設定 */
  display: flex;
  flex-direction: column; /* 縦積みに設定 */
}
/* 2番目の子（"会社案内"）を1番目に表示 */
.api_map_text .text-side_inner > .spacer-item_wrap:nth-child(2) {
  order: 0;
}
.api_map_text .text-side_inner > .spacer-item_wrap:nth-child(2) .spaceable {
  display: none;
}
/* 1番目の子（"COMPANY"）を2番目に表示 */
.api_map_text .text-side_inner > .spacer-item_wrap:nth-child(1) {
  order: 1;
  padding-bottom: 30px;
}
/* 3番目の子（"ライティング..."）を3番目に表示 */
.api_map_text .text-side_inner > .spacer-item_wrap:nth-child(3) {
  order: 2;
}
/* 4番目の子（"詳細を見る"ボタン）を4番目に表示 */
.api_map_text .text-side_inner > .section_btn {
  order: 3;
}

/* =============================================== */
/***** 事業内容 *****/
/* =============================================== */
.wide_block_link_flex .duplicatable-container {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin: 0 2rem;
}
.wide_block_link_flex .frame-image {
  /* 疑似要素を配置する基準にするため */
  position: relative; 
}
@media only screen and (min-width: 768px) {
  .wide_block_link_flex .frame-image::before {
    content: ''; /* 疑似要素には必須 */
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-left: 40px solid #1d1d1d;
    background-color: rgba(227, 135, 44, 0.5);
  }
}
@media only screen and (max-width: 768px) {
  .wide_block_link_flex .frame-image::before {
    content: ''; /* 疑似要素には必須 */
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-left: 30px solid #1d1d1d;
    background-color: rgba(227, 135, 44, 0.5);
  }
}
/*.wide_block_link_flex .image-side .image-frame-bg {
  background: #fff !important;
  border: 1px solid #1d1d1d;
}
.wide_block_link_flex .text-side .letter {
  color: #1d1d1d;
}*/

/* =============================================== */
/***** 選ばれる理由 *****/
/* =============================================== */
@media only screen and (min-width: 768px) {
  .title_backcolor .text-side .headding_wrap {
    display: inline-block;
    width: 400px;
    padding: 4px 20px;
    background: #1d1d1d;
  }
}
@media only screen and (max-width: 768px) {
  .title_backcolor .text-side .headding_wrap {
    display: inline-block;
    width: 280px;
    padding: 4px 20px;
    background: #1d1d1d;
  }
}
.title_backcolor .text-side .subtitle_wrap {
  display: inline-block;
  padding: 4px 20px;
  background: #E3872C;
}

/* =============================================== */
/***** 施工事例・新着情報 *****/
/* =============================================== */
.showcase_chart .showcase_chart_popnews_item_title_wrap,
.blog_posts .blog_chart_popnews_item_title_wrap {
  justify-content: space-between;
  flex-direction: column-reverse;
}
.showcase_chart .showcase_chart_popnews_item_day,
.blog_posts .post_popnews_data {
  text-align: left !important;
}
@media (min-width: 767.9px) {
  .blog_posts .posts_title,
  .showcase_chart .showcase_chart_title {
    font-size: 36px !important;
    font-weight: 600 !important;
  }
  .showcase_chart .post_popnews_title,
  .showcase_chart .showcase_chart_sidebar_title {
    font-size: 24px !important;
  }
  h2.showcase_chart_item_title,
  h3.showcase_chart_popnews_item_title,
  h2.blog_post_title,
  h3.post_popnews_text {
    font-size: 20px !important;
    font-weight: bold;
  }
}
@media (max-width: 768px) {
  .blog_posts .posts_title,
  .showcase_chart .showcase_chart_title {
    font-size: 28px !important;
    font-weight: 600 !important;
  }
  .showcase_chart .post_popnews_title,
  .showcase_chart .showcase_chart_sidebar_title,
  .blog_posts .post_archives_title,
  .blog_posts .post_category_title,
  .blog_posts .post_popnews_title,
  .blog_posts .post_tag_title {
    font-size: 20px !important;
  }
  h2.showcase_chart_item_title,
  h3.showcase_chart_popnews_item_title,
  h2.blog_post_title,
  h3.post_popnews_text {
    font-size: 18px !important;
    font-weight: bold;
  }
  .showcase_chart .banner_text:nth-child(3),
  .blog_posts .banner_text:nth-child(3) {
    font-size: 15px !important;
  }
}

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

  /* ★ アニメーション土台の追加 ★ */
  overflow: hidden; /* スライド要素をボタン内に隠す */
  position: relative; /* スライド要素の位置基準 */
  z-index: 1; /* スライド要素 (z-index: -1) の上にコンテンツを表示 */
  transition: color 0.2s; /* ホバー時に文字色がスムーズに変わるように */
}
/* スライドアニメーションの要素を定義 (全セレクタ共通) */
.blog_posts .banner_text .banner_link::after,
.showcase_chart .banner_text .banner_link::after,
.banner_text .banner_link::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;

  /* スライドの色 = ホバー時の背景色 (黒 #1d1d1d) */
  background: #1d1d1d;

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

  /* アニメーションの速度とイージング */
  transition: transform 0.2s cubic-bezier(0.45, 0, 0.55, 1); 

  /* 最背面に配置 */
  z-index: -1;
}
/* ホバー時のデザインとアニメーションの実行 (全セレクタ共通) */
.blog_posts .banner_text .banner_link:hover,
.showcase_chart .banner_text .banner_link:hover,
.banner_text .banner_link:hover {
  /* ホバー時は文字色と枠線を白に変更 */
  color: #fff !important;
  border-color: #fff;
  opacity: 1;
  /* background-color の変更は ::after が担うため不要 */
}

/* ホバー時にスライド要素を拡大 (アニメーション実行) */
.blog_posts .banner_text .banner_link:hover::after,
.showcase_chart .banner_text .banner_link:hover::after,
.banner_text .banner_link:hover::after {
  /* 最終状態: スケールを1にして全体を表示 */
  transform: scale(1, 1);
}

.blog_posts .banner_text ._color_,
.showcase_chart .banner_text ._color_,
.banner_text ._color_ {
  color: #E3872C !important;
}
.blog_posts .banner_text:nth-child(3),
.showcase_chart .banner_text:nth-child(3) {
  font-size: 15px !important;
  font-weight: 600;
}
/*** 新着情報 ***/
.breadcrumb_item {
  display: flex;
  place-items: center;
}
.blog_posts_index .blog_posts_sidebar {
  flex: 1 0 320px !important;
  margin: 0 0 0 84px;
}

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

/* =============================================== */
/***** e-thanks *****/
/* =============================================== */
@media only screen and (min-width: 1025px) {
  section:first-of-type .content {
    padding: 0;
  }
  .thanks_page .catch_text {
    padding: 4rem 0;
    font-size: 36px !important;
    font-weight: bold;
    color: #1d1d1d;
    text-align: center !important;
    letter-spacing: 0.1em
  }
}
.thanks_page {
  background-color: #F0F0F0;
}
.catch.text-side {
  margin: 0;
}
.thanks_page .catch {
  padding: 5%;
  background-color: #fff;
  border: 0.2rem;
  border: none !important;
}
.thanks_page .headding_wrap,
.thanks_page .subtitle_wrap {
  display: flex;
  justify-content: center;
}

.thanks_page .catch_text {
  font-weight: bold;
  color: #1d1d1d;
  text-align: center !important;
  letter-spacing: 0.1em
}
.thanks_page .subtitle_wrap .catch_subtext {
  color: #E3872C;
  font-weight: bold;
  text-align: center !important;
  letter-spacing: 0.1em;
}

@media only screen and (max-width: 768px) {
  .thanks_contents .section_inner {
    padding: 20rem 3rem;
  }
}

/* =============================================== */
/***** その他 *****/
/* =============================================== */
@media only screen and (max-width: 768px) {
  .letter,
  /*span:not(.mainvisual_shiflt .section_inner .text-side h1 *),*/
  .mainvisual_shift .catch .catch_subtext,
  .multiple_btn .section_inner .section_btn .linker a,
  .title_light_builder_company .letter_wrap font,
  .text-side .subtitle .font-en,
  .text-side .subtitle .font-ja:not(.flamingoSlide_app .mainvisual_responsive_slider .text-side .subtitle .font-ja),
  .spacer-item_wrap .editable.subtitle * {
    font-size: 15px !important;
  }
  .wide_block_link_flex .section_inner .text-side .letter,
  .wide_block_link_flex .section_inner .text-side .letter *,
  .title_backcolor .text-side .headding_wrap .headding {
    font-size: 24px !important;
  }
  .formapps .section_btn {
    display: flex;
  }
}
@media only screen and (max-width: 768px) {
  .mainvisual_shift .catch .catch_text span {
    font-size: 6rem !important;
  }
  .footer_menu_center_builder .detail-side {
    background-color: #E3872C;
  }
  .footer_menu_center_builder .detail-side_first .tel {
    color: #fff;
  }
}

#global-nav .gnav_accordion_icon_builder .gnav_sp .gnav-editable-contents {
    margin-top: 0;
}
#global-nav .gnav_accordion_icon_builder .gnav_sp .gnav-editable-contents .gnav-btn {
  width: 60%;
  color: #fff !important;
  margin-top: 30px;
  margin-left: 0;
  padding: 2rem;
  height: 40px;
  border-radius: 0;
}

/* === MV テキストのシャドウ削除＋背景追加*/
.mainvisual_responsive_slider .catch,
.mainvisual_responsive_slider .catch_text {
  text-shadow: none !important;
}
/*
.mainvisual_responsive_slider .catch {
  background: rgba(255, 255, 255, 0.88);
  padding: 2rem 2.5rem;
  display: inline-block;
}
*/
/*20260109修正--------------------------------------------------*/
/*mv*/
.mainvisual_responsive_slider .catch {
  width: 71%;
  background: #e3872c;
  padding: 2.0rem 3rem;
  left: 35%;
  top: 62%;
}
.flamingo-slider-pagination{
display:none;
}
.mainvisual_responsive_slider{
border-left: 40px solid #E3872C;
}
@media only screen and (min-width: 1025px) {
    .mainvisual_responsive_slider .headding_wrap .headding{
        font-size: 5.4rem;
  }
}
/*mv_sp調整*/
@media only screen and (max-width: 1024px) {
.mainvisual_responsive_slider .headding_wrap .headding{
       font-size: 4vw;
  }
}
@media only screen and (max-width: 480px) {
.mainvisual_responsive_slider .headding_wrap .headding{
       font-size: 2.0rem;
  }
.mainvisual_responsive_slider .catch{
       width: 90%;
      left: 44%;
}
}
@media only screen and (max-width: 767px) {
.mainvisual_responsive_slider .section_block{
height: 100vh;
}
.mainvisual_responsive_slider .catch{
    padding: 1.5rem 2rem;
}
}

