.elementor-1228 .elementor-element.elementor-element-25aa729{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1228 .elementor-element.elementor-element-78692b1{--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:100px;--padding-left:0px;--padding-right:0px;}.elementor-1228 .elementor-element.elementor-element-78692b1.e-con{--align-self:center;}.elementor-1228 .elementor-element.elementor-element-e7f654b{width:var( --container-widget-width, 609px );max-width:609px;--container-widget-width:609px;--container-widget-flex-grow:0;text-align:center;font-size:16px;line-height:30px;letter-spacing:1px;color:#333333;}.elementor-1228 .elementor-element.elementor-element-9a717af{width:100%;max-width:100%;}.elementor-1228 .elementor-element.elementor-element-959d60e{--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:60px 60px;--row-gap:60px;--column-gap:60px;--padding-top:100px;--padding-bottom:100px;--padding-left:0px;--padding-right:0px;}.elementor-1228 .elementor-element.elementor-element-959d60e:not(.elementor-motion-effects-element-type-background), .elementor-1228 .elementor-element.elementor-element-959d60e > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F8F8F8;}.elementor-1228 .elementor-element.elementor-element-f769da2{--display:flex;--align-items:center;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1228 .elementor-element.elementor-element-6fb5f89{text-align:start;}.elementor-1228 .elementor-element.elementor-element-6fb5f89 .elementor-heading-title{font-family:"Noto Sans JP", Sans-serif;font-size:40px;text-transform:uppercase;line-height:36px;color:#4F5C7F;}.elementor-1228 .elementor-element.elementor-element-7de36b0 .elementor-heading-title{font-size:18px;letter-spacing:1px;color:var( --e-global-color-primary );}.elementor-1228 .elementor-element.elementor-element-fde0139{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-1228 .elementor-element.elementor-element-fde0139 .elementor-button-content-wrapper{flex-direction:row-reverse;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-field-group{padding-right:calc( 10px/2 );padding-left:calc( 10px/2 );margin-bottom:10px;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-form-fields-wrapper{margin-left:calc( -10px/2 );margin-right:calc( -10px/2 );margin-bottom:-10px;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-field-group.recaptcha_v3-bottomleft, .elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-field-group.recaptcha_v3-bottomright{margin-bottom:0;}body.rtl .elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-labels-inline .elementor-field-group > label{padding-left:0px;}body:not(.rtl) .elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-labels-inline .elementor-field-group > label{padding-right:0px;}body .elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-labels-above .elementor-field-group > label{padding-bottom:0px;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-field-group > label, .elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-field-subgroup label{color:#333333;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-field-group > label{font-family:"Noto Sans JP", Sans-serif;font-weight:500;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-field-type-html{padding-bottom:0px;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-field-group .elementor-field{color:#969696;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-field-group .elementor-field, .elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-field-subgroup label{font-family:"Noto Sans JP", Sans-serif;font-size:14px;font-weight:400;letter-spacing:1px;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-field-group .elementor-field:not(.elementor-select-wrapper){background-color:#ffffff;border-color:#D3D3D3;border-width:1px 1px 1px 1px;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-field-group .elementor-select-wrapper select{background-color:#ffffff;border-color:#D3D3D3;border-width:1px 1px 1px 1px;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-field-group .elementor-select-wrapper::before{color:#D3D3D3;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-button{font-family:"Noto Sans JP", Sans-serif;word-spacing:1px;border-radius:100px 100px 100px 100px;padding:30px 60px 30px 60px;}.elementor-1228 .elementor-element.elementor-element-fde0139 .e-form__buttons__wrapper__button-next{background-color:#4F5C7F;color:#ffffff;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-button[type="submit"]{background-color:#4F5C7F;color:#ffffff;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-button[type="submit"] svg *{fill:#ffffff;}.elementor-1228 .elementor-element.elementor-element-fde0139 .e-form__buttons__wrapper__button-previous{color:#ffffff;}.elementor-1228 .elementor-element.elementor-element-fde0139 .e-form__buttons__wrapper__button-next:hover{background-color:#A33434;color:#ffffff;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-button[type="submit"]:hover{background-color:#A33434;color:#ffffff;}.elementor-1228 .elementor-element.elementor-element-fde0139 .elementor-button[type="submit"]:hover svg *{fill:#ffffff;}.elementor-1228 .elementor-element.elementor-element-fde0139 .e-form__buttons__wrapper__button-previous:hover{color:#ffffff;}@media(max-width:767px){.elementor-1228 .elementor-element.elementor-element-78692b1{--gap:40px 40px;--row-gap:40px;--column-gap:40px;--padding-top:40px;--padding-bottom:40px;--padding-left:0px;--padding-right:0px;}.elementor-1228 .elementor-element.elementor-element-e7f654b{padding:0px 20px 0px 20px;text-align:start;font-size:14px;line-height:1.6em;}.elementor-1228 .elementor-element.elementor-element-959d60e{--gap:40px 40px;--row-gap:40px;--column-gap:40px;--padding-top:40px;--padding-bottom:40px;--padding-left:0px;--padding-right:0px;}.elementor-1228 .elementor-element.elementor-element-6fb5f89 .elementor-heading-title{font-size:24px;line-height:0.8em;}.elementor-1228 .elementor-element.elementor-element-7de36b0 .elementor-heading-title{font-size:20px;}.elementor-1228 .elementor-element.elementor-element-fde0139{padding:0px 20px 0px 20px;}}/* Start custom CSS for html, class: .elementor-element-9a717af *//* 全体のコンテナ */
.ay-contact-wrapper {
  display: flex;
  gap: 28px;
  max-width: 900px;
  margin: 0 auto;
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", sans-serif !important;
  box-sizing: border-box;
}

/* カード共通設定 */
.ay-contact-card {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  border-radius: 20px;
  text-decoration: none !important;
  text-align: center;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  min-height: 240px;
  box-sizing: border-box;
}

.ay-contact-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}

/* アイコン円形部分 */
.ay-icon-circle {
  width: 70px;
  height: 70px;
  border-radius: 50% !important;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}

.ay-icon-circle img {
  width: 35px !important;
  height: 35px !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block;
}

/* --- 電話カード --- */
.ay-tel-card {
  background: #ffffff !important;
  border: 1px solid #e0e6ed !important;
}

.ay-tel-card .ay-icon-circle {
  background: #4F5C7F !important; /* 塾のテーマカラー */
}

.ay-tel-link {
  display: block;
  font-family: "Helvetica Neue", Arial, sans-serif !important;
  font-size: 28px !important;
  font-weight: 800 !important;
  color: #1e2e3d !important;
  text-decoration: none !important;
  margin-bottom: 5px !important;
  line-height: 1.2 !important;
}

.ay-work-time {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #1e2e3d !important;
  margin: 0 0 12px 0 !important;
}

.ay-caution-text {
  font-size: 11px !important;
  line-height: 1.6 !important;
  color: #666 !important;
  max-width: 280px;
  margin: 0 auto !important;
  text-align: left; /* 注意書きは左寄せが見やすい */
}

/* --- LINEカード --- */
.ay-line-card {
  background: #2dae51 !important;
  border: none !important;
}

.ay-line-card .ay-icon-circle {
  background: #ffffff !important;
}

.ay-line-title {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif !important;
  font-size: 20px !important;
  font-weight: 800 !important;
  color: #ffffff !important;
  margin: 0 0 8px 0 !important;
  padding: 0 !important;
  letter-spacing: 0.05em !important;
  line-height: 1.4 !important;
}

.ay-line-sub {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #ffffff !important;
  margin: 0 !important;
  opacity: 0.9 !important;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
  .ay-contact-wrapper {
    flex-direction: column;
    padding: 0 20px;
    gap: 20px;
  }
  .ay-contact-card {
    padding: 30px 20px;
    min-height: auto;
  }
  .ay-tel-link { font-size: 24px !important; }
  .ay-line-title { font-size: 18px !important; }
}/* End custom CSS */
/* Start custom CSS for form, class: .elementor-element-fde0139 *//* ========== 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;
    }
}/* End custom CSS */