.elementor-39 .elementor-element.elementor-element-c78af00{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-39 .elementor-element.elementor-element-6d1cfbb{--display:flex;--align-items:center;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:40px;--padding-bottom:40px;--padding-left:0px;--padding-right:0px;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-39 .elementor-element.elementor-element-1021fdc{width:var( --container-widget-width, 735px );max-width:735px;--container-widget-width:735px;--container-widget-flex-grow:0;text-align:center;font-size:16px;line-height:30px;letter-spacing:1px;color:#333333;}.elementor-39 .elementor-element.elementor-element-3186f3f{--display:flex;--align-items:center;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--gap:60px 60px;--row-gap:60px;--column-gap:60px;--padding-top:100px;--padding-bottom:0100px;--padding-left:0px;--padding-right:0px;}.elementor-39 .elementor-element.elementor-element-3186f3f:not(.elementor-motion-effects-element-type-background), .elementor-39 .elementor-element.elementor-element-3186f3f > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F3F3F3;}.elementor-39 .elementor-element.elementor-element-3186f3f.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-39 .elementor-element.elementor-element-6a00967{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );color:var( --e-global-color-primary );}.elementor-39 .elementor-element.elementor-element-79a750d{width:100%;max-width:100%;text-align:center;}.elementor-39 .elementor-element.elementor-element-79a750d.elementor-element{--align-self:center;}.elementor-39 .elementor-element.elementor-element-79a750d .elementor-heading-title{font-family:"Afacad", Sans-serif;font-size:60px;font-weight:400;text-transform:uppercase;line-height:40px;color:#6065AF;}.elementor-39 .elementor-element.elementor-element-8b5053a{text-align:center;}.elementor-39 .elementor-element.elementor-element-8b5053a .elementor-heading-title{font-family:"Noto Sans JP", Sans-serif;font-weight:500;color:#333333;}.elementor-widget-form .elementor-field-group > label, .elementor-widget-form .elementor-field-subgroup label{color:var( --e-global-color-text );}.elementor-widget-form .elementor-field-group > label{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .elementor-field-type-html{color:var( --e-global-color-text );font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .elementor-field-group .elementor-field{color:var( --e-global-color-text );}.elementor-widget-form .elementor-field-group .elementor-field, .elementor-widget-form .elementor-field-subgroup label{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .elementor-button{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-widget-form .e-form__buttons__wrapper__button-next{background-color:var( --e-global-color-accent );}.elementor-widget-form .elementor-button[type="submit"]{background-color:var( --e-global-color-accent );}.elementor-widget-form .e-form__buttons__wrapper__button-previous{background-color:var( --e-global-color-accent );}.elementor-widget-form .elementor-message{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .e-form__indicators__indicator, .elementor-widget-form .e-form__indicators__indicator__label{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-widget-form{--e-form-steps-indicator-inactive-primary-color:var( --e-global-color-text );--e-form-steps-indicator-active-primary-color:var( --e-global-color-accent );--e-form-steps-indicator-completed-primary-color:var( --e-global-color-accent );--e-form-steps-indicator-progress-color:var( --e-global-color-accent );--e-form-steps-indicator-progress-background-color:var( --e-global-color-text );--e-form-steps-indicator-progress-meter-color:var( --e-global-color-text );}.elementor-widget-form .e-form__indicators__indicator__progress__meter{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-39 .elementor-element.elementor-element-54895ec{width:var( --container-widget-width, 800px );max-width:800px;--container-widget-width:800px;--container-widget-flex-grow:0;--e-form-steps-indicators-spacing:20px;--e-form-steps-indicator-padding:30px;--e-form-steps-indicator-inactive-secondary-color:#ffffff;--e-form-steps-indicator-active-secondary-color:#ffffff;--e-form-steps-indicator-completed-secondary-color:#ffffff;--e-form-steps-divider-width:1px;--e-form-steps-divider-gap:10px;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-button-content-wrapper{flex-direction:row-reverse;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-field-group{padding-right:calc( 10px/2 );padding-left:calc( 10px/2 );margin-bottom:10px;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-form-fields-wrapper{margin-left:calc( -10px/2 );margin-right:calc( -10px/2 );margin-bottom:-10px;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-field-group.recaptcha_v3-bottomleft, .elementor-39 .elementor-element.elementor-element-54895ec .elementor-field-group.recaptcha_v3-bottomright{margin-bottom:0;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-field-group > label, .elementor-39 .elementor-element.elementor-element-54895ec .elementor-field-subgroup label{color:#333333;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-field-group > label{font-family:"Noto Sans JP", Sans-serif;font-weight:500;word-spacing:1px;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-field-type-html{padding-bottom:0px;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-field-group .elementor-field, .elementor-39 .elementor-element.elementor-element-54895ec .elementor-field-subgroup label{font-family:"Noto Sans JP", Sans-serif;letter-spacing:1px;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-field-group .elementor-field:not(.elementor-select-wrapper){background-color:#ffffff;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-field-group .elementor-select-wrapper select{background-color:#ffffff;}.elementor-39 .elementor-element.elementor-element-54895ec .e-form__buttons__wrapper__button-next{background-color:#5B487E;color:#ffffff;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-button[type="submit"]{background-color:#5B487E;color:#ffffff;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-button[type="submit"] svg *{fill:#ffffff;}.elementor-39 .elementor-element.elementor-element-54895ec .e-form__buttons__wrapper__button-previous{color:#ffffff;}.elementor-39 .elementor-element.elementor-element-54895ec .e-form__buttons__wrapper__button-next:hover{background-color:#A3598D;color:#ffffff;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-button[type="submit"]:hover{background-color:#A3598D;color:#ffffff;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-button[type="submit"]:hover svg *{fill:#ffffff;}.elementor-39 .elementor-element.elementor-element-54895ec .e-form__buttons__wrapper__button-previous:hover{color:#ffffff;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-button{border-radius:100px 100px 100px 100px;padding:20px 40px 20px 40px;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-message{font-family:"Noto Sans JP", Sans-serif;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-message.elementor-message-success{color:#333333;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-message.elementor-message-danger{color:#C22929;}@media(min-width:768px){.elementor-39 .elementor-element.elementor-element-3186f3f{--width:115.202%;}}@media(max-width:767px){.elementor-39 .elementor-element.elementor-element-6d1cfbb{--padding-top:20px;--padding-bottom:20px;--padding-left:20px;--padding-right:20px;}.elementor-39 .elementor-element.elementor-element-1021fdc{font-size:14px;line-height:1.6em;}.elementor-39 .elementor-element.elementor-element-3186f3f{--gap:40px 40px;--row-gap:40px;--column-gap:40px;--margin-top:40px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:40px;--padding-bottom:40px;--padding-left:20px;--padding-right:20px;}.elementor-39 .elementor-element.elementor-element-79a750d .elementor-heading-title{font-size:36px;line-height:0.8em;letter-spacing:1px;}.elementor-39 .elementor-element.elementor-element-8b5053a .elementor-heading-title{font-size:16px;}.elementor-39 .elementor-element.elementor-element-54895ec .elementor-message{letter-spacing:1px;}}/* Start custom CSS for form, class: .elementor-element-54895ec *//* ========== Elementor Form: 左ラベル／右入力（2カラム） ========== */
.form--side-label .elementor-form-fields-wrapper{
  display: grid;
  gap: 18px; /* 行間 */
}

/* 各フィールドを2カラムに */
.form--side-label .elementor-field-group{
  display: grid;
  grid-template-columns: 220px minmax(0,1fr); /* 左:ラベル幅／右:入力 */
  align-items: center;
  gap: 14px;
}

/* ラベル体裁 */
.form--side-label .elementor-field-label{
  margin: 0;
  color: #fff;              /* ダーク背景想定：必要に応じて調整 */
  font-weight: 600;
  letter-spacing: .02em;
}

/* テキストエリアなどは上揃えに */
.form--side-label .elementor-field-group.elementor-field-type-textarea{
  align-items: start;
}

/* 送信ボタン行：右列に合わせる（左ラベル余白を空ける） */
.form--side-label .elementor-field-group.elementor-field-type-submit,
.form--side-label .e-form__buttons{
  grid-column: 2;
  justify-content: flex-start;
}

/* チェックボックス／ラジオの並び微調整 */
.form--side-label .elementor-field-type-checkbox .elementor-field-subgroup,
.form--side-label .elementor-field-type-acceptance .elementor-field-subgroup,
.form--side-label .elementor-field-type-radio .elementor-field-subgroup{
  display: grid;
  gap: 8px;
}

/* ========== 必須マーク：* を「必須」バッジに ========== */
/* Elementorの必須マークは .elementor-mark-required（環境で名称が異なる場合あり） */
.form--side-label .elementor-field-label .elementor-mark-required{
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px 3px;
  border-radius: 6px;
  font-size: 12px;
  line-height: 1;
  font-weight: 700;
  background: #E94E77;   /* バッジ背景色（お好みで） */
  color: #fff;
  vertical-align: middle;
  /* 既存の「*」を消して擬似要素で文言を出す */
  font-family: inherit;
  position: relative;
  overflow: hidden;
}
.form--side-label .elementor-field-label .elementor-mark-required::before{
  content: "必須";
}
.form--side-label .elementor-field-label .elementor-mark-required{
  /* 一部環境で * が残る場合の保険（0にして擬似要素で表示） */
  font-size: 0;
}

/* ========== レスポンシブ（タブレット／スマホ） ========== */
@media (max-width: 1024px){
  .form--side-label .elementor-field-group{
    grid-template-columns: 180px minmax(0,1fr);
  }
}

@media (max-width: 640px){
  .form--side-label .elementor-field-group{
    grid-template-columns: 1fr;
    align-items: stretch;
  }
  /* スマホではラベルの上→入力の縦積み */
  .form--side-label .elementor-field-label{ margin-bottom: 6px; }
  /* 送信ボタンは全幅のまま中央 or 左寄せ（好みで） */
  .form--side-label .elementor-field-group.elementor-field-type-submit,
  .form--side-label .e-form__buttons{
    grid-column: 1;
    justify-content: center; /* 左寄せにしたい場合は flex-start */
  }
}
/* ▼フォーム全体にこのクラスを付与： form--side-label */
/* フィールドを必ず1列（フル幅）にする：Elementorの列設定を無効化 */
.form--side-label .elementor-form-fields-wrapper{
  /* Elementorが使う列数のCSS変数を強制リセット（対応ver用） */
  --e-form-columns: 1 !important;
  --grid-columns: 1 !important;
}

/* グリッド系テンプレでも必ず1行に展開 */
.form--side-label .elementor-form-fields-wrapper{
  display: grid;               /* 左ラベル／右入力のための土台 */
  gap: 18px;
}

/* 各フィールドを1行扱いに固定（横2分割を禁止） */
.form--side-label .elementor-field-group{
  /* ここで左:ラベル幅 右:入力 の2カラムに分ける */
  display: grid !important;
  grid-template-columns: 220px minmax(0,1fr) !important;
  align-items: center;
  gap: 14px;
  /* Elementorの2カラム指定を打ち消す保険 */
  width: 100% !important;
  max-width: 100% !important;
  grid-column: 1 / -1 !important;   /* span指定を無効化 */
  flex: 0 0 100% !important;
}

/* ラベル体裁 */
.form--side-label .elementor-field-label{
  margin: 0;
  font-weight: 600;
}

/* テキストエリアは上揃え */
.form--side-label .elementor-field-group.elementor-field-type-textarea{
  align-items: start;
}

/* 送信ボタン行は右列に合わせる（左のラベル幅を空けない） */
.form--side-label .elementor-field-group.elementor-field-type-submit,
.form--side-label .e-form__buttons{
  grid-column: 2 !important;
  justify-content: flex-start;
}

/* スマホは縦積み（ラベル→入力） */
@media (max-width: 640px){
  .form--side-label .elementor-field-group{
    grid-template-columns: 1fr !important;
    align-items: stretch;
  }
  .form--side-label .elementor-field-label{ margin-bottom: 6px; }
  .form--side-label .elementor-field-group.elementor-field-type-submit,
  .form--side-label .e-form__buttons{
    grid-column: 1 !important;
    justify-content: center;
  }
}
/* ▼フォーム全体に付けたクラス（例） */
.form--side-label {

  /* 送信ボタン行を “右列（2列目）に揃えて” 自在に整列 */
  /* ElementorのDOM差異に対応して両方指定 */
  /* 1) 送信ボタンが .elementor-field-group に入っている場合 */
  /* 2) 送信ボタンが .e-form__buttons だけで出ている場合 */
}
.form--side-label .elementor-field-group.elementor-field-type-submit,
.form--side-label .e-form__buttons{
  grid-column: 2 / 3 !important;   /* 入力欄の列に置く */
  justify-content: flex-start;     /* 左寄せ */
  align-items: flex-start;         /* 上揃え（テキストエリア横にならない） */
  margin-top: 10px;                /* ひと呼吸あける（任意） */
}

/* 念のため、送信ボタンの自己整列も左に固定 */
.form--side-label .elementor-field-group.elementor-field-type-submit{
  justify-self: start;             /* グリッド内で左端に */
  align-self: start;               /* 行の上に */
  display: block;                  /* 余計な2カラム化を防止 */
}

/* Elementorのボタンラッパーが横幅を縮めないように */
.form--side-label .e-form__buttons,
.form--side-label .elementor-field-group.elementor-field-type-submit .elementor-button-wrapper{
  width: auto;
}

/* 余計な margin-left が入っていた場合のリセット */
.form--side-label .elementor-button{
  margin-left: 0 !important;
}

/* スマホでは1列にして中央寄せ（お好みで left に） */
@media (max-width: 640px){
  .form--side-label .elementor-field-group.elementor-field-type-submit,
  .form--side-label .e-form__buttons{
    grid-column: 1 / -1 !important;
    justify-content: center;       /* ←左寄せが良ければ flex-start に変更 */
    margin-top: 12px;
  }
}
/* ========= 送信ボタンの位置だけを安定させる最小パッチ ========= */
/* ラベル幅を変えるときはここを変更（PC/タブレット） */
.form--side-label{ --label-w:220px; --label-w-md:180px; }

/* 入力欄は既存の「左ラベル／右入力」のまま */

/* 送信ボタン行を“右列の頭”に合わせる：左インデントで吸収 */
.form--side-label .e-form__buttons,
.form--side-label .elementor-field-group.elementor-field-type-submit{
  display:flex !important;
  justify-content:flex-start !important;
  align-items:flex-start !important;

  /* ラベルと同じ幅だけ押し下げる（横にズラす）*/
  padding-left: var(--label-w);

  /* 余計な指定をリセット */
  margin-left: 0 !important;
  width: 100%;
  grid-column: 1 / -1 !important;  /* グリッド列指定は使わない */
}

/* タブレット：ラベル幅に合わせてインデント縮小 */
@media (max-width:1024px){
  .form--side-label{ --label-w: var(--label-w-md); }
}

/* スマホ：縦積みなのでインデントなし＋中央寄せ（左寄せにしたければ flex-start） */
@media (max-width:640px){
  .form--side-label{ --label-w: 0px; }
  .form--side-label .e-form__buttons,
  .form--side-label .elementor-field-group.elementor-field-type-submit{
    padding-left: 0;
    justify-content: center !important; /* ←左寄せなら flex-start */
  }
}
/* =======================
   送信ボタン：常に中央寄せ
   ======================= */
.form--side-label .e-form__buttons,
.form--side-label .elementor-field-group.elementor-field-type-submit{
  /* 2カラム位置指定は使わずフル幅の独立行にする */
  grid-column: 1 / -1 !important;
  padding-left: 0 !important;
  margin-left: 0 !important;

  display: flex !important;
  justify-content: center !important;  /* ←中央寄せ */
  align-items: center !important;
  width: 100%;
}

/* （任意）スマホで全幅ボタンにしたい場合は解除コメントをON
.form--side-label .e-form__buttons .elementor-button,
.form--side-label .elementor-field-group.elementor-field-type-submit .elementor-button{
  width: 100%;
  max-width: 420px;  // 好みで
}
*/

/* ==============================
   Required Mark を「必須」バッジに
   ============================== */
/* Elementorの環境によりクラスが異なることがあるので両対応 */
.form--side-label .elementor-field-label .elementor-mark-required,
.form--side-label .elementor-field-label .elementor-required{
  font-size: 0;                 /* 既存の * を消す */
  margin-left: 8px;
  position: relative;
  display: inline-flex;
  align-items: center;
}

/* バッジ（アイコン風） */
.form--side-label .elementor-field-label .elementor-mark-required::before,
.form--side-label .elementor-field-label .elementor-required::before{
  content: "必須";
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  background: #E94E77;          /* バッジ色：お好みで */
  border-radius: 999px;
  padding: 3px 8px;
  letter-spacing: .02em;
  display: inline-block;
  transform: translateY(-1px);  /* ベースライン微調整 */
}

/* （任意）薄い枠にしたい場合は以下をON
.form--side-label .elementor-field-label .elementor-mark-required::before,
.form--side-label .elementor-field-label .elementor-required::before{
  background: transparent;
  color: #E94E77;
  border: 1px solid #E94E77;
}
*/
/* 必須マークを「必須」バッジに置き換え（このフォームだけに適用） */
.form--side-label .elementor-mark-required .elementor-field-label::after{
  content: "必須";                 /* ← “*” を上書き */
  display: inline-block;
  margin-left: 8px;
  padding: 3px 8px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: .02em;

  color: #fff;
  background: #E94E77; }/* End custom CSS */