最新カスタムCSS

コピー元サイトに記述しているCSSの最新版です。
マスターテンプレートをもとにしたサイトのアップセルや、元の記述を参照したい時などに活用してください。

//C2-24.1211

/*
variables(変数)
webフォント
Mixins
spフォント設定
common(ウェブサイト共通) >> セクション、リッチテキスト、CTA(共通パーツ)、リンク埋め込みパーツ、ブログ、サーチエリア、リンクリスト、検索結果、ページネーション
entry-list( 記事リストパーツ)
header・logo・navigations(ヘッダー・ロゴ・ナビゲーション)
main-visual(メインビジュアル)
breadcrumbs(パンくず)
button(ボタン)
heading(見出し)
article-post(ブログ用見出し)
main(コンテンツ) >> CTAを用いたパーツ、CTA内の基本設定、2カラム(CTA)、フォームフッター、デザインLPパーツ、カスタムパーツ、ユニバーサルクラス、フォームパーツ、
blog(ブログテンプレート)
カテゴリ・タグ自動生成ページ
side bar(サイドバー) >> カテゴリー、ランキング、カテゴリーアイコン
foot(フッター)
LP(フルカスタム用)
col空処理
編集画面用CSS(編集画面のみに効くCSS)
*/

/* --------------------------------
    variables(変数)
----------------------------------- */
//フォント
$font_feature_settings:"palt" 1;
$font_family_awsm: "FontAwesome";
$font_family_awsm6: "Font Awesome 6 Free";
//既存フォント以外のフォントファミリー設定(使用しない場合は削除してください)
// #__next {
//   --fo-heading-font-family: "Hiragino Kaku Gothic ProN", Meiryo, メイリオ, sans-serif;
//   --fo-text-font-family: "Hiragino Kaku Gothic ProN", Meiryo, メイリオ, sans-serif;
// }

//hover用
$hover_opacity: .4;

//文字の太さ
$font_weight: bold;

//カラー
$border_color: #eee; //ボーダーカラー
$form_hissu_color: #c70909; //赤 フォームの「必須マーク」カラー

//ヘッダーロゴ
$header_logo: 300px; //PCでの幅サイズ(固定)
$header_sp_logo: 35px; //SPでの高さサイズ(maxサイズ)

