.elementor-59 .elementor-element.elementor-element-0ba84f0{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:20px 20px;--row-gap:20px;--column-gap:20px;border-style:solid;--border-style:solid;border-width:0px 0px 0px 40px;--border-top-width:0px;--border-right-width:0px;--border-bottom-width:0px;--border-left-width:40px;border-color:#349960;--border-color:#349960;--margin-top:80px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:20px;--padding-bottom:20px;--padding-left:40px;--padding-right:40px;}.elementor-59 .elementor-element.elementor-element-8f8039c{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-59 .elementor-element.elementor-element-366bf65{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 4px 0px;}.elementor-59 .elementor-element.elementor-element-4f95d0d{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}.elementor-59 .elementor-element.elementor-element-4f95d0d .elementor-heading-title{font-family:"Noto Serif JP", Sans-serif;font-size:28px;letter-spacing:2px;color:#333333;}.elementor-59 .elementor-element.elementor-element-3c06583{font-family:"Helvetica", Sans-serif;font-size:12px;color:#333333;}.elementor-59 .elementor-element.elementor-element-3c06583 a{color:#9FA78F;}.elementor-59 .elementor-element.elementor-element-3c06583 a:hover{color:#CECECE;}.elementor-59 .elementor-element.elementor-element-0280c84{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:40px 40px;--row-gap:40px;--column-gap:40px;border-style:solid;--border-style:solid;border-width:0px 0px 0px 40px;--border-top-width:0px;--border-right-width:0px;--border-bottom-width:0px;--border-left-width:40px;border-color:#349960;--border-color:#349960;--padding-top:40px;--padding-bottom:40px;--padding-left:40px;--padding-right:40px;}.elementor-59 .elementor-element.elementor-element-02b72bb{--display:flex;--flex-direction:column;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--align-items:center;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-59 .elementor-element.elementor-element-728f4ff{width:var( --container-widget-width, 732px );max-width:732px;--container-widget-width:732px;--container-widget-flex-grow:0;text-align:center;font-family:"Noto Serif JP", Sans-serif;line-height:30px;letter-spacing:1px;color:var( --e-global-color-primary );}.elementor-59 .elementor-element.elementor-element-39acb2f{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-59 .elementor-element.elementor-element-fbf32d8{text-align:center;}.elementor-59 .elementor-element.elementor-element-fbf32d8 .elementor-heading-title{font-family:"Noto Serif JP", Sans-serif;letter-spacing:2px;color:var( --e-global-color-secondary );}.elementor-59 .elementor-element.elementor-element-0316806{--display:flex;--flex-direction:row;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:center;--align-items:center;--gap:8px 8px;--row-gap:8px;--column-gap:8px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-59 .elementor-element.elementor-element-0316806.e-con{--align-self:center;}.elementor-59 .elementor-element.elementor-element-d4ffa7e .elementor-heading-title{font-family:"Times New Roman", Sans-serif;font-size:34px;color:#004707;}.elementor-59 .elementor-element.elementor-element-58594dc .elementor-heading-title{font-family:"Times New Roman", Sans-serif;font-size:48px;letter-spacing:1px;color:#004707;}.elementor-59 .elementor-element.elementor-element-9115486{text-align:center;}.elementor-59 .elementor-element.elementor-element-9115486 .elementor-heading-title{font-family:"Noto Serif JP", Sans-serif;font-size:14px;letter-spacing:1px;color:var( --e-global-color-text );}.elementor-59 .elementor-element.elementor-element-fe16eea{--display:flex;--flex-direction:column;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--align-items:center;--gap:40px 40px;--row-gap:40px;--column-gap:40px;border-style:solid;--border-style:solid;border-width:0px 0px 0px 40px;--border-top-width:0px;--border-right-width:0px;--border-bottom-width:0px;--border-left-width:40px;border-color:#349960;--border-color:#349960;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:40px;--padding-bottom:40px;--padding-left:40px;--padding-right:40px;}.elementor-59 .elementor-element.elementor-element-fe16eea:not(.elementor-motion-effects-element-type-background), .elementor-59 .elementor-element.elementor-element-fe16eea > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F1F1F1;}.elementor-59 .elementor-element.elementor-element-0f33702{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--justify-content:center;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-59 .elementor-element.elementor-element-9d849dc{width:100%;max-width:100%;text-align:center;}.elementor-59 .elementor-element.elementor-element-9d849dc .elementor-heading-title{font-family:"Noto Serif JP", Sans-serif;font-size:24px;font-weight:600;line-height:40px;letter-spacing:1px;color:#578665;}.elementor-59 .elementor-element.elementor-element-6d6f295{--divider-border-style:solid;--divider-color:#D5D5D5;--divider-border-width:1px;}.elementor-59 .elementor-element.elementor-element-6d6f295 .elementor-divider-separator{width:140px;margin:0 auto;margin-center:0;}.elementor-59 .elementor-element.elementor-element-6d6f295 .elementor-divider{text-align:center;padding-block-start:0px;padding-block-end:0px;}.elementor-59 .elementor-element.elementor-element-92f5a62{width:var( --container-widget-width, 600px );max-width:600px;--container-widget-width:600px;--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-59 .elementor-element.elementor-element-92f5a62 .elementor-field-group{padding-right:calc( 10px/2 );padding-left:calc( 10px/2 );margin-bottom:10px;}.elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-form-fields-wrapper{margin-left:calc( -10px/2 );margin-right:calc( -10px/2 );margin-bottom:-10px;}.elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-field-group.recaptcha_v3-bottomleft, .elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-field-group.recaptcha_v3-bottomright{margin-bottom:0;}body.rtl .elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-labels-inline .elementor-field-group > label{padding-left:0px;}body:not(.rtl) .elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-labels-inline .elementor-field-group > label{padding-right:0px;}body .elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-labels-above .elementor-field-group > label{padding-bottom:0px;}.elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-field-group > label, .elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-field-subgroup label{color:#333333;}.elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-field-group > label{font-family:"Noto Serif JP", Sans-serif;}.elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-field-type-html{padding-bottom:0px;font-family:"Noto Serif JP", Sans-serif;}.elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-field-group .elementor-field, .elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-field-subgroup label{font-family:"Noto Serif JP", Sans-serif;}.elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-field-group .elementor-field:not(.elementor-select-wrapper){background-color:#ffffff;}.elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-field-group .elementor-select-wrapper select{background-color:#ffffff;}.elementor-59 .elementor-element.elementor-element-92f5a62 .e-form__buttons__wrapper__button-next{background-color:#359F48;color:#ffffff;}.elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-button[type="submit"]{background-color:#359F48;color:#ffffff;}.elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-button[type="submit"] svg *{fill:#ffffff;}.elementor-59 .elementor-element.elementor-element-92f5a62 .e-form__buttons__wrapper__button-previous{color:#ffffff;}.elementor-59 .elementor-element.elementor-element-92f5a62 .e-form__buttons__wrapper__button-next:hover{background-color:#359B9F;color:#ffffff;}.elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-button[type="submit"]:hover{background-color:#359B9F;color:#ffffff;}.elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-button[type="submit"]:hover svg *{fill:#ffffff;}.elementor-59 .elementor-element.elementor-element-92f5a62 .e-form__buttons__wrapper__button-previous:hover{color:#ffffff;}.elementor-59 .elementor-element.elementor-element-92f5a62 .elementor-button{padding:20px 60px 20px 60px;}@media(min-width:768px){.elementor-59 .elementor-element.elementor-element-0280c84{--content-width:900px;}.elementor-59 .elementor-element.elementor-element-02b72bb{--width:100%;}.elementor-59 .elementor-element.elementor-element-fe16eea{--content-width:900px;}.elementor-59 .elementor-element.elementor-element-0f33702{--width:52%;}}@media(max-width:767px){.elementor-59 .elementor-element.elementor-element-0ba84f0{--gap:20px 20px;--row-gap:20px;--column-gap:20px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:20px;--padding-bottom:20px;--padding-left:20px;--padding-right:20px;}.elementor-59 .elementor-element.elementor-element-8f8039c{--gap:8px 8px;--row-gap:8px;--column-gap:8px;}.elementor-59 .elementor-element.elementor-element-366bf65{margin:-4px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-59 .elementor-element.elementor-element-4f95d0d .elementor-heading-title{font-size:20px;line-height:1.6em;}.elementor-59 .elementor-element.elementor-element-3c06583{font-size:10px;}.elementor-59 .elementor-element.elementor-element-728f4ff{text-align:start;font-size:14px;line-height:1.6em;}.elementor-59 .elementor-element.elementor-element-39acb2f{--align-items:center;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );}.elementor-59 .elementor-element.elementor-element-fbf32d8{width:var( --container-widget-width, 245px );max-width:245px;--container-widget-width:245px;--container-widget-flex-grow:0;}.elementor-59 .elementor-element.elementor-element-fbf32d8 .elementor-heading-title{line-height:1.4em;}.elementor-59 .elementor-element.elementor-element-d4ffa7e .elementor-heading-title{font-size:30px;}.elementor-59 .elementor-element.elementor-element-58594dc .elementor-heading-title{font-size:38px;}.elementor-59 .elementor-element.elementor-element-9115486 .elementor-heading-title{font-size:14px;}.elementor-59 .elementor-element.elementor-element-9d849dc{width:100%;max-width:100%;text-align:center;}.elementor-59 .elementor-element.elementor-element-9d849dc .elementor-heading-title{font-size:24px;line-height:1.4em;}}/* Start custom CSS for html, class: .elementor-element-366bf65 *//* ベースの長方形アイコン */
.grad-rect-icon{
  position: relative;
  width: 50px;
  height: 30px;
  border-radius: 2px;
  overflow: hidden;
  background: #0b6a40;      /* 外周の深いグリーンに変更 */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #f9fafb;
  font-size: 14px;
}

/* テキスト（任意） */
.grad-rect-icon__label{
  position: relative;
  z-index: 1;
}

/* 左上で光っている“円形グラデーション” */
.grad-rect-icon::before{
  content: "";
  position: absolute;
  left: -30%;
  top: -40%;
  width: 200%;
  height: 200%;
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 20% 20%,
      #b5f3c3 0%,          /* 明るいミント（中心光） */
      #1b8f62 25%,         /* メインのグリーン */
      #1485d1 55%,         /* ブルーのグロウ */
      #28c6d8 75%,         /* シアン／ターコイズのグロウ */
      #0b6a40 100%         /* 外周の深いグリーンで締める */
    );
  background-size: 200% 200%;
  filter: blur(4px);
  opacity: 0.9;
  animation: grad-rect-move 6s ease-in-out infinite alternate;
}

