.elementor-29 .elementor-element.elementor-element-7344784{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-29 .elementor-element.elementor-element-0d3efb8{--display:flex;border-style:solid;--border-style:solid;border-width:0px 0px 0px 10px;--border-top-width:0px;--border-right-width:0px;--border-bottom-width:0px;--border-left-width:10px;border-color:#5799D9;--border-color:#5799D9;--padding-top:60px;--padding-bottom:60px;--padding-left:0px;--padding-right:0px;}.elementor-29 .elementor-element.elementor-element-fb5ff2c{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:40px;--padding-right:0px;}.elementor-29 .elementor-element.elementor-element-335f798 .elementor-heading-title{font-family:"Noto Sans JP", Sans-serif;font-size:36px;font-weight:500;letter-spacing:1px;color:var( --e-global-color-primary );}.elementor-29 .elementor-element.elementor-element-ddfb646.elementor-element{--align-self:flex-start;}.elementor-29 .elementor-element.elementor-element-ddfb646 .elementor-heading-title{font-family:"Outfit", Sans-serif;font-size:20px;font-weight:500;letter-spacing:2px;color:var( --e-global-color-accent );}.elementor-29 .elementor-element.elementor-element-efad9ce{--display:flex;--padding-top:10px;--padding-bottom:10px;--padding-left:0px;--padding-right:0px;}.elementor-29 .elementor-element.elementor-element-6f2af21{font-family:"Noto Sans JP", Sans-serif;color:var( --e-global-color-text );}.elementor-29 .elementor-element.elementor-element-6f2af21 a{color:var( --e-global-color-text );}.elementor-29 .elementor-element.elementor-element-6f2af21 a:hover{color:var( --e-global-color-accent );}.elementor-29 .elementor-element.elementor-element-e41f9ef{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:100px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-29 .elementor-element.elementor-element-781ec1b{text-align:center;}.elementor-29 .elementor-element.elementor-element-781ec1b .elementor-heading-title{font-size:20px;letter-spacing:1px;color:var( --e-global-color-secondary );}.elementor-29 .elementor-element.elementor-element-60f36d5{--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-29 .elementor-element.elementor-element-de0f011 .elementor-heading-title{font-family:"Helvetica", Sans-serif;font-size:32px;color:var( --e-global-color-text );}.elementor-29 .elementor-element.elementor-element-1311e43 .elementor-heading-title{font-family:"Helvetica", Sans-serif;font-size:46px;color:var( --e-global-color-text );}.elementor-29 .elementor-element.elementor-element-edf3476{text-align:center;}.elementor-29 .elementor-element.elementor-element-edf3476 .elementor-heading-title{font-size:16px;letter-spacing:1px;color:var( --e-global-color-secondary );}.elementor-29 .elementor-element.elementor-element-dbd4faa{--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;--margin-top:100px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:100px;--padding-bottom:100px;--padding-left:0px;--padding-right:0px;}.elementor-29 .elementor-element.elementor-element-dbd4faa:not(.elementor-motion-effects-element-type-background), .elementor-29 .elementor-element.elementor-element-dbd4faa > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F5F5F5;}.elementor-29 .elementor-element.elementor-element-1e5585c{--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;--justify-content:center;--align-items:center;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-29 .elementor-element.elementor-element-22da9ac{width:100%;max-width:100%;text-align:center;}.elementor-29 .elementor-element.elementor-element-22da9ac.elementor-element{--align-self:flex-start;}.elementor-29 .elementor-element.elementor-element-22da9ac .elementor-heading-title{font-family:"Outfit", Sans-serif;font-size:46px;font-weight:500;line-height:38px;letter-spacing:2px;color:#5799D9;}.elementor-29 .elementor-element.elementor-element-01725c1{text-align:center;}.elementor-29 .elementor-element.elementor-element-01725c1 .elementor-heading-title{font-size:20px;letter-spacing:1px;color:var( --e-global-color-secondary );}.elementor-29 .elementor-element.elementor-element-be89158{width:100%;max-width:100%;--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-29 .elementor-element.elementor-element-be89158 .elementor-field-group{padding-right:calc( 10px/2 );padding-left:calc( 10px/2 );margin-bottom:20px;}.elementor-29 .elementor-element.elementor-element-be89158 .elementor-form-fields-wrapper{margin-left:calc( -10px/2 );margin-right:calc( -10px/2 );margin-bottom:-20px;}.elementor-29 .elementor-element.elementor-element-be89158 .elementor-field-group.recaptcha_v3-bottomleft, .elementor-29 .elementor-element.elementor-element-be89158 .elementor-field-group.recaptcha_v3-bottomright{margin-bottom:0;}.elementor-29 .elementor-element.elementor-element-be89158 .elementor-field-group > label, .elementor-29 .elementor-element.elementor-element-be89158 .elementor-field-subgroup label{color:#333333;}.elementor-29 .elementor-element.elementor-element-be89158 .elementor-field-group > label{font-family:"Noto Sans JP", Sans-serif;}.elementor-29 .elementor-element.elementor-element-be89158 .elementor-field-type-html{padding-bottom:0px;}.elementor-29 .elementor-element.elementor-element-be89158 .elementor-field-group .elementor-field:not(.elementor-select-wrapper){background-color:#ffffff;}.elementor-29 .elementor-element.elementor-element-be89158 .elementor-field-group .elementor-select-wrapper select{background-color:#ffffff;}.elementor-29 .elementor-element.elementor-element-be89158 .e-form__buttons__wrapper__button-next{color:#ffffff;}.elementor-29 .elementor-element.elementor-element-be89158 .elementor-button[type="submit"]{color:#ffffff;}.elementor-29 .elementor-element.elementor-element-be89158 .elementor-button[type="submit"] svg *{fill:#ffffff;}.elementor-29 .elementor-element.elementor-element-be89158 .e-form__buttons__wrapper__button-previous{color:#ffffff;}.elementor-29 .elementor-element.elementor-element-be89158 .e-form__buttons__wrapper__button-next:hover{color:#ffffff;}.elementor-29 .elementor-element.elementor-element-be89158 .elementor-button[type="submit"]:hover{color:#ffffff;}.elementor-29 .elementor-element.elementor-element-be89158 .elementor-button[type="submit"]:hover svg *{fill:#ffffff;}.elementor-29 .elementor-element.elementor-element-be89158 .e-form__buttons__wrapper__button-previous:hover{color:#ffffff;}@media(min-width:768px){.elementor-29 .elementor-element.elementor-element-dbd4faa{--content-width:800px;}}@media(max-width:767px){.elementor-29 .elementor-element.elementor-element-0d3efb8{border-width:0px 0px 0px 4px;--border-top-width:0px;--border-right-width:0px;--border-bottom-width:0px;--border-left-width:4px;--padding-top:30px;--padding-bottom:30px;--padding-left:0px;--padding-right:0px;}.elementor-29 .elementor-element.elementor-element-335f798 .elementor-heading-title{font-size:22px;}.elementor-29 .elementor-element.elementor-element-ddfb646 .elementor-heading-title{font-size:16px;}.elementor-29 .elementor-element.elementor-element-efad9ce{--padding-top:0px;--padding-bottom:0px;--padding-left:20px;--padding-right:20px;}.elementor-29 .elementor-element.elementor-element-6f2af21{font-size:12px;}.elementor-29 .elementor-element.elementor-element-e41f9ef{--padding-top:20px;--padding-bottom:20px;--padding-left:20px;--padding-right:20px;}.elementor-29 .elementor-element.elementor-element-781ec1b .elementor-heading-title{font-size:16px;}.elementor-29 .elementor-element.elementor-element-de0f011 .elementor-heading-title{font-size:24px;}.elementor-29 .elementor-element.elementor-element-1311e43 .elementor-heading-title{font-size:34px;line-height:0.8em;}.elementor-29 .elementor-element.elementor-element-edf3476 .elementor-heading-title{font-size:14px;}.elementor-29 .elementor-element.elementor-element-dbd4faa{--margin-top:20px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:40px;--padding-bottom:40px;--padding-left:20px;--padding-right:020px;}.elementor-29 .elementor-element.elementor-element-1e5585c{--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-29 .elementor-element.elementor-element-22da9ac .elementor-heading-title{font-size:36px;line-height:0.8em;}.elementor-29 .elementor-element.elementor-element-01725c1 .elementor-heading-title{font-size:16px;}}/* Start custom CSS for form, class: .elementor-element-be89158 *//* フォーム全体：白背景＋影で浮かせる */
.elementor-29 .elementor-element.elementor-element-be89158 {
    background: #ffffff;              /* 白背景 */
    padding: 40px;
    border-radius: 0;                 /* 角をシャープに */
    box-shadow: 0 8px 20px rgba(0,0,0,0.08); /* 軽い影で立体感 */
    max-width: 600px;
    margin: 0 auto;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

/* ラベル */
.elementor-29 .elementor-element.elementor-element-be89158 label {
    font-weight: 600;
    font-size: 14px;
    color: #333333;
    margin-bottom: 6px;
    display: block;
}

/* 入力欄・テキストエリア */
.elementor-29 .elementor-element.elementor-element-be89158 input[type="text"],
.elementor-29 .elementor-element.elementor-element-be89158 input[type="email"],
.elementor-29 .elementor-element.elementor-element-be89158 input[type="tel"],
.elementor-29 .elementor-element.elementor-element-be89158 textarea {
    border: 1.5px solid #ccc;
    border-radius: 0; 
    padding: 12px 14px;
    font-size: 15px;
    transition: all 0.3s ease;
}

/* フォーカス時 */
.elementor-29 .elementor-element.elementor-element-be89158 input[type="text"]:focus,
.elementor-29 .elementor-element.elementor-element-be89158 input[type="email"]:focus,
.elementor-29 .elementor-element.elementor-element-be89158 input[type="tel"]:focus,
.elementor-29 .elementor-element.elementor-element-be89158 textarea:focus {
    border-color: #5799D9;
    box-shadow: 0 0 6px rgba(87,153,217,0.3);
    outline: none;
}

/* プレースホルダー */
.elementor-29 .elementor-element.elementor-element-be89158 input::placeholder,
.elementor-29 .elementor-element.elementor-element-be89158 textarea::placeholder {
    color: #888888;
}

/* 送信ボタン */
.elementor-29 .elementor-element.elementor-element-be89158 button {
    background-color: #5799D9;
    color: #ffffff;
    border: none;
    border-radius: 0;
    padding: 14px 32px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.3s ease, transform 0.2s ease;
}

/* ボタンホバー */
.elementor-29 .elementor-element.elementor-element-be89158 button:hover {
    background-color: #3173C4;         /* 濃い青で強調 */
    transform: translateY(-2px);       /* 軽く浮かせる */
}

/* 入力欄とボタンの間の余白 */
.elementor-29 .elementor-element.elementor-element-be89158 .elementor-field-group {
    margin-bottom: 18px;
}


/* ========== 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; }   
  /* 送信完了メッセージを目立たせる */
.elementor-message-success {
    background-color: #f8fafd !important; /* 薄い青背景 */
    border: 2px solid #4F5C7F !important; /* 塾のテーマカラー */
    border-radius: 12px !important;
    color: #1e2e3d !important;
    padding: 25px !important;
    margin-top: 20px !important;
    font-weight: bold !important;
    font-family: "Hiragino Kaku Gothic ProN", sans-serif !important;
    text-align: center !important;
    line-height: 1.8 !important;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05) !important;
}

/* スマホでは文字サイズを調整 */
@media (max-width: 768px) {
    .elementor-message-success {
        font-size: 14px !important;
        padding: 20px !important;
    }
}
/* チェックボックスとテキストを横並びに揃える */
.elementor-field-option label {
    display: inline-flex !important;
    align-items: center !important;
    margin-bottom: 0 !important;
    line-height: 1.5 !important;
}

/* チェックボックス本体の余白を調整 */
.elementor-field-option input[type="checkbox"] {
    margin-right: 8px !important;
    margin-top: 0 !important;
}/* End custom CSS */