//ボックスシャドウ
$box_shadow_common: 0 3px 8px var(--fo-shadow-color); //ボックスシャドウ
$navigation_box_shadow_common: 0 3px 8px rgba(#000,.1); //ナビゲーション専用

//角丸
$border_radius_common: 20px;

//メインビジュアル
$mv_padding: 40px 0; //PC時の上下余白
$sp_mv_padding: 30px 0 40px; //SP時の上下余白
$top_mv_height: 490px; //PC時の最低の高さ(SPはauto)
$sub_mv_height: 273px; //PC時の最低の高さ(SPはauto)

//見出し
$hd_font_strong: 400; //見出し用(編集画面の「.strong」に対応)
//ページ内リンクのずれ用
$inPage_link: 74px; //上部にあるコンテンツの高さ(PC)
$sp_inPage_link: 64px; //上部にあるコンテンツの高さ(SP)

//グロナビ PC
$header_bg_color: var(--fo-background-color1); //ヘッダー全体の背景色
$navigation_bg_color: $header_bg_color; //グロナビの背景色
$navigation_font_size: 14px; //グロナビのフォントサイズ(1〜3階層)
$navigation_font_weight: normal; //グロナビのフォントの太さ(1〜3階層) normal or bold
$navigation_hover_opacity: 1; //グロナビをホバーした時の透視度
$navigation_bg2_color: $navigation_bg_color; //グロナビの背景色(2階層以下)
$navigation_text_color: var(--fo-text-main-color); //グロナビのテキストカラー
$navigation_text2_color: $navigation_text_color; //グロナビのテキストカラー(2階層以下)
$navigation_hover_bg_color: #fff; //グロナビをホバーした時の背景色
$navigation_hover_bg2_color: var(--fo-main-color); //グロナビをホバーした時の背景色(2階層以下)
$navigation_hover_text_color: var(--fo-main-color); //グロナビをホバーした時のテキストカラー
$navigation_hover_text2_color: #fff; //グロナビをホバーした時のテキストカラー(2階層以下)
$navigation_arrow1_color: $navigation_text_color; //矢印カラー(1階層)
$navigation_arrow2_color: $navigation_arrow1_color; //矢印カラー(2階層)

//グロナビ ハンバーガーメニュー
$navigation_sp_font_size: 14px; //ハンバーガーメニュー(SP)時のテキストサイズ(1〜3階層)
$navigation_sp_font_weight: normal; //ハンバーガーメニュー(SP)時のテキストの太さ(1〜3階層) normal or bold
$navigation_sp_text_color: var(--fo-text-main-color); //ハンバーガーメニュー(SP)時のテキストカラー 1階層
$navigation_sp_text2_color: var(--fo-text-main-color); //ハンバーガーメニュー(SP)時のテキストカラー(2階層)
$navigation_sp_text3_color: var(--fo-text-main-color); //ハンバーガーメニュー(SP)時のテキストカラー(3階層)
$navigation_sp_hover_text_color: #fff; //ハンバーガーメニュー(SP)時のホバーした時の2階層のテキスト&矢印のカラー
$navigation_sp_arrow1_color: $navigation_sp_text_color; //ハンバーガーメニュー(SP) 矢印カラー(1階層)
$navigation_sp_arrow2_color: $navigation_sp_text2_color; //ハンバーガーメニュー(SP) 矢印カラー(2階層)
$navigation_sp_bg_color: var(--fo-main-color); //ハンバーガーメニュー(SP)時の背景色(1階層)
$navigation_sp_bg2_color: #fff; //ハンバーガーメニュー(SP)時の背景色(2階層)
$navigation_sp_bg3_color: #eee; //ハンバーガーメニュー(SP)時の背景色(3階層)
$navigation_sp_border-bottom: 1px dashed var(--fo-main-color); //ハンバーガーメニュー(SP)時のボーダー(hamburger_custom 使用時)

//見出しサイズ統一
$list_heading_pc_fontsize: 20px;
$list_heading_sp_fontsize: 20px;

//記事リストパーツ
$case_border_radius: 0; //画像の角丸
$case_title_letter_spacing: var(--fo-text-letter-spacing); //記事リストパーツのタイトル(h3) letter-spacing(文字間)
$case_title_font_family: inherit; //記事リスト内見出しのフォントファミリー(caseContent_style・news_list)
$case_date_font_family: inherit; //記事リスト内日付のフォントファミリー(caseContent_style・news_list)
$case_pagination_color: var(--fo-main-color); //記事リストパーツのページネーションカラー
$case_box_shadow_common: $box_shadow_common; //記事リストパーツ用( 0 0 3px #ddd;)
$case_img_fit_height: 200px; //caseContent_style画像のオプション(option_img_fit)の高さ(sp時も高さ維持)
$case_list_space: 12px; //caseContent_style記事間の余白
//news_list
$news_list_text_decoration: none; //見出しアンカーの下線の無有(news_list) underline or none
$news_list_hover_opacity: $hover_opacity; //見出しアンカーのhover時の不透明度(news_list)

//ブログ
$blog_title_fontsize: 20px; //ブログトップタグ・カテゴリ一覧とのタイトル(h2)フォントサイズ
$blog_border_radius: 0; //ブログ記事一覧画像の角丸
$blog_border_color: $border_color; //一覧のボーダーと人気記事ランキングのボーダーカラー
$blog_title_h1_fontsize_pc: 36px; //ブログ詳細h1見出しフォントサイズ(PC)
$blog_title_h1_fontsize_sp: 28px; //ブログ詳細h1見出しフォントサイズ(SP)
$blog_title_h2_fontsize_pc: 32px; //ブログ詳細h2見出しフォントサイズ(PC)
$blog_title_h2_fontsize_sp: 24px; //ブログ詳細h2見出しフォントサイズ(SP)
$blog_title_h3_fontsize_pc: var(--fo-h3-font-size-pc); //ブログ詳細h3見出しフォントサイズ(PC)
$blog_title_h3_fontsize_sp: var(--fo-h3-font-size-sp); //ブログ詳細h3見出しフォントサイズ(SP)
$blog_title_h4_fontsize_pc: var(--fo-h4-font-size-pc); //ブログ詳細h4見出しフォントサイズ(PC)
$blog_title_h4_fontsize_sp: var(--fo-h4-font-size-sp); //ブログ詳細h4見出しフォントサイズ(SP)
$blog_title_h5_fontsize_pc: var(--fo-h5-font-size-pc); //ブログ詳細h5見出しフォントサイズ(PC)
$blog_title_h5_fontsize_sp: var(--fo-h5-font-size-sp); //ブログ詳細h5見出しフォントサイズ(SP)

//フッター
$footer_bg_color: var(--fo-background-color2); //フッター全体の背景色
$copyright_bg_color: inherit;  //コピーライトの背景色
$copyright_text_color: var(--fo-text-main-color); //コピーライトのテキストカラー
$copyright_text_fontsize: 12px; //コピーライトのフォントサイズ

//その他
$max_width: 1240px; //コンテンツ幅調整用

/*------------- variables(変数)END -------------*/

/* --------------------------------
   webフォント
----------------------------------- */
/*---  Web fonts ---*/
//Awesome Font 6
@import url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.2/css/all.min.css");
//Awesome Font
@import url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css");

/*------------- webフォント END -------------*/

/*----------------------------------
    Mixins
----------------------------------*/
@mixin breakpoint-ssp {
  @media screen and (max-width: 576px) {
    @content;
  }
}

@mixin breakpoint-sp {
  @media screen and (max-width: 769px) {
    @content;
  }
}

@mixin breakpoint-msp {
  @media screen and (max-width: 834px) {
    @content;
  }
}

@mixin breakpoint-tb {
  @media screen and (min-width: 577px) and (max-width: 769px) {
    @content;
  }
}

@mixin breakpoint-pro_s {
  @media screen and (min-width: 770px) and (max-width: 834px) {
    @content;
  }
}

@mixin breakpoint-pro {
  @media screen and (min-width: 770px) and (max-width: 1024px) {
    @content;
  }
}

@mixin breakpoint-pc {
  @media screen and (min-width: 770px) {
    @content;
  }
}

////タグ・カテゴリー 設定
//タグスタイルコントロール
@mixin tag_custom {
  background-color: var(--fo-tag-background-color);
  font-size: 12px;
  line-height: 1.2;
  letter-spacing: normal;
  color: var(--fo-tag-text-color);
  border: 1px solid var(--fo-tag-border-color,var(--fo-tag-background-color));
  border-radius: var(--fo-tag-border-radius);
  margin: 5px 10px 5px 0;
  padding: 5px 15px;
  &:hover {
    opacity: $hover_opacity;
  }
}
//タグアイコンコントロール
@mixin tag_icon_custom {
  content: var(--fo-tag-fa-unicode,none);
  font-family: $font_family_awsm;
  margin-right: 5px;
}
//カテゴリーアイコンコントロール
@mixin category_icon_custom {
  content: "\f115"; //f0c9
  font-family: $font_family_awsm;
  color: var(--fo-main-color);
  margin-right: 5px;
}
////タグ・カテゴリー 設定 end

//ブログ見出し
@mixin hd_blog {
  :is(h1,h2,h3,h4,h5) {
    font-family: var(--fo-heading-font-family);
    font-weight: 700;
    line-height: var(--fo-heading-line-height);
    letter-spacing: var(--fo-heading-letter-spacing);
    color: var(--fo-heading-main-color);
    @include breakpoint-sp {
      overflow-wrap: break-word;
    }
  }
  h1 {
    @include breakpoint-pc {
      font-size: $blog_title_h1_fontsize_pc;
    }
    @include breakpoint-sp {
      font-size: $blog_title_h1_fontsize_sp;
    }
  }
  h2 {
    @include breakpoint-pc {
      font-size: $blog_title_h2_fontsize_pc;
    }
    @include breakpoint-sp {
      font-size: $blog_title_h2_fontsize_sp;
    }
  }
  h3 {
    border-color: $border_color;
    @include breakpoint-pc {
      font-size: $blog_title_h3_fontsize_pc;
    }
    @include breakpoint-sp {
      font-size: $blog_title_h3_fontsize_sp;
    }
  }
  h4 {
    @include breakpoint-pc {
      font-size: $blog_title_h4_fontsize_pc;
    }
    @include breakpoint-sp {
      font-size: $blog_title_h4_fontsize_sp;
    }
  }
  h5 {
    @include breakpoint-pc {
      font-size: $blog_title_h5_fontsize_pc;
    }
    @include breakpoint-sp {
      font-size: $blog_title_h5_fontsize_sp;
    }
  }
  .strong {
    font-weight: 400;
  }
}
//ブログ見出し end

//.page_top_rowスタイルコントロール
@mixin page_top {
  min-height: unset;
  :is(.col,.cta-column) {
    padding: 0;
    .component {
      &.image {
        width: auto;
        position: fixed;
        right: 0;
        bottom: 0;
        z-index: 1000;
        margin: 0;
        img {
          width: 60px !important;
        }
      }
    }
  }
}
//編集画面用
@mixin edit-page_top {
  :is(.col,.cta-column) {
    .component {
      &.image {
        position: static;
        width: 100%;
        margin: 10px 0;
        outline: 1px dotted #0987d4;
        &::before {
          content: "↑ 公開ページでは右下に固定されます ↑";
          display: inline-block;
          text-align: center;
          background: #0987d4;
          font-size: 12px;
          color: #fff;
          position: absolute;
          right: 0;
          top: calc(100% - 9px);
          left: 0;
          z-index: 1;
          padding: 5px;
        }
      }
    }
  }
}
//.page_top_row 設定 end

//.foot-copyrightスタイルコントロール
@mixin copyright_custom {
  display: flex;
  justify-content: center;
  align-items: center;
  background: $copyright_bg_color;
  height: 60px;
  margin: 0;
  padding: 0;
  @include breakpoint-sp {
    padding: 0 70px 0 10px;
  }
  @include breakpoint-tb {
    padding: 0;
  }
  p {
    font-size: $copyright_text_fontsize;
    letter-spacing: var(--fo-text-letter-spacing);
    line-height: 1.3;
    color: $copyright_text_color;
    margin: 0;
  }
}
//.foot-copyright一括修正 end

//検索結果画面コンテンツ幅統一用
@mixin search_container {
  max-width: $max_width;
  margin: auto;
  padding: 0 20px;
}

//編集画面用CSS
@mixin edit-page {
  .frame-root .frame-content {
    @content;
  }
}

//セクション余白
@mixin sectionSpace($padding:none) {
  @if($padding == none) {}
  @else if($padding > 0) {
    @include breakpoint-pc {
      padding: calc(#{$padding} * var(--fo-spacing-coef) - 30px) 0 calc(#{$padding} * var(--fo-spacing-coef) - 40px);
    }
    @include breakpoint-sp {
      padding: calc(#{$padding} * var(--fo-spacing-coef) * .75 - 30px) 0;
    }
  }
}

//ボタン(1~3)
@mixin btn_custom($btn) {
  &:is(.size-s,.size-m,.size-l) {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--fo-button#{$btn}-background) -1px/calc(100% + 2px);
    box-sizing: border-box;
    font-family: var(--fo-text-font-family);
    color: var(--fo-button#{$btn}-text-color);
    text-decoration: none;
    text-align-last: left;
    letter-spacing: var(--fo-text-letter-spacing);
    line-height: var(--fo-text-line-height);
    border: 1px solid var(--fo-button#{$btn}-border-color,transparent);
    border-radius: var(--fo-button#{$btn}-border-radius);
    box-shadow: $box_shadow_common;
  }
  &.size-s {
    min-width: var(--fo-button-small-min-width-pc);
    font-size: var(--fo-button-small-font-size);
    padding: 6.75px 20px;
    @include breakpoint-sp {
      min-width: var(--fo-button-small-min-width-sp);
      width: auto;
    }
    @include breakpoint-tb {
      min-width: var(--fo-button-small-min-width-pc);
    }
  }
  &.size-m {
    min-width: var(--fo-button-medium-min-width-pc);
    font-size: var(--fo-button-medium-font-size);
    padding: 13.5px 20px;
    @include breakpoint-sp {
      width: auto;
      min-width: var(--fo-button-medium-min-width-sp);
    }
    @include breakpoint-tb {
      min-width: var(--fo-button-medium-min-width-pc);
    }
  }
  &.size-l {
    min-width: var(--fo-button-large-min-width-pc);
    font-size: var(--fo-button-large-font-size);
    padding: 17.5px 20px;
    @include breakpoint-sp {
      width: var(--fo-button-large-min-width-sp);
      min-width: auto;
    }
    @include breakpoint-tb {
      width: auto;
      min-width: var(--fo-button-large-min-width-pc);
    }
  }
  &:hover {
    opacity: var(--fo-button#{$btn}-hover-opacity,1);
    scale: var(--fo-button#{$btn}-hover-scale,1);
    //反転
    background: var(--fo-button#{$btn}-hover-background-color,var(--fo-button#{$btn}-background)) -1px/calc(100% + 2px);
    color: var(--fo-button#{$btn}-hover-text-color,var(--fo-button#{$btn}-text-color));
    border: 1px solid var(--fo-button#{$btn}-hover-border-color, var(--fo-button#{$btn}-border-color, transparent));
  }
}

//flex
@mixin flex-setting($gap:null,$direction:null,$wrap:null,$justify-content:null,$align-items:null,$device:all) {
  @if($device == all) {
    display : flex;
    gap: $gap;
    flex-direction : $direction;
    flex-wrap : $wrap;
    justify-content : $justify-content;
    align-items : $align-items;
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      display : flex;
      gap: $gap;
      flex-direction : $direction;
      flex-wrap : $wrap;
      justify-content : $justify-content;
      align-items : $align-items;
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      display : flex;
      gap: $gap;
      flex-direction : $direction;
      flex-wrap : $wrap;
      justify-content : $justify-content;
      align-items : $align-items;
    }
  }
}
//gap
@mixin flex-gap ($gap:20px,$device:all) {
  @if($device == all) {
    gap: calc(#{$gap} * var(--fo-spacing-coef));
    @include breakpoint-sp {
      gap: calc((#{$gap} * var(--fo-spacing-coef)) * .75);
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      gap: calc(#{$gap} * var(--fo-spacing-coef));
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      gap: calc(#{$gap} * var(--fo-spacing-coef));
    }
  }
}

// カラム内要素の位置調整
@mixin row-col-flex($directio:column) {
  .col {
    &:is(.vertical_position_top,.vertical_position_middle,.vertical_position_bottom) {
      @include breakpoint-pc {
        display: flex;
        flex-direction: #{$directio};
        align-self: auto !important;
      }
      .component {
        & + .component {
          @include breakpoint-pc {
            margin-top: 0;
          }
        }
      }
    }
    &.vertical_position_top {
      @include breakpoint-pc {
        justify-content: start;
      }
    }
    &.vertical_position_middle {
      @include breakpoint-pc {
        justify-content: center;
      }
    }
    &.vertical_position_bottom {
      @include breakpoint-pc {
        justify-content: end;
      }
    }
  }
}

//padding
@mixin padding-All($paddingTop:20px,$paddingRight:20px,$paddingBottom:20px,$paddingLeft:20px,$device:all) {
  @if($device == all) {
    @include breakpoint-pc {
      padding: calc(#{$paddingTop} * var(--fo-spacing-coef)) calc(#{$paddingRight} * var(--fo-spacing-coef)) calc(#{$paddingBottom} * var(--fo-spacing-coef)) calc(#{$paddingLeft} * var(--fo-spacing-coef));
    }
    @include breakpoint-sp {
      padding: calc((#{$paddingTop}  * var(--fo-spacing-coef)) * .75) calc((#{$paddingRight} * var(--fo-spacing-coef)) * .75) calc((#{$paddingBottom} * var(--fo-spacing-coef)) * .75) calc((#{$paddingLeft} * var(--fo-spacing-coef)) * .75);
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      padding: calc(#{$paddingTop} * var(--fo-spacing-coef)) calc(#{$paddingRight} * var(--fo-spacing-coef)) calc(#{$paddingBottom} * var(--fo-spacing-coef)) calc(#{$paddingLeft} * var(--fo-spacing-coef));
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      padding: calc(#{$paddingTop} * var(--fo-spacing-coef)) calc(#{$paddingRight} * var(--fo-spacing-coef)) calc(#{$paddingBottom} * var(--fo-spacing-coef)) calc(#{$paddingLeft} * var(--fo-spacing-coef));
    }
  }
}

//padding 一方向
@mixin padding-property($property:top,$value:20px,$device:all) {
  @if($device == all) {
    @include breakpoint-pc {
      padding-#{$property}: calc(#{$value} * var(--fo-spacing-coef));
    }
    @include breakpoint-sp {
      padding-#{$property}: calc((#{$value} * var(--fo-spacing-coef)) * .75);
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      padding-#{$property}: calc(#{$value} * var(--fo-spacing-coef));
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      padding-#{$property}: calc(#{$value} * var(--fo-spacing-coef));
    }
  }
}

//padding上下左右
@mixin padding-yx($paddingY:20px,$paddingX:20px,$device:all) {
  @if($device == all) {
    @include breakpoint-pc {
      padding: calc(#{$paddingY} * var(--fo-spacing-coef)) calc(#{$paddingX} * var(--fo-spacing-coef));
    }
    @include breakpoint-sp {
      padding: calc((#{$paddingY} * var(--fo-spacing-coef)) * .75) calc((#{$paddingX} * var(--fo-spacing-coef)) * .75);
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      padding: calc(#{$paddingY} * var(--fo-spacing-coef)) calc(#{$paddingX} * var(--fo-spacing-coef));
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      padding: calc(#{$paddingY} * var(--fo-spacing-coef)) calc(#{$paddingX} * var(--fo-spacing-coef));
    }
  }
}

//margin上下
@mixin margin-y($marginTop:20px,$marginBottom:20px,$device:all) {
  @if($device == all) {
    @include breakpoint-pc {
      margin: unquote('max(calc(#{$marginTop} * var(--fo-spacing-coef)),0px)') auto unquote('max(calc(#{$marginBottom} * var(--fo-spacing-coef)),0px)');
    }
    @include breakpoint-sp {
      margin: unquote('max(calc((#{$marginTop} * var(--fo-spacing-coef)) * .75),0px)') auto unquote('max(calc((#{$marginBottom} * var(--fo-spacing-coef)) * .75),0px)');
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      margin: unquote('max(calc(#{$marginTop} * var(--fo-spacing-coef)),0px)') auto unquote('max(calc(#{$marginBottom} * var(--fo-spacing-coef)),0px)');
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      margin: unquote('max(calc(#{$marginTop} * var(--fo-spacing-coef)),0px)') auto unquote('max(calc(#{$marginBottom} * var(--fo-spacing-coef)),0px)');
    }
  }
}

//margin一方向
@mixin margin-property($property:top,$value:20px,$device:all) {
  @if($device == all) {
    @include breakpoint-pc {
      margin-#{$property}: unquote('max(calc(#{$value} * var(--fo-spacing-coef)),0px)');
    }
    @include breakpoint-sp {
      margin-#{$property}: unquote('max(calc((#{$value} * var(--fo-spacing-coef)) * .75),0px)');
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      margin-#{$property}: unquote('max(calc(#{$value} * var(--fo-spacing-coef)),0px)');
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      margin-#{$property}: unquote('max(calc(#{$value} * var(--fo-spacing-coef)),0px)');
    }
  }
}

//見出し用margin-bottom
@mixin heading-marginBottom($marginBottom:60px,$device:all) {
  @if($device == all) {
    @include breakpoint-pc {
      margin-bottom: unquote('max(calc((#{$marginBottom} * var(--fo-spacing-coef)) - 20px),0px)');
    }
    @include breakpoint-sp {
      margin-bottom: unquote('max(calc((#{$marginBottom} * var(--fo-spacing-coef)) * .75),0px)');
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      margin-bottom: unquote('max(calc(#{$marginBottom} * var(--fo-spacing-coef)),0px)');
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      margin-bottom: unquote('max(calc(#{$marginBottom} * var(--fo-spacing-coef)),0px)');
    }
  }
}

//隣接要素のmargin
@mixin adjacentMargin($className:row,$marginTop:46px,$device:all) {
  & + .#{$className} {
    @if($device == all) {
      @include breakpoint-pc {
        margin-top: unquote('max(calc(#{$marginTop} * var(--fo-spacing-coef)),0px)');
      }
      @include breakpoint-sp {
        margin-top: unquote('max(calc((#{$marginTop} * var(--fo-spacing-coef)) * .75),0px)');
      }
    }
    @else if($device == pc) {
      @include breakpoint-pc {
        margin-top: unquote('max(calc(#{$marginTop} * var(--fo-spacing-coef)),0px)');
      }
    }
    @else if($device == sp) {
      @include breakpoint-sp {
        margin-top: unquote('max(calc(#{$marginTop} * var(--fo-spacing-coef)),0px)');
      }
    }
  }
}

//テーマ出力
@mixin theme-fo-base {
  .theme-fo-base {
    .wrapper {
      .contents {
        :is(section,section[data-designpart-id]) {
          @content;
        }
      }
    }
  }
}

/*------------- Mixins END -------------*/

/* --------------------------------
   spフォント設定
----------------------------------- */
.component {
  :is(
    .font-size-20px,
    [style*="font-size:20px;"]
  )
   {
    @include breakpoint-sp {
      font-size: 18px !important;
    }
  }
  :is(
    .font-size-22px,
    [style*="font-size:22px;"]
  ) {
    @include breakpoint-sp {
      font-size: 20px !important;
    }
  }
  :is(
    .font-size-24px,
    .font-size-26px,
    [style*="font-size:24px;"],
    [style*="font-size:26px;"]
    ) {
    @include breakpoint-sp {
      font-size: 22px !important;
    }
  }
  :is(
    .font-size-28px,
    .font-size-30px,
    [style*="font-size:28px;"],
    [style*="font-size:30px;"]
    ) {
    @include breakpoint-sp {
      font-size: 24px !important;
    }
  }
  :is(
    .font-size-32px,
    .font-size-34px,
    .font-size-36px,
    [style*="font-size:32px;"],
    [style*="font-size:34px;"],
    [style*="font-size:36px;"]
    ) {
    @include breakpoint-sp {
      font-size: 26px !important;
    }
  }
  :is(
    .font-size-38px,
    .font-size-42px,
    .font-size-46px,
    [style*="font-size:38px;"],
    [style*="font-size:42px;"],
    [style*="font-size:46px;"]
    ) {
    @include breakpoint-sp {
      font-size: 28px !important;
    }
  }
  :is(
    .font-size-50px,
    .font-size-54px,
    [style*="font-size:50px;"],
    [style*="font-size:54px;"],
    ) {
    @include breakpoint-sp {
      font-size: 32px !important;
    }
  }
  :is(
    .font-size-60px,
    .font-size-66px,
    .font-size-72px,
    [style*="font-size:60px;"],
    [style*="font-size:66px;"],
    [style*="font-size:72px;"]
    ) {
    @include breakpoint-sp {
      font-size: 36px !important;
    }
  }
  :is(
    .font-size-78px,
    .font-size-86px,
    .font-size-94px,
    [style*="font-size:78px;"],
    [style*="font-size:86px;"],
    [style*="font-size:94px;"]
    ) {
    @include breakpoint-sp {
      font-size: 40px !important;
    }
  }
}
/*------------- spフォント設定 END -------------*/

/* --------------------------------
   common(ウェブサイト共通)
----------------------------------- */
//ドラックカラー
::selection {
  background: color-mix(in srgb, var(--fo-accent-color) 50%, transparent);
}

//sticky解放用
.theme-fo-base {
  &:has(.lp_sticky_sec) {
    overflow: initial;
    .wrapper {
      .contents {
        section {
          overflow: hidden;
        }
      }
    }
  }
}

//SP時のリンクタップの色を削除&下線削除
:is(.navi-001-01,.navi-002-01,.theme-fo-base) {
  font-family: var(--fo-text-font-family);
  font-feature-settings: $font_feature_settings;
  a {
    transition: unset;
    -webkit-tap-highlight-color:rgba(0,0,0,0);
  }
  :visited {
    text-decoration: none;
  }
  :link {
    text-decoration: none;
  }
}

//画像のhover一括設定
:is(.navi-001-01,.navi-002-01) {
  header {
    .inner {
      a[href] {
        img {
          &:hover {
            opacity: $hover_opacity;
          }
        }
      }
    }
  }
}
.theme-fo-base {
  .main-visual {
    .component {
      a {
        img {
          &:hover {
            opacity: 1;
          }
        }
      }
      a[href] {
        img {
          &:hover {
            opacity: $hover_opacity;
          }
        }
      }
    }
  }
  .wrapper {
    .contents {
      section {
        a {
          img {
            &:hover {
              opacity: 1;
            }
          }
        }
        a[href] {
          img {
            &:hover {
              opacity: $hover_opacity;
            }
          }
        }
      }
    }
    .side {
      .inner {
        .component {
          a {
            img {
              &:hover {
                opacity: 1;
              }
            }
          }
          a[href] {
            img {
              &:hover {
                opacity: $hover_opacity;
              }
            }
          }
        }
      }
    }
  }
  .foot {
    .foot-cont {
      .component {
        a {
          img {
            &:hover {
              opacity: 1;
            }
          }
        }
        a[href] {
          img {
            &:hover {
              opacity: $hover_opacity;
            }
          }
        }
      }
    }
  }
}

/*- セクションパーツ -*/
//セクション余白
// ()内に指定したいサイズを入れると適用されます。例:(100px)
// ()内に数値が入ってない場合は適用されません。(デフォルト設定)
section[data-designpart-id]:not(:root:root:root:root) {
  @include sectionSpace();
}
//コンテンツ幅
@include theme-fo-base {
  .inner {
    max-width: $max_width;
  }
}

/*--- リッチテキストパーツ ---*/
.component {
  &.richtext {
    :link {
      text-decoration: none;
    }
    :visited {
      text-decoration: none;
    }
    //リスト
    li {
      font-size: inherit;
      a {
        font-size: inherit;
      }
    }
    //表
    table {
      border: none;
      &[align="center"] {
        margin: auto;
      }
      :is(thead,tbody,tr,th,td) {
        border-color: $border_color;
        tr {
          :is(th,td) {
            background-clip: padding-box; //FF,edgeでボーダー消える現象回避;
            position: static; //FF,edgeでボーダー消える現象回避;
            p {
              font-size: inherit;
              & + p {
                margin-top: 10px !important;
              }
            }
            :is(ul,ol) {
              margin-left: 25px;
            }
          }
        }
      }
    }
    .normal-table {
      &::after {
        content: "";
        display: table;
        clear: both;
      }
    }
    .table-with-row-header {
      &::after {
        content: "";
        display: table;
        clear: both;
      }
    }
    .table-with-two-headers {
      overflow: auto;
      &::after {
        content: "";
        display: table;
        clear: both;
      }
    }
    .component {
      &.button:not(:root) {
        .button-cont {
          a {
            &.blue {
              background: #254a73;
              color: #fff !important;
              text-decoration: none;
              &:hover {
                opacity: $hover_opacity;
              }
            }
          }
        }
      }
    }
    //sp時右寄せ
    &.sp_r {
      @include breakpoint-sp {
        text-align: right !important;
      }
      :is(p,.rich-text-normal,.align-center,.align-right) {
        @include breakpoint-sp {
          text-align: right !important;
        }
      }
    }
    //sp中央寄せ
    &.sp_c {
      @include breakpoint-sp {
        text-align: center !important;
      }
      :is(p,.rich-text-normal,.align-center,.align-right) {
        @include breakpoint-sp {
          text-align: center !important;
        }
      }
    }
    //sp時左寄せ
    &.sp_l {
      @include breakpoint-sp {
        text-align: left !important;
      }
      :is(p,.rich-text-normal,.align-center,.align-right) {
        @include breakpoint-sp {
          text-align: left !important;
        }
      }
    }
  }
}

/*--- 区切り線パーツ ---*/
.theme-fo-base {
  :is(.main-visual,.wrapper .contents,.foot ) {
    .component {
      &.border {
        hr {
          &.type01 {
            background-image: -webkit-linear-gradient(left, transparent, $border_color, transparent);
          }
          &:is(.type02,.type03,.type04) {
            border-color: $border_color;
          }
        }
      }
    }
  }
}

/*--- CTA(共通パーツ)---*/
.component {
  &.cta {
    .cta-row {
      display: table;
      table-layout: fixed;
      width: 100%;
      margin: 0;
      @include breakpoint-sp {
        display: block;
      }
      & + .cta-row {
        @include breakpoint-pc {
          padding-top: 10px;
        }
      }
      .cta-column {
        display: table-cell;
        vertical-align: top;
        margin: 0;
        @include breakpoint-sp {
          display: block;
          width: 100% !important;
        }
      }
    }
  }
}

/*---  リンク埋め込みパーツ---*/
.component {
  // ページ
  &.link-embed {
    .article-embed {
      .quote-link {
        &:hover {
          opacity: $hover_opacity;
        }
        .quote-link_entry {
          .quote-link-img {
            .quote-link-img-item {
              img {
                height: 150px;
                position: static;
                object-fit: cover;
                &:hover {
                  opacity: 1;
                }
              }
            }
          }
          .cont {
            :is(.quote-link_title,.quote-link_desp,.quote-link_site) {
              p {
                color: var(--fo-text-main-color);
              }
            }
          }
        }
      }
    }
  }
  //ブログ
  &.richtext {
    .article-embed[data-embed-type="url"] {
      .quote-link {
        .quote-link_entry {
          .quote-link-img {
            .quote-link-img-item {
              background-position: center;
            }
          }
          .cont {
            .quote-link_desp {
              margin-bottom: 10px;
            }
          }
        }
      }
    }
  }
}

/*------- サーチエリア --------*/
.component {
  &.search {
    .search-cont {
      input[type=search] {
        -webkit-appearance: none;
        border-radius: 0;
        font-family: inherit !important;
        font-size: 16px;
        height: 40px;
        outline: unset;
        &::placeholder {
          font-family: inherit !important;
          color: rgba(0,0,0,.3);
        }
        &:focus {
          background-color: #fff;
          color: #555;
          border-color: #5a5a5a;
        }
      }
      input[type=submit] {
        padding: 13px 10px;
      }
    }
  }
}

/*------- リンクリスト --------*/
.component {
  &.list {
    &.vertical {
      ul {
        li {
          a {
            &:hover {
              background: rgba(#ccc,.15);
            }
          }
        }
      }
    }
  }
}

//検索結果カラム余白調整
.theme-fo-base {
  .wrapper {
    //1カラム用
    &.none {
      .contents {
        & > .component {
          &.search {
            margin: 50px auto;
          }
        }
      }
    }
    //2カラム
    &:is(.side-right,.side-left) {
      .contents {
        & > .component {
          &.search {
            margin: 20px auto 50px;
          }
        }
      }
    }
    //3カラム
    &.side-both {
      .contents {
        & > .component {
          &.search {
            margin: 10px auto 50px;
          }
        }
      }
    }
  }
}
//検索結果画面
.theme-fo-base {
  .wrapper {
    .contents {
      & > .component {
        &.search {
          @include search_container;
          & + .entry-list {
            padding-bottom: 25px;
            .entry-list-unit {
              border-bottom: 1px solid $border_color;
              margin: 10px 0;
              padding: 10px 0;
              @include breakpoint-pc {
                display: flex;
              }
              .img {
                @include breakpoint-pc {
                  width: 30%;
                  padding: 0 0 10px 0;
                }
                @include breakpoint-sp {
                  padding-bottom: 10px;
                }
                img {
                  border-radius: $case_border_radius;
                  &:hover {
                    opacity: $hover_opacity;
                  }
                }
              }
              .cont {
                border-left: 0;
                @include breakpoint-pc {
                  width: 70%;
                  padding: 0 10px 10px;
                }
                h3 {
                  @include breakpoint-sp {
                    padding: 0;
                  }
                  a {
                    font-family: var(--fo-heading-font-family);
                    font-size: $list_heading_pc_fontsize;
                    color: var(--fo-heading-main-color);
                    line-height: var(--fo-heading-line-height);
                    letter-spacing: var(--fo-heading-letter-spacing);
                    padding: 0 10px;
                    @include breakpoint-sp {
                      font-size: $list_heading_sp_fontsize;
                      padding: 0;
                    }
                    &:hover {
                      text-decoration: none;
                      opacity: $hover_opacity;
                    }
                  }
                }
                h4 {
                  color: var(--fo-text-main-color);
                  padding: 0 10px;
                  @include breakpoint-sp {
                    padding: 0;
                  }
                }
                p {
                  font-size: var(--fo-text-font-size-pc);
                  letter-spacing: var(--fo-text-letter-spacing);
                  line-height: var(--fo-text-line-height);
                  color: var(--fo-text-main-color);
                  @include breakpoint-sp {
                    font-size: var(--fo-text-font-size-sp);
                    padding: 0;
                  }
                }
              }
            }
            .row {
              .text-center {
                padding-top: 30px;
              }
            }
          }
        }
      }
      .component {
        &.search {
          & + h1 {
            font-family: var(--fo-heading-font-family);
            font-size: $list_heading_pc_fontsize;
            color: var(--fo-heading-main-color);
            line-height: var(--fo-heading-line-height);
            letter-spacing: var(--fo-heading-letter-spacing);
            @include search_container;
            @include breakpoint-sp {
              font-size: $list_heading_sp_fontsize;
            }
          }
          & + h1 + p {
            font-size: var(--fo-text-font-size-pc);
            letter-spacing: var(--fo-text-letter-spacing);
            line-height: var(--fo-text-line-height);
            color: var(--fo-text-main-color);
            @include search_container;
            @include breakpoint-sp {
              font-size: var(--fo-text-font-size-sp);
            }
          }
          & + h1 + p + .entry-list {
            margin-bottom: 50px;
          }
        }
      }
      .entry-list {
        .row-none {
          @include search_container
        }
      }
    }
  }
}

/*------- ページネーション部分 通常ページ ブログ共通仕様 --------*/
.entry-list {
  .pagination {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 5px 10px;
    line-height: 0;
    padding-bottom: 0;
    li {
      color: var(--fo-main-color);
      margin: 0;
      a {
        color: var(--fo-main-color);
        border: 1px solid var(--fo-main-color);
        background: #fff;
      }
      &.active > a {
        background: var(--fo-main-color);
        color: #fff;
      }
      &:hover > a {
        opacity: $hover_opacity;
      }
    }
  }
}

/*--- アイコンパーツ ---*/
//デフォルトのCSSが5なので表示されないアイコンがあるため
i:is(.fa,.far,.fas) {
  font-family: $font_family_awsm6;
  font-family: $font_family_awsm;
}

/*--- カルーセルパーツ ---*/
.component {
  &.carousel {
    .flexslider {
      .flex-control-paging {
        li {
          a {
            background: #eee;
            box-shadow: none;
            &.flex-active {
              background: var(--fo-main-color);
            }
          }
        }
      }
      .flex-direction-nav {
        :is(.flex-next,.flex-prev) {
          color: var(--fo-main-color);
        }
      }
    }
  }
}

/*------------- common(ウェブサイト共通)END -------------*/

/*----------------------------------
    entry-list( 記事リストパーツ)
----------------------------------*/

/*--- 記事リストパーツ ---*/
//デフォルト
//テーマの崩れを修正・基本ここは触らない。
.component {
  &.entry-list {
    .entry-list-unit {
      & + .entry-list-unit {
        @include breakpoint-sp {
          margin: 10px auto 0;
        }
      }
      .cont {
        @include breakpoint-sp {
          border: none;
        }
        h3 {
          max-height: none;
          line-height: normal;
          @include breakpoint-sp {
            padding: 0;
          }
          a {
            font-family: var(--fo-heading-font-family);
            font-size: $list_heading_pc_fontsize;
            color: var(--fo-heading-main-color);
            line-height: var(--fo-heading-line-height);
            letter-spacing: var(--fo-heading-letter-spacing);
            @include breakpoint-sp {
              font-size: $list_heading_sp_fontsize;
            }
            &:hover {
              opacity: $hover_opacity;
            }
          }
        }
        h4 {
          font-size: var(--fo-text-font-size-pc);
          letter-spacing: var(--fo-text-letter-spacing);
          color: var(--fo-text-main-color);
        }
        p {
          &.category {
            a {
              &:hover {
                opacity: $hover_opacity;
              }
            }
          }
          &.description {
            max-height: none;
            font-size: var(--fo-text-font-size-pc);
            letter-spacing: var(--fo-text-letter-spacing);
            line-height: var(--fo-text-line-height);
            color: var(--fo-text-main-color);
            @include breakpoint-sp {
              font-size: var(--fo-text-font-size-sp);
              margin: 10px 0;
              padding: 0;
            }
          }
        }
      }
    }
    //カード型
    &:is(
      .entry-image-card-1-col,
      .entry-image-card-2-col,
      .entry-image-card-3-col
    ) {
      .article-list {
        .entry-list-unit {
          .img {
            @include breakpoint-sp {
              padding-right: 0;
            }
          }
          .cont {
            h3 {
              a {
                @include breakpoint-pc {
                  padding: 0 !important;
                }
              }
            }
            h4 {
              margin: 10px 0;
              @include breakpoint-pc {
                padding: 0 !important;
              }
            }
            p {
              &.category {
                margin: 10px 0 10px 3px;
              }
            }
            div {
              &.tags {
                margin: 0 0 5px;
                padding: 0;
              }
            }
          }
        }
      }
    }
    //リスト型・スタイル選択
    .entry-list-unit {
      border-bottom: 1px solid $blog_border_color !important;
      .img {
        @include breakpoint-pc {
          padding-right: 25px;
        }
      }
      .cont {
        a {
          &:hover {
            text-decoration: none;
          }
        }
        //タイトル
        h3 {
          a {
            @include breakpoint-pc {
              padding: 0 10px;
            }
          }
        }
        h4 {
          padding: 0 10px;
          @include breakpoint-sp {
            padding: 0;
          }
        }
        p {
          &.category {
            margin: 10px;
            @include breakpoint-sp {
              padding-left: 0;
            }
          }
          &.description {}
        }
        //記事リスト共通 タグ
        div {
          &.tags {
            display: flex;
            gap: 5px 10px;
            flex-wrap: wrap;
            margin: 16px 10px 10px;
            padding: 0 10px;
            @include breakpoint-sp {
              margin: 16px 0 10px;
              padding: 0;
            }
            a {
              &.tag {
                margin: 0;
                &:hover {
                  opacity: $hover_opacity;
                }
              }
            }
          }
        }
      }
    }
  }
}
//サイドバー時
.side {
  .component {
    &.entry-list {
      .entry-list-unit {
        .img {
          padding-right: 0;
        }
      }
    }
  }
}
.article-per-page {
  &:empty {
    margin-top: 0;
  }
}

//デザインパーツ
// .component {
//   &:not(:root:root:root:root) {
//     &.entry-list[data-designpart-id] {
//     }
//   }
// }

//デフォルトパーツ
.component {
  &.entry-list {
    //事例
    &.caseContent_style {
      .article-list {
        .entry-list-unit {
          background: var(--fo-background-color1);
          padding: 20px 20px 10px;
          border-bottom: 1px solid $blog_border_color;
          @include breakpoint-sp {
            width: 100%;
          }
          a {
            &.img {
              img {
                border-radius: $case_border_radius;
              }
            }
          }
          .cont {
            h3 {
              a {
                &:hover {
                  opacity: $hover_opacity;
                }
              }
            }
            h4 {
              font-family: $case_date_font_family;
            }
            p {
              &.category {
                i {
                  display: none;
                }
                a {
                  color: var(--fo-tag-text-color);
                  &::before {
                    @include category_icon_custom;
                  }
                  &:hover {
                    opacity: $hover_opacity;
                  }
                }
              }
              &.description {
                margin: 10px;
                @include breakpoint-pc {
                  padding: 0 10px;
                }
                @include breakpoint-sp {
                  margin: 10px 0;
                  padding-left: 0;
                }
              }
            }
            div {
              &.tags {
                a.tag {
                  @include tag_custom;
                  &::before {
                    @include tag_icon_custom;
                  }
                  i {
                    display: none;
                  }
                  &:last-child {
                    margin-right: 0;
                  }
                }
              }
            }
          }
        }
      }
      &:is(
        .entry-image-card-1-col,
        .entry-image-card-2-col,
        .entry-image-card-3-col
      ) {
        .article-list {
          display: flex !important;
          flex-wrap: wrap;
          gap: $case_list_space;
          @include breakpoint-sp {
            gap: 20px;
          }
          .entry-list-unit {
            box-shadow: $case_box_shadow_common;
            border: 0;
            margin: 0 !important;
            a {
              &.img {
                max-height: none;
              }
            }
            .cont {
              border-left: none;
              padding-top: 10px;
              h3 {}
              h4 {}
              p {
                &.category {}
                &.description {
                  margin: 10px 0;
                  @include breakpoint-pc {
                    padding: 0;
                  }
                }
              }
              div {
                &.tags {
                  @include breakpoint-sp {
                    margin: 10px 0;
                  }
                }
              }
            }
          }
          .article-per-page {
            width: 100%;
            margin-top: 8px;
            &:empty {
              display: none;
              margin-top: 0;
            }
          }
        }
      }
      //カード型1列
      &.entry-image-card-1-col {
        .article-list {
          .entry-list-unit {
            width: 100%;
            a {}
            .cont {}
          }
        }
      }
      //カード型2列
      &.entry-image-card-2-col {
        .article-list {
          .entry-list-unit {
            @include breakpoint-pc {
              width: calc((100% - #{$case_list_space}) / 2);
            }
            a {}
            .cont {}
          }
        }
      }
      //カード型3列
      &.entry-image-card-3-col {
        .article-list {
          .entry-list-unit {
            @include breakpoint-pc {
              width: calc((100% - (#{$case_list_space} * 2)) / 3);
            }
            a {}
            .cont {}
          }
        }
      }
      //リスト型
      &.entry-image-list {
        .article-list {
          padding-bottom: 0;
          .entry-list-unit {
            box-shadow: $case_box_shadow_common !important;
            border: 0 !important;
            margin: 20px auto 0;
            padding-bottom: 10px;
            @include breakpoint-sp {
              display: block !important;
              width: 100%;
              padding: 20px 20px 10px;
            }
            &:first-child {
              margin-top: 0;
            }
            &:nth-last-child(2) {
              border-bottom: 0 !important;
            }
            a {
              &.img {
                width: 35% !important;
                padding: 0 !important;
                @include breakpoint-sp {
                  display: block !important;
                  width: 100% !important;
                }
                img {
                  padding-bottom: 10px;
                  @include breakpoint-sp {
                    padding-bottom: 0;
                  }
                }
              }
            }
            .cont {
              width: 65% !important;
              border-left: none;
              margin: 20px auto 0;
              @include breakpoint-sp {
                width: 100% !important;
                display: block !important;
              }
              h3 {
                text-align: left;
                margin: 0 20px 10px;
                @include breakpoint-sp {
                  margin: 10px 0;
                  padding-left: 0;
                }
                a {
                  &:hover {}
                }
              }
              h4 {
                padding: 0 20px;
                @include breakpoint-sp {
                  padding-left: 0;
                }
              }
              p {
                @include breakpoint-sp {
                  margin: 10px 0;
                  padding: 0;
                }
                &.category {}
                &.description {
                  @include breakpoint-pc {
                    padding: 0 20px;
                  }
                }
              }
              div {
                &.tags {
                  padding: 0 20px;
                  @include breakpoint-sp {
                    margin: 10px 0;
                    padding: 0;
                  }
                }
              }
            }
          }
        }
      }
      //ここからオプション
      //col余白なし オプション1
      &.option_padding_none {
        .article-list {
          .entry-list-unit {
            padding: 0;
            a {
              &.img {
                img {
                  padding: 0;
                }
              }
            }
            .cont {
              padding: 10px 20px;
              h3 {}
              h4 {}
              p {
                &.category {}
                &.description {}
              }
            }
          }
        }
        &.entry-image-list {
          .article-list {
            .entry-list-unit {
              .cont {
                vertical-align: middle;
                padding: 20px 20px 20px 0;
                @include breakpoint-sp {
                  margin-top: 0;
                  padding: 10px 20px;
                }
                h3 {}
                p {
                  &.description {}
                }
              }
            }
          }
        }
      }
      //シャドウなし オプション2
      &.option_shadow_none {
        .article-list {
          .entry-list-unit {
            box-shadow: none !important;
          }
        }
      }
      // 画像フィット オプション3
      &.option_img_fit {
        .article-list {
          .entry-list-unit {
            a {
              &.img {
                img {
                  @include breakpoint-pc {
                    height: $case_img_fit_height;
                    object-fit: cover;
                  }
                }
              }
            }
          }
        }
        &.entry-image-list {
          .article-list {
            .entry-list-unit {
              a {
                &.img {
                  img {
                    @include breakpoint-pc {
                      width: calc(35% - 14px);
                      height: calc(100% - 30px);
                      object-fit: cover;
                      position: absolute;
                    }
                  }
                }
              }
            }
          }
        }
        &.option_padding_none {
          &.entry-image-list {
            .article-list {
              .entry-list-unit {
                a {
                  &.img {
                    img {
                      @include breakpoint-pc {
                        width: 35%;
                        height: 100%;
                        position: absolute;
                        object-fit: cover;
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
      //テキスト制限 オプション4
      &.option_text_limit {
        .article-list {
          .entry-list-unit {
            .cont {
              h3 {
                display: -webkit-box;
                -webkit-line-clamp: 2;
                -webkit-box-orient: vertical;
                overflow: hidden;
                text-overflow: ellipsis;
              }
              p {
                &.description {
                  display: -webkit-box;
                  -webkit-box-orient: vertical;
                  -webkit-line-clamp: 5;
                  overflow: hidden;
                  text-overflow: ellipsis;
                }
              }
            }
          }
        }
        &.entry-image-list {
          .article-list {
            .entry-list-unit {
              .cont {
                h3 {
                  -webkit-line-clamp: 1;
                }
                p {
                  &.description {
                    -webkit-line-clamp: 3;
                  }
                }
              }
            }
          }
        }
      }
    }
    //ニュース
    &.news_list {
      padding: 40px 50px;
      @include breakpoint-sp {
        padding: 20px;
      }
      .article-list {
        .entry-list-unit {
          border-bottom: 1px solid $border_color;
          padding: 15px 10px 10px;
          @include breakpoint-sp {
            padding: 0 0 10px;
          }
          .cont {
            display: flex;
            justify-content: flex-end;
            flex-direction: row-reverse;
            width: 100%;
            border: 0;
            @include breakpoint-sp {
              flex-direction: column-reverse;
            }
            h3 {
              flex-grow: 1;
              margin: 0;
              @include breakpoint-sp {
                width: 100%;
                padding-left: 0;
              }
              a {
                font-family: $case_title_font_family;
                font-size: var(--fo-text-font-size-pc);
                line-height: var(--fo-text-line-height);
                color: inherit;
                text-decoration: $news_list_text_decoration;
                margin-bottom: 5px;
                padding-top: 1px;
                &:hover {
                  opacity: $news_list_hover_opacity;
                }
              }
            }
            h4 {
              font-family: $case_date_font_family;
              text-align: center;
              white-space: nowrap;
              margin: 4px 10px 0 0;
              padding: 0;
              @include breakpoint-sp {
                text-align: left;
                margin: 0 0 5px;
              }
            }
            div {
              &.tags {
                max-width: 140px;
                margin: 0 10px 0 0;
                padding: 0;
                @include breakpoint-sp {
                  width: 100%;
                  max-width: initial;
                  margin: 0;
                }
                a {
                  &.tag {
                    @include tag_custom;
                    margin-top: 0;
                    margin-bottom: 5px;
                    @include breakpoint-sp {
                      margin: 0 5px 10px 0;
                    }
                    &::before {
                      @include tag_icon_custom;
                    }
                    &:first-child {
                      @include breakpoint-sp {
                        margin-left: 0;
                      }
                    }
                    &:not(:first-child) {
                      display: none;
                    }
                    i {
                      display: none;
                    }
                  }
                }
              }
            }
          }
        }
      }
      //タグ2個以上 オプション
      &.option_column {
        .article-list {
          .entry-list-unit {
            .cont {
              flex-wrap: wrap;
              flex-direction: inherit;
              h3 {
                order: 2;
                width: 100%;
                a {
                  margin-bottom: 15px;
                  padding-left: 0;
                }
              }
              h4 {
                order: 1;
                width: 100%;
                text-align: left;
                margin: 0 0 5px 0;
              }
              div {
                &.tags {
                  order: 3;
                  max-width: 100%;
                  width: 100%;
                  a {
                    &.tag {
                      &:not(:first-child) {
                        display: inline-block;
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}
//サイドバー用
.side {
  .component {
    &.entry-list {
      //事例
      &.caseContent_style {
        .article-list {
          .entry-list-unit {
            @include breakpoint-pc {
              padding: 10px 10px 5px;
            }
            .cont {
              @include breakpoint-pc {
                padding-right: 0;
              }
              h3 {
                @include breakpoint-pc {
                  margin: 0;
                }
                a {
                  @include breakpoint-pc {
                    font-size: 16px;
                    padding: 0;
                  }
                }
              }
              h4 {
                @include breakpoint-pc {
                  font-size: 12px;
                  margin: 5px 0;
                  padding: 0;
                }
              }
              p {
                &.category {
                  @include breakpoint-pc {
                    margin: 5px 0;
                    padding: 0;
                  }
                  a {
                    @include breakpoint-pc {
                      font-size: 12px;
                      padding: 0;
                    }
                  }
                }
                &.description {
                  @include breakpoint-pc {
                    font-size: 12px;
                    margin: 5px 0 0;
                    padding: 0;
                  }
                }
              }
              div {
                &.tags {
                  @include breakpoint-pc {
                    margin: 0;
                    padding: 0;
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}

/*------------- entry-list( 記事リストパーツ))END -------------*/

/* --------------------------------
    header・logo・navigations(ヘッダー・ロゴ・ナビゲーション)
----------------------------------- */
.navi_base_custom {
  //1段のとき
  &.navi-001-01 {
    header#navigations {
      min-height: 51px;
      font-family: var(--fo-text-font-family);
      border-bottom: 0;
      box-shadow: $navigation_box_shadow_common;
      .inner {
        @include breakpoint-pc {
          box-sizing: border-box;
          display: flex;
          padding: 0;
        }
      }
      .logo {
        float: none;
        @include breakpoint-pc {
          width: $header_logo;
          padding: 10px;
        }
        @include breakpoint-sp {
          box-sizing: border-box;
          width: 100%;
          padding-left: 10px;
        }
        a {
          height: auto;
          img {
            @include breakpoint-sp {
              max-height: $header_sp_logo;
            }
          }
        }
      }
      //ハンバーガーメニュー
      a.menu-trigger {
        background: var(--fo-main-color);
        span {
          background-color: #fff;
        }
      }
      .main-menu {
        float: none;
        @include breakpoint-pc {
          width: calc(100% - #{$header_logo});
          max-width: none;
        }
        &.navigation-font-family {}
        ul.clearfix {
          background: $navigation_bg_color;
        }
        //PC用
        @include breakpoint-pc {
          .level-01,
          .level-01-trigger {
            a {
              font-size: $navigation_font_size;
              font-weight: $navigation_font_weight;
              color: $navigation_text_color;
              border-left: none;
              border-right: none;
              padding: 25px 10px;
            }
          }
          .level-01:hover {
            background-color: $navigation_hover_bg_color;
            a {
              color: $navigation_hover_text_color;
              opacity: $navigation_hover_opacity;
            }
          }
          .level-01-trigger {
            //三角部分
            &::after {
              content: "\f107";
              font-size: 20px;
              font-weight: 400;
              line-height: 1;
              color: $navigation_arrow1_color;
              translate: 0 -50%;
              margin-top: 0;
            }
            &:hover::after {
              color: $navigation_hover_text_color;
              rotate: 180deg;
            }
            &:hover {
              background: $navigation_hover_bg_color;
              & > a {
                color: $navigation_hover_text_color;
                opacity: $navigation_hover_opacity;
              }
            }
            ul.level-01-cont {
              background: $navigation_bg2_color;
              border: 0;
              a {
                color: $navigation_text2_color;
                padding: 20px;
                &:hover {
                  background: $navigation_hover_bg2_color;
                  color: $navigation_hover_text2_color;
                }
              }
              .level-02-trigger {
                &::after {
                  content: "\f105";
                  font-size: 20px;
                  font-weight: 400;
                  color: $navigation_arrow2_color;
                  right: 10px;
                  translate: 0 -50%;
                  margin-top: 0;
                }
                &:has(> a:hover) {
                  &::after {
                    color: $navigation_hover_text2_color;
                  }
                }
                .level-02-cont {
                  background: $navigation_bg2_color;
                  li {}
                  .level-03 {
                    a {
                      padding: 20px 10px;
                    }
                  }
                }
              }
            }
          }
        }
        //SP用は共通ハンバーガー
      }
    }
  }
  //2段のとき
  &.navi-002-01 {
    font-family: var(--fo-text-font-family);
    header#navigations {
      background: $header_bg_color;
      box-shadow: $navigation_box_shadow_common;
      .inner {
        //ロゴ ヘッダーボタンエリア
        .navigation-cont {
          box-sizing: border-box;
          max-width: $max_width;
          padding: 10px 20px;
          @include breakpoint-pc {
            display: flex;
            align-items: center;
            justify-content: space-between;
          }
          @include breakpoint-sp {
            padding: 0 0 10px;
          }
          //ロゴ
          .logo {
            float: none;
            @include breakpoint-pc {
              width: $header_logo;
              padding: 0;
            }
            @include breakpoint-sp {
              display: flex;
              align-items: center;
              min-height: 51px;
            }
            div {
              line-height: normal;
              padding: 0;
              a {
                @include breakpoint-sp {
                  display: block;
                  height: auto;
                  line-height: 0;
                }
                img {
                  vertical-align: middle;
                  padding: 0;
                  max-height: 60px;
                  @include breakpoint-sp {
                    max-height: $header_sp_logo;
                  }
                }
              }
            }
          }
          .cont {
            box-sizing: border-box;
            min-width: auto;
            max-width: none;
            float: none;
            @include breakpoint-pc {
              width: calc(100% - #{$header_logo});
            }
            .row {
              display: flex;
              justify-content: flex-end;
              width: 100%;
              min-width: inherit;
              @include breakpoint-sp {
                display: block;
              }
              @include breakpoint-tb {
                display: flex;
                justify-content: center;
              }
              .col {
                @include breakpoint-sp {
                  padding: 0;
                }
                //ボタンのカスタマイズ用
                // .component {
                //   &.button[data-designpart-id] {
                //     .button-cont {
                //       a {
                //         &.size-s {
                //           &::before {}
                //         }
                //       }
                //     }
                //   }
                // }
              }
            }
          }
        }
        //ハンバーガーメニュー
        a.menu-trigger {
          background: var(--fo-main-color);
          span {
            background-color: #fff;
          }
        }
        //グロナビ
        .main-menu {
          background: $navigation_bg_color;
          border-top: solid 1px #ccc;
          border-bottom: solid 1px #ccc;
          &.navigation-font-family {}
          //PC用
          @include breakpoint-pc {
            .level-01,
            .level-01-trigger {
              a {
                font-weight: $navigation_font_weight;
                font-size: $navigation_font_size;
                color: $navigation_text_color;
                border-left: none;
                border-right: none;
              }
            }
            .level-01:hover {
              background-color: $navigation_hover_bg_color;
              a {
                color: $navigation_hover_text_color;
                opacity: $navigation_hover_opacity;
              }
            }
            .level-01-trigger {
              //三角部分
              &::after {
                content: "\f107";
                font-size: 20px;
                font-weight: 400;
                line-height: 1;
                color: $navigation_arrow1_color;
                translate: 0 -50%;
                margin-top: 0;
              }
              &:hover::after {
                color: $navigation_hover_text_color;
                rotate: 180deg;
              }
              &:hover {
                background: $navigation_hover_bg_color;
                & > a {
                  color: $navigation_hover_text_color;
                  opacity: $navigation_hover_opacity;
                }
              }
              ul.level-01-cont {
                width: 100%;
                background: $navigation_bg2_color;
                border: 0;
                a {
                  color: $navigation_text2_color;
                  padding: 20px;
                  &:hover {
                    background: $navigation_hover_bg2_color;
                    color: $navigation_hover_text2_color;
                  }
                }
                .level-02-trigger {
                  &::after {
                    content: "\f105";
                    font-size: 20px;
                    font-weight: 400;
                    color: $navigation_arrow2_color;
                    translate: 0 -50%;
                    right: 10px;
                    margin-top: 0;
                  }
                  &:has(> a:hover) {
                    &::after {
                      color: $navigation_hover_text2_color;
                    }
                  }
                  .level-02-cont {
                    background: $navigation_bg2_color;
                    li {
                      width: 100%;
                    }
                    .level-03 {
                      a {
                        padding: 20px 10px;
                      }
                    }
                  }
                }
              }
            }
          }
          //SP用は共通ハンバーガー
        }
      }
    }
    //2段から1段への変更(変更不可)
    &.stage1 {
      header#navigations {
        .inner {
          //ロゴ ヘッダーボタンエリア
          .navigation-cont {
            @include breakpoint-sp {
              display: flex;
              align-items: center;
              justify-content: space-between;
              min-height: 51px;
              margin: 0;
              padding: 0;
            }
            .logo {
              @include breakpoint-sp {
                width: 45%;
                padding: 0 0 0 10px;
              }
            }
            .cont {
              @include breakpoint-sp {
                width: 55%;
                padding: 0 65px 0 0;
              }
              .row {
                @include breakpoint-sp {
                  display: flex;
                  justify-content: flex-end;
                  min-width: 112px;
                }
              }
            }
          }
        }
      }
    }
  }
  // hover挙動記述エリア
  &:is(.navi-001-01,.navi-002-01) {
    header#navigations {
      .inner {
        .main-menu {
          @include breakpoint-pc {
            ul {
              li {
                &:is(.level-01,.level-01-trigger) {
                  & > a {
                    position: relative;
                    &:before {
                      content: "";
                      position: absolute;
                      height: 2.5px;
                      width: 0;
                      margin: 0 auto;
                      right: 0;
                      bottom: 0;
                      left: 0;
                      background-color: var(--fo-main-color);
                      transition: width 0.3s ease-in-out;
                    }
                  }
                  &:hover {
                    a {
                      &::before {
                        width: 60px;
                      }
                    }
                  }
                }
                a {
                  transition: 0.3s ease-in-out;
                }
              }
            }
          }
        }
      }
    }
  }
  //共通ハンバーガー(1段・2段)
  &:is(.navi-001-01,.navi-002-01) {
    header#navigations {
      .inner {
        .main-menu {
          //SP共通
          @include breakpoint-sp {
            .toggle.fa.fa-angle-down,
            .toggle.fa.fa-angle-up {
              &::before {
                font-size: 20px;
                color: $navigation_sp_arrow1_color;
                position: absolute;
                top: 50%;
                right: 4px;
                margin-top: -11px;
              }
            }
            .level-01,
            .level-01-trigger {
              border-right: 0;
              border-left: 0;
              a {
                font-size: $navigation_sp_font_size;
                font-weight: $navigation_sp_font_weight;
                color: $navigation_sp_text_color;
                border-left: none;
                border-right: none;
                position: relative;
                padding: 10px 20px;
              }
            }
            .level-01 {
              &:hover {
                background: none;
              }
            }
            .level-01-trigger {
              &:hover {
                background: $navigation_sp_bg_color;
                a {
                  color: $navigation_sp_hover_text_color;
                  .toggle.fa.fa-angle-down,
                  .toggle.fa.fa-angle-up {
                    &::before {
                      color: $navigation_sp_hover_text_color;
                    }
                  }
                }
              }
              .level-01-cont {
                background: $navigation_sp_bg2_color;
                a {
                  color: $navigation_sp_text_color;
                  &:hover {
                    background: $navigation_sp_bg3_color;
                  }
                }
                .level-02-trigger {
                  padding-right: 0 !important;
                  &::after {
                    content: none !important;
                  }
                  a {
                    color: $navigation_sp_text3_color;
                    .toggle.fa.fa-angle-down,
                    .toggle.fa.fa-angle-up {
                      &::before {
                        color: $navigation_sp_arrow2_color;
                      }
                    }
                  }
                  .level-02-cont li a {
                    background: $navigation_sp_bg3_color;
                    color: $navigation_sp_text3_color;
                    //border-top: 1px solid $navigation_sp_bg3_color;
                  }
                }
                .level-02 {
                  border-top: 1px solid var(--fo-main-color);
                  a {
                    color: $navigation_sp_text2_color;
                  }
                }
              }
            }
          }
          //デザイン用
          @include breakpoint-sp {
            .toggle.fa.fa-angle-down,
            .toggle.fa.fa-angle-up {
              &::before {
                display: flex;
                justify-content: center;
                align-items: center;
                width: 30px;
                height: 100%;
                font-size: 30px;
                top: 10px;
                right: 0;
              }
            }
            .level-01,
            .level-01-trigger {
              a {
                text-align: left;
                border-top: $navigation_sp_border-bottom;
                padding: 20px 10px;
              }
            }
            .level-01-trigger {
              & > a {
                padding-right: 30px;
              }
              .level-01-cont {
                .level-02-trigger {
                  & > a {
                    padding: 20px 30px 20px calc(10px + 1em);
                  }
                  .level-03 {
                    a {
                      padding: 20px 30px 20px calc(10px + 2em);
                    }
                  }
                }
                .level-02 {
                  a {
                    padding: 20px 30px 20px calc(10px + 1em);
                  }
                }
                .level-02-cont {
                  // border-top: $navigation_sp_border-bottom !important;
                }
              }
            }
            ul {
              li {
                &[class*="level-01"] {
                  &:first-child {
                    & > a {
                      border: none;
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}

//2段のナビ非表示
.navi-002-01 {
  &.nav_none {
    header#navigations {
      .inner {
        .main-menu {
          display: none !important;
        }
        a.menu-trigger {
          display: none;
        }
      }
    }
  }
}

//ヘッダー固定時のみ(ハンバーガーメニュー内をスクロール表示)
:is(.navi-001-01,.navi-002-01) {
  &:is(
    .one_row_sticky-navi__GU_fr,
    .two_row_sticky-navi__8HtZT
  ) {
    header#navigations {
      .inner {
        .main-menu {
          @include breakpoint-sp {
            max-height: calc(100vh - 51px);
            overflow-y: auto;
            /*----
            //スクロールバー非表示
            -ms-overflow-style: none; //Edge
            scrollbar-width: none; //Firefox
            &::-webkit-scrollbar {
              display: none;
            }
            ----*/
          }
        }
      }
    }
  }
}

/*------------- header・logo・navigations(ヘッダー・ロゴ・ナビゲーション)END -------------*/

/*----------------------------------
    main-visual(メインビジュアル)
----------------------------------*/
//オーバーレイが公開画面で二重にかかるバグ
.theme-fo-base {
  .main-visual {
    .overlay {
      display: none !important;
    }
  }
}

//colのズレ対策
.theme-fo-base {
  .main-visual {
    .clearfix {
      .row {
        .col {
          vertical-align: top;
        }
      }
    }
  }
}

//メインビジュアル
.theme-fo-base {
  .main-visual {
    background-repeat: no-repeat;
    min-height: auto;
    padding: $mv_padding;
    @include breakpoint-sp {
      padding: $sp_mv_padding;
    } 
    @include breakpoint-tb {
      min-height: auto;
    }
    & > :is(.clearfix,.main-visual-content) {
        width: 100%;
        max-width: $max_width;
        display: flex;
        flex-direction: column;
        justify-content: center;
        min-height: auto;
        margin: auto;
        padding: 0 20px;
        @include breakpoint-sp {
          min-height: auto;
        }
      .row {
        .col {
          .component {
            &.heading {
              &.hd_custom {
                :is(h1,h2,h3,h4,h5) {
                  margin-bottom: 0;
                }
                h1 {
                  @include breakpoint-pc {
                    font-size: calc(var(--fo-h1-font-size-pc) + 4px);
                  }
                }
              }
            }
          }
        }
      }
    }
    //TOP
    &.mv_custom {
      & > :is(.clearfix,.main-visual-content) {
        min-height: $top_mv_height;
        @include breakpoint-sp {
          min-height: auto;
        }
        .row {
          --fo-heading-main-color: #fff;
          --fo-text-main-color: #fff;
          .col {
            .component {
              &.hd_custom {
                h1{}
              }
            }
          }
        }
      }
    }
    //下層
    &.mv_sub_custom {
      & > :is(.clearfix,.main-visual-content) {
        min-height: $sub_mv_height;
        .row {
          --fo-heading-main-color: #fff;
          --fo-text-main-color: #fff;
          --fo-text-link-color: #fff;
          .col {
            .component {
              &.cta {
                .cta-row {
                  &.mv_design01_row {
                    margin-top: 22px;
                    .cta-column {
                      display: flex;
                      flex-direction: column;
                      gap: 8px;
                      width: 100%;
                      .component {
                        &.button[data-designpart-id] {
                          margin: 0;
                        }
                      }
                    }
                  }
                }
              }
              &.hd_custom {
                h1{}
              }
            }
          }
        }
      }
    }
    //幅100%
    &.maxWidth_custom {
      & > :is(.clearfix,.main-visual-content) {
        max-width: none;
      }
    }
  }
}


/*------------- main-visual(メインビジュアル)END -------------*/

/*----------------------------------
  breadcrumbs(パンくず)
----------------------------------*/
.theme-fo-base {
  .breadcrumbs {
    background: #fff;
    max-width: 100%;
    margin: 0;
    ul {
      width: 100%;
      max-width: $max_width - 20px;
      margin: auto;
      padding: 15px 0;
      li {
        a {
          &:hover {
            color: var(--fo-text-main-color);
            text-decoration: unset;
            opacity: $hover_opacity;
          }
          &::after {
            content: "\f105";
            font-family: $font_family_awsm;
            color: var(--fo-text-main-color);
            border-top: none;
            border-bottom: none;
            border-left: none;
            position: absolute;
            padding: 0;
            top: 0;
            right: -1px;
            margin-top: 0;
          }
        }
        a,
        span {
          font-size: 14px;
          color: var(--fo-text-main-color);
          text-decoration: unset;
          padding: 0 20px;
        }
      }
    }
  }
}

/*------------- breadcrumbs(パンくず)END -------------*/

/*----------------------------------
    button(ボタン)
----------------------------------*/
/*--- ボタン全体スタイル ---*/
:is(
  .component.button,
  .button.cta-button
) {
  .button-cont {
    a {
      transition: none;
      &:hover {
        @include breakpoint-pc {
          transition: all .2s cubic-bezier(.02,.42,.24,.74);
        }
      }
    }
  }
}

//デザインパーツ
.component {
  &:not(:root:root:root:root:root) {
    //ボタン全体(例:自由にカスタマイズしてください)
    // &.button[data-designpart-id] {
    //   margin-top: 0;
    //   .button-cont {
    //     a {
    //       &.size-s {}
    //       &.size-m {}
    //       &.size-l {}
    //       &:is(.size-s,.size-m,.size-l) {
    //         box-shadow: none;
    //       }
    //     }
    //   }
    // }

    &.button {
      &.btn1_custom01 {
        .button-cont {
          a {
            &:is(.size-s,.size-m,.size-l) {
              &::before {}
            }
            &:is(.blue,.red,.orange,.black,.white) {}
            &:hover {}
          }
        }
      }
    }

    //TELボタン
    &.button[data-designpart-id="642f669ce4dc09621d945abc"] {
      .button-cont {
        a {
          //サイズ小
          &.size-s {
            font-size: calc(4px + var(--fo-button-small-font-size));
          }
          //サイズ中
          &.size-m {
            font-size: calc(4px + var(--fo-button-medium-font-size));
          }
          //サイズ大
          &.size-l {
            font-size: calc(12px + var(--fo-button-large-font-size));
          }
        }
      }
    }
  }
}
//ボタン共通
.component {
  &.button {
    //sp時センター寄せ
    &.sp_center {
      .button-cont:is(.left,.right) {
        @include breakpoint-sp {
          text-align: center;
        }
      }
    }
    //sp時アイコン化
    &.sp_icon {
      .button-cont {
        a {
          &:is(.size-s,.size-m,.size-l) {
            @include breakpoint-msp {
              background: none !important;
              width: auto !important;
              min-width: auto !important;
              font-size: 0 !important;
              letter-spacing: 0 !important;
              border: 0 !important;
              border-radius: 0 !important;
              box-shadow: none !important;
              margin: 0;
              padding: 5px 10px 5px 5px;
            }
            @include breakpoint-ssp {
              padding: 5px;
            }
          }
          &::before,
          &::after {
            @include breakpoint-msp {
              font-size: 22px;
              line-height: 1;
              color: var(--fo-main-color);
              margin: 0;
              top: 0;
            }
            @include breakpoint-ssp {
              font-size: 20px;
            }
          }
        }
      }
    }

    //デフォルトパーツ
    &.btn_custom01 {
      .button-cont {
        a {
          &:is(.size-s,.size-m,.size-l) {
            &::before {}
          }
          &:is(.blue,.red,.orange,.black,.white) {}
          &:hover {}
        }
      }
    }

  }
}

/*------------- button(ボタン)END -------------*/

/*----------------------------------
    heading(見出し)
----------------------------------*/
//ページ内リンクずれ対策class
.theme-fo-base {
  .wrapper {
    .contents {
      section {
        .component {
          &.heading:not(:root) {
            &.inPage_link {
              @include breakpoint-pc {
                margin-top: calc(-#{$inPage_link} - 10px);
                padding-top: calc(#{$inPage_link} + 10px);
              }
              @include breakpoint-sp {
                margin-top: calc(-#{$sp_inPage_link} - 10px);
                padding-top: calc(#{$sp_inPage_link} + 10px);
              }
            }
          }
        }
      }
    }
  }
}

//デザインパーツ
.component {
  //見出し下余白条件分岐用
  &:not(:root:root:root:root) {
    &.heading[data-designpart-id] {
      &:has(+ .component) {
        :is(h1,h2,h3) {
          @include margin-property(bottom,32px);
        }
        :is(h4,h5) {
          @include margin-property(bottom,24px);
        }
      }
    }
  }
  &:not(:root:root:root:root:root) {
    // 見出し全体(例:自由にカスタマイズしてください)
    &.heading[data-designpart-id] {
      :is(h1,h2,h3,h4,h5) {}
    }
    //デザインパーツ
    &.heading {
      &.hd_custom01 {
        :is(h1,h2,h3,h4,h5) {}
      }
      &.mt0_hd {
        margin-top: 0;
      }
      &.mainClr_hd {
        --fo-heading-main-color: var(--fo-main-color);
      }
      &.subClr_hd {
        --fo-heading-main-color: var(--fo-sub-color);
      }
      &.accentClr_hd {
        --fo-heading-main-color: var(--fo-accent-color);
      }
    }
  }
}

//デフォルトパーツ
.theme-fo-base {
  :is(.main-visual,.contents,.side,.foot) {
    .component {
      &.heading {
        //&.rich-heading-align-right {}
        //&.rich-heading-align-center {}
        //&.rich-heading-align-left {}

        //見出し01
        &.hd_custom01 {
          :is(h1,h2,h3,h4,h5) {}
        }

        //sp時センター
        &.sp_center {
          &:is(.rich-heading-align-right,.rich-heading-align-left) {
            @include breakpoint-sp {
              text-align: center !important;
            }
          }
        }

        //細字設定
        :is(h1,h2,h3,h4,h5) {
          .strong {
            font-weight: $hd_font_strong;
          }
        }
      }
    }
  }
}

/*------------- heading(見出し)END -------------*/


/*----------------------------------
    article-post(ブログ用見出し)
----------------------------------*/
/*--- ブログ見出しフォント指定 ---*/
.component {
  &.blog_article {
    .article-post {
      @include hd_blog;
    }
  }
}
/*------------- article-post(ブログ用見出し)END -------------*/

/*----------------------------------
    main(コンテンツ)
----------------------------------*/
@include theme-fo-base {
  .inner {
    .row {
      &.loop_row {
        @include adjacentMargin(loop_row,40px);
      }
      //料金
      &.price_table_row {
        .col {
          .component {
            &.richtext {
              :is(.normal-table,.table-with-two-headers) {
                table {
                  thead {
                    tr {
                      th {
                        background-color: #fff;
                        font-weight: normal;
                        &:nth-child(2) {
                          background-color: color-mix(in srgb, var(--fo-main-color) 80%, #fff);
                        }
                        &:nth-child(3) {
                          background-color: color-mix(in srgb, var(--fo-main-color) 60%, #fff);
                        }
                        &:nth-child(n+4) {
                          background-color: color-mix(in srgb, var(--fo-main-color) 40%, #fff);
                        }
                      }
                    }
                  }
                  tbody {
                    tr {
                      :is(th,td) {
                        font-weight: normal;
                        background-color: #fff;
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
      .col {
        .component {
          //リッチテキストパーツ
          &.richtext {}
          //画像パーツ
          &.image {}
          //リストパーツ
          &.list {}
        }
      }
    }
  }
}

/*--- CTAパーツ ---*/
@include theme-fo-base {
  //通常用
  &.cta_sec {
    .inner {
      .row {
        .col {
          .component {
            &.cta {
              margin: 0;
              .cta-row {
                --fo-heading-main-color: #fff;
                --fo-text-main-color: #fff;
                --tel-botton-color: #fff;
                &.btn_row {
                  @include breakpoint-pc {
                    display: flex;
                    max-width: 892px;
                    margin: auto;
                  }
                  @include breakpoint-pro_s {
                    display: block;
                  }
                  .cta-column {
                    @include breakpoint-pc {
                      display: flex;
                      justify-content: space-between;
                    }
                    @include breakpoint-pro_s {
                      display: block;
                      width: 100% !important;
                    }
                    &:not(:first-child) {
                      @include breakpoint-pro_s {
                        margin-top: 20px;
                      }
                    }
                    .component {
                      &.button[data-designpart-id] {
                        margin: 10px 0;
                      }
                    }
                  }
                  & + .cta-row {
                    max-width: 892px;
                    margin: auto;
                    .cta-column {
                      .component {
                        &.button[data-designpart-id] {
                          margin: 10px 0;
                        }
                      }
                    }
                  }
                }
                &.tel_row {
                  .cta-column {
                    .component {
                      &.button {
                        .button-cont {
                          a {
                            &:is(.size-s,.size-m,.size-l) {
                              color: var(--tel-botton-color,#000);
                            }
                          }
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}
//2カラム(CTA)
.theme-fo-base {
  .wrapper {
    &[class*="side-"] {
      .contents {
        section {
          &.cta_sec {
            .inner {
              .row {
                .col {
                  .component {
                    &.cta {
                      .cta-row {
                        &.btn_row {
                          display: block;
                          .cta-column {
                            display: block;
                            width: 100% !important;
                          }
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
      .side {
        .inner {
          .component {
            &.heading {
              & + .button {
                margin-top: 0;
              }
            }
          }
        }
      }
    }
  }
}

/*--- デザインLPパーツ ---*/
@include theme-fo-base {
  //ヘッダー
  &.foPrp_header_sec {
    padding: 0;
    .inner {
      padding: 10px 20px;
      @include breakpoint-sp {
        padding: 10px;
      }
      .row {
        &.foPrp_header_row {
          display: flex;
          align-items: center;
          @include breakpoint-pc {
            min-height: 60px;
          }
          .col {
            padding: 0;
            &.foPrp_logo_col {
              @include breakpoint-pc {
                max-width: 300px;
                min-width: 150px;
                width: auto !important;
              }
              .component {
                &.image {
                  margin: 0;
                  &.foPrp_logo_img {
                    img {
                      @include breakpoint-pc {
                        max-width: $header_logo !important;
                        width: 100% !important;
                      }
                      @include breakpoint-sp {
                        max-height: $header_sp_logo !important;
                      }
                    }
                  }
                }
              }
            }
            &.foPrp_btn_col {
              display: flex !important;
              justify-content: flex-end;
              align-items: center;
              flex: 1;
              @include breakpoint-pc {
                width: auto !important;
              }
              .component {
                margin: 0;
                &:not(:first-child) {
                  @include breakpoint-pc {
                    margin-left: 15px;
                  }
                }
                &.button {
                  margin-top: 0;
                  .button-cont {
                    a {
                      @include breakpoint-sp {
                        background: none;
                        width: auto;
                        min-width: auto;
                        font-size: 0 !important;
                        letter-spacing: 0;
                        border-radius: 0;
                        border: 0;
                        margin: 0;
                        box-shadow: none;
                        padding: 5px 10px 5px 5px;
                      }
                      &::before {
                        @include breakpoint-sp {
                          font-size: 22px;
                          line-height: 1;
                          color: var(--fo-main-color);
                          margin: 0;
                        }
                      }
                    }
                  }
                  &[data-designpart-id="642f669ce4dc09621d945abc"] {
                    .button-cont {
                      a {
                        @include breakpoint-pro {
                          background: none;
                          width: auto;
                          min-width: auto;
                          font-size: 0 !important;
                          letter-spacing: 0;
                          border-radius: 0;
                          border: 0;
                          margin: 0;
                          box-shadow: none;
                          padding: 5px 10px 5px 5px;
                        }
                        &::before {
                          @include breakpoint-pro {
                            font-size: 22px;
                            line-height: 1;
                            color: inherit;
                            margin: 0;
                          }
                          @include breakpoint-sp {
                            color: inherit;
                          }
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
  //フッター
  &.foPrp_footer_sec {
    padding: 0;
    background: $footer_bg_color;
    .inner {
      max-width: unset;
      padding: 0;
      .row {
        .col {
          padding: 0;
          .component {
            &.cta {
              margin: 0;
              .cta-row {
                padding-top: 0;
                &.page_top_row {
                  @include page_top;
                }
                .cta-column {
                  padding: 0;
                  .component {
                    &.richtext {
                      &.foot-copyright {
                        @include copyright_custom;
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}

/*---------------------------------------------------
ここのパーツは自由に使用してください。
カスタマイズする場合はコピーして所定の場所で使用してください。
-----------------------------------------------------*/
@include theme-fo-base {
  .inner {
    .row {
      .col {
        .component {
          &.richtext {
            //テーブル(ボーダー無し)
            &.custom_table {
              table {
                border: none;
                :is(thead,tbody) {
                  border: 0;
                  tr {
                    border: 0;
                    th {
                      vertical-align: top;
                      border: 0;
                    }
                    td {
                      vertical-align: top;
                      border: 0;
                    }
                    p {
                      @include breakpoint-tb {}
                    }
                  }
                }
              }
            }
            //スマホ時テーブル固定スクロール
            &.sp_table_scroll {
              :is(
                .normal-table,
                .table-with-row-header,
                .table-with-two-headers
              ) {
                @include breakpoint-sp {
                  overflow-x: auto;
                  -webkit-overflow-scrolling: touch;
                  margin-bottom: 40px;
                }
                &::after {
                  @include breakpoint-sp {
                    content: "\f07e";
                    display: inline-block;
                    font-family: $font_family_awsm;
                    font-size: 30px;
                    line-height: 1;
                    color: var(--fo-main-color);
                    position: absolute;
                    left: 50%;
                    margin-left: -15px;
                  }
                }
              }
              table {
                @include breakpoint-tb {
                  min-width: 130vw;
                }
                @include breakpoint-ssp {
                  min-width: 200vw;
                }
                thead {
                  tr {
                    th {
                      @include breakpoint-sp {
                        white-space: initial;
                      }
                    }
                  }
                }
                tbody {
                  tr {
                    th {
                      @include breakpoint-sp {
                        display: table-cell !important;
                        white-space: nowrap;
                      }
                    }
                    td {
                      vertical-align: top;
                      @include breakpoint-sp {
                        display: table-cell !important;
                        white-space: initial;
                      }
                      p {
                        @include breakpoint-tb {}
                      }
                    }
                  }
                }
              }
            }
            //英語テキスト
            &.en_text {
              color: var(--fo-main-color);
              table {
                border: none;
                :is(thead,tbody) {
                  border: 0;
                  tr {
                    border: 0;
                    th {
                      border: 0;
                      padding: 0;
                    }
                    td {
                      border: 0;
                      padding: 0;
                    }
                    p {
                      margin: 0 !important;
                      @include breakpoint-tb {}
                    }
                  }
                }
              }
            }
            //ナンバー
            &.number_text {
              table {
                width: auto !important;
                border: none;
                :is(thead,tbody) {
                  border: 0;
                  tr {
                    border: 0;
                    th {
                      border: 0;
                      line-height: 1;
                      padding: 0;
                    }
                    td {
                      border: 0;
                      line-height: 1;
                      padding: 0;
                    }
                    p {
                      margin: 0 !important;
                      line-height: 1;
                      @include breakpoint-tb {}
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}

/*------------------------------
カスタムパーツ 格納場所
基本的にパーツ単体の記述でお願いします。
パーツ名を忘れず記載してください。
-------------------------------*/
@include theme-fo-base {
  .inner {
    .row {
      .col {
        .component {}
      }
    }
  }
}
/*--- カスタムパーツ 格納場所 end ---*/


/*----------------------------------
    ユニバーサルクラス
----------------------------------*/

//スマホだけ表示させる
.spOnly {
  @include breakpoint-pc {
    display: none !important;
  }
}

//PCだけ表示させる
.pcOnly {
  @include breakpoint-sp {
    display: none !important;
  }
}

//displayNoneクラス
.displayNone {
  display: none !important;
}

//ギャラリーパーツ
.poptrox-overlay {
  z-index: 9999 !important;
  .poptrox-popup {
    .pic {
      z-index: 10000;
    }
  }
}

//iframe
.component {
  &.iframe {
    display: flex;
    //左寄せ
    &.right {
      justify-content: flex-end;
    }
    //中央寄せ
    &.center {
      justify-content: center;
    }
    //ワイド
    &.if_16-9 {
      aspect-ratio: 16/9;
    }
    //スタンダート
    &.if_4-3 {
      aspect-ratio: 4/3;
    }
    //スクエア
    &.if_1-1 {
      aspect-ratio: 1/1;
    }
    //縦撮り
    &.if_9-16 {
      aspect-ratio: 9/16;
    }
    //シネマスコープ
    &.if_235-1 {
      aspect-ratio: 2.35/1;
    }
    //カスタムclass
    &.if_custom {
      width: 100%;
      height: 0;
      position: relative;
      $var: 300;
      @while $var <= 3000 {
        &.pc-h#{$var} {
          @include breakpoint-pc {
            height: #{$var}px;
          }
        }
        &.sp-h#{$var} {
          @include breakpoint-sp {
            height: #{$var}px;
          }
        }
        $var: $var + 10;
      }
      iframe {
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
      }
    }
  }
}

//スムーススクロール
html {
  scroll-behavior: smooth !important;
}

//フォームパーツ
.component {
  &.form {
    .form-title {
      color: var(--fo-text-main-color);
    }
    //フォームの必須
    .form-label {
      &.require {
        &::after {
          padding: 2px 7px 4px !important;
          margin-left: 20px;
        }
      }
    }
    input[type=checkbox],
    input[type=radio] {
      min-height: auto;
    }
    .form-submit {
      .popup-link {
        font-weight: $font_weight;
      }
    }
    &.vertical {
      .form-label {
        &::after {
          position: relative;
          top: -2px;
        }
      }
    }
    &.horizontal {
      .form-label {
        padding-right: 10px;
        &::after {
          @include breakpoint-pc {
            top: 8px !important;
          }
          @include breakpoint-sp {
            top: -2px !important;
          }
        }
      }
    }
  }
}

//ズレ対策
.component {
  &.form {
    label.agreement {
      display: flex;
      align-items: center;
      .form-label {
        padding-top: 6px;
        &::after {
          top: -1.5px;
        }
      }
    }
  }
}

//角丸専用
.radius_all {
  border-radius: $border_radius_common;
}

//2カラム時、PCとSPでカラムの位置を入れ替える
.reverse {
  @include breakpoint-sp {
    display: flex !important;
    flex-wrap: wrap-reverse;
  }
}

//全てbr非表示
.allbrClear {
  br {
    display: none;
  }
}

//PCの時はbr非表示
.pcbrClear {
  br {
    display: none;
    @include breakpoint-sp {
      display: block;
    }
  }
}

//TABの時はbr非表示
.tbbrClear {
  br {
    @include breakpoint-tb {
      display: none;
    }
  }
}

//width1024の時はbr非表示
.probrClear {
  br {
    @include breakpoint-pro {
      display: none;
    }
  }
}

//スマホの時はbr非表示
.spbrClear {
  br {
    @include breakpoint-sp {
      display: none;
    }
  }
}


/*------------- main(コンテンツ) END -------------*/

/* ----------------------------------
  blog(ブログテンプレート)
----------------------------------*/
/*--- ブログページ一覧 ---*/
.component {
  &.blog_articles {
    hr {
      border: 0;
      border-bottom: 1px solid $blog_border_color;
      margin-bottom: 30px;
      @include breakpoint-sp {
        margin-bottom: 10px;
      }
    }
    article {
      .infomation {
        padding: 0 0 0 30px;
        //タイトル
        & > h2 {
          line-height: 1.5;
          padding: 0;
          a {
            display: inline-block;
            font-family: var(--fo-heading-font-family);
            font-size: $list_heading_pc_fontsize;
            font-weight: bold;
            letter-spacing: var(--fo-heading-letter-spacing);
            line-height: var(--fo-heading-line-height);
            color: var(--fo-heading-main-color);
            @include breakpoint-sp {
              font-size: $list_heading_sp_fontsize;
            }
            &:hover {
              opacity: $hover_opacity;
            }
          }
        }
        p {
          font-size: var(--fo-text-font-size-pc);
          color: var(--fo-text-main-color);
          line-height: var(--fo-text-line-height);
          letter-spacing: var(--fo-text-letter-spacing);
          padding: 0;
          @include breakpoint-sp {
            font-size: var(--fo-text-font-size-sp);
          }
        }
        //記事を見るの位置
        a {
          &.view-article {
            display: inline-block;
            width: 100%;
            font-size: var(--fo-text-font-size-pc);
            color: var(--fo-text-link-color,var(--fo-text-main-color));
            line-height: var(--fo-text-line-height);
            letter-spacing: var(--fo-text-letter-spacing);
            text-align: right;
            text-decoration: underline;
            @include breakpoint-sp {
              font-size: var(--fo-text-font-size-sp);
            }
            &:hover {
              opacity: $hover_opacity;
              text-decoration: none;
            }
          }
        }
        //日付の背景色
        span {
          &.published_at {
            background: none;
            font-size: 14px;
            color: var(--fo-text-main-color);
            text-align: left;
            padding: .5rem 0;
          }
        }
        //タグスタイル
        .tags {
          padding-left: 0;
          a {
            &.tag {
              @include tag_custom;
              i {
                margin-right: 0;
                &::before {
                  @include tag_icon_custom;
                }
              }
            }
          }
        }
      }
      .catch,
      .infomation {
        @include breakpoint-sp {
          width: 100%;
          float: none;
          padding: 1em 0 0;
        }
      }
      .catch {
        a {
          img {
            border-radius: $blog_border_radius;
          }
        }
      }
    }
  }
}

/*--- ブログ記事詳細 ---*/
.theme-fo-base {
  .clearfix {
    .contents {
      &.blog-contents {
        padding: 0;
        section {
          .inner {
            @include breakpoint-sp {
              padding: 0 20px 10px;
            }
            .row {
              .col {
                .component {
                  &.blog_article {
                    margin-top: 0;
                    .article-component {
                      //目次内
                      &.contents-table {
                        border-color: $border_color;
                        @include breakpoint-sp {
                          padding: 10px 20px;
                        }
                        ol {
                          @include breakpoint-sp {
                            margin-left: 0;
                          }
                          ol {
                            @include breakpoint-sp {
                              margin-left: 1em;
                            }
                          }
                        }
                      }
                    }
                    //日付・タグ
                    .article-meta-info {
                      opacity: unset;
                      span {
                        &.post-date {
                          time {
                            font-family: var(--fo-text-font-family);
                          }
                        }
                        &.article-category {
                          i {
                            display: none;
                          }
                          a {
                            color: var(--fo-main-color);
                            &::before {
                              @include category_icon_custom;
                            }
                            &:hover {
                              opacity: $hover_opacity;
                            }
                          }
                        }
                        &.article-tags {
                          i {
                            display: none;
                          }
                          a {
                            @include tag_custom;
                            display: inline-block;
                            margin-top: 10px;
                            &::before {
                              @include tag_icon_custom;
                            }
                            &::after {
                              content: none;
                            }
                          }
                        }
                      }
                    }
                    //詳細ページ設定
                    .article-eyecatch {
                      @include breakpoint-pc {
                        margin-bottom: 30px;
                      }
                      @include breakpoint-sp {
                        margin: 30px 0;
                      }
                    }
                    .article-post {
                      color: var(--fo-text-main-color);
                      padding: 0;
                      a {
                        color: var(--fo-text-main-color);
                        &:hover {
                          opacity: $hover_opacity;
                        }
                      }
                      //ブログ詳細の本文
                      .component {
                        &.richtext {
                          font-size: var(--fo-text-font-size-pc);
                          letter-spacing: var(--fo-text-letter-spacing);
                          line-height: var(--fo-text-line-height);
                          color: var(--fo-text-main-color);
                          @include breakpoint-sp {
                            font-size: var(--fo-text-font-size-sp);
                          }
                          p {
                            font-size: inherit;
                            letter-spacing: inherit;
                            line-height: inherit;
                            color: inherit;
                            a {
                              color: var(--fo-text-link-color);
                              &:hover {
                                opacity: var(--fo-text-link-hover-opacity,1);
                                text-decoration: var(--fo-text-link-hover-text-decoration,none);
                                font-weight: var(--fo-text-link-hover-font-weight,inherit);
                                color: var(--fo-text-link-color);
                                filter: unquote('invert(var(--fo-text-link-hover-invert,0))');
                              }
                              &.show-area {
                                &:hover {
                                  opacity: $hover_opacity;
                                  text-decoration: none;
                                  font-weight: inherit;
                                  color: var(--fo-text-link-color);
                                  filter: none;
                                }
                              }
                            }
                          }
                          //ブログ詳細の表
                          table {
                            .table-content {
                              a {
                                color: var(--fo-text-link-color);
                                &:hover {
                                  opacity: var(--fo-text-link-hover-opacity,1);
                                  text-decoration: var(--fo-text-link-hover-text-decoration,none);
                                  font-weight: var(--fo-text-link-hover-font-weight,inherit);
                                  color: var(--fo-text-link-color);
                                  filter: unquote('invert(var(--fo-text-link-hover-invert,0))');
                                }
                              }
                            }
                          }
                          .border {
                            margin-top: 0;
                            hr {
                              &.type01 {
                                background-image: -webkit-linear-gradient(left, transparent, $border_color, transparent);
                              }
                              &:is(.type02,.type03,.type04) {
                                border-color: $border_color;
                              }
                            }
                          }
                          //ブログ詳細の引用
                          blockquote {
                            font-size: inherit;
                            color: inherit;
                            padding: 40px 30px;
                            @include breakpoint-sp {
                              padding: 20px;
                            }
                            &::before {
                              font-size: 500%;
                            }
                          }
                        }
                      }
                    }
                    section {
                      //著者
                      &.author {
                        padding: 0;
                        border-color: $border_color;
                        @include breakpoint-sp {
                          display: flex;
                          padding: 15px;
                        }
                        .author-image {
                          margin-right: 15px;
                          @include breakpoint-sp {
                            width: 50%;
                          }
                          img {
                            border-radius: $blog_border_radius;
                          }
                        }
                        .author-info {
                          .author-name {
                            font-family: var(--fo-heading-font-family);
                            font-size: 18px;
                            color: var(--fo-heading-main-color);
                            line-height: var(--fo-heading-line-height);
                            letter-spacing: var(--fo-heading-letter-spacing);
                            @include breakpoint-sp {
                              font-size: 16px;
                            }
                          }
                          .author-description {
                            white-space: pre-wrap;
                            font-size: var(--fo-text-font-size-pc);
                            letter-spacing: var(--fo-text-letter-spacing);
                            line-height: var(--fo-text-line-height);
                            color: var(--fo-text-main-color);
                            @include breakpoint-sp {
                              font-size: var(--fo-text-font-size-sp);
                            }
                          }
                        }
                      }
                    }
                  }
                }
                section {
                  //ページネーション
                  &.prev-next-link {
                    display: flex;
                    gap: calc(40px * var(--fo-spacing-coef));
                    margin-top: calc(40px * var(--fo-spacing-coef));
                    @include breakpoint-sp {
                      flex-direction: column;
                      gap: 0;
                      margin: calc((40px * var(--fo-spacing-coef)) * .75) 0 20px;
                      padding: 0;
                    }
                    a {
                      color: var(--fo-text-main-color);
                      border-color: $border_color;
                      &:hover {
                        background: transparent;
                        opacity: $hover_opacity;
                      }
                      &::before,
                      &::after {
                        color: var(--fo-main-color);
                      }
                      //前の記事 次の記事
                      h3 {
                        &.prev-next-label {
                          font-family: var(--fo-heading-font-family);
                          font-size: 18px;
                          color: var(--fo-heading-main-color);
                          line-height: var(--fo-heading-line-height);
                          letter-spacing: var(--fo-heading-letter-spacing);
                          @include breakpoint-sp {
                            font-size: 16px;
                          }
                        }
                      }
                      div.thumb-wrap {
                        display: flex;
                        img {
                          float: none;
                          margin-right: 15px;
                        }
                        p {
                          font-size: 14px;
                          letter-spacing: var(--fo-text-letter-spacing);
                          line-height: var(--fo-text-line-height);
                          color: var(--fo-text-main-color);
                          display: -webkit-box;
                          -webkit-line-clamp: 2;
                          -webkit-box-orient: vertical;
                          text-overflow: ellipsis;
                          max-height: calc((14px * var(--fo-text-line-height)) * 2);
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}

/*------------- blog(ブログテンプレート) END -------------*/

/* ----------------------------------
  カテゴリ・タグ自動生成ページ
----------------------------------*/
.theme-fo-base {
  &.clearfix {
    .wrapper {
      &.clearfix {
        .contents {
          :is(
            .category-preview,
            .tag-preview
          ) {
            box-sizing: border-box;
            margin: auto;
            article {
              display: table;
              border-bottom: 1px solid $blog_border_color;
              @include breakpoint-sp {
                display: block;
                width: 100%;
                margin: 20px 0;
                padding: 0;
              }
              .article-thumbnail {
                display: table-cell;
                width: 30%;
                padding-bottom: 10px;
                @include breakpoint-sp {
                  display: block;
                  width: 100%;
                }
                a {
                  display: block;
                  @include breakpoint-sp {
                    margin-bottom: 10px;
                  }
                  img {
                    width: 100%;
                    border-radius: 0;
                  }
                }
              }
              .article-cont {
                display: table-cell;
                width: 70%;
                height: auto;
                vertical-align: top;
                padding: 10px 30px;
                @include breakpoint-sp {
                  display: block;
                  width: 100%;
                  margin-bottom: 20px;
                  padding: 0;
                }
                .article-title {
                  overflow: auto;
                  max-height: none;
                  a {
                    font-family: var(--fo-heading-font-family);
                    font-size: $list_heading_pc_fontsize;
                    font-weight: inherit;
                    color: var(--fo-heading-main-color);
                    line-height: var(--fo-heading-line-height);
                    letter-spacing: var(--fo-heading-letter-spacing);
                    @include breakpoint-sp {
                      font-size: $list_heading_sp_fontsize;
                    }
                    &:hover {
                      opacity: $hover_opacity;
                    }
                  }
                }
                .article-meta-info {
                  position: relative;
                  .article-category {
                    &::before {
                      content: none;
                    }
                    a {
                      color: var(--fo-text-link-color,var(--fo-text-main-color));
                      &::before {
                        @include category_icon_custom;
                      }
                      &:hover {
                        opacity: $hover_opacity;
                      }
                    }
                  }
                  //タグ自動生成のタグスタイル
                  .tag-lists {
                    @include breakpoint-sp {
                      display: block;
                    }
                    .article-tags {
                      @include tag_custom;
                      &::before {
                        @include tag_icon_custom;
                      }
                    }
                  }
                  //カレンダーアイコン削除
                  span {
                    &.post-date {
                      color: var(--fo-text-main-color);
                      &::before {
                        content: none;
                      }
                      time {
                        font-family: var(--fo-text-font-family);
                      }
                    }
                    &.article-author {
                      color: var(--fo-text-main-color);
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}
:is(
  .tag-preview article .article-cont .article-meta-info .tag-lists,
  .category-preview article .article-cont .article-meta-info .tag-lists
) {
  max-height: 100% !important;
}
/*------------- カテゴリ・タグ自動生成ページ END -------------*/

/*----------------------------------
    side bar(サイドバー)
----------------------------------*/
//834幅から1カラム設定
.theme-fo-base {
  .wrapper {
    &:is(.side-left,.side-right) {
      max-width: $max_width;
      @include breakpoint-pro_s {
        display: block; //崩れ対策
      }
      .contents {
        background: transparent;
        max-width: unset;
        border-left: 0;
        border-right: 0;
        padding: 0;
        @include breakpoint-pro_s {
          display: block; //崩れ対策
        }
        section {
          .inner {
            padding: 20px;
          }
        }
      }
      .side {
        @include breakpoint-pro_s {
          display: block;
        }
        &:is(.left,.right) {
          padding: 0;
          @include breakpoint-pro_s {
            width: 100%;
          }
          @include breakpoint-tb {
            width: 100%;
            margin: auto;
          }
          .inner {
            padding: 20px;
            .component:not(:root:root) {
              margin: 20px 0;
              &:first-child {
                margin-top: 0;
              }
              &.heading {
                h1 {
                  @include breakpoint-pc {
                    font-size: $blog_title_h1_fontsize_pc;
                  }
                  @include breakpoint-sp {
                    font-size: $blog_title_h1_fontsize_sp;
                  }
                }
                h2 {
                  @include breakpoint-pc {
                    font-size: $blog_title_h2_fontsize_pc - 2px;
                  }
                  @include breakpoint-sp {
                    font-size: $blog_title_h2_fontsize_sp;
                  }
                }
              }
              &.blog-ranking {
                &[data-designpart-id="642f669ce4dc09621d945ab4"] {
                  div {
                    &:nth-child(1 of .entry-list-unit) {
                      @include breakpoint-sp {
                        padding-top: 0;
                      }
                    }
                  }
                }
              }
              &.button {
                .button-cont {
                  a {
                    &:is(.size-s,.size-m,.size-l) {
                      @include breakpoint-pc {
                        width: 100%;
                        min-width: 100%;
                      }
                    }
                    &.size-s {
                      @include breakpoint-pro_s {
                        width: initial;
                        min-width: 200px;
                      }
                    }
                    &.size-m {
                      @include breakpoint-pro_s {
                        width: initial;
                        min-width: 280px;
                      }
                    }
                    &.size-l {
                      @include breakpoint-pc {
                        font-size: 16px;
                      }
                      @include breakpoint-pro_s {
                        font-size: 22px;
                        width: initial;
                        min-width: 350px;
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
    &.side-left {
      @include breakpoint-pro_s {
        display: flex;
        flex-wrap: wrap;
        flex-direction: column-reverse;
      }
    }
    &.side-both {
      @include breakpoint-pro_s {
        display: flex;
        flex-wrap: wrap;
      }
      .contents {
        @include breakpoint-pc {
          width: 100%;
          max-width: 560px;
        }
        @include breakpoint-pro_s {
          display: block;
          max-width: none;
          order: 1;
          padding: 10px 0;
        }
        @include breakpoint-sp {
          padding: 10px 0;
        }
        section {
          .inner {
            padding: 20px;
            .row {
              .col {
                @include breakpoint-pro_s {
                  padding: 0;
                }
              }
            }
          }
        }
      }
      .side {
        &:is(.left,.right) {
          @include breakpoint-pro_s {
            display: block;
            width: 100%;
          }
          @include breakpoint-msp {
            padding: 0;
          }
          @include breakpoint-tb {
            width: 100%;
            margin: auto;
          }
          .inner {
            @include breakpoint-msp {
              padding: 20px;
            }
          }
        }
        &.left {
          @include breakpoint-pro_s {
            order: 2;
          }
        }
        &.right {
          @include breakpoint-pro_s {
            order: 3;
          }
        }
      }
    }
  }
}

/*--- カテゴリ --- */
.component {
  &.category {
    &.category_custom {
      margin-bottom: 20px !important;
      a {
        color: var(--fo-text-main-color);
        &:hover {
          opacity: $hover_opacity;
        }
      }
    }
  }
}

/*--- ランキング ---*/
.component {
  &.blog-ranking {
    &.ranking_custom {
      @include breakpoint-sp {
        width: 100%;
        margin: auto;
      }
      .entry-list-unit {
        border-color: $blog_border_color;
        @include breakpoint-sp {
          padding: 20px 0 10px;
        }
        .img {
          padding: 0 !important;
          @include breakpoint-sp {
            padding-right: 0 !important;
          }
          img {
            border-radius: 0;
          }
        }
        .cont {
          border-left: 0;
          @include breakpoint-sp {
            padding: 0 !important;
          }
          h3 {
            display: -webkit-box;
            -webkit-box-orient: vertical;
            -webkit-line-clamp: 2;
            overflow: hidden;
            text-overflow: ellipsis;
            color: var(--fo-text-main-color);
            margin: 0 0 10px;
            @include breakpoint-sp {
              margin-top: 1em;
              padding: 0;
            }
            a {
              padding: 0;
              margin: 0;
            }
          }
          p {
            display: -webkit-box;
            -webkit-box-orient: vertical;
            -webkit-line-clamp: 4;
            overflow: hidden;
            text-overflow: ellipsis;
            padding: 0;
          }
        }
        .article-rank {
          background: #fff;
          color: var(--fo-main-color);
          border: 1px solid var(--fo-main-color);
          z-index: 2;
          @include breakpoint-msp {
            min-width: 45px;
            height: 45px;
            font-size: 20px;
            line-height: 45px;
          }
          &:is(.rank-1,.rank-2,.rank-3) {
            background: var(--fo-main-color) !important;
            color: #fff;
            border: 1px solid var(--fo-main-color);
          }
        }
      }
    }
  }
}

/*--- カテゴリーアイコン ---*/
.fa-folder-open-o::before {
  font-family: $font_family_awsm;
}

/*------------- side bar(サイドバー)END -------------*/

/*----------------------------------
    foot(フッター)
----------------------------------*/
.theme-fo-base {
  .foot {
    &.ft_custom {
      background: $footer_bg_color;
      background-repeat: no-repeat;
      color: var(--fo-text-main-color);
      padding: 0;
      .foot-cont {
        padding: 60px 20px 70px;
        @include breakpoint-msp {
          padding: 40px 20px;
        }
        .row {
          //ロゴの部分
          &.ft_logo_row {
            & + .ft_site_map_row {
              @include breakpoint-pc {
                margin-top: 30px;
              }
              @include breakpoint-msp {
                margin-top: 20px;
              }
            }
          }
          &.ft_site_map_row {
            @include breakpoint-tb {
              display: flex;
              gap: 10px;
            }
            & + .ft_bottom_row {
              margin-top: 35px;
              @include breakpoint-ssp {
                margin-top: 15px;
              }
            }
            //各colの幅やスタイル部分
            .col {
              vertical-align: top;
              //リンクリストの部分
              &.site_map_col {
                & + .site_map_col {
                  @include breakpoint-ssp {
                    padding-top: 10px;
                  }
                }
              }
            }
          }
          //ボタン固定
          &.page_top_row {
            @include page_top;
          }
          .col {
            @include breakpoint-sp {
              margin: 0;
              padding: 0;
            }
            .component {
              //イメージ
              &.image {
                &.ft_logo_img {
                  img {
                    max-width: 244px !important;
                    width: 100% !important;
                  }
                }
              }
              //リスト
              &.list {
                &.site_map_list {
                  margin: 0;
                  ul {
                    font-size: inherit;
                    li {
                      list-style-type: none;
                      font-size: inherit;
                      color: inherit;
                      &:not(:first-child) {
                        margin: 8px 0 0;
                      }
                      a {
                        display: inline-block;
                        color: inherit;
                        padding: 0;
                        &:hover {
                          background: transparent;
                          opacity: $hover_opacity;
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
      //コピーライト部分
      .foot-copyright {
        @include copyright_custom;
      }
    }
  }
}

/*------------- foot(フッター END)-------------*/

/*----------------------------------
    LP(フルカスタム用)
----------------------------------*/
/*
LP variables(変数)
LP button(ボタン)
LP header (見出し)
LP richtext(テキスト)
LP form(フォーム)
LP メインビジュアル
LP contents(コンテンツ)
LP body(本体)
*/

/* --------------------------------
    LP variables(変数)
----------------------------------- */

//フォント
$lp_font_family: "Noto Sans JP";

//hover時の不透明度
$lp_hover_opacity: .4;

//カラー
$lp_main_color: black; //メインカラー
$lp_sub_color: #eee; //サブカラー
$lp_accent_color: #df8c3b; //アクセントカラー
$lp_text_color: #333; //テキストカラー
$lp_a_text_color: #003b82; //テキストリンクのカラ
$lp_form_hissu_color: #c70909;//赤 フォームの「必須マーク」カラー

//ヘッダー
$lp_header_logo: 200px; //PCでの幅サイズ(固定)
$lp_header_sp_logo: 30px; //SPでの高さサイズ(maxサイズ)
$lp_header_height: 80px; //PC時のヘッダーの高さ(固定時に使用)
$lp_header_sp_height: 52px; //SP時のヘッダーの高さ(固定時に使用)

//セクション余白
$lp_section_padding: 120px; //PC時のパディング
$lp_section_sp_padding: 60; //SP時のパディング

//テキスト
$lp_text_pc_fontsize: 16px; //ベースとなるフォントサイズ(PC)
$lp_text_sp_fontsize: 16px; //ベースとなるフォントサイズ(SP)
$lp_text_line_height: 1.5; //ベースとなるline-height(行間)
$lp_text_letter_spacing: .04em;

//見出し
$lp_hd_line_height: 1.5; //見出し用line-height(行間)
$lp_hd_letter_spacing:.04em;
$lp_hd_font_weight: bold; //見出し用
$lp_hd_font_strong: normal; //見出し用(編集画面の「.strong」に対応)
$lp_title_font_family: $lp_font_family; //サイト内見出しのフォントファミリー
////pc
$lp_hd_pc_h1_fontsize: 46px; //サイト内(ブログコンテンツを除く)の見出しh1のフォントサイズ(PC)
$lp_hd_pc_h2_fontsize: 38px; //サイト内(ブログコンテンツを除く)の見出しh2のフォントサイズ(PC)
$lp_hd_pc_h3_fontsize: 30px; //サイト内(ブログコンテンツを除く)の見出しh3のフォントサイズ(PC)
$lp_hd_pc_h4_fontsize: 20px; //サイト内(ブログコンテンツを除く)の見出しh4のフォントサイズ(PC)
$lp_hd_pc_h5_fontsize: 18px; //サイト内(ブログコンテンツを除く)の見出しh5のフォントサイズ(PC)
////sp
$lp_hd_sp_h1_fontsize: 26px; //サイト内(ブログコンテンツを除く)の見出しh1のフォントサイズ(SP)
$lp_hd_sp_h2_fontsize: 24px; //サイト内(ブログコンテンツを除く)の見出しh2のフォントサイズ(SP)
$lp_hd_sp_h3_fontsize: 22px; //サイト内(ブログコンテンツを除く)の見出しh3のフォントサイズ(SP)
$lp_hd_sp_h4_fontsize: 18px; //サイト内(ブログコンテンツを除く)の見出しh4のフォントサイズ(SP)
$lp_hd_sp_h5_fontsize: 16px; //サイト内(ブログコンテンツを除く)の見出しh5のフォントサイズ(SP)

//ボックスシャドウ
$lp_box_shadow_common: 2px 2px 10px 0 rgba(#000,.08);
$lp_box_shadow_nav_common: 0 3px 6px  rgba(#000,.08);

//コピーライト
$lp_copyright_bg_color: #eae8e8; //コピーライトの背景色
$lp_copyright_text_color: $lp_text_color; //コピーライトのテキストカラー
$lp_copyright_text_fontsize: 12px; //コピーライトのフォントサイズ

//角丸
$lp_border_radius_common: 10px;
$lp_border_radius_btn_common: 50vh;

//その他
$lp_max_width: 1100px; //検索結果コンテンツ幅調整用
$lp_border_color: #eee;
$lp_inPageLink_pc: 80px; //ページ内リンクPC(PC時のヘッダーの高さを指定)
$lp_inPageLink_sp: 52px; //ページ内リンクSP(SP時のヘッダーの高さを指定)

/*----------------------------------
    LP button(ボタン)
----------------------------------*/
.component {
  &.button {
    &:is(
      .lp_btn_custom01,
      .lp_btn_custom02
      ) {
      .button-cont {
        a {
          box-sizing: border-box;
          letter-spacing: $lp_text_letter_spacing;
          line-height: 1.3;
          text-align: left;
          text-decoration: none;
          border-radius: 0;
          //サイズ小のとき
          &.size-s {
            //フォントサイズやボタンの大きさを設定
            min-width: 220px;
            font-size: 14px;
            padding: 9px 20px;
            @include breakpoint-pro {
              min-width: 200px;
            }
            @include breakpoint-sp {
              min-width: 80%;
              width: auto;
            }
            @include breakpoint-tb {
              min-width: 200px;
            }
          }
          //サイズ中のとき
          &.size-m {
            min-width: 280px;
            font-size: 16px;
            padding: 15.5px 20px;
            @include breakpoint-sp {
              width: auto;
              min-width: 90%;
              padding: 15px;
            }
            @include breakpoint-tb {
              min-width: 280px;
            }
          }
          //サイズ大のとき
          &.size-l {
            display: inline-block;
            min-width: 350px;
            font-size: 20px;
            margin: auto;
            padding: 20px;
            @include breakpoint-sp {
              width: 100%;
              min-width: auto;
            }
            @include breakpoint-tb {
              width: auto;
              min-width: 350px;
            }
          }
          &:hover {
            opacity: 1;
          }
        }
      }
    }
    //ボタン01
    &.lp_btn_custom01 {
      .button-cont {
        a {
          &:is(.size-s,.size-m,.size-l) {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            border-radius: $lp_border_radius_btn_common;
            border: 2px solid rgba(0,0,0,0);
            &::before {
              content: "\f15c";
              font-family: $font_family_awsm6;
              font-weight: 400;
              color: inherit;
              margin-right: 10px;
              position: relative;
              top: .5px;
            }
          }
          &:is(.blue,.red,.orange,.black,.white) {
            background: $lp_main_color;
            color: #fff;
            border-color: $lp_main_color;
          }
          &:hover {
            opacity: $lp_hover_opacity;
          }
        }
      }
    }
    //ボタン02
    &.lp_btn_custom02 {
      .button-cont {
        a {
          &:is(.size-s,.size-m,.size-l) {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            border-radius: $lp_border_radius_btn_common;
            border: 2px solid rgba(0,0,0,0);
            &::before {
              content: "\f0e0";
              font-family: $font_family_awsm6;
              font-weight: 400;
              color: inherit;
              margin-right: 10px;
              position: relative;
              top: .5px;
            }
          }
          &:is(.blue,.red,.orange,.black,.white) {
            background: $lp_sub_color;
            color: #000;
            border-color: $lp_sub_color;
          }
          &:hover {
            opacity: $lp_hover_opacity;
          }
        }
      }
    }
    //telボタン
    &.lp_btn_custom_tel {
      .button-cont {
        a {
          &:where(.size-s,.size-m,.size-l) {
            background-color: transparent;
            font-family: $lp_font_family;
            letter-spacing: $lp_text_letter_spacing;
            color: $lp_text_color;
            text-decoration: none;
            position: relative;
            border-radius: 0;
            margin: 0;
            padding: 0;
            //背景色とかborder色など外観を設定
            &::before {
              content: "\f095";
              font-family: $font_family_awsm6;
              font-size: 100%;
              font-weight: 900;
              position: relative;
              margin-right: .3rem;
            }
            &:visited {
              color: $lp_text_color;
              text-decoration: none;
            }
            &:hover {
              opacity: $lp_hover_opacity;
            }
            &.size-s {
              font-size: 18px;
            }
            &.size-m {
              font-size: 20px;
            }
            &.size-l {
              display: inline-block;
              font-size: 32px;
            }
          }
        }
      }
    }
  }
}

/*----------------------------------
    LP heading(見出し)
----------------------------------*/
@mixin lp-heading {
  .component {
    &.heading {
      &.lp_inPageLink {
        @include breakpoint-pc {
          margin-top: calc(-#{$lp_inPageLink_pc} - 10px);
          padding-top: calc(#{$lp_inPageLink_pc} + 10px);
        }
        @include breakpoint-sp {
          margin-top: calc(-#{$lp_inPageLink_sp} - 10px);
          padding-top: calc(#{$lp_inPageLink_sp} + 10px);
        }
      }
      &.lp_hd_custom01 {
        :is(h1,h2,h3,h4,h5) {
          font-family: $lp_font_family;
          font-weight: $lp_hd_font_weight;
          line-height: $lp_hd_line_height;
          letter-spacing: $lp_hd_letter_spacing;
          .strong {
            font-weight: $lp_hd_font_strong;
          }
          @include breakpoint-sp {
            overflow-wrap: break-word;
          }
        }
        h1 {
          font-size: $lp_hd_pc_h1_fontsize;
          @include breakpoint-sp {
            font-size: $lp_hd_sp_h1_fontsize;
          }
        }
        h2 {
          font-size: $lp_hd_pc_h2_fontsize;
          @include breakpoint-sp {
            font-size: $lp_hd_sp_h2_fontsize;
          }
        }
        h3 {
          font-size: $lp_hd_pc_h3_fontsize;
          @include breakpoint-sp {
            font-size: $lp_hd_sp_h3_fontsize;
          }
        }
        h4 {
          font-size: $lp_hd_pc_h4_fontsize;
          @include breakpoint-sp {
            font-size: $lp_hd_sp_h4_fontsize;
          }
        }
        h5 {
          font-size: $lp_hd_pc_h5_fontsize;
          @include breakpoint-sp {
            font-size: $lp_hd_sp_h5_fontsize;
          }
        }
      }
      /*--- カスタム見出し ---*/
      // カスタム見出し01
      &.lp_hd_custom01 {
        :is(h1,h2) {
          margin-bottom: 60px;
        }
        :is(h3,h4,h5) {
          margin-bottom: 30px;
        }
      }
    }
  }
}

/*----------------------------------
    LP richtext(テキスト)
----------------------------------*/
@mixin lp-richtext($lp-marginTop:10px) {
  .component {
    &.richtext {
      font-family: $lp_font_family;
      font-size: $lp_text_pc_fontsize;
      color: $lp_text_color;
      line-height: $lp_text_line_height;
      letter-spacing: $lp_text_letter_spacing;
      @include breakpoint-sp {
        font-size: $lp_text_sp_fontsize;
      }
      :link {
        text-decoration: none;
      }
      :visited {
        text-decoration: none;
      }
      a {
        color: $lp_a_text_color;
        &:hover {
          opacity: $lp_hover_opacity;
        }
      }
      p {
        font-size: inherit;
        line-height: inherit;
        margin: 0;
        & + :is(p,ul,ol,.normal-table,.table-with-row-header,.table-with-two-headers,.component.button) {
          margin-top: $lp-marginTop;
        }
      }
      //リスト
      li {
        font-size: inherit;
        a {
          font-size: inherit;
        }
      }
      //テーブル
      table {
        :is(thead,tbody,tr,th,td) {
          border-color: #eee;
          tr {
            :is(th,td) {
              background-clip: padding-box; //FF,edgeでボーダー消える現象回避;
              position: static; //FF,edgeでボーダー消える現象回避;
              p {
                font-size: inherit;
                & + :is(p,ul,ol,.component.button) {
                  margin-top: $lp-marginTop !important;
                }
              }
              :is(ul,ol) {
                margin-left: 25px;
                & + :is(p,ul,ol,.component.button) {
                  margin-top: $lp-marginTop !important;
                }
              }
              .component.button {
                & + :is(p,ul,ol,.component.button) {
                  margin-top: $lp-marginTop !important;
                }
              }
            }
          }
        }
      }
      :is(ul,ol) {
        margin: 0 0 0 25px;
        & + :is(p,ul,ol,.normal-table,.table-with-row-header,.table-with-two-headers,.component.button) {
          margin-top: $lp-marginTop;
        }
      }
      :is(table,.normal-table,.table-with-row-header,.table-with-two-headers) {
        & + :is(p,ul,ol,.normal-table,.table-with-row-header,.table-with-two-headers,.component.button) {
          margin-top: $lp-marginTop;
        }
      }
      .component.button {
        margin: 0;
        &.button {
          & + :is(p,ul,ol,.normal-table,.table-with-row-header,.table-with-two-headers,.component.button) {
            margin-top: $lp-marginTop;
          }
          .button-cont {
            a {
              &.blue {
                background: #254a73;
                color: #fff !important;
                text-decoration: none;
                &:hover {
                  opacity: .4;
                }
              }
            }
          }
        }
      }
    }
  }
}
/*----------------------------------
    LP form(フォーム)
----------------------------------*/
@mixin lp-form($font-weight:bold) {
  .component {
    &.form {
      //カスタムフォーム
      &.lp_form_custom {
        font-family: $lp_font_family;
        font-size: $lp_text_pc_fontsize;
        color: $lp_text_color;
        @include breakpoint-sp {
          font-size: $lp_text_sp_fontsize;
        }
        .form-title {
          font-size: inherit;
          color: inherit;
          &:empty {
            display: none;
          }
        }
        //エラー
        .show-notice {
          font-size: inherit;
          border-radius: 0;
          font-size: $lp_text_pc_fontsize;
          @include breakpoint-sp {
            font-size: $lp_text_sp_fontsize;
          }
          &:empty {
            display: none;
          }
          span {
            padding: 5px;
            & + span {
              padding: 0 5px 5px;
            }
          }
        }
        .form-label {
          &::after {
            line-height: 1.5;
            padding: 3px 7px !important;
          }
        }
        .contact_form {
          font-size: inherit;
          color: inherit;
          input {
            accent-color: $lp_main_color;
          }
          //inputフルカスタム(必要な時に使用)
          input[type="text"],
          input[type="email"],
          input[type="password"],
          input[type="date"],
          input[type="search"],
          input[type="url"],
          select,
          textarea {
            background: #fff;
            height: auto;
            font-family: inherit !important;
            font-size: inherit;
            line-height: $lp_text_line_height;
            letter-spacing: $lp_text_letter_spacing;
            color: inherit;
            border-radius: 0;
            border: solid 1px rgba(0,0,0,.20);
            padding: .6rem .75rem;
            &::placeholder {
              font-family: inherit;
              font-size: inherit;
              color: rgba(0,0,0,.30);
            }
            &:hover {}
            &:focus {
              background-color: #fff;
              color: #555;
              border-color: #5a5a5a;
            }
          }
          input[type="text"].form-error,
          input[type="email"].form-error,
          input[type="password"].form-error,
          input[type="date"].form-error,
          input[type="search"].form-error,
          input[type="url"].form-error,
          select.form-error,
          textarea.form-error {
            background: #fdf5f2;
            border: 1px solid $lp_form_hissu_color !important;
          }
          .group {
            font-size: inherit;
            color: inherit;
            margin: 20px 0;
            .form-cont {
              font-size: inherit;
              color: inherit;
            }
          }
          .form-label {
            font-size: inherit;
            @include breakpoint-sp {
              display: inline-block !important;
            }
          }
          .agree-label {
            line-height: 1.5;
          }
          .form-cont {
            font-size: inherit;
            p {
              font-size: inherit;
              margin-top: .25rem;
            }
            :is(.checkbox,.radio) {
              label {
                display: flex;
                align-items: center;
              }
            }
          }
          //規約テキスト
          .service_term {
            background: #fff;
            overflow: auto;
            font-size: inherit;
            padding: 20px;
          }
          //規約リンク
          .service_term_link {
            font-size: inherit;
            margin-top: 20px;
            margin-bottom: 5px;
            a {
              color: $lp_a_text_color;
              letter-spacing: 0;
              text-decoration: none;
              &:hover {
                opacity: .4;
              }
            }
            & + label.agreement {
              padding: 5px 0;
              .form-label {
                display: flex !important;
                align-items: center;
                padding: 0;
                &::after {
                  position: initial;
                  padding: 3px 7px !important;
                }
              }
            }
          }
        }
      }
      //送信ボタンスタイル
      &.lp_form_btn_custom01 {
        .form-submit {
          margin-top: 20px;
          .popup-link {
            min-width: 200px;
            background: $lp_main_color;
            font-family: $lp_font_family;
            font-size: 18px;
            font-weight: $font-weight;
            border: 1px solid $lp_main_color;
            border-radius: $lp_border_radius_btn_common;
            padding: 15px 60px;
            @include breakpoint-tb {
              min-width: 200px;
              width: auto;
            }
            @include breakpoint-sp {
              padding: 10px 60px;
            }
            &:hover {
              background: #fff;
              color: $lp_main_color;
            }
          }
        }
      }
      //フォームの必須
      .form-label.require {
        &:after {
          background: $lp_form_hissu_color;
          margin-left: 20px;
        }
      }
      input[type=checkbox],
      input[type=radio] {
        min-height: auto;
      }
      &.vertical {
        .form-label {
          &:after {
            position: relative;
            top: -2px;
          }
        }
      }
      &.horizontal {
        .form-label {
          &:after {
            @include breakpoint-pc {
              top: 6px;
            }
            @include breakpoint-sp {
              top: -3px;
            }
          }
        }
      }
    }
  }
}
/*----------------------------------
    LP メインビジュアル
----------------------------------*/
@mixin lp-mv {
  &.lp_mv_sec {
    padding: 0;
  }
}
/*----------------------------------
    LP contents(コンテンツ)
----------------------------------*/
@mixin lp-contents {
  font-family: $lp_font_family;
  color: $lp_text_color;
  line-height: $lp_text_line_height;
  letter-spacing: $lp_text_letter_spacing;
  //セクション余白調整
  @include breakpoint-pc {
    padding: calc(#{$lp_section_padding} - 30px) 0 calc(#{$lp_section_padding} - 40px);
  }
  @include breakpoint-sp {
    padding: $lp_section_sp_padding 0;
  }
  &.lp_cta_sec {
    .inner {
      .row {
        .col {
          .component {
            &.cta {
              margin: 0;
            }
          }
        }
      }
    }
  }
  .inner {
    .row {
      //よくあるご質問
      &.lp_faq_row {
        margin: 10px 0 20px;
        & + .lp_faq_row {
          margin-top: 40px;
        }
        .col {
          background: #fff;
          box-shadow: $lp_box_shadow_common;
          border-radius: $lp_border_radius_common;
          padding: 20px;
          .component {
            &.richtext {
              &:is(.faq_qu,.faq_an) {
                position: relative;
                border-bottom: 1px solid $lp_border_color;
                margin: 0;
                padding: 15px 15px 15px 50px;
                @include breakpoint-sp {
                  padding-left: 40px;
                }
                &::before {
                  content: "Q.";
                  display: inline-block;
                  font-size: 28px;
                  font-weight: bold;
                  color: $lp_accent_color;
                  position: absolute;
                  left: 5px;
                  top: 4px;
                  @include breakpoint-sp {
                    top: 2px;
                  }
                }
              }
              &.faq_an {
                border-bottom: 0;
                &::before {
                  content: "A.";
                  color: $lp_text_color;
                }
              }
            }
          }
        }
      }
      .col {
        .component {
          &.richtext {}
          &.image {}
          &.list {}
        }
      }
    }
  }
}

/*----------------------------------
    LP body(本体)
    基本触らないでください
----------------------------------*/
//ヘッダー固定時ズレを修正
html {
  &:has(.lp_sticky_sec) {
    @include breakpoint-pc {
      scroll-padding-top: calc(#{$lp_header_height} + 10px);
    }
    @include breakpoint-sp {
      scroll-padding-top: calc(#{$lp_header_height} + 10px);
    }
  }
}

@include theme-fo-base {
  //LPヘッダー
  &.lp_header_sec {
    font-family: $lp_font_family;
    color: $lp_text_color;
    line-height: $lp_text_line_height;
    letter-spacing: $lp_text_letter_spacing;
    padding: 0;
    @include lp-heading();
    @include lp-richtext();
    @include lp-form();
    .inner {
      padding: 10px 20px;
      @include breakpoint-sp {
        padding: 10px;
      }
      .row {
        &.header_row {
          display: flex;
          align-items: center;
          @include breakpoint-pc {
            min-height: 60px;
          }
          .col {
            padding: 0;
            &.logo_col {
              @include breakpoint-pc {
                max-width: 300px;
                min-width: 150px;
                width: auto !important;
              }
              .component {
                &.image {
                  margin: 0;
                  &.lp_logo_img {
                    img {
                      @include breakpoint-pc {
                        max-width: $lp_header_logo !important;
                        width: 100% !important;
                      }
                      @include breakpoint-sp {
                        max-height: $lp_header_sp_logo !important;
                      }
                    }
                  }
                }
              }
            }
            &.btn_col {
              display: flex !important;
              justify-content: flex-end;
              align-items: center;
              flex: 1;
              @include breakpoint-pc {
                width: auto !important;
              }
              .component {
                margin: 0;
                &:not(:first-child) {
                  @include breakpoint-pc {
                    margin-left: 15px;
                  }
                }
                &.button {
                  margin-top: 0;
                  .button-cont {
                    a {
                      @include breakpoint-sp {
                        background: none;
                        width: auto;
                        min-width: auto;
                        font-size: 0 !important;
                        letter-spacing: 0;
                        border-radius: 0;
                        border: 0;
                        margin: 0;
                        box-shadow: none;
                        padding: 5px 10px 5px 5px;
                      }
                      &::before {
                        @include breakpoint-sp {
                          font-size: 22px;
                          line-height: 1;
                          color: $lp_main_color;
                          margin: 0;
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
        &.nav_row {
          @include breakpoint-pc {
            margin: 20px 0 -10px;
          }
          .col {
            padding: 0;
            .component {
              &.list {
                margin: 0;
                ul {
                  @include breakpoint-pc {
                    display: table;
                    width: 100%;
                    table-layout: fixed;
                  }
                  li {
                    margin: 0;
                    padding: 0;
                    font-size: 14px;
                    @include breakpoint-pc {
                      display: table-cell;
                    }
                    @include breakpoint-sp {
                      width: 50%;
                    }
                    a {
                      display: block;
                      font-size: inherit;
                      color: inherit;
                      text-align: center;
                      padding: 20px 10px;
                      @include breakpoint-sp {
                        padding: 10px 5px;
                      }
                      &:hover {
                        background-color: $lp_main_color;
                        color: #fff;
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
    //LPコンテンツ記述
    & ~ section {
      @include lp-heading();
      @include lp-richtext();
      @include lp-form();
      @include lp-mv();
      @include lp-contents();
      //フッター
      &.lp_footer_sec {
        padding: 0;
        .inner {
          max-width: 100% !important;
          padding: 0;
          .row {
            padding: 0;
            &:not(.copyright_row) {
              max-width: $lp_max_width;
              margin: 0 auto;
              padding: 0 20px;
            }
            &.site_map_row {
              padding: 40px 20px;
              .col {
                vertical-align: middle;
              }
            }
            &.page_top_row {
              @include page_top;
            }
            &.copyright_row {
              .col {
                padding: 0;
                .component {
                  &.richtext {
                    &.foot-copyright {
                      @include copyright_custom;
                    }
                  }
                }
              }
            }
            .col {
              padding: 0;
              .component {
                &.image {
                  &.footLogo_img {
                    img {
                      max-width: 250px !important;
                      width: 100% !important;
                    }
                  }
                }
                &.list {
                  &.site_map_list {
                    ul {
                      display: flex;
                      gap: 10px 20px;
                      @include breakpoint-sp {
                        flex-direction: column;
                      }
                      li {
                        margin: 0;
                        padding: 0;
                        a {
                          color: inherit;
                          &:hover {
                            opacity: $lp_hover_opacity;
                          }
                        }
                      }
                    }
                    &.vertical {
                      ul {
                        flex-direction: column;
                        li {
                          a {
                            padding: 0;
                          }
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
  //LPセクション固定
  &.lp_sticky_sec {
    position: sticky;
    top: 0;
    z-index: 1000;
    box-shadow: $lp_box_shadow_nav_common;
  }
}
/*------------- LP(フルカスタム用) END-------------*/
/*----------------------------------
    JSパーツ記述場所
----------------------------------*/

/*------------- JSパーツ記述場所 END-------------*/

//col空処理
@include theme-fo-base {
  .inner {
    .row {
      .col {
        &:empty {
          background: none;
          border: 0;
          @include breakpoint-sp {
            display: none !important;
          }
        }
        &.styles_col-shadow__imO2S {
          &:empty {
            box-shadow: none;
          }
        }
      }
    }
  }
}

/*----------------------------------
    編集画面用CSS(編集画面のみに効くCSS)
----------------------------------*/
@include edit-page {
  //既存フォント以外のフォントファミリー設定(使用しない場合は削除してください)
  // --fo-heading-font-family: "Hiragino Kaku Gothic ProN", Meiryo, メイリオ, sans-serif;
  // --fo-text-font-family: "Hiragino Kaku Gothic ProN", Meiryo, メイリオ, sans-serif;
  //SP編集画面の幅制限
  @include breakpoint-sp {
    max-width: 769px;
    margin: auto;
  }
  .pcOnly {
    border: 1px solid blue;
    &::before {
      content: "PCのみ表示";
      background: blue;
      color: #fff;
      position: absolute;
      top: -24px;
      right: 0;
      padding: 0 5px;
    }
  }
  .spOnly {
    @include breakpoint-pc {
      display: block !important;
      border: 1px solid red;
      opacity: .5;
      z-index: 1;
    }
    &::before {
      @include breakpoint-pc {
        content: "SPのみ表示";
        position: absolute;
        background: red;
        color: #fff;
        top: -24px;
        right: 0;
        padding: 0 5px;
      }
    }
  }
  .displayNone {
    @include breakpoint-pc {
      display: block !important;
      opacity: .5;
    }
    &::before {
      @include breakpoint-pc {
        content: "classで非表示設定";
        background: black;
        color: #fff;
        position: absolute;
        top: -24px;
        right: 0;
        padding: 0 5px;
      }
    }
  }
  //新CMS編集画面の共通ナビ固定解除
  header#navigations {
    &[class*="one_row_fix-navi"],
    &[class*="two_row_fix-navi"] {
      position: relative !important;
      width: 100%;
      &::after {
        content: "ナビ固定中";
        background: #0987d4;
        box-sizing: border-box;
        width: 100%;
        font-size: 18px;
        line-height: 25px;
        color: #fff;
        text-align: center;
        position: absolute;
        bottom: -45px;
        padding: 10px;
        z-index: -1;
      }
    }
  }
  //hover時に下線を削除
  :is(.navi-001-01,.navi-002-01) {
    header {
      .inner {
        .main-menu {
          .level-01-trigger {
            &:hover {
              text-decoration: none;
            }
          }
          a {
            text-decoration: none;
          }
        }

      }
    }
  }
  //メインビジュアルパレット見えない対策
  .theme-fo-base {
    //新CMS編集画面のヘッダ固定解除
    &[style*="padding-top"] {
      padding-top: 45px !important;
    }
  }
  //オーバーレイが公開画面で二重にかかるバグ
  .theme-fo-base {
    .main-visual {
      .overlay {
        display: block !important;
      }
    }
  }
  //row余白調整
  :where(.theme-fo-base) {
    :where(
      .main-visual .main-visual-content,
      .wrapper .contents section .inner,
      .foot .foot-cont
    ) {
      :where(.row) {
        &:not(:first-child) {
          margin-top: 30px;
        }
      }
    }
  }
  //sticky解放用
  .theme-fo-base {
    &:has(:is(.lp_sticky_sec)) {
      .wrapper {
        .contents {
          section {
            overflow: visible;
          }
        }
      }
    }
  }
  //ページ内リンクずれ対策class
  .theme-fo-base {
    .wrapper {
      .contents {
        section {
          .component {
            &.heading {
              &.inPage_link {
                margin-top: 10px;
                padding-top: 0;
              }
            }
          }
        }
      }
    }
  }
  //コンテンツ
  .theme-fo-base {
    .wrapper {
      .contents {
        section {
          //編集画面内の仕様回避の為
          margin: 50px 0 !important;
          &.foPrp_footer_sec {
            margin-bottom: 100px !important;
            .inner {
              padding: 20px 0;
              .row {
                .col {
                  .component {
                    &.cta {
                      .cta-row {
                        &.page_top_row {
                          @include edit-page_top;
                          margin-bottom: 30px;
                        }
                      }
                    }
                  }
                }
              }
            }
          }
          .inner {
            .row {
              .col {
                .component {
                  &.richtext {
                    &.foot-copyright {
                      text-align: center;
                      @include copyright_custom;
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
  //sp時センター寄せ
  .component {
    &.button {
      &.sp_center {
        &::before {
          content: "SP時に中央よせ";
          background: #0987d4;
          color: #fff;
          position: absolute;
          bottom: -24px;
          left: 0;
          padding: 0 5px;
        }
      }
    }
  }
  //フッター
  .theme-fo-base {
    .foot {
      &.ft_custom {
        .foot-cont {
          .row {
            &.page_top_row {
              @include edit-page_top;
            }
          }
        }
      }
    }
  }
  //カスタムパーツの記述はここにお願いします
  .theme-fo-base {
    .wrapper {
      .contents {
        section {
          .inner {
            .row {
              .col {}
            }
          }
        }
      }
    }
  }
  //LPの記述はここにお願いします
  .theme-fo-base {
    .wrapper {
      .contents {
        section {
          &.lp_sticky_sec {
            position: relative;
            &::after {
              content: "固定中";
              color: #fff;
              font-size: 18px;
              position: absolute;
              bottom: -45px;
              line-height: 25px;
              width: 100%;
              box-sizing: border-box;
              background: #0987d4;
              text-align: center;
              padding: 10px;
            }
          }
          &.lp_footer_sec {
            .inner {
              .row {
                &.page_top_row {
                  .col {
                    .component {
                      &.image {
                        position: static !important;
                        margin: 10px 0 !important;
                        &::before {
                          content: "ページ右下に固定されます";
                          display: inline-block;
                          text-align: center;
                          background: #0987d4;
                          color: #fff;
                          position: absolute;
                          right: 0;
                          bottom: -24px;
                          left: 0;
                          z-index: 1;
                          padding: 0 5px;
                        }
                      }
                    }
                  }
                }
                &.copyright_row {
                  margin-top: 30px;
                }
              }
            }
          }
          .inner {
            .row {
              .col {
                .component {
                  &.heading {
                    &.lp_inPageLink {
                      margin-top: 10px;
                      padding-top: 0;
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
  //JSパーツの記述はここにお願いします
  .theme-fo-base {
    .wrapper {
      .contents {
        section {
          .inner {
            .row {
              .col {}
            }
          }
        }
      }
    }
  }
}

/*------------- 編集画面用CSS END -------------*/
 

//C2-24.1203

/*
variables(変数)
webフォント
Mixins
spフォント設定
common(ウェブサイト共通) >> セクション、リッチテキスト、CTA(共通パーツ)、リンク埋め込みパーツ、ブログ、サーチエリア、リンクリスト、検索結果、ページネーション
entry-list( 記事リストパーツ)
header・logo・navigations(ヘッダー・ロゴ・ナビゲーション)
main-visual(メインビジュアル)
breadcrumbs(パンくず)
button(ボタン)
heading(見出し)
article-post(ブログ用見出し)
main(コンテンツ) >> CTAを用いたパーツ、CTA内の基本設定、2カラム(CTA)、フォームフッター、デザインLPパーツ、カスタムパーツ、ユニバーサルクラス、フォームパーツ、
blog(ブログテンプレート)
カテゴリ・タグ自動生成ページ
side bar(サイドバー) >> カテゴリー、ランキング、カテゴリーアイコン
foot(フッター)
LP(フルカスタム用)
col空処理
編集画面用CSS(編集画面のみに効くCSS)
*/

/* --------------------------------
    variables(変数)
----------------------------------- */
//フォント
$font_feature_settings:"palt" 1;
$font_family_awsm: "FontAwesome";
$font_family_awsm6: "Font Awesome 6 Free";
//既存フォント以外のフォントファミリー設定(使用しない場合は削除してください)
// #__next {
//   --fo-heading-font-family: "Hiragino Kaku Gothic ProN", Meiryo, メイリオ, sans-serif;
//   --fo-text-font-family: "Hiragino Kaku Gothic ProN", Meiryo, メイリオ, sans-serif;
// }

//hover用
$hover_opacity: .4;

//文字の太さ
$font_weight: bold;

//カラー
$border_color: #eee; //ボーダーカラー
$form_hissu_color: #c70909; //赤 フォームの「必須マーク」カラー

//ヘッダーロゴ
$header_logo: 300px; //PCでの幅サイズ(固定)
$header_sp_logo: 35px; //SPでの高さサイズ(maxサイズ)

//ボックスシャドウ
$box_shadow_common: 0 3px 8px var(--fo-shadow-color); //ボックスシャドウ
$navigation_box_shadow_common: 0 3px 8px rgba(#000,.1); //ナビゲーション専用

//角丸
$border_radius_common: 20px;

//メインビジュアル
$mv_padding: 40px 0; //PC時の上下余白
$sp_mv_padding: 30px 0 40px; //SP時の上下余白
$top_mv_height: 490px; //PC時の最低の高さ(SPはauto)
$sub_mv_height: 273px; //PC時の最低の高さ(SPはauto)

//見出し
$hd_font_strong: 400; //見出し用(編集画面の「.strong」に対応)
//ページ内リンクのずれ用
$inPage_link: 74px; //上部にあるコンテンツの高さ(PC)
$sp_inPage_link: 64px; //上部にあるコンテンツの高さ(SP)

//グロナビ PC
$header_bg_color: var(--fo-background-color1); //ヘッダー全体の背景色
$navigation_bg_color: $header_bg_color; //グロナビの背景色
$navigation_font_size: 14px; //グロナビのフォントサイズ(1〜3階層)
$navigation_font_weight: normal; //グロナビのフォントの太さ(1〜3階層) normal or bold
$navigation_hover_opacity: 1; //グロナビをホバーした時の透視度
$navigation_bg2_color: $navigation_bg_color; //グロナビの背景色(2階層以下)
$navigation_text_color: var(--fo-text-main-color); //グロナビのテキストカラー
$navigation_text2_color: $navigation_text_color; //グロナビのテキストカラー(2階層以下)
$navigation_hover_bg_color: #fff; //グロナビをホバーした時の背景色
$navigation_hover_bg2_color: var(--fo-main-color); //グロナビをホバーした時の背景色(2階層以下)
$navigation_hover_text_color: var(--fo-main-color); //グロナビをホバーした時のテキストカラー
$navigation_hover_text2_color: #fff; //グロナビをホバーした時のテキストカラー(2階層以下)
$navigation_arrow1_color: $navigation_text_color; //矢印カラー(1階層)
$navigation_arrow2_color: $navigation_arrow1_color; //矢印カラー(2階層)

//グロナビ ハンバーガーメニュー
$navigation_sp_font_size: 14px; //ハンバーガーメニュー(SP)時のテキストサイズ(1〜3階層)
$navigation_sp_font_weight: normal; //ハンバーガーメニュー(SP)時のテキストの太さ(1〜3階層) normal or bold
$navigation_sp_text_color: var(--fo-text-main-color); //ハンバーガーメニュー(SP)時のテキストカラー 1階層
$navigation_sp_text2_color: var(--fo-text-main-color); //ハンバーガーメニュー(SP)時のテキストカラー(2階層)
$navigation_sp_text3_color: var(--fo-text-main-color); //ハンバーガーメニュー(SP)時のテキストカラー(3階層)
$navigation_sp_hover_text_color: #fff; //ハンバーガーメニュー(SP)時のホバーした時の2階層のテキスト&矢印のカラー
$navigation_sp_arrow1_color: $navigation_sp_text_color; //ハンバーガーメニュー(SP) 矢印カラー(1階層)
$navigation_sp_arrow2_color: $navigation_sp_text2_color; //ハンバーガーメニュー(SP) 矢印カラー(2階層)
$navigation_sp_bg_color: var(--fo-main-color); //ハンバーガーメニュー(SP)時の背景色(1階層)
$navigation_sp_bg2_color: #fff; //ハンバーガーメニュー(SP)時の背景色(2階層)
$navigation_sp_bg3_color: #eee; //ハンバーガーメニュー(SP)時の背景色(3階層)
$navigation_sp_border-bottom: 1px dashed var(--fo-main-color); //ハンバーガーメニュー(SP)時のボーダー(hamburger_custom 使用時)

//見出しサイズ統一
$list_heading_pc_fontsize: 20px;
$list_heading_sp_fontsize: 20px;

//記事リストパーツ
$case_border_radius: 0; //画像の角丸
$case_title_letter_spacing: var(--fo-text-letter-spacing); //記事リストパーツのタイトル(h3) letter-spacing(文字間)
$case_title_font_family: inherit; //記事リスト内見出しのフォントファミリー(caseContent_style・news_list)
$case_date_font_family: inherit; //記事リスト内日付のフォントファミリー(caseContent_style・news_list)
$case_pagination_color: var(--fo-main-color); //記事リストパーツのページネーションカラー
$case_box_shadow_common: $box_shadow_common; //記事リストパーツ用( 0 0 3px #ddd;)
$case_img_fit_height: 200px; //caseContent_style画像のオプション(option_img_fit)の高さ(sp時も高さ維持)
$case_list_space: 12px; //caseContent_style記事間の余白
//news_list
$news_list_text_decoration: none; //見出しアンカーの下線の無有(news_list) underline or none
$news_list_hover_opacity: $hover_opacity; //見出しアンカーのhover時の不透明度(news_list)

//ブログ
$blog_title_fontsize: 20px; //ブログトップタグ・カテゴリ一覧とのタイトル(h2)フォントサイズ
$blog_border_radius: 0; //ブログ記事一覧画像の角丸
$blog_border_color: $border_color; //一覧のボーダーと人気記事ランキングのボーダーカラー
$blog_title_h1_fontsize_pc: 36px; //ブログ詳細h1見出しフォントサイズ(PC)
$blog_title_h1_fontsize_sp: 28px; //ブログ詳細h1見出しフォントサイズ(SP)
$blog_title_h2_fontsize_pc: 32px; //ブログ詳細h2見出しフォントサイズ(PC)
$blog_title_h2_fontsize_sp: 24px; //ブログ詳細h2見出しフォントサイズ(SP)
$blog_title_h3_fontsize_pc: var(--fo-h3-font-size-pc); //ブログ詳細h3見出しフォントサイズ(PC)
$blog_title_h3_fontsize_sp: var(--fo-h3-font-size-sp); //ブログ詳細h3見出しフォントサイズ(SP)
$blog_title_h4_fontsize_pc: var(--fo-h4-font-size-pc); //ブログ詳細h4見出しフォントサイズ(PC)
$blog_title_h4_fontsize_sp: var(--fo-h4-font-size-sp); //ブログ詳細h4見出しフォントサイズ(SP)
$blog_title_h5_fontsize_pc: var(--fo-h5-font-size-pc); //ブログ詳細h5見出しフォントサイズ(PC)
$blog_title_h5_fontsize_sp: var(--fo-h5-font-size-sp); //ブログ詳細h5見出しフォントサイズ(SP)

//フッター
$footer_bg_color: var(--fo-background-color2); //フッター全体の背景色
$copyright_bg_color: inherit;  //コピーライトの背景色
$copyright_text_color: var(--fo-text-main-color); //コピーライトのテキストカラー
$copyright_text_fontsize: 12px; //コピーライトのフォントサイズ

//その他
$max_width: 1240px; //コンテンツ幅調整用

/*------------- variables(変数)END -------------*/

/* --------------------------------
   webフォント
----------------------------------- */
/*---  Web fonts ---*/
//Awesome Font 6
@import url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.2/css/all.min.css");
//Awesome Font
@import url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css");

/*------------- webフォント END -------------*/

/*----------------------------------
    Mixins
----------------------------------*/
@mixin breakpoint-ssp {
  @media screen and (max-width: 576px) {
    @content;
  }
}

@mixin breakpoint-sp {
  @media screen and (max-width: 769px) {
    @content;
  }
}

@mixin breakpoint-msp {
  @media screen and (max-width: 834px) {
    @content;
  }
}

@mixin breakpoint-tb {
  @media screen and (min-width: 577px) and (max-width: 769px) {
    @content;
  }
}

@mixin breakpoint-pro_s {
  @media screen and (min-width: 770px) and (max-width: 834px) {
    @content;
  }
}

@mixin breakpoint-pro {
  @media screen and (min-width: 770px) and (max-width: 1024px) {
    @content;
  }
}

@mixin breakpoint-pc {
  @media screen and (min-width: 770px) {
    @content;
  }
}

////タグ・カテゴリー 設定
//タグスタイルコントロール
@mixin tag_custom {
  background-color: var(--fo-tag-background-color);
  font-size: 12px;
  line-height: 1.2;
  letter-spacing: normal;
  color: var(--fo-tag-text-color);
  border: 1px solid var(--fo-tag-border-color,var(--fo-tag-background-color));
  border-radius: var(--fo-tag-border-radius);
  margin: 5px 10px 5px 0;
  padding: 5px 15px;
  &:hover {
    opacity: $hover_opacity;
  }
}
//タグアイコンコントロール
@mixin tag_icon_custom {
  content: var(--fo-tag-fa-unicode,none);
  font-family: $font_family_awsm;
  margin-right: 5px;
}
//カテゴリーアイコンコントロール
@mixin category_icon_custom {
  content: "\f115"; //f0c9
  font-family: $font_family_awsm;
  color: var(--fo-main-color);
  margin-right: 5px;
}
////タグ・カテゴリー 設定 end

//ブログ見出し
@mixin hd_blog {
  :is(h1,h2,h3,h4,h5) {
    font-family: var(--fo-heading-font-family);
    font-weight: 700;
    line-height: var(--fo-heading-line-height);
    letter-spacing: var(--fo-heading-letter-spacing);
    color: var(--fo-heading-main-color);
    @include breakpoint-sp {
      overflow-wrap: break-word;
    }
  }
  h1 {
    @include breakpoint-pc {
      font-size: $blog_title_h1_fontsize_pc;
    }
    @include breakpoint-sp {
      font-size: $blog_title_h1_fontsize_sp;
    }
  }
  h2 {
    @include breakpoint-pc {
      font-size: $blog_title_h2_fontsize_pc;
    }
    @include breakpoint-sp {
      font-size: $blog_title_h2_fontsize_sp;
    }
  }
  h3 {
    border-color: $border_color;
    @include breakpoint-pc {
      font-size: $blog_title_h3_fontsize_pc;
    }
    @include breakpoint-sp {
      font-size: $blog_title_h3_fontsize_sp;
    }
  }
  h4 {
    @include breakpoint-pc {
      font-size: $blog_title_h4_fontsize_pc;
    }
    @include breakpoint-sp {
      font-size: $blog_title_h4_fontsize_sp;
    }
  }
  h5 {
    @include breakpoint-pc {
      font-size: $blog_title_h5_fontsize_pc;
    }
    @include breakpoint-sp {
      font-size: $blog_title_h5_fontsize_sp;
    }
  }
  .strong {
    font-weight: 400;
  }
}
//ブログ見出し end

//.page_top_rowスタイルコントロール
@mixin page_top {
  min-height: unset;
  :is(.col,.cta-column) {
    padding: 0;
    .component {
      &.image {
        width: auto;
        position: fixed;
        right: 0;
        bottom: 0;
        z-index: 1000;
        margin: 0;
        img {
          width: 60px !important;
        }
      }
    }
  }
}
//編集画面用
@mixin edit-page_top {
  :is(.col,.cta-column) {
    .component {
      &.image {
        position: static;
        width: 100%;
        margin: 10px 0;
        outline: 1px dotted #0987d4;
        &::before {
          content: "↑ 公開ページでは右下に固定されます ↑";
          display: inline-block;
          text-align: center;
          background: #0987d4;
          font-size: 12px;
          color: #fff;
          position: absolute;
          right: 0;
          top: calc(100% - 9px);
          left: 0;
          z-index: 1;
          padding: 5px;
        }
      }
    }
  }
}
//.page_top_row 設定 end

//.foot-copyrightスタイルコントロール
@mixin copyright_custom {
  display: flex;
  justify-content: center;
  align-items: center;
  background: $copyright_bg_color;
  height: 60px;
  margin: 0;
  padding: 0;
  @include breakpoint-sp {
    padding: 0 70px 0 10px;
  }
  @include breakpoint-tb {
    padding: 0;
  }
  p {
    font-size: $copyright_text_fontsize;
    letter-spacing: var(--fo-text-letter-spacing);
    line-height: 1.3;
    color: $copyright_text_color;
    margin: 0;
  }
}
//.foot-copyright一括修正 end

//検索結果画面コンテンツ幅統一用
@mixin search_container {
  max-width: $max_width;
  margin: auto;
  padding: 0 20px;
}

//編集画面用CSS
@mixin edit-page {
  .frame-root .frame-content {
    @content;
  }
}

//セクション余白
@mixin sectionSpace($padding:none) {
  @if($padding == none) {}
  @else if($padding > 0) {
    @include breakpoint-pc {
      padding: calc(#{$padding} * var(--fo-spacing-coef) - 30px) 0 calc(#{$padding} * var(--fo-spacing-coef) - 40px);
    }
    @include breakpoint-sp {
      padding: calc(#{$padding} * var(--fo-spacing-coef) * .75 - 30px) 0;
    }
  }
}

//ボタン(1~3)
@mixin btn_custom($btn) {
  &:is(.size-s,.size-m,.size-l) {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--fo-button#{$btn}-background) -1px/calc(100% + 2px);
    box-sizing: border-box;
    font-family: var(--fo-text-font-family);
    color: var(--fo-button#{$btn}-text-color);
    text-decoration: none;
    text-align-last: left;
    letter-spacing: var(--fo-text-letter-spacing);
    line-height: var(--fo-text-line-height);
    border: 1px solid var(--fo-button#{$btn}-border-color,transparent);
    border-radius: var(--fo-button#{$btn}-border-radius);
    box-shadow: $box_shadow_common;
  }
  &.size-s {
    min-width: var(--fo-button-small-min-width-pc);
    font-size: var(--fo-button-small-font-size);
    padding: 6.75px 20px;
    @include breakpoint-sp {
      min-width: var(--fo-button-small-min-width-sp);
      width: auto;
    }
    @include breakpoint-tb {
      min-width: var(--fo-button-small-min-width-pc);
    }
  }
  &.size-m {
    min-width: var(--fo-button-medium-min-width-pc);
    font-size: var(--fo-button-medium-font-size);
    padding: 13.5px 20px;
    @include breakpoint-sp {
      width: auto;
      min-width: var(--fo-button-medium-min-width-sp);
    }
    @include breakpoint-tb {
      min-width: var(--fo-button-medium-min-width-pc);
    }
  }
  &.size-l {
    min-width: var(--fo-button-large-min-width-pc);
    font-size: var(--fo-button-large-font-size);
    padding: 17.5px 20px;
    @include breakpoint-sp {
      width: var(--fo-button-large-min-width-sp);
      min-width: auto;
    }
    @include breakpoint-tb {
      width: auto;
      min-width: var(--fo-button-large-min-width-pc);
    }
  }
  &:hover {
    opacity: var(--fo-button#{$btn}-hover-opacity,1);
    scale: var(--fo-button#{$btn}-hover-scale,1);
    //反転
    background: var(--fo-button#{$btn}-hover-background-color,var(--fo-button#{$btn}-background)) -1px/calc(100% + 2px);
    color: var(--fo-button#{$btn}-hover-text-color,var(--fo-button#{$btn}-text-color));
    border: 1px solid var(--fo-button#{$btn}-hover-border-color, var(--fo-button#{$btn}-border-color, transparent));
  }
}

//flex
@mixin flex-setting($gap:null,$direction:null,$wrap:null,$justify-content:null,$align-items:null,$device:all) {
  @if($device == all) {
    display : flex;
    gap: $gap;
    flex-direction : $direction;
    flex-wrap : $wrap;
    justify-content : $justify-content;
    align-items : $align-items;
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      display : flex;
      gap: $gap;
      flex-direction : $direction;
      flex-wrap : $wrap;
      justify-content : $justify-content;
      align-items : $align-items;
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      display : flex;
      gap: $gap;
      flex-direction : $direction;
      flex-wrap : $wrap;
      justify-content : $justify-content;
      align-items : $align-items;
    }
  }
}
//gap
@mixin flex-gap ($gap:20px,$device:all) {
  @if($device == all) {
    gap: calc(#{$gap} * var(--fo-spacing-coef));
    @include breakpoint-sp {
      gap: calc((#{$gap} * var(--fo-spacing-coef)) * .75);
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      gap: calc(#{$gap} * var(--fo-spacing-coef));
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      gap: calc(#{$gap} * var(--fo-spacing-coef));
    }
  }
}

// カラム内要素の位置調整
@mixin row-col-flex($directio:column) {
  .col {
    &:is(.vertical_position_top,.vertical_position_middle,.vertical_position_bottom) {
      display: flex;
      flex-direction: #{$directio};
      align-self: auto !important;
      .component {
        & + .component {
          margin-top: 0;
        }
      }
    }
    &.vertical_position_top {
      justify-content: start;
    }
    &.vertical_position_middle {
      justify-content: center;
    }
    &.vertical_position_bottom {
      justify-content: end;
    }
  }
}

//padding
@mixin padding-All($paddingTop:20px,$paddingRight:20px,$paddingBottom:20px,$paddingLeft:20px,$device:all) {
  @if($device == all) {
    @include breakpoint-pc {
      padding: calc(#{$paddingTop} * var(--fo-spacing-coef)) calc(#{$paddingRight} * var(--fo-spacing-coef)) calc(#{$paddingBottom} * var(--fo-spacing-coef)) calc(#{$paddingLeft} * var(--fo-spacing-coef));
    }
    @include breakpoint-sp {
      padding: calc((#{$paddingTop}  * var(--fo-spacing-coef)) * .75) calc((#{$paddingRight} * var(--fo-spacing-coef)) * .75) calc((#{$paddingBottom} * var(--fo-spacing-coef)) * .75) calc((#{$paddingLeft} * var(--fo-spacing-coef)) * .75);
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      padding: calc(#{$paddingTop} * var(--fo-spacing-coef)) calc(#{$paddingRight} * var(--fo-spacing-coef)) calc(#{$paddingBottom} * var(--fo-spacing-coef)) calc(#{$paddingLeft} * var(--fo-spacing-coef));
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      padding: calc(#{$paddingTop} * var(--fo-spacing-coef)) calc(#{$paddingRight} * var(--fo-spacing-coef)) calc(#{$paddingBottom} * var(--fo-spacing-coef)) calc(#{$paddingLeft} * var(--fo-spacing-coef));
    }
  }
}

//padding 一方向
@mixin padding-property($property:top,$value:20px,$device:all) {
  @if($device == all) {
    @include breakpoint-pc {
      padding-#{$property}: calc(#{$value} * var(--fo-spacing-coef));
    }
    @include breakpoint-sp {
      padding-#{$property}: calc((#{$value} * var(--fo-spacing-coef)) * .75);
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      padding-#{$property}: calc(#{$value} * var(--fo-spacing-coef));
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      padding-#{$property}: calc(#{$value} * var(--fo-spacing-coef));
    }
  }
}

//padding上下左右
@mixin padding-yx($paddingY:20px,$paddingX:20px,$device:all) {
  @if($device == all) {
    @include breakpoint-pc {
      padding: calc(#{$paddingY} * var(--fo-spacing-coef)) calc(#{$paddingX} * var(--fo-spacing-coef));
    }
    @include breakpoint-sp {
      padding: calc((#{$paddingY} * var(--fo-spacing-coef)) * .75) calc((#{$paddingX} * var(--fo-spacing-coef)) * .75);
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      padding: calc(#{$paddingY} * var(--fo-spacing-coef)) calc(#{$paddingX} * var(--fo-spacing-coef));
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      padding: calc(#{$paddingY} * var(--fo-spacing-coef)) calc(#{$paddingX} * var(--fo-spacing-coef));
    }
  }
}

//margin上下
@mixin margin-y($marginTop:20px,$marginBottom:20px,$device:all) {
  @if($device == all) {
    @include breakpoint-pc {
      margin: unquote('max(calc(#{$marginTop} * var(--fo-spacing-coef)),0px)') auto unquote('max(calc(#{$marginBottom} * var(--fo-spacing-coef)),0px)');
    }
    @include breakpoint-sp {
      margin: unquote('max(calc((#{$marginTop} * var(--fo-spacing-coef)) * .75),0px)') auto unquote('max(calc((#{$marginBottom} * var(--fo-spacing-coef)) * .75),0px)');
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      margin: unquote('max(calc(#{$marginTop} * var(--fo-spacing-coef)),0px)') auto unquote('max(calc(#{$marginBottom} * var(--fo-spacing-coef)),0px)');
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      margin: unquote('max(calc(#{$marginTop} * var(--fo-spacing-coef)),0px)') auto unquote('max(calc(#{$marginBottom} * var(--fo-spacing-coef)),0px)');
    }
  }
}

//margin一方向
@mixin margin-property($property:top,$value:20px,$device:all) {
  @if($device == all) {
    @include breakpoint-pc {
      margin-#{$property}: unquote('max(calc(#{$value} * var(--fo-spacing-coef)),0px)');
    }
    @include breakpoint-sp {
      margin-#{$property}: unquote('max(calc((#{$value} * var(--fo-spacing-coef)) * .75),0px)');
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      margin-#{$property}: unquote('max(calc(#{$value} * var(--fo-spacing-coef)),0px)');
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      margin-#{$property}: unquote('max(calc(#{$value} * var(--fo-spacing-coef)),0px)');
    }
  }
}

//見出し用margin-bottom
@mixin heading-marginBottom($marginBottom:60px,$device:all) {
  @if($device == all) {
    @include breakpoint-pc {
      margin-bottom: unquote('max(calc((#{$marginBottom} * var(--fo-spacing-coef)) - 20px),0px)');
    }
    @include breakpoint-sp {
      margin-bottom: unquote('max(calc((#{$marginBottom} * var(--fo-spacing-coef)) * .75),0px)');
    }
  }
  @else if($device == pc) {
    @include breakpoint-pc {
      margin-bottom: unquote('max(calc(#{$marginBottom} * var(--fo-spacing-coef)),0px)');
    }
  }
  @else if($device == sp) {
    @include breakpoint-sp {
      margin-bottom: unquote('max(calc(#{$marginBottom} * var(--fo-spacing-coef)),0px)');
    }
  }
}

//隣接要素のmargin
@mixin adjacentMargin($className:row,$marginTop:46px,$device:all) {
  & + .#{$className} {
    @if($device == all) {
      @include breakpoint-pc {
        margin-top: unquote('max(calc(#{$marginTop} * var(--fo-spacing-coef)),0px)');
      }
      @include breakpoint-sp {
        margin-top: unquote('max(calc((#{$marginTop} * var(--fo-spacing-coef)) * .75),0px)');
      }
    }
    @else if($device == pc) {
      @include breakpoint-pc {
        margin-top: unquote('max(calc(#{$marginTop} * var(--fo-spacing-coef)),0px)');
      }
    }
    @else if($device == sp) {
      @include breakpoint-sp {
        margin-top: unquote('max(calc(#{$marginTop} * var(--fo-spacing-coef)),0px)');
      }
    }
  }
}

//テーマ出力
@mixin theme-fo-base {
  .theme-fo-base {
    .wrapper {
      .contents {
        :is(section,section[data-designpart-id]) {
          @content;
        }
      }
    }
  }
}

/*------------- Mixins END -------------*/

/* --------------------------------
   spフォント設定
----------------------------------- */
.component {
  :is(
    .font-size-20px,
    [style*="font-size:20px;"]
  )
   {
    @include breakpoint-sp {
      font-size: 18px !important;
    }
  }
  :is(
    .font-size-22px,
    [style*="font-size:22px;"]
  ) {
    @include breakpoint-sp {
      font-size: 20px !important;
    }
  }
  :is(
    .font-size-24px,
    .font-size-26px,
    [style*="font-size:24px;"],
    [style*="font-size:26px;"]
    ) {
    @include breakpoint-sp {
      font-size: 22px !important;
    }
  }
  :is(
    .font-size-28px,
    .font-size-30px,
    [style*="font-size:28px;"],
    [style*="font-size:30px;"]
    ) {
    @include breakpoint-sp {
      font-size: 24px !important;
    }
  }
  :is(
    .font-size-32px,
    .font-size-34px,
    .font-size-36px,
    [style*="font-size:32px;"],
    [style*="font-size:34px;"],
    [style*="font-size:36px;"]
    ) {
    @include breakpoint-sp {
      font-size: 26px !important;
    }
  }
  :is(
    .font-size-38px,
    .font-size-42px,
    .font-size-46px,
    [style*="font-size:38px;"],
    [style*="font-size:42px;"],
    [style*="font-size:46px;"]
    ) {
    @include breakpoint-sp {
      font-size: 28px !important;
    }
  }
  :is(
    .font-size-50px,
    .font-size-54px,
    [style*="font-size:50px;"],
    [style*="font-size:54px;"],
    ) {
    @include breakpoint-sp {
      font-size: 32px !important;
    }
  }
  :is(
    .font-size-60px,
    .font-size-66px,
    .font-size-72px,
    [style*="font-size:60px;"],
    [style*="font-size:66px;"],
    [style*="font-size:72px;"]
    ) {
    @include breakpoint-sp {
      font-size: 36px !important;
    }
  }
  :is(
    .font-size-78px,
    .font-size-86px,
    .font-size-94px,
    [style*="font-size:78px;"],
    [style*="font-size:86px;"],
    [style*="font-size:94px;"]
    ) {
    @include breakpoint-sp {
      font-size: 40px !important;
    }
  }
}
/*------------- spフォント設定 END -------------*/

/* --------------------------------
   common(ウェブサイト共通)
----------------------------------- */
//ドラックカラー
::selection {
  background: color-mix(in srgb, var(--fo-accent-color) 50%, transparent);
}

//sticky解放用
.theme-fo-base {
  &:has(.lp_sticky_sec) {
    overflow: initial;
    .wrapper {
      .contents {
        section {
          overflow: hidden;
        }
      }
    }
  }
}

//SP時のリンクタップの色を削除&下線削除
:is(.navi-001-01,.navi-002-01,.theme-fo-base) {
  font-family: var(--fo-text-font-family);
  font-feature-settings: $font_feature_settings;
  a {
    transition: unset;
    -webkit-tap-highlight-color:rgba(0,0,0,0);
  }
  :visited {
    text-decoration: none;
  }
  :link {
    text-decoration: none;
  }
}

//画像のhover一括設定
:is(.navi-001-01,.navi-002-01) {
  header {
    .inner {
      a[href] {
        img {
          &:hover {
            opacity: $hover_opacity;
          }
        }
      }
    }
  }
}
.theme-fo-base {
  .main-visual {
    .component {
      a {
        img {
          &:hover {
            opacity: 1;
          }
        }
      }
      a[href] {
        img {
          &:hover {
            opacity: $hover_opacity;
          }
        }
      }
    }
  }
  .wrapper {
    .contents {
      section {
        a {
          img {
            &:hover {
              opacity: 1;
            }
          }
        }
        a[href] {
          img {
            &:hover {
              opacity: $hover_opacity;
            }
          }
        }
      }
    }
    .side {
      .inner {
        .component {
          a {
            img {
              &:hover {
                opacity: 1;
              }
            }
          }
          a[href] {
            img {
              &:hover {
                opacity: $hover_opacity;
              }
            }
          }
        }
      }
    }
  }
  .foot {
    .foot-cont {
      .component {
        a {
          img {
            &:hover {
              opacity: 1;
            }
          }
        }
        a[href] {
          img {
            &:hover {
              opacity: $hover_opacity;
            }
          }
        }
      }
    }
  }
}

/*- セクションパーツ -*/
//セクション余白
// ()内に指定したいサイズを入れると適用されます。例:(100px)
// ()内に数値が入ってない場合は適用されません。(デフォルト設定)
section[data-designpart-id]:not(:root:root:root:root) {
  @include sectionSpace();
}
//コンテンツ幅
@include theme-fo-base {
  .inner {
    max-width: $max_width;
  }
}

/*--- リッチテキストパーツ ---*/
.component {
  &.richtext {
    :link {
      text-decoration: none;
    }
    :visited {
      text-decoration: none;
    }
    //リスト
    li {
      font-size: inherit;
      a {
        font-size: inherit;
      }
    }
    //表
    table {
      border: none;
      &[align="center"] {
        margin: auto;
      }
      :is(thead,tbody,tr,th,td) {
        border-color: $border_color;
        tr {
          :is(th,td) {
            background-clip: padding-box; //FF,edgeでボーダー消える現象回避;
            position: static; //FF,edgeでボーダー消える現象回避;
            p {
              font-size: inherit;
              & + p {
                margin-top: 10px !important;
              }
            }
            :is(ul,ol) {
              margin-left: 25px;
            }
          }
        }
      }
    }
    .normal-table {
      &::after {
        content: "";
        display: table;
        clear: both;
      }
    }
    .table-with-row-header {
      &::after {
        content: "";
        display: table;
        clear: both;
      }
    }
    .table-with-two-headers {
      overflow: auto;
      &::after {
        content: "";
        display: table;
        clear: both;
      }
    }
    .component {
      &.button:not(:root) {
        .button-cont {
          a {
            &.blue {
              background: #254a73;
              color: #fff !important;
              text-decoration: none;
              &:hover {
                opacity: $hover_opacity;
              }
            }
          }
        }
      }
    }
    //sp時右寄せ
    &.sp_r {
      @include breakpoint-sp {
        text-align: right !important;
      }
      :is(p,.rich-text-normal,.align-center,.align-right) {
        @include breakpoint-sp {
          text-align: right !important;
        }
      }
    }
    //sp中央寄せ
    &.sp_c {
      @include breakpoint-sp {
        text-align: center !important;
      }
      :is(p,.rich-text-normal,.align-center,.align-right) {
        @include breakpoint-sp {
          text-align: center !important;
        }
      }
    }
    //sp時左寄せ
    &.sp_l {
      @include breakpoint-sp {
        text-align: left !important;
      }
      :is(p,.rich-text-normal,.align-center,.align-right) {
        @include breakpoint-sp {
          text-align: left !important;
        }
      }
    }
  }
}

/*--- 区切り線パーツ ---*/
.theme-fo-base {
  :is(.main-visual,.wrapper .contents,.foot ) {
    .component {
      &.border {
        hr {
          &.type01 {
            background-image: -webkit-linear-gradient(left, transparent, $border_color, transparent);
          }
          &:is(.type02,.type03,.type04) {
            border-color: $border_color;
          }
        }
      }
    }
  }
}

/*--- CTA(共通パーツ)---*/
.component {
  &.cta {
    .cta-row {
      display: table;
      table-layout: fixed;
      width: 100%;
      margin: 0;
      @include breakpoint-sp {
        display: block;
      }
      & + .cta-row {
        @include breakpoint-pc {
          padding-top: 10px;
        }
      }
      .cta-column {
        display: table-cell;
        vertical-align: top;
        margin: 0;
        @include breakpoint-sp {
          display: block;
          width: 100% !important;
        }
      }
    }
  }
}

/*---  リンク埋め込みパーツ---*/
.component {
  // ページ
  &.link-embed {
    .article-embed {
      .quote-link {
        &:hover {
          opacity: $hover_opacity;
        }
        .quote-link_entry {
          .quote-link-img {
            .quote-link-img-item {
              img {
                height: 150px;
                position: static;
                object-fit: cover;
                &:hover {
                  opacity: 1;
                }
              }
            }
          }
          .cont {
            :is(.quote-link_title,.quote-link_desp,.quote-link_site) {
              p {
                color: var(--fo-text-main-color);
              }
            }
          }
        }
      }
    }
  }
  //ブログ
  &.richtext {
    .article-embed[data-embed-type="url"] {
      .quote-link {
        .quote-link_entry {
          .quote-link-img {
            .quote-link-img-item {
              background-position: center;
            }
          }
          .cont {
            .quote-link_desp {
              margin-bottom: 10px;
            }
          }
        }
      }
    }
  }
}

/*------- サーチエリア --------*/
.component {
  &.search {
    .search-cont {
      input[type=search] {
        -webkit-appearance: none;
        border-radius: 0;
        font-family: inherit !important;
        font-size: 16px;
        height: 40px;
        outline: unset;
        &::placeholder {
          font-family: inherit !important;
          color: rgba(0,0,0,.3);
        }
        &:focus {
          background-color: #fff;
          color: #555;
          border-color: #5a5a5a;
        }
      }
      input[type=submit] {
        padding: 13px 10px;
      }
    }
  }
}

/*------- リンクリスト --------*/
.component {
  &.list {
    &.vertical {
      ul {
        li {
          a {
            &:hover {
              background: rgba(#ccc,.15);
            }
          }
        }
      }
    }
  }
}

//検索結果カラム余白調整
.theme-fo-base {
  .wrapper {
    //1カラム用
    &.none {
      .contents {
        & > .component {
          &.search {
            margin: 50px auto;
          }
        }
      }
    }
    //2カラム
    &:is(.side-right,.side-left) {
      .contents {
        & > .component {
          &.search {
            margin: 20px auto 50px;
          }
        }
      }
    }
    //3カラム
    &.side-both {
      .contents {
        & > .component {
          &.search {
            margin: 10px auto 50px;
          }
        }
      }
    }
  }
}
//検索結果画面
.theme-fo-base {
  .wrapper {
    .contents {
      & > .component {
        &.search {
          @include search_container;
          & + .entry-list {
            padding-bottom: 25px;
            .entry-list-unit {
              border-bottom: 1px solid $border_color;
              margin: 10px 0;
              padding: 10px 0;
              @include breakpoint-pc {
                display: flex;
              }
              .img {
                @include breakpoint-pc {
                  width: 30%;
                  padding: 0 0 10px 0;
                }
                @include breakpoint-sp {
                  padding-bottom: 10px;
                }
                img {
                  border-radius: $case_border_radius;
                  &:hover {
                    opacity: $hover_opacity;
                  }
                }
              }
              .cont {
                border-left: 0;
                @include breakpoint-pc {
                  width: 70%;
                  padding: 0 10px 10px;
                }
                h3 {
                  @include breakpoint-sp {
                    padding: 0;
                  }
                  a {
                    font-family: var(--fo-heading-font-family);
                    font-size: $list_heading_pc_fontsize;
                    color: var(--fo-heading-main-color);
                    line-height: var(--fo-heading-line-height);
                    letter-spacing: var(--fo-heading-letter-spacing);
                    padding: 0 10px;
                    @include breakpoint-sp {
                      font-size: $list_heading_sp_fontsize;
                      padding: 0;
                    }
                    &:hover {
                      text-decoration: none;
                      opacity: $hover_opacity;
                    }
                  }
                }
                h4 {
                  color: var(--fo-text-main-color);
                  padding: 0 10px;
                  @include breakpoint-sp {
                    padding: 0;
                  }
                }
                p {
                  font-size: var(--fo-text-font-size-pc);
                  letter-spacing: var(--fo-text-letter-spacing);
                  line-height: var(--fo-text-line-height);
                  color: var(--fo-text-main-color);
                  @include breakpoint-sp {
                    font-size: var(--fo-text-font-size-sp);
                    padding: 0;
                  }
                }
              }
            }
            .row {
              .text-center {
                padding-top: 30px;
              }
            }
          }
        }
      }
      .component {
        &.search {
          & + h1 {
            font-family: var(--fo-heading-font-family);
            font-size: $list_heading_pc_fontsize;
            color: var(--fo-heading-main-color);
            line-height: var(--fo-heading-line-height);
            letter-spacing: var(--fo-heading-letter-spacing);
            @include search_container;
            @include breakpoint-sp {
              font-size: $list_heading_sp_fontsize;
            }
          }
          & + h1 + p {
            font-size: var(--fo-text-font-size-pc);
            letter-spacing: var(--fo-text-letter-spacing);
            line-height: var(--fo-text-line-height);
            color: var(--fo-text-main-color);
            @include search_container;
            @include breakpoint-sp {
              font-size: var(--fo-text-font-size-sp);
            }
          }
          & + h1 + p + .entry-list {
            margin-bottom: 50px;
          }
        }
      }
      .entry-list {
        .row-none {
          @include search_container
        }
      }
    }
  }
}

/*------- ページネーション部分 通常ページ ブログ共通仕様 --------*/
.entry-list {
  .pagination {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 5px 10px;
    line-height: 0;
    padding-bottom: 0;
    li {
      color: var(--fo-main-color);
      margin: 0;
      a {
        color: var(--fo-main-color);
        border: 1px solid var(--fo-main-color);
        background: #fff;
      }
      &.active > a {
        background: var(--fo-main-color);
        color: #fff;
      }
      &:hover > a {
        opacity: $hover_opacity;
      }
    }
  }
}

/*--- アイコンパーツ ---*/
//デフォルトのCSSが5なので表示されないアイコンがあるため
i:is(.fa,.far,.fas) {
  font-family: $font_family_awsm6;
  font-family: $font_family_awsm;
}

/*--- カルーセルパーツ ---*/
.component {
  &.carousel {
    .flexslider {
      .flex-control-paging {
        li {
          a {
            background: #eee;
            box-shadow: none;
            &.flex-active {
              background: var(--fo-main-color);
            }
          }
        }
      }
      .flex-direction-nav {
        :is(.flex-next,.flex-prev) {
          color: var(--fo-main-color);
        }
      }
    }
  }
}

/*------------- common(ウェブサイト共通)END -------------*/

/*----------------------------------
    entry-list( 記事リストパーツ)
----------------------------------*/

/*--- 記事リストパーツ ---*/
//デフォルト
//テーマの崩れを修正・基本ここは触らない。
.component {
  &.entry-list {
    .entry-list-unit {
      & + .entry-list-unit {
        @include breakpoint-sp {
          margin: 10px auto 0;
        }
      }
      .cont {
        @include breakpoint-sp {
          border: none;
        }
        h3 {
          max-height: none;
          line-height: normal;
          @include breakpoint-sp {
            padding: 0;
          }
          a {
            font-family: var(--fo-heading-font-family);
            font-size: $list_heading_pc_fontsize;
            color: var(--fo-heading-main-color);
            line-height: var(--fo-heading-line-height);
            letter-spacing: var(--fo-heading-letter-spacing);
            @include breakpoint-sp {
              font-size: $list_heading_sp_fontsize;
            }
            &:hover {
              opacity: $hover_opacity;
            }
          }
        }
        h4 {
          font-size: var(--fo-text-font-size-pc);
          letter-spacing: var(--fo-text-letter-spacing);
          color: var(--fo-text-main-color);
        }
        p {
          &.category {
            a {
              &:hover {
                opacity: $hover_opacity;
              }
            }
          }
          &.description {
            max-height: none;
            font-size: var(--fo-text-font-size-pc);
            letter-spacing: var(--fo-text-letter-spacing);
            line-height: var(--fo-text-line-height);
            color: var(--fo-text-main-color);
            @include breakpoint-sp {
              font-size: var(--fo-text-font-size-sp);
              margin: 10px 0;
              padding: 0;
            }
          }
        }
      }
    }
    //カード型
    &:is(
      .entry-image-card-1-col,
      .entry-image-card-2-col,
      .entry-image-card-3-col
    ) {
      .article-list {
        .entry-list-unit {
          .img {
            @include breakpoint-sp {
              padding-right: 0;
            }
          }
          .cont {
            h3 {
              a {
                @include breakpoint-pc {
                  padding: 0 !important;
                }
              }
            }
            h4 {
              margin: 10px 0;
              @include breakpoint-pc {
                padding: 0 !important;
              }
            }
            p {
              &.category {
                margin: 10px 0 10px 3px;
              }
            }
            div {
              &.tags {
                margin: 0 0 5px;
                padding: 0;
              }
            }
          }
        }
      }
    }
    //リスト型・スタイル選択
    .entry-list-unit {
      border-bottom: 1px solid $blog_border_color !important;
      .img {
        @include breakpoint-pc {
          padding-right: 25px;
        }
      }
      .cont {
        a {
          &:hover {
            text-decoration: none;
          }
        }
        //タイトル
        h3 {
          a {
            @include breakpoint-pc {
              padding: 0 10px;
            }
          }
        }
        h4 {
          padding: 0 10px;
          @include breakpoint-sp {
            padding: 0;
          }
        }
        p {
          &.category {
            margin: 10px;
            @include breakpoint-sp {
              padding-left: 0;
            }
          }
          &.description {}
        }
        //記事リスト共通 タグ
        div {
          &.tags {
            display: flex;
            gap: 5px 10px;
            flex-wrap: wrap;
            margin: 16px 10px 10px;
            padding: 0 10px;
            @include breakpoint-sp {
              margin: 16px 0 10px;
              padding: 0;
            }
            a {
              &.tag {
                margin: 0;
                &:hover {
                  opacity: $hover_opacity;
                }
              }
            }
          }
        }
      }
    }
  }
}
//サイドバー時
.side {
  .component {
    &.entry-list {
      .entry-list-unit {
        .img {
          padding-right: 0;
        }
      }
    }
  }
}
.article-per-page {
  &:empty {
    margin-top: 0;
  }
}

//デザインパーツ
// .component {
//   &:not(:root:root:root:root) {
//     &.entry-list[data-designpart-id] {
//     }
//   }
// }

//デフォルトパーツ
.component {
  &.entry-list {
    //事例
    &.caseContent_style {
      .article-list {
        .entry-list-unit {
          background: var(--fo-background-color1);
          padding: 20px 20px 10px;
          border-bottom: 1px solid $blog_border_color;
          @include breakpoint-sp {
            width: 100%;
          }
          a {
            &.img {
              img {
                border-radius: $case_border_radius;
              }
            }
          }
          .cont {
            h3 {
              a {
                &:hover {
                  opacity: $hover_opacity;
                }
              }
            }
            h4 {
              font-family: $case_date_font_family;
            }
            p {
              &.category {
                i {
                  display: none;
                }
                a {
                  color: var(--fo-tag-text-color);
                  &::before {
                    @include category_icon_custom;
                  }
                  &:hover {
                    opacity: $hover_opacity;
                  }
                }
              }
              &.description {
                margin: 10px;
                @include breakpoint-pc {
                  padding: 0 10px;
                }
                @include breakpoint-sp {
                  margin: 10px 0;
                  padding-left: 0;
                }
              }
            }
            div {
              &.tags {
                a.tag {
                  @include tag_custom;
                  &::before {
                    @include tag_icon_custom;
                  }
                  i {
                    display: none;
                  }
                  &:last-child {
                    margin-right: 0;
                  }
                }
              }
            }
          }
        }
      }
      &:is(
        .entry-image-card-1-col,
        .entry-image-card-2-col,
        .entry-image-card-3-col
      ) {
        .article-list {
          display: flex !important;
          flex-wrap: wrap;
          gap: $case_list_space;
          @include breakpoint-sp {
            gap: 20px;
          }
          .entry-list-unit {
            box-shadow: $case_box_shadow_common;
            border: 0;
            margin: 0 !important;
            a {
              &.img {
                max-height: none;
              }
            }
            .cont {
              border-left: none;
              padding-top: 10px;
              h3 {}
              h4 {}
              p {
                &.category {}
                &.description {
                  margin: 10px 0;
                  @include breakpoint-pc {
                    padding: 0;
                  }
                }
              }
              div {
                &.tags {
                  @include breakpoint-sp {
                    margin: 10px 0;
                  }
                }
              }
            }
          }
          .article-per-page {
            width: 100%;
            margin-top: 8px;
            &:empty {
              display: none;
              margin-top: 0;
            }
          }
        }
      }
      //カード型1列
      &.entry-image-card-1-col {
        .article-list {
          .entry-list-unit {
            width: 100%;
            a {}
            .cont {}
          }
        }
      }
      //カード型2列
      &.entry-image-card-2-col {
        .article-list {
          .entry-list-unit {
            @include breakpoint-pc {
              width: calc((100% - #{$case_list_space}) / 2);
            }
            a {}
            .cont {}
          }
        }
      }
      //カード型3列
      &.entry-image-card-3-col {
        .article-list {
          .entry-list-unit {
            @include breakpoint-pc {
              width: calc((100% - (#{$case_list_space} * 2)) / 3);
            }
            a {}
            .cont {}
          }
        }
      }
      //リスト型
      &.entry-image-list {
        .article-list {
          padding-bottom: 0;
          .entry-list-unit {
            box-shadow: $case_box_shadow_common !important;
            border: 0 !important;
            margin: 20px auto 0;
            padding-bottom: 10px;
            @include breakpoint-sp {
              display: block !important;
              width: 100%;
              padding: 20px 20px 10px;
            }
            &:first-child {
              margin-top: 0;
            }
            &:nth-last-child(2) {
              border-bottom: 0 !important;
            }
            a {
              &.img {
                width: 35% !important;
                padding: 0 !important;
                @include breakpoint-sp {
                  display: block !important;
                  width: 100% !important;
                }
                img {
                  padding-bottom: 10px;
                  @include breakpoint-sp {
                    padding-bottom: 0;
                  }
                }
              }
            }
            .cont {
              width: 65% !important;
              border-left: none;
              margin: 20px auto 0;
              @include breakpoint-sp {
                width: 100% !important;
                display: block !important;
              }
              h3 {
                text-align: left;
                margin: 0 20px 10px;
                @include breakpoint-sp {
                  margin: 10px 0;
                  padding-left: 0;
                }
                a {
                  &:hover {}
                }
              }
              h4 {
                padding: 0 20px;
                @include breakpoint-sp {
                  padding-left: 0;
                }
              }
              p {
                @include breakpoint-sp {
                  margin: 10px 0;
                  padding: 0;
                }
                &.category {}
                &.description {
                  @include breakpoint-pc {
                    padding: 0 20px;
                  }
                }
              }
              div {
                &.tags {
                  padding: 0 20px;
                  @include breakpoint-sp {
                    margin: 10px 0;
                    padding: 0;
                  }
                }
              }
            }
          }
        }
      }
      //ここからオプション
      //col余白なし オプション1
      &.option_padding_none {
        .article-list {
          .entry-list-unit {
            padding: 0;
            a {
              &.img {
                img {
                  padding: 0;
                }
              }
            }
            .cont {
              padding: 10px 20px;
              h3 {}
              h4 {}
              p {
                &.category {}
                &.description {}
              }
            }
          }
        }
        &.entry-image-list {
          .article-list {
            .entry-list-unit {
              .cont {
                vertical-align: middle;
                padding: 20px 20px 20px 0;
                @include breakpoint-sp {
                  margin-top: 0;
                  padding: 10px 20px;
                }
                h3 {}
                p {
                  &.description {}
                }
              }
            }
          }
        }
      }
      //シャドウなし オプション2
      &.option_shadow_none {
        .article-list {
          .entry-list-unit {
            box-shadow: none !important;
          }
        }
      }
      // 画像フィット オプション3
      &.option_img_fit {
        .article-list {
          .entry-list-unit {
            a {
              &.img {
                img {
                  @include breakpoint-pc {
                    height: $case_img_fit_height;
                    object-fit: cover;
                  }
                }
              }
            }
          }
        }
        &.entry-image-list {
          .article-list {
            .entry-list-unit {
              a {
                &.img {
                  img {
                    @include breakpoint-pc {
                      width: calc(35% - 14px);
                      height: calc(100% - 30px);
                      object-fit: cover;
                      position: absolute;
                    }
                  }
                }
              }
            }
          }
        }
        &.option_padding_none {
          &.entry-image-list {
            .article-list {
              .entry-list-unit {
                a {
                  &.img {
                    img {
                      @include breakpoint-pc {
                        width: 35%;
                        height: 100%;
                        position: absolute;
                        object-fit: cover;
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
      //テキスト制限 オプション4
      &.option_text_limit {
        .article-list {
          .entry-list-unit {
            .cont {
              h3 {
                display: -webkit-box;
                -webkit-line-clamp: 2;
                -webkit-box-orient: vertical;
                overflow: hidden;
                text-overflow: ellipsis;
              }
              p {
                &.description {
                  display: -webkit-box;
                  -webkit-box-orient: vertical;
                  -webkit-line-clamp: 5;
                  overflow: hidden;
                  text-overflow: ellipsis;
                }
              }
            }
          }
        }
        &.entry-image-list {
          .article-list {
            .entry-list-unit {
              .cont {
                h3 {
                  -webkit-line-clamp: 1;
                }
                p {
                  &.description {
                    -webkit-line-clamp: 3;
                  }
                }
              }
            }
          }
        }
      }
    }
    //ニュース
    &.news_list {
      padding: 40px 50px;
      @include breakpoint-sp {
        padding: 20px;
      }
      .article-list {
        .entry-list-unit {
          border-bottom: 1px solid $border_color;
          padding: 15px 10px 10px;
          @include breakpoint-sp {
            padding: 0 0 10px;
          }
          .cont {
            display: flex;
            justify-content: flex-end;
            flex-direction: row-reverse;
            width: 100%;
            border: 0;
            @include breakpoint-sp {
              flex-direction: column-reverse;
            }
            h3 {
              flex-grow: 1;
              margin: 0;
              @include breakpoint-sp {
                width: 100%;
                padding-left: 0;
              }
              a {
                font-family: $case_title_font_family;
                font-size: var(--fo-text-font-size-pc);
                line-height: var(--fo-text-line-height);
                color: inherit;
                text-decoration: $news_list_text_decoration;
                margin-bottom: 5px;
                padding-top: 1px;
                &:hover {
                  opacity: $news_list_hover_opacity;
                }
              }
            }
            h4 {
              font-family: $case_date_font_family;
              text-align: center;
              white-space: nowrap;
              margin: 4px 10px 0 0;
              padding: 0;
              @include breakpoint-sp {
                text-align: left;
                margin: 0 0 5px;
              }
            }
            div {
              &.tags {
                max-width: 140px;
                margin: 0 10px 0 0;
                padding: 0;
                @include breakpoint-sp {
                  width: 100%;
                  max-width: initial;
                  margin: 0;
                }
                a {
                  &.tag {
                    @include tag_custom;
                    margin-top: 0;
                    margin-bottom: 5px;
                    @include breakpoint-sp {
                      margin: 0 5px 10px 0;
                    }
                    &::before {
                      @include tag_icon_custom;
                    }
                    &:first-child {
                      @include breakpoint-sp {
                        margin-left: 0;
                      }
                    }
                    &:not(:first-child) {
                      display: none;
                    }
                    i {
                      display: none;
                    }
                  }
                }
              }
            }
          }
        }
      }
      //タグ2個以上 オプション
      &.option_column {
        .article-list {
          .entry-list-unit {
            .cont {
              flex-wrap: wrap;
              flex-direction: inherit;
              h3 {
                order: 2;
                width: 100%;
                a {
                  margin-bottom: 15px;
                  padding-left: 0;
                }
              }
              h4 {
                order: 1;
                width: 100%;
                text-align: left;
                margin: 0 0 5px 0;
              }
              div {
                &.tags {
                  order: 3;
                  max-width: 100%;
                  width: 100%;
                  a {
                    &.tag {
                      &:not(:first-child) {
                        display: inline-block;
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}
//サイドバー用
.side {
  .component {
    &.entry-list {
      //事例
      &.caseContent_style {
        .article-list {
          .entry-list-unit {
            @include breakpoint-pc {
              padding: 10px 10px 5px;
            }
            .cont {
              @include breakpoint-pc {
                padding-right: 0;
              }
              h3 {
                @include breakpoint-pc {
                  margin: 0;
                }
                a {
                  @include breakpoint-pc {
                    font-size: 16px;
                    padding: 0;
                  }
                }
              }
              h4 {
                @include breakpoint-pc {
                  font-size: 12px;
                  margin: 5px 0;
                  padding: 0;
                }
              }
              p {
                &.category {
                  @include breakpoint-pc {
                    margin: 5px 0;
                    padding: 0;
                  }
                  a {
                    @include breakpoint-pc {
                      font-size: 12px;
                      padding: 0;
                    }
                  }
                }
                &.description {
                  @include breakpoint-pc {
                    font-size: 12px;
                    margin: 5px 0 0;
                    padding: 0;
                  }
                }
              }
              div {
                &.tags {
                  @include breakpoint-pc {
                    margin: 0;
                    padding: 0;
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}

/*------------- entry-list( 記事リストパーツ))END -------------*/

/* --------------------------------
    header・logo・navigations(ヘッダー・ロゴ・ナビゲーション)
----------------------------------- */
.navi_base_custom {
  //1段のとき
  &.navi-001-01 {
    header#navigations {
      min-height: 51px;
      font-family: var(--fo-text-font-family);
      border-bottom: 0;
      box-shadow: $navigation_box_shadow_common;
      .inner {
        @include breakpoint-pc {
          box-sizing: border-box;
          display: flex;
          padding: 0;
        }
      }
      .logo {
        float: none;
        @include breakpoint-pc {
          width: $header_logo;
          padding: 10px;
        }
        @include breakpoint-sp {
          box-sizing: border-box;
          width: 100%;
          padding-left: 10px;
        }
        a {
          height: auto;
          img {
            @include breakpoint-sp {
              max-height: $header_sp_logo;
            }
          }
        }
      }
      //ハンバーガーメニュー
      a.menu-trigger {
        background: var(--fo-main-color);
        span {
          background-color: #fff;
        }
      }
      .main-menu {
        float: none;
        @include breakpoint-pc {
          width: calc(100% - #{$header_logo});
          max-width: none;
        }
        &.navigation-font-family {}
        ul.clearfix {
          background: $navigation_bg_color;
        }
        //PC用
        @include breakpoint-pc {
          .level-01,
          .level-01-trigger {
            a {
              font-size: $navigation_font_size;
              font-weight: $navigation_font_weight;
              color: $navigation_text_color;
              border-left: none;
              border-right: none;
              padding: 25px 10px;
            }
          }
          .level-01:hover {
            background-color: $navigation_hover_bg_color;
            a {
              color: $navigation_hover_text_color;
              opacity: $navigation_hover_opacity;
            }
          }
          .level-01-trigger {
            //三角部分
            &::after {
              content: "\f107";
              font-size: 20px;
              font-weight: 400;
              line-height: 1;
              color: $navigation_arrow1_color;
              translate: 0 -50%;
              margin-top: 0;
            }
            &:hover::after {
              color: $navigation_hover_text_color;
              rotate: 180deg;
            }
            &:hover {
              background: $navigation_hover_bg_color;
              & > a {
                color: $navigation_hover_text_color;
                opacity: $navigation_hover_opacity;
              }
            }
            ul.level-01-cont {
              background: $navigation_bg2_color;
              border: 0;
              a {
                color: $navigation_text2_color;
                padding: 20px;
                &:hover {
                  background: $navigation_hover_bg2_color;
                  color: $navigation_hover_text2_color;
                }
              }
              .level-02-trigger {
                &::after {
                  content: "\f105";
                  font-size: 20px;
                  font-weight: 400;
                  color: $navigation_arrow2_color;
                  right: 10px;
                  translate: 0 -50%;
                  margin-top: 0;
                }
                &:has(> a:hover) {
                  &::after {
                    color: $navigation_hover_text2_color;
                  }
                }
                .level-02-cont {
                  background: $navigation_bg2_color;
                  li {}
                  .level-03 {
                    a {
                      padding: 20px 10px;
                    }
                  }
                }
              }
            }
          }
        }
        //SP用は共通ハンバーガー
      }
    }
  }
  //2段のとき
  &.navi-002-01 {
    font-family: var(--fo-text-font-family);
    header#navigations {
      background: $header_bg_color;
      box-shadow: $navigation_box_shadow_common;
      .inner {
        //ロゴ ヘッダーボタンエリア
        .navigation-cont {
          box-sizing: border-box;
          max-width: $max_width;
          padding: 10px 20px;
          @include breakpoint-pc {
            display: flex;
            align-items: center;
            justify-content: space-between;
          }
          @include breakpoint-sp {
            padding: 0 0 10px;
          }
          //ロゴ
          .logo {
            float: none;
            @include breakpoint-pc {
              width: $header_logo;
              padding: 0;
            }
            @include breakpoint-sp {
              display: flex;
              align-items: center;
              min-height: 51px;
            }
            div {
              line-height: normal;
              padding: 0;
              a {
                @include breakpoint-sp {
                  display: block;
                  height: auto;
                  line-height: 0;
                }
                img {
                  vertical-align: middle;
                  padding: 0;
                  max-height: 60px;
                  @include breakpoint-sp {
                    max-height: $header_sp_logo;
                  }
                }
              }
            }
          }
          .cont {
            box-sizing: border-box;
            min-width: auto;
            max-width: none;
            float: none;
            @include breakpoint-pc {
              width: calc(100% - #{$header_logo});
            }
            .row {
              display: flex;
              justify-content: flex-end;
              width: 100%;
              min-width: inherit;
              @include breakpoint-sp {
                display: block;
              }
              @include breakpoint-tb {
                display: flex;
                justify-content: center;
              }
              .col {
                @include breakpoint-sp {
                  padding: 0;
                }
                //ボタンのカスタマイズ用
                // .component {
                //   &.button[data-designpart-id] {
                //     .button-cont {
                //       a {
                //         &.size-s {
                //           &::before {}
                //         }
                //       }
                //     }
                //   }
                // }
              }
            }
          }
        }
        //ハンバーガーメニュー
        a.menu-trigger {
          background: var(--fo-main-color);
          span {
            background-color: #fff;
          }
        }
        //グロナビ
        .main-menu {
          background: $navigation_bg_color;
          border-top: solid 1px #ccc;
          border-bottom: solid 1px #ccc;
          &.navigation-font-family {}
          //PC用
          @include breakpoint-pc {
            .level-01,
            .level-01-trigger {
              a {
                font-weight: $navigation_font_weight;
                font-size: $navigation_font_size;
                color: $navigation_text_color;
                border-left: none;
                border-right: none;
              }
            }
            .level-01:hover {
              background-color: $navigation_hover_bg_color;
              a {
                color: $navigation_hover_text_color;
                opacity: $navigation_hover_opacity;
              }
            }
            .level-01-trigger {
              //三角部分
              &::after {
                content: "\f107";
                font-size: 20px;
                font-weight: 400;
                line-height: 1;
                color: $navigation_arrow1_color;
                translate: 0 -50%;
                margin-top: 0;
              }
              &:hover::after {
                color: $navigation_hover_text_color;
                rotate: 180deg;
              }
              &:hover {
                background: $navigation_hover_bg_color;
                & > a {
                  color: $navigation_hover_text_color;
                  opacity: $navigation_hover_opacity;
                }
              }
              ul.level-01-cont {
                width: 100%;
                background: $navigation_bg2_color;
                border: 0;
                a {
                  color: $navigation_text2_color;
                  padding: 20px;
                  &:hover {
                    background: $navigation_hover_bg2_color;
                    color: $navigation_hover_text2_color;
                  }
                }
                .level-02-trigger {
                  &::after {
                    content: "\f105";
                    font-size: 20px;
                    font-weight: 400;
                    color: $navigation_arrow2_color;
                    translate: 0 -50%;
                    right: 10px;
                    margin-top: 0;
                  }
                  &:has(> a:hover) {
                    &::after {
                      color: $navigation_hover_text2_color;
                    }
                  }
                  .level-02-cont {
                    background: $navigation_bg2_color;
                    li {
                      width: 100%;
                    }
                    .level-03 {
                      a {
                        padding: 20px 10px;
                      }
                    }
                  }
                }
              }
            }
          }
          //SP用は共通ハンバーガー
        }
      }
    }
    //2段から1段への変更(変更不可)
    &.stage1 {
      header#navigations {
        .inner {
          //ロゴ ヘッダーボタンエリア
          .navigation-cont {
            @include breakpoint-sp {
              display: flex;
              align-items: center;
              justify-content: space-between;
              min-height: 51px;
              margin: 0;
              padding: 0;
            }
            .logo {
              @include breakpoint-sp {
                width: 45%;
                padding: 0 0 0 10px;
              }
            }
            .cont {
              @include breakpoint-sp {
                width: 55%;
                padding: 0 65px 0 0;
              }
              .row {
                @include breakpoint-sp {
                  display: flex;
                  justify-content: flex-end;
                  min-width: 112px;
                }
              }
            }
          }
        }
      }
    }
  }
  // hover挙動記述エリア
  &:is(.navi-001-01,.navi-002-01) {
    header#navigations {
      .inner {
        .main-menu {
          @include breakpoint-pc {
            ul {
              li {
                &:is(.level-01,.level-01-trigger) {
                  & > a {
                    position: relative;
                    &:before {
                      content: "";
                      position: absolute;
                      height: 2.5px;
                      width: 0;
                      margin: 0 auto;
                      right: 0;
                      bottom: 0;
                      left: 0;
                      background-color: var(--fo-main-color);
                      transition: width 0.3s ease-in-out;
                    }
                  }
                  &:hover {
                    a {
                      &::before {
                        width: 60px;
                      }
                    }
                  }
                }
                a {
                  transition: 0.3s ease-in-out;
                }
              }
            }
          }
        }
      }
    }
  }
  //共通ハンバーガー(1段・2段)
  &:is(.navi-001-01,.navi-002-01) {
    header#navigations {
      .inner {
        .main-menu {
          //SP共通
          @include breakpoint-sp {
            .toggle.fa.fa-angle-down,
            .toggle.fa.fa-angle-up {
              &::before {
                font-size: 20px;
                color: $navigation_sp_arrow1_color;
                position: absolute;
                top: 50%;
                right: 4px;
                margin-top: -11px;
              }
            }
            .level-01,
            .level-01-trigger {
              border-right: 0;
              border-left: 0;
              a {
                font-size: $navigation_sp_font_size;
                font-weight: $navigation_sp_font_weight;
                color: $navigation_sp_text_color;
                border-left: none;
                border-right: none;
                position: relative;
                padding: 10px 20px;
              }
            }
            .level-01 {
              &:hover {
                background: none;
              }
            }
            .level-01-trigger {
              &:hover {
                background: $navigation_sp_bg_color;
                a {
                  color: $navigation_sp_hover_text_color;
                  .toggle.fa.fa-angle-down,
                  .toggle.fa.fa-angle-up {
                    &::before {
                      color: $navigation_sp_hover_text_color;
                    }
                  }
                }
              }
              .level-01-cont {
                background: $navigation_sp_bg2_color;
                a {
                  color: $navigation_sp_text_color;
                  &:hover {
                    background: $navigation_sp_bg3_color;
                  }
                }
                .level-02-trigger {
                  padding-right: 0 !important;
                  &::after {
                    content: none !important;
                  }
                  a {
                    color: $navigation_sp_text3_color;
                    .toggle.fa.fa-angle-down,
                    .toggle.fa.fa-angle-up {
                      &::before {
                        color: $navigation_sp_arrow2_color;
                      }
                    }
                  }
                  .level-02-cont li a {
                    background: $navigation_sp_bg3_color;
                    color: $navigation_sp_text3_color;
                    //border-top: 1px solid $navigation_sp_bg3_color;
                  }
                }
                .level-02 {
                  border-top: 1px solid var(--fo-main-color);
                  a {
                    color: $navigation_sp_text2_color;
                  }
                }
              }
            }
          }
          //デザイン用
          @include breakpoint-sp {
            .toggle.fa.fa-angle-down,
            .toggle.fa.fa-angle-up {
              &::before {
                display: flex;
                justify-content: center;
                align-items: center;
                width: 30px;
                height: 100%;
                font-size: 30px;
                top: 10px;
                right: 0;
              }
            }
            .level-01,
            .level-01-trigger {
              a {
                text-align: left;
                border-top: $navigation_sp_border-bottom;
                padding: 20px 10px;
              }
            }
            .level-01-trigger {
              & > a {
                padding-right: 30px;
              }
              .level-01-cont {
                .level-02-trigger {
                  & > a {
                    padding: 20px 30px 20px calc(10px + 1em);
                  }
                  .level-03 {
                    a {
                      padding: 20px 30px 20px calc(10px + 2em);
                    }
                  }
                }
                .level-02 {
                  a {
                    padding: 20px 30px 20px calc(10px + 1em);
                  }
                }
                .level-02-cont {
                  // border-top: $navigation_sp_border-bottom !important;
                }
              }
            }
            ul {
              li {
                &[class*="level-01"] {
                  &:first-child {
                    & > a {
                      border: none;
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}

//2段のナビ非表示
.navi-002-01 {
  &.nav_none {
    header#navigations {
      .inner {
        .main-menu {
          display: none !important;
        }
        a.menu-trigger {
          display: none;
        }
      }
    }
  }
}

//ヘッダー固定時のみ(ハンバーガーメニュー内をスクロール表示)
:is(.navi-001-01,.navi-002-01) {
  &:is(
    .one_row_sticky-navi__GU_fr,
    .two_row_sticky-navi__8HtZT
  ) {
    header#navigations {
      .inner {
        .main-menu {
          @include breakpoint-sp {
            max-height: calc(100vh - 51px);
            overflow-y: auto;
            /*----
            //スクロールバー非表示
            -ms-overflow-style: none; //Edge
            scrollbar-width: none; //Firefox
            &::-webkit-scrollbar {
              display: none;
            }
            ----*/
          }
        }
      }
    }
  }
}

/*------------- header・logo・navigations(ヘッダー・ロゴ・ナビゲーション)END -------------*/

/*----------------------------------
    main-visual(メインビジュアル)
----------------------------------*/
//オーバーレイが公開画面で二重にかかるバグ
.theme-fo-base {
  .main-visual {
    .overlay {
      display: none !important;
    }
  }
}

//colのズレ対策
.theme-fo-base {
  .main-visual {
    .clearfix {
      .row {
        .col {
          vertical-align: top;
        }
      }
    }
  }
}

//メインビジュアル
.theme-fo-base {
  .main-visual {
    background-repeat: no-repeat;
    min-height: auto;
    padding: $mv_padding;
    @include breakpoint-sp {
      padding: $sp_mv_padding;
    } 
    @include breakpoint-tb {
      min-height: auto;
    }
    & > :is(.clearfix,.main-visual-content) {
        width: 100%;
        max-width: $max_width;
        display: flex;
        flex-direction: column;
        justify-content: center;
        min-height: auto;
        margin: auto;
        padding: 0 20px;
        @include breakpoint-sp {
          min-height: auto;
        }
      .row {
        .col {
          .component {
            &.heading {
              &.hd_custom {
                :is(h1,h2,h3,h4,h5) {
                  margin-bottom: 0;
                }
                h1 {
                  @include breakpoint-pc {
                    font-size: calc(var(--fo-h1-font-size-pc) + 4px);
                  }
                }
              }
            }
          }
        }
      }
    }
    //TOP
    &.mv_custom {
      & > :is(.clearfix,.main-visual-content) {
        min-height: $top_mv_height;
        @include breakpoint-sp {
          min-height: auto;
        }
        .row {
          --fo-heading-main-color: #fff;
          --fo-text-main-color: #fff;
          .col {
            .component {
              &.hd_custom {
                h1{}
              }
            }
          }
        }
      }
    }
    //下層
    &.mv_sub_custom {
      & > :is(.clearfix,.main-visual-content) {
        min-height: $sub_mv_height;
        .row {
          --fo-heading-main-color: #fff;
          --fo-text-main-color: #fff;
          --fo-text-link-color: #fff;
          .col {
            .component {
              &.cta {
                .cta-row {
                  &.mv_design01_row {
                    margin-top: 22px;
                    .cta-column {
                      display: flex;
                      flex-direction: column;
                      gap: 8px;
                      width: 100%;
                      .component {
                        &.button[data-designpart-id] {
                          margin: 0;
                        }
                      }
                    }
                  }
                }
              }
              &.hd_custom {
                h1{}
              }
            }
          }
        }
      }
    }
    //幅100%
    &.maxWidth_custom {
      & > :is(.clearfix,.main-visual-content) {
        max-width: none;
      }
    }
  }
}


/*------------- main-visual(メインビジュアル)END -------------*/

/*----------------------------------
  breadcrumbs(パンくず)
----------------------------------*/
.theme-fo-base {
  .breadcrumbs {
    background: #fff;
    max-width: 100%;
    margin: 0;
    ul {
      width: 100%;
      max-width: $max_width - 20px;
      margin: auto;
      padding: 15px 0;
      li {
        a {
          &:hover {
            color: var(--fo-text-main-color);
            text-decoration: unset;
            opacity: $hover_opacity;
          }
          &::after {
            content: "\f105";
            font-family: $font_family_awsm;
            color: var(--fo-text-main-color);
            border-top: none;
            border-bottom: none;
            border-left: none;
            position: absolute;
            padding: 0;
            top: 0;
            right: -1px;
            margin-top: 0;
          }
        }
        a,
        span {
          font-size: 14px;
          color: var(--fo-text-main-color);
          text-decoration: unset;
          padding: 0 20px;
        }
      }
    }
  }
}

/*------------- breadcrumbs(パンくず)END -------------*/

/*----------------------------------
    button(ボタン)
----------------------------------*/
/*--- ボタン全体スタイル ---*/
:is(
  .component.button,
  .button.cta-button
) {
  .button-cont {
    a {
      transition: none;
      &:hover {
        @include breakpoint-pc {
          transition: all .2s cubic-bezier(.02,.42,.24,.74);
        }
      }
    }
  }
}

//デザインパーツ
.component {
  &:not(:root:root:root:root:root) {
    //ボタン全体(例:自由にカスタマイズしてください)
    // &.button[data-designpart-id] {
    //   margin-top: 0;
    //   .button-cont {
    //     a {
    //       &.size-s {}
    //       &.size-m {}
    //       &.size-l {}
    //       &:is(.size-s,.size-m,.size-l) {
    //         box-shadow: none;
    //       }
    //     }
    //   }
    // }

    &.button {
      &.btn1_custom01 {
        .button-cont {
          a {
            &:is(.size-s,.size-m,.size-l) {
              &::before {}
            }
            &:is(.blue,.red,.orange,.black,.white) {}
            &:hover {}
          }
        }
      }
    }

    //TELボタン
    &.button[data-designpart-id="642f669ce4dc09621d945abc"] {
      .button-cont {
        a {
          //サイズ小
          &.size-s {
            font-size: calc(4px + var(--fo-button-small-font-size));
          }
          //サイズ中
          &.size-m {
            font-size: calc(4px + var(--fo-button-medium-font-size));
          }
          //サイズ大
          &.size-l {
            font-size: calc(12px + var(--fo-button-large-font-size));
          }
        }
      }
    }
  }
}
//ボタン共通
.component {
  &.button {
    //sp時センター寄せ
    &.sp_center {
      .button-cont:is(.left,.right) {
        @include breakpoint-sp {
          text-align: center;
        }
      }
    }
    //sp時アイコン化
    &.sp_icon {
      .button-cont {
        a {
          &:is(.size-s,.size-m,.size-l) {
            @include breakpoint-msp {
              background: none !important;
              width: auto !important;
              min-width: auto !important;
              font-size: 0 !important;
              letter-spacing: 0 !important;
              border: 0 !important;
              border-radius: 0 !important;
              box-shadow: none !important;
              margin: 0;
              padding: 5px 10px 5px 5px;
            }
            @include breakpoint-ssp {
              padding: 5px;
            }
          }
          &::before,
          &::after {
            @include breakpoint-msp {
              font-size: 22px;
              line-height: 1;
              color: var(--fo-main-color);
              margin: 0;
              top: 0;
            }
            @include breakpoint-ssp {
              font-size: 20px;
            }
          }
        }
      }
    }

    //デフォルトパーツ
    &.btn_custom01 {
      .button-cont {
        a {
          &:is(.size-s,.size-m,.size-l) {
            &::before {}
          }
          &:is(.blue,.red,.orange,.black,.white) {}
          &:hover {}
        }
      }
    }

  }
}

/*------------- button(ボタン)END -------------*/

/*----------------------------------
    heading(見出し)
----------------------------------*/
//ページ内リンクずれ対策class
.theme-fo-base {
  .wrapper {
    .contents {
      section {
        .component {
          &.heading:not(:root) {
            &.inPage_link {
              @include breakpoint-pc {
                margin-top: calc(-#{$inPage_link} - 10px);
                padding-top: calc(#{$inPage_link} + 10px);
              }
              @include breakpoint-sp {
                margin-top: calc(-#{$sp_inPage_link} - 10px);
                padding-top: calc(#{$sp_inPage_link} + 10px);
              }
            }
          }
        }
      }
    }
  }
}

//デザインパーツ
.component {
  //見出し下余白条件分岐用
  &:not(:root:root:root:root) {
    &.heading[data-designpart-id] {
      &:has(+ .component) {
        :is(h1,h2,h3) {
          @include margin-property(bottom,32px);
        }
        :is(h4,h5) {
          @include margin-property(bottom,24px);
        }
      }
    }
  }
  &:not(:root:root:root:root:root) {
    // 見出し全体(例:自由にカスタマイズしてください)
    &.heading[data-designpart-id] {
      :is(h1,h2,h3,h4,h5) {}
    }
    //デザインパーツ
    &.heading {
      &.hd_custom01 {
        :is(h1,h2,h3,h4,h5) {}
      }
      &.mt0_hd {
        margin-top: 0;
      }
      &.mainClr_hd {
        --fo-heading-main-color: var(--fo-main-color);
      }
      &.subClr_hd {
        --fo-heading-main-color: var(--fo-sub-color);
      }
      &.accentClr_hd {
        --fo-heading-main-color: var(--fo-accent-color);
      }
    }
  }
}

//デフォルトパーツ
.theme-fo-base {
  :is(.main-visual,.contents,.side,.foot) {
    .component {
      &.heading {
        //&.rich-heading-align-right {}
        //&.rich-heading-align-center {}
        //&.rich-heading-align-left {}

        //見出し01
        &.hd_custom01 {
          :is(h1,h2,h3,h4,h5) {}
        }

        //sp時センター
        &.sp_center {
          &:is(.rich-heading-align-right,.rich-heading-align-left) {
            @include breakpoint-sp {
              text-align: center !important;
            }
          }
        }

        //細字設定
        :is(h1,h2,h3,h4,h5) {
          .strong {
            font-weight: $hd_font_strong;
          }
        }
      }
    }
  }
}

/*------------- heading(見出し)END -------------*/


/*----------------------------------
    article-post(ブログ用見出し)
----------------------------------*/
/*--- ブログ見出しフォント指定 ---*/
.component {
  &.blog_article {
    .article-post {
      @include hd_blog;
    }
  }
}
/*------------- article-post(ブログ用見出し)END -------------*/

/*----------------------------------
    main(コンテンツ)
----------------------------------*/
@include theme-fo-base {
  .inner {
    .row {
      &.loop_row {
        @include adjacentMargin(loop_row,40px);
      }
      //料金
      &.price_table_row {
        .col {
          .component {
            &.richtext {
              :is(.normal-table,.table-with-two-headers) {
                table {
                  thead {
                    tr {
                      th {
                        background-color: #fff;
                        font-weight: normal;
                        &:nth-child(2) {
                          background-color: color-mix(in srgb, var(--fo-main-color) 80%, #fff);
                        }
                        &:nth-child(3) {
                          background-color: color-mix(in srgb, var(--fo-main-color) 60%, #fff);
                        }
                        &:nth-child(n+4) {
                          background-color: color-mix(in srgb, var(--fo-main-color) 40%, #fff);
                        }
                      }
                    }
                  }
                  tbody {
                    tr {
                      :is(th,td) {
                        font-weight: normal;
                        background-color: #fff;
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
      .col {
        .component {
          //リッチテキストパーツ
          &.richtext {}
          //画像パーツ
          &.image {}
          //リストパーツ
          &.list {}
        }
      }
    }
  }
}

/*--- CTAパーツ ---*/
@include theme-fo-base {
  //通常用
  &.cta_sec {
    .inner {
      .row {
        .col {
          .component {
            &.cta {
              margin: 0;
              .cta-row {
                --fo-heading-main-color: #fff;
                --fo-text-main-color: #fff;
                --tel-botton-color: #fff;
                &.btn_row {
                  @include breakpoint-pc {
                    display: flex;
                    max-width: 892px;
                    margin: auto;
                  }
                  @include breakpoint-pro_s {
                    display: block;
                  }
                  .cta-column {
                    @include breakpoint-pc {
                      display: flex;
                      justify-content: space-between;
                    }
                    @include breakpoint-pro_s {
                      display: block;
                      width: 100% !important;
                    }
                    &:not(:first-child) {
                      @include breakpoint-pro_s {
                        margin-top: 20px;
                      }
                    }
                    .component {
                      &.button[data-designpart-id] {
                        margin: 10px 0;
                      }
                    }
                  }
                  & + .cta-row {
                    max-width: 892px;
                    margin: auto;
                    .cta-column {
                      .component {
                        &.button[data-designpart-id] {
                          margin: 10px 0;
                        }
                      }
                    }
                  }
                }
                &.tel_row {
                  .cta-column {
                    .component {
                      &.button {
                        .button-cont {
                          a {
                            &:is(.size-s,.size-m,.size-l) {
                              color: var(--tel-botton-color,#000);
                            }
                          }
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}
//2カラム(CTA)
.theme-fo-base {
  .wrapper {
    &[class*="side-"] {
      .contents {
        section {
          &.cta_sec {
            .inner {
              .row {
                .col {
                  .component {
                    &.cta {
                      .cta-row {
                        &.btn_row {
                          display: block;
                          .cta-column {
                            display: block;
                            width: 100% !important;
                          }
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
      .side {
        .inner {
          .component {
            &.heading {
              & + .button {
                margin-top: 0;
              }
            }
          }
        }
      }
    }
  }
}

/*--- デザインLPパーツ ---*/
@include theme-fo-base {
  //ヘッダー
  &.foPrp_header_sec {
    padding: 0;
    .inner {
      padding: 10px 20px;
      @include breakpoint-sp {
        padding: 10px;
      }
      .row {
        &.foPrp_header_row {
          display: flex;
          align-items: center;
          @include breakpoint-pc {
            min-height: 60px;
          }
          .col {
            padding: 0;
            &.foPrp_logo_col {
              @include breakpoint-pc {
                max-width: 300px;
                min-width: 150px;
                width: auto !important;
              }
              .component {
                &.image {
                  margin: 0;
                  &.foPrp_logo_img {
                    img {
                      @include breakpoint-pc {
                        max-width: $header_logo !important;
                        width: 100% !important;
                      }
                      @include breakpoint-sp {
                        max-height: $header_sp_logo !important;
                      }
                    }
                  }
                }
              }
            }
            &.foPrp_btn_col {
              display: flex !important;
              justify-content: flex-end;
              align-items: center;
              flex: 1;
              @include breakpoint-pc {
                width: auto !important;
              }
              .component {
                margin: 0;
                &:not(:first-child) {
                  @include breakpoint-pc {
                    margin-left: 15px;
                  }
                }
                &.button {
                  margin-top: 0;
                  .button-cont {
                    a {
                      @include breakpoint-sp {
                        background: none;
                        width: auto;
                        min-width: auto;
                        font-size: 0 !important;
                        letter-spacing: 0;
                        border-radius: 0;
                        border: 0;
                        margin: 0;
                        box-shadow: none;
                        padding: 5px 10px 5px 5px;
                      }
                      &::before {
                        @include breakpoint-sp {
                          font-size: 22px;
                          line-height: 1;
                          color: var(--fo-main-color);
                          margin: 0;
                        }
                      }
                    }
                  }
                  &[data-designpart-id="642f669ce4dc09621d945abc"] {
                    .button-cont {
                      a {
                        @include breakpoint-pro {
                          background: none;
                          width: auto;
                          min-width: auto;
                          font-size: 0 !important;
                          letter-spacing: 0;
                          border-radius: 0;
                          border: 0;
                          margin: 0;
                          box-shadow: none;
                          padding: 5px 10px 5px 5px;
                        }
                        &::before {
                          @include breakpoint-pro {
                            font-size: 22px;
                            line-height: 1;
                            color: inherit;
                            margin: 0;
                          }
                          @include breakpoint-sp {
                            color: inherit;
                          }
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
  //フッター
  &.foPrp_footer_sec {
    padding: 0;
    background: $footer_bg_color;
    .inner {
      max-width: unset;
      padding: 0;
      .row {
        .col {
          padding: 0;
          .component {
            &.cta {
              margin: 0;
              .cta-row {
                padding-top: 0;
                &.page_top_row {
                  @include page_top;
                }
                .cta-column {
                  padding: 0;
                  .component {
                    &.richtext {
                      &.foot-copyright {
                        @include copyright_custom;
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}

/*---------------------------------------------------
ここのパーツは自由に使用してください。
カスタマイズする場合はコピーして所定の場所で使用してください。
-----------------------------------------------------*/
@include theme-fo-base {
  .inner {
    .row {
      .col {
        .component {
          &.richtext {
            //テーブル(ボーダー無し)
            &.custom_table {
              table {
                border: none;
                :is(thead,tbody) {
                  border: 0;
                  tr {
                    border: 0;
                    th {
                      vertical-align: top;
                      border: 0;
                    }
                    td {
                      vertical-align: top;
                      border: 0;
                    }
                    p {
                      @include breakpoint-tb {}
                    }
                  }
                }
              }
            }
            //スマホ時テーブル固定スクロール
            &.sp_table_scroll {
              :is(
                .normal-table,
                .table-with-row-header,
                .table-with-two-headers
              ) {
                @include breakpoint-sp {
                  overflow-x: auto;
                  -webkit-overflow-scrolling: touch;
                  margin-bottom: 40px;
                }
                &::after {
                  @include breakpoint-sp {
                    content: "\f07e";
                    display: inline-block;
                    font-family: $font_family_awsm;
                    font-size: 30px;
                    line-height: 1;
                    color: var(--fo-main-color);
                    position: absolute;
                    left: 50%;
                    margin-left: -15px;
                  }
                }
              }
              table {
                @include breakpoint-tb {
                  min-width: 130vw;
                }
                @include breakpoint-ssp {
                  min-width: 200vw;
                }
                thead {
                  tr {
                    th {
                      @include breakpoint-sp {
                        white-space: initial;
                      }
                    }
                  }
                }
                tbody {
                  tr {
                    th {
                      @include breakpoint-sp {
                        display: table-cell !important;
                        white-space: nowrap;
                      }
                    }
                    td {
                      vertical-align: top;
                      @include breakpoint-sp {
                        display: table-cell !important;
                        white-space: initial;
                      }
                      p {
                        @include breakpoint-tb {}
                      }
                    }
                  }
                }
              }
            }
            //英語テキスト
            &.en_text {
              color: var(--fo-main-color);
              table {
                border: none;
                :is(thead,tbody) {
                  border: 0;
                  tr {
                    border: 0;
                    th {
                      border: 0;
                      padding: 0;
                    }
                    td {
                      border: 0;
                      padding: 0;
                    }
                    p {
                      margin: 0 !important;
                      @include breakpoint-tb {}
                    }
                  }
                }
              }
            }
            //ナンバー
            &.number_text {
              table {
                width: auto !important;
                border: none;
                :is(thead,tbody) {
                  border: 0;
                  tr {
                    border: 0;
                    th {
                      border: 0;
                      line-height: 1;
                      padding: 0;
                    }
                    td {
                      border: 0;
                      line-height: 1;
                      padding: 0;
                    }
                    p {
                      margin: 0 !important;
                      line-height: 1;
                      @include breakpoint-tb {}
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}

/*------------------------------
カスタムパーツ 格納場所
基本的にパーツ単体の記述でお願いします。
パーツ名を忘れず記載してください。
-------------------------------*/
@include theme-fo-base {
  .inner {
    .row {
      .col {
        .component {}
      }
    }
  }
}
/*--- カスタムパーツ 格納場所 end ---*/


/*----------------------------------
    ユニバーサルクラス
----------------------------------*/

//スマホだけ表示させる
.spOnly {
  @include breakpoint-pc {
    display: none !important;
  }
}

//PCだけ表示させる
.pcOnly {
  @include breakpoint-sp {
    display: none !important;
  }
}

//displayNoneクラス
.displayNone {
  display: none !important;
}

//ギャラリーパーツ
.poptrox-overlay {
  z-index: 9999 !important;
  .poptrox-popup {
    .pic {
      z-index: 10000;
    }
  }
}

//iframe
.component {
  &.iframe {
    display: flex;
    //左寄せ
    &.right {
      justify-content: flex-end;
    }
    //中央寄せ
    &.center {
      justify-content: center;
    }
    //ワイド
    &.if_16-9 {
      aspect-ratio: 16/9;
    }
    //スタンダート
    &.if_4-3 {
      aspect-ratio: 4/3;
    }
    //スクエア
    &.if_1-1 {
      aspect-ratio: 1/1;
    }
    //縦撮り
    &.if_9-16 {
      aspect-ratio: 9/16;
    }
    //シネマスコープ
    &.if_235-1 {
      aspect-ratio: 2.35/1;
    }
    //カスタムclass
    &.if_custom {
      width: 100%;
      height: 0;
      position: relative;
      $var: 300;
      @while $var <= 3000 {
        &.pc-h#{$var} {
          @include breakpoint-pc {
            height: #{$var}px;
          }
        }
        &.sp-h#{$var} {
          @include breakpoint-sp {
            height: #{$var}px;
          }
        }
        $var: $var + 10;
      }
      iframe {
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
      }
    }
  }
}

//スムーススクロール
html {
  scroll-behavior: smooth !important;
}

//フォームパーツ
.component {
  &.form {
    .form-title {
      color: var(--fo-text-main-color);
    }
    //フォームの必須
    .form-label {
      &.require {
        &::after {
          padding: 2px 7px 4px !important;
          margin-left: 20px;
        }
      }
    }
    input[type=checkbox],
    input[type=radio] {
      min-height: auto;
    }
    .form-submit {
      .popup-link {
        font-weight: $font_weight;
      }
    }
    &.vertical {
      .form-label {
        &::after {
          position: relative;
          top: -2px;
        }
      }
    }
    &.horizontal {
      .form-label {
        padding-right: 10px;
        &::after {
          @include breakpoint-pc {
            top: 8px !important;
          }
          @include breakpoint-sp {
            top: -2px !important;
          }
        }
      }
    }
  }
}

//ズレ対策
.component {
  &.form {
    label.agreement {
      display: flex;
      align-items: center;
      .form-label {
        padding-top: 6px;
        &::after {
          top: -1.5px;
        }
      }
    }
  }
}

//角丸専用
.radius_all {
  border-radius: $border_radius_common;
}

//2カラム時、PCとSPでカラムの位置を入れ替える
.reverse {
  @include breakpoint-sp {
    display: flex !important;
    flex-wrap: wrap-reverse;
  }
}

//全てbr非表示
.allbrClear {
  br {
    display: none;
  }
}

//PCの時はbr非表示
.pcbrClear {
  br {
    display: none;
    @include breakpoint-sp {
      display: block;
    }
  }
}

//TABの時はbr非表示
.tbbrClear {
  br {
    @include breakpoint-tb {
      display: none;
    }
  }
}

//width1024の時はbr非表示
.probrClear {
  br {
    @include breakpoint-pro {
      display: none;
    }
  }
}

//スマホの時はbr非表示
.spbrClear {
  br {
    @include breakpoint-sp {
      display: none;
    }
  }
}


/*------------- main(コンテンツ) END -------------*/

/* ----------------------------------
  blog(ブログテンプレート)
----------------------------------*/
/*--- ブログページ一覧 ---*/
.component {
  &.blog_articles {
    hr {
      border: 0;
      border-bottom: 1px solid $blog_border_color;
      margin-bottom: 30px;
      @include breakpoint-sp {
        margin-bottom: 10px;
      }
    }
    article {
      .infomation {
        padding: 0 0 0 30px;
        //タイトル
        & > h2 {
          line-height: 1.5;
          padding: 0;
          a {
            display: inline-block;
            font-family: var(--fo-heading-font-family);
            font-size: $list_heading_pc_fontsize;
            font-weight: bold;
            letter-spacing: var(--fo-heading-letter-spacing);
            line-height: var(--fo-heading-line-height);
            color: var(--fo-heading-main-color);
            @include breakpoint-sp {
              font-size: $list_heading_sp_fontsize;
            }
            &:hover {
              opacity: $hover_opacity;
            }
          }
        }
        p {
          font-size: var(--fo-text-font-size-pc);
          color: var(--fo-text-main-color);
          line-height: var(--fo-text-line-height);
          letter-spacing: var(--fo-text-letter-spacing);
          padding: 0;
          @include breakpoint-sp {
            font-size: var(--fo-text-font-size-sp);
          }
        }
        //記事を見るの位置
        a {
          &.view-article {
            display: inline-block;
            width: 100%;
            font-size: var(--fo-text-font-size-pc);
            color: var(--fo-text-link-color,var(--fo-text-main-color));
            line-height: var(--fo-text-line-height);
            letter-spacing: var(--fo-text-letter-spacing);
            text-align: right;
            text-decoration: underline;
            @include breakpoint-sp {
              font-size: var(--fo-text-font-size-sp);
            }
            &:hover {
              opacity: $hover_opacity;
              text-decoration: none;
            }
          }
        }
        //日付の背景色
        span {
          &.published_at {
            background: none;
            font-size: 14px;
            color: var(--fo-text-main-color);
            text-align: left;
            padding: .5rem 0;
          }
        }
        //タグスタイル
        .tags {
          padding-left: 0;
          a {
            &.tag {
              @include tag_custom;
              i {
                margin-right: 0;
                &::before {
                  @include tag_icon_custom;
                }
              }
            }
          }
        }
      }
      .catch,
      .infomation {
        @include breakpoint-sp {
          width: 100%;
          float: none;
          padding: 1em 0 0;
        }
      }
      .catch {
        a {
          img {
            border-radius: $blog_border_radius;
          }
        }
      }
    }
  }
}

/*--- ブログ記事詳細 ---*/
.theme-fo-base {
  .clearfix {
    .contents {
      &.blog-contents {
        padding: 0;
        section {
          .inner {
            @include breakpoint-sp {
              padding: 0 20px 10px;
            }
            .row {
              .col {
                .component {
                  &.blog_article {
                    margin-top: 0;
                    .article-component {
                      //目次内
                      &.contents-table {
                        border-color: $border_color;
                        @include breakpoint-sp {
                          padding: 10px 20px;
                        }
                        ol {
                          @include breakpoint-sp {
                            margin-left: 0;
                          }
                          ol {
                            @include breakpoint-sp {
                              margin-left: 1em;
                            }
                          }
                        }
                      }
                    }
                    //日付・タグ
                    .article-meta-info {
                      opacity: unset;
                      span {
                        &.post-date {
                          time {
                            font-family: var(--fo-text-font-family);
                          }
                        }
                        &.article-category {
                          i {
                            display: none;
                          }
                          a {
                            color: var(--fo-main-color);
                            &::before {
                              @include category_icon_custom;
                            }
                            &:hover {
                              opacity: $hover_opacity;
                            }
                          }
                        }
                        &.article-tags {
                          i {
                            display: none;
                          }
                          a {
                            @include tag_custom;
                            display: inline-block;
                            margin-top: 10px;
                            &::before {
                              @include tag_icon_custom;
                            }
                            &::after {
                              content: none;
                            }
                          }
                        }
                      }
                    }
                    //詳細ページ設定
                    .article-eyecatch {
                      @include breakpoint-pc {
                        margin-bottom: 30px;
                      }
                      @include breakpoint-sp {
                        margin: 30px 0;
                      }
                    }
                    .article-post {
                      color: var(--fo-text-main-color);
                      padding: 0;
                      a {
                        color: var(--fo-text-main-color);
                        &:hover {
                          opacity: $hover_opacity;
                        }
                      }
                      //ブログ詳細の本文
                      .component {
                        &.richtext {
                          font-size: var(--fo-text-font-size-pc);
                          letter-spacing: var(--fo-text-letter-spacing);
                          line-height: var(--fo-text-line-height);
                          color: var(--fo-text-main-color);
                          @include breakpoint-sp {
                            font-size: var(--fo-text-font-size-sp);
                          }
                          p {
                            font-size: inherit;
                            letter-spacing: inherit;
                            line-height: inherit;
                            color: inherit;
                            a {
                              color: var(--fo-text-link-color);
                              &:hover {
                                opacity: var(--fo-text-link-hover-opacity,1);
                                text-decoration: var(--fo-text-link-hover-text-decoration,none);
                                font-weight: var(--fo-text-link-hover-font-weight,inherit);
                                color: var(--fo-text-link-color);
                                filter: unquote('invert(var(--fo-text-link-hover-invert,0))');
                              }
                              &.show-area {
                                &:hover {
                                  opacity: $hover_opacity;
                                  text-decoration: none;
                                  font-weight: inherit;
                                  color: var(--fo-text-link-color);
                                  filter: none;
                                }
                              }
                            }
                          }
                          //ブログ詳細の表
                          table {
                            .table-content {
                              a {
                                color: var(--fo-text-link-color);
                                &:hover {
                                  opacity: var(--fo-text-link-hover-opacity,1);
                                  text-decoration: var(--fo-text-link-hover-text-decoration,none);
                                  font-weight: var(--fo-text-link-hover-font-weight,inherit);
                                  color: var(--fo-text-link-color);
                                  filter: unquote('invert(var(--fo-text-link-hover-invert,0))');
                                }
                              }
                            }
                          }
                          .border {
                            margin-top: 0;
                            hr {
                              &.type01 {
                                background-image: -webkit-linear-gradient(left, transparent, $border_color, transparent);
                              }
                              &:is(.type02,.type03,.type04) {
                                border-color: $border_color;
                              }
                            }
                          }
                          //ブログ詳細の引用
                          blockquote {
                            font-size: inherit;
                            color: inherit;
                            padding: 40px 30px;
                            @include breakpoint-sp {
                              padding: 20px;
                            }
                            &::before {
                              font-size: 500%;
                            }
                          }
                        }
                      }
                    }
                    section {
                      //著者
                      &.author {
                        padding: 0;
                        border-color: $border_color;
                        @include breakpoint-sp {
                          display: flex;
                          padding: 15px;
                        }
                        .author-image {
                          margin-right: 15px;
                          @include breakpoint-sp {
                            width: 50%;
                          }
                          img {
                            border-radius: $blog_border_radius;
                          }
                        }
                        .author-info {
                          .author-name {
                            font-family: var(--fo-heading-font-family);
                            font-size: 18px;
                            color: var(--fo-heading-main-color);
                            line-height: var(--fo-heading-line-height);
                            letter-spacing: var(--fo-heading-letter-spacing);
                            @include breakpoint-sp {
                              font-size: 16px;
                            }
                          }
                          .author-description {
                            white-space: pre-wrap;
                            font-size: var(--fo-text-font-size-pc);
                            letter-spacing: var(--fo-text-letter-spacing);
                            line-height: var(--fo-text-line-height);
                            color: var(--fo-text-main-color);
                            @include breakpoint-sp {
                              font-size: var(--fo-text-font-size-sp);
                            }
                          }
                        }
                      }
                    }
                  }
                }
                section {
                  //ページネーション
                  &.prev-next-link {
                    display: flex;
                    gap: calc(40px * var(--fo-spacing-coef));
                    margin-top: calc(40px * var(--fo-spacing-coef));
                    @include breakpoint-sp {
                      flex-direction: column;
                      gap: 0;
                      margin: calc((40px * var(--fo-spacing-coef)) * .75) 0 20px;
                      padding: 0;
                    }
                    a {
                      color: var(--fo-text-main-color);
                      border-color: $border_color;
                      &:hover {
                        background: transparent;
                        opacity: $hover_opacity;
                      }
                      &::before,
                      &::after {
                        color: var(--fo-main-color);
                      }
                      //前の記事 次の記事
                      h3 {
                        &.prev-next-label {
                          font-family: var(--fo-heading-font-family);
                          font-size: 18px;
                          color: var(--fo-heading-main-color);
                          line-height: var(--fo-heading-line-height);
                          letter-spacing: var(--fo-heading-letter-spacing);
                          @include breakpoint-sp {
                            font-size: 16px;
                          }
                        }
                      }
                      div.thumb-wrap {
                        display: flex;
                        img {
                          float: none;
                          margin-right: 15px;
                        }
                        p {
                          font-size: 14px;
                          letter-spacing: var(--fo-text-letter-spacing);
                          line-height: var(--fo-text-line-height);
                          color: var(--fo-text-main-color);
                          display: -webkit-box;
                          -webkit-line-clamp: 2;
                          -webkit-box-orient: vertical;
                          text-overflow: ellipsis;
                          max-height: calc((14px * var(--fo-text-line-height)) * 2);
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}

/*------------- blog(ブログテンプレート) END -------------*/

/* ----------------------------------
  カテゴリ・タグ自動生成ページ
----------------------------------*/
.theme-fo-base {
  &.clearfix {
    .wrapper {
      &.clearfix {
        .contents {
          :is(
            .category-preview,
            .tag-preview
          ) {
            box-sizing: border-box;
            margin: auto;
            article {
              display: table;
              border-bottom: 1px solid $blog_border_color;
              @include breakpoint-sp {
                display: block;
                width: 100%;
                margin: 20px 0;
                padding: 0;
              }
              .article-thumbnail {
                display: table-cell;
                width: 30%;
                padding-bottom: 10px;
                @include breakpoint-sp {
                  display: block;
                  width: 100%;
                }
                a {
                  display: block;
                  @include breakpoint-sp {
                    margin-bottom: 10px;
                  }
                  img {
                    width: 100%;
                    border-radius: 0;
                  }
                }
              }
              .article-cont {
                display: table-cell;
                width: 70%;
                height: auto;
                vertical-align: top;
                padding: 10px 30px;
                @include breakpoint-sp {
                  display: block;
                  width: 100%;
                  margin-bottom: 20px;
                  padding: 0;
                }
                .article-title {
                  overflow: auto;
                  max-height: none;
                  a {
                    font-family: var(--fo-heading-font-family);
                    font-size: $list_heading_pc_fontsize;
                    font-weight: inherit;
                    color: var(--fo-heading-main-color);
                    line-height: var(--fo-heading-line-height);
                    letter-spacing: var(--fo-heading-letter-spacing);
                    @include breakpoint-sp {
                      font-size: $list_heading_sp_fontsize;
                    }
                    &:hover {
                      opacity: $hover_opacity;
                    }
                  }
                }
                .article-meta-info {
                  position: relative;
                  .article-category {
                    &::before {
                      content: none;
                    }
                    a {
                      color: var(--fo-text-link-color,var(--fo-text-main-color));
                      &::before {
                        @include category_icon_custom;
                      }
                      &:hover {
                        opacity: $hover_opacity;
                      }
                    }
                  }
                  //タグ自動生成のタグスタイル
                  .tag-lists {
                    @include breakpoint-sp {
                      display: block;
                    }
                    .article-tags {
                      @include tag_custom;
                      &::before {
                        @include tag_icon_custom;
                      }
                    }
                  }
                  //カレンダーアイコン削除
                  span {
                    &.post-date {
                      color: var(--fo-text-main-color);
                      &::before {
                        content: none;
                      }
                      time {
                        font-family: var(--fo-text-font-family);
                      }
                    }
                    &.article-author {
                      color: var(--fo-text-main-color);
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}
:is(
  .tag-preview article .article-cont .article-meta-info .tag-lists,
  .category-preview article .article-cont .article-meta-info .tag-lists
) {
  max-height: 100% !important;
}
/*------------- カテゴリ・タグ自動生成ページ END -------------*/

/*----------------------------------
    side bar(サイドバー)
----------------------------------*/
//834幅から1カラム設定
.theme-fo-base {
  .wrapper {
    &:is(.side-left,.side-right) {
      max-width: $max_width;
      @include breakpoint-pro_s {
        display: block; //崩れ対策
      }
      .contents {
        background: transparent;
        max-width: unset;
        border-left: 0;
        border-right: 0;
        padding: 0;
        @include breakpoint-pro_s {
          display: block; //崩れ対策
        }
        section {
          .inner {
            padding: 20px;
          }
        }
      }
      .side {
        @include breakpoint-pro_s {
          display: block;
        }
        &:is(.left,.right) {
          padding: 0;
          @include breakpoint-pro_s {
            width: 100%;
          }
          @include breakpoint-tb {
            width: 100%;
            margin: auto;
          }
          .inner {
            padding: 20px;
            .component:not(:root:root) {
              margin: 20px 0;
              &:first-child {
                margin-top: 0;
              }
              &.heading {
                h1 {
                  @include breakpoint-pc {
                    font-size: $blog_title_h1_fontsize_pc;
                  }
                  @include breakpoint-sp {
                    font-size: $blog_title_h1_fontsize_sp;
                  }
                }
                h2 {
                  @include breakpoint-pc {
                    font-size: $blog_title_h2_fontsize_pc - 2px;
                  }
                  @include breakpoint-sp {
                    font-size: $blog_title_h2_fontsize_sp;
                  }
                }
              }
              &.blog-ranking {
                &[data-designpart-id="642f669ce4dc09621d945ab4"] {
                  div {
                    &:nth-child(1 of .entry-list-unit) {
                      @include breakpoint-sp {
                        padding-top: 0;
                      }
                    }
                  }
                }
              }
              &.button {
                .button-cont {
                  a {
                    &:is(.size-s,.size-m,.size-l) {
                      @include breakpoint-pc {
                        width: 100%;
                        min-width: 100%;
                      }
                    }
                    &.size-s {
                      @include breakpoint-pro_s {
                        width: initial;
                        min-width: 200px;
                      }
                    }
                    &.size-m {
                      @include breakpoint-pro_s {
                        width: initial;
                        min-width: 280px;
                      }
                    }
                    &.size-l {
                      @include breakpoint-pc {
                        font-size: 16px;
                      }
                      @include breakpoint-pro_s {
                        font-size: 22px;
                        width: initial;
                        min-width: 350px;
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
    &.side-left {
      @include breakpoint-pro_s {
        display: flex;
        flex-wrap: wrap;
        flex-direction: column-reverse;
      }
    }
    &.side-both {
      @include breakpoint-pro_s {
        display: flex;
        flex-wrap: wrap;
      }
      .contents {
        @include breakpoint-pc {
          width: 100%;
          max-width: 560px;
        }
        @include breakpoint-pro_s {
          display: block;
          max-width: none;
          order: 1;
          padding: 10px 0;
        }
        @include breakpoint-sp {
          padding: 10px 0;
        }
        section {
          .inner {
            padding: 20px;
            .row {
              .col {
                @include breakpoint-pro_s {
                  padding: 0;
                }
              }
            }
          }
        }
      }
      .side {
        &:is(.left,.right) {
          @include breakpoint-pro_s {
            display: block;
            width: 100%;
          }
          @include breakpoint-msp {
            padding: 0;
          }
          @include breakpoint-tb {
            width: 100%;
            margin: auto;
          }
          .inner {
            @include breakpoint-msp {
              padding: 20px;
            }
          }
        }
        &.left {
          @include breakpoint-pro_s {
            order: 2;
          }
        }
        &.right {
          @include breakpoint-pro_s {
            order: 3;
          }
        }
      }
    }
  }
}

/*--- カテゴリ --- */
.component {
  &.category {
    &.category_custom {
      margin-bottom: 20px !important;
      a {
        color: var(--fo-text-main-color);
        &:hover {
          opacity: $hover_opacity;
        }
      }
    }
  }
}

/*--- ランキング ---*/
.component {
  &.blog-ranking {
    &.ranking_custom {
      @include breakpoint-sp {
        width: 100%;
        margin: auto;
      }
      .entry-list-unit {
        border-color: $blog_border_color;
        @include breakpoint-sp {
          padding: 20px 0 10px;
        }
        .img {
          padding: 0 !important;
          @include breakpoint-sp {
            padding-right: 0 !important;
          }
          img {
            border-radius: 0;
          }
        }
        .cont {
          border-left: 0;
          @include breakpoint-sp {
            padding: 0 !important;
          }
          h3 {
            display: -webkit-box;
            -webkit-box-orient: vertical;
            -webkit-line-clamp: 2;
            overflow: hidden;
            text-overflow: ellipsis;
            color: var(--fo-text-main-color);
            margin: 0 0 10px;
            @include breakpoint-sp {
              margin-top: 1em;
              padding: 0;
            }
            a {
              padding: 0;
              margin: 0;
            }
          }
          p {
            display: -webkit-box;
            -webkit-box-orient: vertical;
            -webkit-line-clamp: 4;
            overflow: hidden;
            text-overflow: ellipsis;
            padding: 0;
          }
        }
        .article-rank {
          background: #fff;
          color: var(--fo-main-color);
          border: 1px solid var(--fo-main-color);
          z-index: 2;
          @include breakpoint-msp {
            min-width: 45px;
            height: 45px;
            font-size: 20px;
            line-height: 45px;
          }
          &:is(.rank-1,.rank-2,.rank-3) {
            background: var(--fo-main-color) !important;
            color: #fff;
            border: 1px solid var(--fo-main-color);
          }
        }
      }
    }
  }
}

/*--- カテゴリーアイコン ---*/
.fa-folder-open-o::before {
  font-family: $font_family_awsm;
}

/*------------- side bar(サイドバー)END -------------*/

/*----------------------------------
    foot(フッター)
----------------------------------*/
.theme-fo-base {
  .foot {
    &.ft_custom {
      background: $footer_bg_color;
      background-repeat: no-repeat;
      color: var(--fo-text-main-color);
      padding: 0;
      .foot-cont {
        padding: 60px 20px 70px;
        @include breakpoint-msp {
          padding: 40px 20px;
        }
        .row {
          //ロゴの部分
          &.ft_logo_row {
            & + .ft_site_map_row {
              @include breakpoint-pc {
                margin-top: 30px;
              }
              @include breakpoint-msp {
                margin-top: 20px;
              }
            }
          }
          &.ft_site_map_row {
            @include breakpoint-tb {
              display: flex;
              gap: 10px;
            }
            & + .ft_bottom_row {
              margin-top: 35px;
              @include breakpoint-ssp {
                margin-top: 15px;
              }
            }
            //各colの幅やスタイル部分
            .col {
              vertical-align: top;
              //リンクリストの部分
              &.site_map_col {
                & + .site_map_col {
                  @include breakpoint-ssp {
                    padding-top: 10px;
                  }
                }
              }
            }
          }
          //ボタン固定
          &.page_top_row {
            @include page_top;
          }
          .col {
            @include breakpoint-sp {
              margin: 0;
              padding: 0;
            }
            .component {
              //イメージ
              &.image {
                &.ft_logo_img {
                  img {
                    max-width: 244px !important;
                    width: 100% !important;
                  }
                }
              }
              //リスト
              &.list {
                &.site_map_list {
                  margin: 0;
                  ul {
                    font-size: inherit;
                    li {
                      list-style-type: none;
                      font-size: inherit;
                      color: inherit;
                      &:not(:first-child) {
                        margin: 8px 0 0;
                      }
                      a {
                        display: inline-block;
                        color: inherit;
                        padding: 0;
                        &:hover {
                          background: transparent;
                          opacity: $hover_opacity;
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
      //コピーライト部分
      .foot-copyright {
        @include copyright_custom;
      }
    }
  }
}

/*------------- foot(フッター END)-------------*/

/*----------------------------------
    LP(フルカスタム用)
----------------------------------*/
/*
LP variables(変数)
LP button(ボタン)
LP header (見出し)
LP richtext(テキスト)
LP form(フォーム)
LP メインビジュアル
LP contents(コンテンツ)
LP body(本体)
*/

/* --------------------------------
    LP variables(変数)
----------------------------------- */

//フォント
$lp_font_family: "Noto Sans JP";

//hover時の不透明度
$lp_hover_opacity: .4;

//カラー
$lp_main_color: black; //メインカラー
$lp_sub_color: #eee; //サブカラー
$lp_accent_color: #df8c3b; //アクセントカラー
$lp_text_color: #333; //テキストカラー
$lp_a_text_color: #003b82; //テキストリンクのカラ
$lp_form_hissu_color: #c70909;//赤 フォームの「必須マーク」カラー

//ヘッダー
$lp_header_logo: 200px; //PCでの幅サイズ(固定)
$lp_header_sp_logo: 30px; //SPでの高さサイズ(maxサイズ)
$lp_header_height: 80px; //PC時のヘッダーの高さ(固定時に使用)
$lp_header_sp_height: 52px; //SP時のヘッダーの高さ(固定時に使用)

//セクション余白
$lp_section_padding: 120px; //PC時のパディング
$lp_section_sp_padding: 60; //SP時のパディング

//テキスト
$lp_text_pc_fontsize: 16px; //ベースとなるフォントサイズ(PC)
$lp_text_sp_fontsize: 16px; //ベースとなるフォントサイズ(SP)
$lp_text_line_height: 1.5; //ベースとなるline-height(行間)
$lp_text_letter_spacing: .04em;

//見出し
$lp_hd_line_height: 1.5; //見出し用line-height(行間)
$lp_hd_letter_spacing:.04em;
$lp_hd_font_weight: bold; //見出し用
$lp_hd_font_strong: normal; //見出し用(編集画面の「.strong」に対応)
$lp_title_font_family: $lp_font_family; //サイト内見出しのフォントファミリー
////pc
$lp_hd_pc_h1_fontsize: 46px; //サイト内(ブログコンテンツを除く)の見出しh1のフォントサイズ(PC)
$lp_hd_pc_h2_fontsize: 38px; //サイト内(ブログコンテンツを除く)の見出しh2のフォントサイズ(PC)
$lp_hd_pc_h3_fontsize: 30px; //サイト内(ブログコンテンツを除く)の見出しh3のフォントサイズ(PC)
$lp_hd_pc_h4_fontsize: 20px; //サイト内(ブログコンテンツを除く)の見出しh4のフォントサイズ(PC)
$lp_hd_pc_h5_fontsize: 18px; //サイト内(ブログコンテンツを除く)の見出しh5のフォントサイズ(PC)
////sp
$lp_hd_sp_h1_fontsize: 26px; //サイト内(ブログコンテンツを除く)の見出しh1のフォントサイズ(SP)
$lp_hd_sp_h2_fontsize: 24px; //サイト内(ブログコンテンツを除く)の見出しh2のフォントサイズ(SP)
$lp_hd_sp_h3_fontsize: 22px; //サイト内(ブログコンテンツを除く)の見出しh3のフォントサイズ(SP)
$lp_hd_sp_h4_fontsize: 18px; //サイト内(ブログコンテンツを除く)の見出しh4のフォントサイズ(SP)
$lp_hd_sp_h5_fontsize: 16px; //サイト内(ブログコンテンツを除く)の見出しh5のフォントサイズ(SP)

//ボックスシャドウ
$lp_box_shadow_common: 2px 2px 10px 0 rgba(#000,.08);
$lp_box_shadow_nav_common: 0 3px 6px  rgba(#000,.08);

//コピーライト
$lp_copyright_bg_color: #eae8e8; //コピーライトの背景色
$lp_copyright_text_color: $lp_text_color; //コピーライトのテキストカラー
$lp_copyright_text_fontsize: 12px; //コピーライトのフォントサイズ

//角丸
$lp_border_radius_common: 10px;
$lp_border_radius_btn_common: 50vh;

//その他
$lp_max_width: 1100px; //検索結果コンテンツ幅調整用
$lp_border_color: #eee;
$lp_inPageLink_pc: 80px; //ページ内リンクPC(PC時のヘッダーの高さを指定)
$lp_inPageLink_sp: 52px; //ページ内リンクSP(SP時のヘッダーの高さを指定)

/*----------------------------------
    LP button(ボタン)
----------------------------------*/
.component {
  &.button {
    &:is(
      .lp_btn_custom01,
      .lp_btn_custom02
      ) {
      .button-cont {
        a {
          box-sizing: border-box;
          letter-spacing: $lp_text_letter_spacing;
          line-height: 1.3;
          text-align: left;
          text-decoration: none;
          border-radius: 0;
          //サイズ小のとき
          &.size-s {
            //フォントサイズやボタンの大きさを設定
            min-width: 220px;
            font-size: 14px;
            padding: 9px 20px;
            @include breakpoint-pro {
              min-width: 200px;
            }
            @include breakpoint-sp {
              min-width: 80%;
              width: auto;
            }
            @include breakpoint-tb {
              min-width: 200px;
            }
          }
          //サイズ中のとき
          &.size-m {
            min-width: 280px;
            font-size: 16px;
            padding: 15.5px 20px;
            @include breakpoint-sp {
              width: auto;
              min-width: 90%;
              padding: 15px;
            }
            @include breakpoint-tb {
              min-width: 280px;
            }
          }
          //サイズ大のとき
          &.size-l {
            display: inline-block;
            min-width: 350px;
            font-size: 20px;
            margin: auto;
            padding: 20px;
            @include breakpoint-sp {
              width: 100%;
              min-width: auto;
            }
            @include breakpoint-tb {
              width: auto;
              min-width: 350px;
            }
          }
          &:hover {
            opacity: 1;
          }
        }
      }
    }
    //ボタン01
    &.lp_btn_custom01 {
      .button-cont {
        a {
          &:is(.size-s,.size-m,.size-l) {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            border-radius: $lp_border_radius_btn_common;
            border: 2px solid rgba(0,0,0,0);
            &::before {
              content: "\f15c";
              font-family: $font_family_awsm6;
              font-weight: 400;
              color: inherit;
              margin-right: 10px;
              position: relative;
              top: .5px;
            }
          }
          &:is(.blue,.red,.orange,.black,.white) {
            background: $lp_main_color;
            color: #fff;
            border-color: $lp_main_color;
          }
          &:hover {
            opacity: $lp_hover_opacity;
          }
        }
      }
    }
    //ボタン02
    &.lp_btn_custom02 {
      .button-cont {
        a {
          &:is(.size-s,.size-m,.size-l) {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            border-radius: $lp_border_radius_btn_common;
            border: 2px solid rgba(0,0,0,0);
            &::before {
              content: "\f0e0";
              font-family: $font_family_awsm6;
              font-weight: 400;
              color: inherit;
              margin-right: 10px;
              position: relative;
              top: .5px;
            }
          }
          &:is(.blue,.red,.orange,.black,.white) {
            background: $lp_sub_color;
            color: #000;
            border-color: $lp_sub_color;
          }
          &:hover {
            opacity: $lp_hover_opacity;
          }
        }
      }
    }
    //telボタン
    &.lp_btn_custom_tel {
      .button-cont {
        a {
          &:where(.size-s,.size-m,.size-l) {
            background-color: transparent;
            font-family: $lp_font_family;
            letter-spacing: $lp_text_letter_spacing;
            color: $lp_text_color;
            text-decoration: none;
            position: relative;
            border-radius: 0;
            margin: 0;
            padding: 0;
            //背景色とかborder色など外観を設定
            &::before {
              content: "\f095";
              font-family: $font_family_awsm6;
              font-size: 100%;
              font-weight: 900;
              position: relative;
              margin-right: .3rem;
            }
            &:visited {
              color: $lp_text_color;
              text-decoration: none;
            }
            &:hover {
              opacity: $lp_hover_opacity;
            }
            &.size-s {
              font-size: 18px;
            }
            &.size-m {
              font-size: 20px;
            }
            &.size-l {
              display: inline-block;
              font-size: 32px;
            }
          }
        }
      }
    }
  }
}

/*----------------------------------
    LP heading(見出し)
----------------------------------*/
@mixin lp-heading {
  .component {
    &.heading {
      &.lp_inPageLink {
        @include breakpoint-pc {
          margin-top: calc(-#{$lp_inPageLink_pc} - 10px);
          padding-top: calc(#{$lp_inPageLink_pc} + 10px);
        }
        @include breakpoint-sp {
          margin-top: calc(-#{$lp_inPageLink_sp} - 10px);
          padding-top: calc(#{$lp_inPageLink_sp} + 10px);
        }
      }
      &.lp_hd_custom01 {
        :is(h1,h2,h3,h4,h5) {
          font-family: $lp_font_family;
          font-weight: $lp_hd_font_weight;
          line-height: $lp_hd_line_height;
          letter-spacing: $lp_hd_letter_spacing;
          .strong {
            font-weight: $lp_hd_font_strong;
          }
          @include breakpoint-sp {
            overflow-wrap: break-word;
          }
        }
        h1 {
          font-size: $lp_hd_pc_h1_fontsize;
          @include breakpoint-sp {
            font-size: $lp_hd_sp_h1_fontsize;
          }
        }
        h2 {
          font-size: $lp_hd_pc_h2_fontsize;
          @include breakpoint-sp {
            font-size: $lp_hd_sp_h2_fontsize;
          }
        }
        h3 {
          font-size: $lp_hd_pc_h3_fontsize;
          @include breakpoint-sp {
            font-size: $lp_hd_sp_h3_fontsize;
          }
        }
        h4 {
          font-size: $lp_hd_pc_h4_fontsize;
          @include breakpoint-sp {
            font-size: $lp_hd_sp_h4_fontsize;
          }
        }
        h5 {
          font-size: $lp_hd_pc_h5_fontsize;
          @include breakpoint-sp {
            font-size: $lp_hd_sp_h5_fontsize;
          }
        }
      }
      /*--- カスタム見出し ---*/
      // カスタム見出し01
      &.lp_hd_custom01 {
        :is(h1,h2) {
          margin-bottom: 60px;
        }
        :is(h3,h4,h5) {
          margin-bottom: 30px;
        }
      }
    }
  }
}

/*----------------------------------
    LP richtext(テキスト)
----------------------------------*/
@mixin lp-richtext($lp-marginTop:10px) {
  .component {
    &.richtext {
      font-family: $lp_font_family;
      font-size: $lp_text_pc_fontsize;
      color: $lp_text_color;
      line-height: $lp_text_line_height;
      letter-spacing: $lp_text_letter_spacing;
      @include breakpoint-sp {
        font-size: $lp_text_sp_fontsize;
      }
      :link {
        text-decoration: none;
      }
      :visited {
        text-decoration: none;
      }
      a {
        color: $lp_a_text_color;
        &:hover {
          opacity: $lp_hover_opacity;
        }
      }
      p {
        font-size: inherit;
        line-height: inherit;
        margin: 0;
        & + :is(p,ul,ol,.normal-table,.table-with-row-header,.table-with-two-headers,.component.button) {
          margin-top: $lp-marginTop;
        }
      }
      //リスト
      li {
        font-size: inherit;
        a {
          font-size: inherit;
        }
      }
      //テーブル
      table {
        :is(thead,tbody,tr,th,td) {
          border-color: #eee;
          tr {
            :is(th,td) {
              background-clip: padding-box; //FF,edgeでボーダー消える現象回避;
              position: static; //FF,edgeでボーダー消える現象回避;
              p {
                font-size: inherit;
                & + :is(p,ul,ol,.component.button) {
                  margin-top: $lp-marginTop !important;
                }
              }
              :is(ul,ol) {
                margin-left: 25px;
                & + :is(p,ul,ol,.component.button) {
                  margin-top: $lp-marginTop !important;
                }
              }
              .component.button {
                & + :is(p,ul,ol,.component.button) {
                  margin-top: $lp-marginTop !important;
                }
              }
            }
          }
        }
      }
      :is(ul,ol) {
        margin: 0 0 0 25px;
        & + :is(p,ul,ol,.normal-table,.table-with-row-header,.table-with-two-headers,.component.button) {
          margin-top: $lp-marginTop;
        }
      }
      :is(table,.normal-table,.table-with-row-header,.table-with-two-headers) {
        & + :is(p,ul,ol,.normal-table,.table-with-row-header,.table-with-two-headers,.component.button) {
          margin-top: $lp-marginTop;
        }
      }
      .component.button {
        margin: 0;
        &.button {
          & + :is(p,ul,ol,.normal-table,.table-with-row-header,.table-with-two-headers,.component.button) {
            margin-top: $lp-marginTop;
          }
          .button-cont {
            a {
              &.blue {
                background: #254a73;
                color: #fff !important;
                text-decoration: none;
                &:hover {
                  opacity: .4;
                }
              }
            }
          }
        }
      }
    }
  }
}
/*----------------------------------
    LP form(フォーム)
----------------------------------*/
@mixin lp-form($font-weight:bold) {
  .component {
    &.form {
      //カスタムフォーム
      &.lp_form_custom {
        font-family: $lp_font_family;
        font-size: $lp_text_pc_fontsize;
        color: $lp_text_color;
        @include breakpoint-sp {
          font-size: $lp_text_sp_fontsize;
        }
        .form-title {
          font-size: inherit;
          color: inherit;
          &:empty {
            display: none;
          }
        }
        //エラー
        .show-notice {
          font-size: inherit;
          border-radius: 0;
          font-size: $lp_text_pc_fontsize;
          @include breakpoint-sp {
            font-size: $lp_text_sp_fontsize;
          }
          &:empty {
            display: none;
          }
          span {
            padding: 5px;
            & + span {
              padding: 0 5px 5px;
            }
          }
        }
        .form-label {
          &::after {
            line-height: 1.5;
            padding: 3px 7px !important;
          }
        }
        .contact_form {
          font-size: inherit;
          color: inherit;
          input {
            accent-color: $lp_main_color;
          }
          //inputフルカスタム(必要な時に使用)
          input[type="text"],
          input[type="email"],
          input[type="password"],
          input[type="date"],
          input[type="search"],
          input[type="url"],
          select,
          textarea {
            background: #fff;
            height: auto;
            font-family: inherit !important;
            font-size: inherit;
            line-height: $lp_text_line_height;
            letter-spacing: $lp_text_letter_spacing;
            color: inherit;
            border-radius: 0;
            border: solid 1px rgba(0,0,0,.20);
            padding: .6rem .75rem;
            &::placeholder {
              font-family: inherit;
              font-size: inherit;
              color: rgba(0,0,0,.30);
            }
            &:hover {}
            &:focus {
              background-color: #fff;
              color: #555;
              border-color: #5a5a5a;
            }
          }
          input[type="text"].form-error,
          input[type="email"].form-error,
          input[type="password"].form-error,
          input[type="date"].form-error,
          input[type="search"].form-error,
          input[type="url"].form-error,
          select.form-error,
          textarea.form-error {
            background: #fdf5f2;
            border: 1px solid $lp_form_hissu_color !important;
          }
          .group {
            font-size: inherit;
            color: inherit;
            margin: 20px 0;
            .form-cont {
              font-size: inherit;
              color: inherit;
            }
          }
          .form-label {
            font-size: inherit;
            @include breakpoint-sp {
              display: inline-block !important;
            }
          }
          .agree-label {
            line-height: 1.5;
          }
          .form-cont {
            font-size: inherit;
            p {
              font-size: inherit;
              margin-top: .25rem;
            }
            :is(.checkbox,.radio) {
              label {
                display: flex;
                align-items: center;
              }
            }
          }
          //規約テキスト
          .service_term {
            background: #fff;
            overflow: auto;
            font-size: inherit;
            padding: 20px;
          }
          //規約リンク
          .service_term_link {
            font-size: inherit;
            margin-top: 20px;
            margin-bottom: 5px;
            a {
              color: $lp_a_text_color;
              letter-spacing: 0;
              text-decoration: none;
              &:hover {
                opacity: .4;
              }
            }
            & + label.agreement {
              padding: 5px 0;
              .form-label {
                display: flex !important;
                align-items: center;
                padding: 0;
                &::after {
                  position: initial;
                  padding: 3px 7px !important;
                }
              }
            }
          }
        }
      }
      //送信ボタンスタイル
      &.lp_form_btn_custom01 {
        .form-submit {
          margin-top: 20px;
          .popup-link {
            min-width: 200px;
            background: $lp_main_color;
            font-family: $lp_font_family;
            font-size: 18px;
            font-weight: $font-weight;
            border: 1px solid $lp_main_color;
            border-radius: $lp_border_radius_btn_common;
            padding: 15px 60px;
            @include breakpoint-tb {
              min-width: 200px;
              width: auto;
            }
            @include breakpoint-sp {
              padding: 10px 60px;
            }
            &:hover {
              background: #fff;
              color: $lp_main_color;
            }
          }
        }
      }
      //フォームの必須
      .form-label.require {
        &:after {
          background: $lp_form_hissu_color;
          margin-left: 20px;
        }
      }
      input[type=checkbox],
      input[type=radio] {
        min-height: auto;
      }
      &.vertical {
        .form-label {
          &:after {
            position: relative;
            top: -2px;
          }
        }
      }
      &.horizontal {
        .form-label {
          &:after {
            @include breakpoint-pc {
              top: 6px;
            }
            @include breakpoint-sp {
              top: -3px;
            }
          }
        }
      }
    }
  }
}
/*----------------------------------
    LP メインビジュアル
----------------------------------*/
@mixin lp-mv {
  &.lp_mv_sec {
    padding: 0;
  }
}
/*----------------------------------
    LP contents(コンテンツ)
----------------------------------*/
@mixin lp-contents {
  font-family: $lp_font_family;
  color: $lp_text_color;
  line-height: $lp_text_line_height;
  letter-spacing: $lp_text_letter_spacing;
  //セクション余白調整
  @include breakpoint-pc {
    padding: calc(#{$lp_section_padding} - 30px) 0 calc(#{$lp_section_padding} - 40px);
  }
  @include breakpoint-sp {
    padding: $lp_section_sp_padding 0;
  }
  &.lp_cta_sec {
    .inner {
      .row {
        .col {
          .component {
            &.cta {
              margin: 0;
            }
          }
        }
      }
    }
  }
  .inner {
    .row {
      //よくあるご質問
      &.lp_faq_row {
        margin: 10px 0 20px;
        & + .lp_faq_row {
          margin-top: 40px;
        }
        .col {
          background: #fff;
          box-shadow: $lp_box_shadow_common;
          border-radius: $lp_border_radius_common;
          padding: 20px;
          .component {
            &.richtext {
              &:is(.faq_qu,.faq_an) {
                position: relative;
                border-bottom: 1px solid $lp_border_color;
                margin: 0;
                padding: 15px 15px 15px 50px;
                @include breakpoint-sp {
                  padding-left: 40px;
                }
                &::before {
                  content: "Q.";
                  display: inline-block;
                  font-size: 28px;
                  font-weight: bold;
                  color: $lp_accent_color;
                  position: absolute;
                  left: 5px;
                  top: 4px;
                  @include breakpoint-sp {
                    top: 2px;
                  }
                }
              }
              &.faq_an {
                border-bottom: 0;
                &::before {
                  content: "A.";
                  color: $lp_text_color;
                }
              }
            }
          }
        }
      }
      .col {
        .component {
          &.richtext {}
          &.image {}
          &.list {}
        }
      }
    }
  }
}

/*----------------------------------
    LP body(本体)
    基本触らないでください
----------------------------------*/
//ヘッダー固定時ズレを修正
html {
  &:has(.lp_sticky_sec) {
    @include breakpoint-pc {
      scroll-padding-top: calc(#{$lp_header_height} + 10px);
    }
    @include breakpoint-sp {
      scroll-padding-top: calc(#{$lp_header_height} + 10px);
    }
  }
}

@include theme-fo-base {
  //LPヘッダー
  &.lp_header_sec {
    font-family: $lp_font_family;
    color: $lp_text_color;
    line-height: $lp_text_line_height;
    letter-spacing: $lp_text_letter_spacing;
    padding: 0;
    @include lp-heading();
    @include lp-richtext();
    @include lp-form();
    .inner {
      padding: 10px 20px;
      @include breakpoint-sp {
        padding: 10px;
      }
      .row {
        &.header_row {
          display: flex;
          align-items: center;
          @include breakpoint-pc {
            min-height: 60px;
          }
          .col {
            padding: 0;
            &.logo_col {
              @include breakpoint-pc {
                max-width: 300px;
                min-width: 150px;
                width: auto !important;
              }
              .component {
                &.image {
                  margin: 0;
                  &.lp_logo_img {
                    img {
                      @include breakpoint-pc {
                        max-width: $lp_header_logo !important;
                        width: 100% !important;
                      }
                      @include breakpoint-sp {
                        max-height: $lp_header_sp_logo !important;
                      }
                    }
                  }
                }
              }
            }
            &.btn_col {
              display: flex !important;
              justify-content: flex-end;
              align-items: center;
              flex: 1;
              @include breakpoint-pc {
                width: auto !important;
              }
              .component {
                margin: 0;
                &:not(:first-child) {
                  @include breakpoint-pc {
                    margin-left: 15px;
                  }
                }
                &.button {
                  margin-top: 0;
                  .button-cont {
                    a {
                      @include breakpoint-sp {
                        background: none;
                        width: auto;
                        min-width: auto;
                        font-size: 0 !important;
                        letter-spacing: 0;
                        border-radius: 0;
                        border: 0;
                        margin: 0;
                        box-shadow: none;
                        padding: 5px 10px 5px 5px;
                      }
                      &::before {
                        @include breakpoint-sp {
                          font-size: 22px;
                          line-height: 1;
                          color: $lp_main_color;
                          margin: 0;
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
        &.nav_row {
          @include breakpoint-pc {
            margin: 20px 0 -10px;
          }
          .col {
            padding: 0;
            .component {
              &.list {
                margin: 0;
                ul {
                  @include breakpoint-pc {
                    display: table;
                    width: 100%;
                    table-layout: fixed;
                  }
                  li {
                    margin: 0;
                    padding: 0;
                    font-size: 14px;
                    @include breakpoint-pc {
                      display: table-cell;
                    }
                    @include breakpoint-sp {
                      width: 50%;
                    }
                    a {
                      display: block;
                      font-size: inherit;
                      color: inherit;
                      text-align: center;
                      padding: 20px 10px;
                      @include breakpoint-sp {
                        padding: 10px 5px;
                      }
                      &:hover {
                        background-color: $lp_main_color;
                        color: #fff;
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
    //LPコンテンツ記述
    & ~ section {
      @include lp-heading();
      @include lp-richtext();
      @include lp-form();
      @include lp-mv();
      @include lp-contents();
      //フッター
      &.lp_footer_sec {
        padding: 0;
        .inner {
          max-width: 100% !important;
          padding: 0;
          .row {
            padding: 0;
            &:not(.copyright_row) {
              max-width: $lp_max_width;
              margin: 0 auto;
              padding: 0 20px;
            }
            &.site_map_row {
              padding: 40px 20px;
              .col {
                vertical-align: middle;
              }
            }
            &.page_top_row {
              @include page_top;
            }
            &.copyright_row {
              .col {
                padding: 0;
                .component {
                  &.richtext {
                    &.foot-copyright {
                      @include copyright_custom;
                    }
                  }
                }
              }
            }
            .col {
              padding: 0;
              .component {
                &.image {
                  &.footLogo_img {
                    img {
                      max-width: 250px !important;
                      width: 100% !important;
                    }
                  }
                }
                &.list {
                  &.site_map_list {
                    ul {
                      display: flex;
                      gap: 10px 20px;
                      @include breakpoint-sp {
                        flex-direction: column;
                      }
                      li {
                        margin: 0;
                        padding: 0;
                        a {
                          color: inherit;
                          &:hover {
                            opacity: $lp_hover_opacity;
                          }
                        }
                      }
                    }
                    &.vertical {
                      ul {
                        flex-direction: column;
                        li {
                          a {
                            padding: 0;
                          }
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
  //LPセクション固定
  &.lp_sticky_sec {
    position: sticky;
    top: 0;
    z-index: 1000;
    box-shadow: $lp_box_shadow_nav_common;
  }
}
/*------------- LP(フルカスタム用) END-------------*/
/*----------------------------------
    JSパーツ記述場所
----------------------------------*/

/*------------- JSパーツ記述場所 END-------------*/

//col空処理
@include theme-fo-base {
  .inner {
    .row {
      .col {
        &:empty {
          background: none;
          border: 0;
          @include breakpoint-sp {
            display: none !important;
          }
        }
        &.styles_col-shadow__imO2S {
          &:empty {
            box-shadow: none;
          }
        }
      }
    }
  }
}

/*----------------------------------
    編集画面用CSS(編集画面のみに効くCSS)
----------------------------------*/
@include edit-page {
  //既存フォント以外のフォントファミリー設定(使用しない場合は削除してください)
  // --fo-heading-font-family: "Hiragino Kaku Gothic ProN", Meiryo, メイリオ, sans-serif;
  // --fo-text-font-family: "Hiragino Kaku Gothic ProN", Meiryo, メイリオ, sans-serif;
  //SP編集画面の幅制限
  @include breakpoint-sp {
    max-width: 769px;
    margin: auto;
  }
  .pcOnly {
    border: 1px solid blue;
    &::before {
      content: "PCのみ表示";
      background: blue;
      color: #fff;
      position: absolute;
      top: -24px;
      right: 0;
      padding: 0 5px;
    }
  }
  .spOnly {
    @include breakpoint-pc {
      display: block !important;
      border: 1px solid red;
      opacity: .5;
      z-index: 1;
    }
    &::before {
      @include breakpoint-pc {
        content: "SPのみ表示";
        position: absolute;
        background: red;
        color: #fff;
        top: -24px;
        right: 0;
        padding: 0 5px;
      }
    }
  }
  .displayNone {
    @include breakpoint-pc {
      display: block !important;
      opacity: .5;
    }
    &::before {
      @include breakpoint-pc {
        content: "classで非表示設定";
        background: black;
        color: #fff;
        position: absolute;
        top: -24px;
        right: 0;
        padding: 0 5px;
      }
    }
  }
  //新CMS編集画面の共通ナビ固定解除
  header#navigations {
    &[class*="one_row_fix-navi"],
    &[class*="two_row_fix-navi"] {
      position: relative !important;
      width: 100%;
      &::after {
        content: "ナビ固定中";
        background: #0987d4;
        box-sizing: border-box;
        width: 100%;
        font-size: 18px;
        line-height: 25px;
        color: #fff;
        text-align: center;
        position: absolute;
        bottom: -45px;
        padding: 10px;
        z-index: -1;
      }
    }
  }
  //hover時に下線を削除
  :is(.navi-001-01,.navi-002-01) {
    header {
      .inner {
        .main-menu {
          .level-01-trigger {
            &:hover {
              text-decoration: none;
            }
          }
          a {
            text-decoration: none;
          }
        }

      }
    }
  }
  //メインビジュアルパレット見えない対策
  .theme-fo-base {
    //新CMS編集画面のヘッダ固定解除
    &[style*="padding-top"] {
      padding-top: 45px !important;
    }
  }
  //オーバーレイが公開画面で二重にかかるバグ
  .theme-fo-base {
    .main-visual {
      .overlay {
        display: block !important;
      }
    }
  }
  //row余白調整
  :where(.theme-fo-base) {
    :where(
      .main-visual .main-visual-content,
      .wrapper .contents section .inner,
      .foot .foot-cont
    ) {
      :where(.row) {
        &:not(:first-child) {
          margin-top: 30px;
        }
      }
    }
  }
  //sticky解放用
  .theme-fo-base {
    &:has(:is(.lp_sticky_sec)) {
      .wrapper {
        .contents {
          section {
            overflow: visible;
          }
        }
      }
    }
  }
  //ページ内リンクずれ対策class
  .theme-fo-base {
    .wrapper {
      .contents {
        section {
          .component {
            &.heading {
              &.inPage_link {
                margin-top: 10px;
                padding-top: 0;
              }
            }
          }
        }
      }
    }
  }
  //コンテンツ
  .theme-fo-base {
    .wrapper {
      .contents {
        section {
          //編集画面内の仕様回避の為
          margin: 50px 0 !important;
          &.foPrp_footer_sec {
            margin-bottom: 100px !important;
            .inner {
              padding: 20px 0;
              .row {
                .col {
                  .component {
                    &.cta {
                      .cta-row {
                        &.page_top_row {
                          @include edit-page_top;
                          margin-bottom: 30px;
                        }
                      }
                    }
                  }
                }
              }
            }
          }
          .inner {
            .row {
              .col {
                .component {
                  &.richtext {
                    &.foot-copyright {
                      text-align: center;
                      @include copyright_custom;
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
  //sp時センター寄せ
  .component {
    &.button {
      &.sp_center {
        &::before {
          content: "SP時に中央よせ";
          background: #0987d4;
          color: #fff;
          position: absolute;
          bottom: -24px;
          left: 0;
          padding: 0 5px;
        }
      }
    }
  }
  //フッター
  .theme-fo-base {
    .foot {
      &.ft_custom {
        .foot-cont {
          .row {
            &.page_top_row {
              @include edit-page_top;
            }
          }
        }
      }
    }
  }
  //カスタムパーツの記述はここにお願いします
  .theme-fo-base {
    .wrapper {
      .contents {
        section {
          .inner {
            .row {
              .col {}
            }
          }
        }
      }
    }
  }
  //LPの記述はここにお願いします
  .theme-fo-base {
    .wrapper {
      .contents {
        section {
          &.lp_sticky_sec {
            position: relative;
            &::after {
              content: "固定中";
              color: #fff;
              font-size: 18px;
              position: absolute;
              bottom: -45px;
              line-height: 25px;
              width: 100%;
              box-sizing: border-box;
              background: #0987d4;
              text-align: center;
              padding: 10px;
            }
          }
          &.lp_footer_sec {
            .inner {
              .row {
                &.page_top_row {
                  .col {
                    .component {
                      &.image {
                        position: static !important;
                        margin: 10px 0 !important;
                        &::before {
                          content: "ページ右下に固定されます";
                          display: inline-block;
                          text-align: center;
                          background: #0987d4;
                          color: #fff;
                          position: absolute;
                          right: 0;
                          bottom: -24px;
                          left: 0;
                          z-index: 1;
                          padding: 0 5px;
                        }
                      }
                    }
                  }
                }
                &.copyright_row {
                  margin-top: 30px;
                }
              }
            }
          }
          .inner {
            .row {
              .col {
                .component {
                  &.heading {
                    &.lp_inPageLink {
                      margin-top: 10px;
                      padding-top: 0;
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
  //JSパーツの記述はここにお願いします
  .theme-fo-base {
    .wrapper {
      .contents {
        section {
          .inner {
            .row {
              .col {}
            }
          }
        }
      }
    }
  }
}

/*------------- 編集画面用CSS END -------------*/

pagetop