/* pages/consultation.css
   POLICY:
   - NO text control (font-size/weight/line-height/color) -> core.css + HTML t-*/c-* only
   ※ただし現状ファイルに存在する consult-badge の見た目は「元のまま維持」する
*/


/* =========================================================
   Thanks panel (legacy name; visual aligns to card system)
   ========================================================= */
.panel--thanks{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  padding: 16px;
}

/* spacing only */
.panel--thanks h1{ margin: 0 0 10px; }
.panel--thanks p{  margin: 0 0 10px; }


/* =========================================================
   必須・任意バッジ（ラベル横）※現状維持
   ========================================================= */
.consult-badge{
  margin-left: .4em;
  font-size: 0.85em;
  font-weight: 500;
}
.consult-badge.req{
  color: var(--orange);
}
.consult-badge.opt{
  color: var(--muted);
}


/* =========================================================
   Consultation form: label left / control right
   Target structure (consultation_form.html):
     .form-box
       .form-row
         label
         input/select/textarea
         small.consult-help (optional)
         .consult-err (optional, repeated)
   ========================================================= */

.consult-wrap .form-box .form-row{
  display: grid;
  grid-template-columns: 170px 1fr; /* 左：ラベル / 右：入力 */
  column-gap: 14px;
  row-gap: 6px;
  align-items: center;
  margin: 14px 0;
}

/* ラベルは左カラム固定 */
.consult-wrap .form-box .form-row > label{
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
}

/* 入力は右カラム */
.consult-wrap .form-box .form-row > input,
.consult-wrap .form-box .form-row > select,
.consult-wrap .form-box .form-row > textarea{
  grid-column: 2;
  grid-row: 1;
  width: 100%;
}

/* help / error は入力の下（右カラム）に落とす */
.consult-wrap .form-box .form-row > .consult-help{
  grid-column: 2;
}
.consult-wrap .form-box .form-row > .consult-err{
  grid-column: 2;
}

/* textarea 行だけ上揃え（:has 対応ブラウザ向け） */
.consult-wrap .form-box .form-row:has(textarea){
  align-items: start;
}
.consult-wrap .form-box .form-row:has(textarea) > label{
  padding-top: 6px; /* 文字位置の見た目を合わせる（spacing only） */
}

/* エラー時の行（クラスはテンプレにある） */
.consult-wrap .form-box .form-row.has-error{
  /* 見た目は触らない。必要なら border 等は別途。 */
}


/* =========================================================
   Actions row (送信ボタン + メッセージ)
   consultation_form.html:
     <div class="consult-actions">
       <button ...>送信</button>
       <div class="consult-msg" ...></div>
     </div>
   ========================================================= */

.consult-wrap .consult-actions{
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 16px;
}

/* ボタンは右寄せ（メッセージは右側に残る） */
.consult-wrap .consult-actions #sendBtn,
.consult-wrap .consult-actions button[type="submit"],
.consult-wrap .consult-actions input[type="submit"]{
  margin-left: auto;
}

/* textarea と actions の間に余白（密着防止） */
.consult-wrap .form-box textarea{
  margin-bottom: 10px;
}


/* =========================================================
   Responsive: mobile stacks
   ========================================================= */
@media (max-width: 720px){
  .consult-wrap .form-box .form-row{
    grid-template-columns: 1fr;
    row-gap: 8px;
  }

  .consult-wrap .form-box .form-row > label,
  .consult-wrap .form-box .form-row > input,
  .consult-wrap .form-box .form-row > select,
  .consult-wrap .form-box .form-row > textarea,
  .consult-wrap .form-box .form-row > .consult-help,
  .consult-wrap .form-box .form-row > .consult-err{
    grid-column: 1;
  }

  .consult-wrap .consult-actions{
    flex-wrap: wrap;
  }

  .consult-wrap .consult-actions #sendBtn,
  .consult-wrap .consult-actions button[type="submit"],
  .consult-wrap .consult-actions input[type="submit"]{
    margin-left: 0;
  }
}