/* グラデーション部分だけがゆっくり動く */
@keyframes grad-rect-move{
  0%{
    background-position: 0% 0%;
    opacity: 0.9;
  }
  40%{
    background-position: 40% 20%;
    opacity: 1;
  }
  70%{
    background-position: 60% 40%;
    opacity: 0.95;
  }
  100%{
    background-position: 100% 60%;
    opacity: 0.9;
  }
}

/* タブレットあたりで少しだけ小さく */
@media (max-width: 1024px){
  .grad-rect-icon{
    width: 44px;
    height: 18px;
    font-size: 13px;
  }
}

/* スマホ：さらに少しだけ縮める */
@media (max-width: 640px){
  .grad-rect-icon{
    width: 30px;
    height: 14px;
    font-size: 12px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-2c90be4 */.progress-bar {
  width: 100%;
  height: 1px;               /* グレーのライン */
  background: #a8a8a8;
  position: relative;
}

.progress-bar .progress {
  width: 20%;                /* ← 進捗率を指定（例: 20%） */
  height: 4px;               /* 緑のバーは太く */
  background: #349960;
  position: absolute;
  top: -1.5px;               /* グレー線の中央にくるよう調整 */
  left: 0;
}/* End custom CSS */
/* Start custom CSS for form, class: .elementor-element-92f5a62 *//* ========== 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 */