/**
 * booking-form-v2.css
 * /booking-form/ ガイド型フォーム UI スタイル
 */

/* --- 人数入力：補足文 --- */
.irico-people-note {
  font-size: 0.8rem;
  color: #888;
  margin: 4px 0 0;
}

/* --- カウンター式 UI --- */
/* style.css の grid (3.2em 1fr) → カウンター幅に合わせて上書き */
.input-number.mtssb-people-item:has(.irico-counter) {
  grid-template-columns: auto 1fr !important;
}

/* カウンターを grid column 1 に配置（select と同じ位置） */
.input-number.mtssb-people-item > .irico-counter {
  grid-column: 1 !important;
  grid-row: 1 !important;
}

.irico-counter {
  display: inline-flex;
  align-items: center;
  gap: 0;
  border: 1px solid #ccc;
  border-radius: 6px;
  overflow: hidden;
}

.irico-counter-btn,
.irico-counter-value {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  font-size: 16px;
  text-align: center;
  border: none !important;
  background: transparent !important;
  padding: 0;
  margin: 0;
  font-family: inherit;
  line-height: 1;
  color: #333;
}

.irico-counter-btn {
  width: 36px;
  cursor: pointer;
  user-select: none;
}

.irico-counter-btn:active {
  background: rgba(0,0,0,0.06) !important;
}

/* input[type=number] — スピナー非表示・中央揃え */
.irico-counter-value {
  width: 3em;
  font-weight: normal;
  border: none;
  background: #fff !important;
  -moz-appearance: textfield;
  padding: 0;
}
.irico-counter-value::-webkit-outer-spin-button,
.irico-counter-value::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.irico-counter-value:focus {
  outline: none;
  background: rgba(0,0,0,0.04);
}

/* --- プランエリア --- */
.irico-plan-area {
  margin: 16px 0;
  padding: 0;
}

.irico-plan-label {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 8px;
  color: #333;
}

/* プランカード */
.irico-plan-card {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #fff;
  border: 2px solid #ddd;
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: border-color 0.2s;
}

.irico-plan-card:has(input:checked) {
  border-color: #f5a623;
  background: #fffbf0;
}

.irico-plan-card.is-recommended:has(input:checked) {
  border-color: #f5a623;
}

.irico-plan-card input[type="radio"] {
  margin: 0;
  flex-shrink: 0;
}

.irico-plan-card__body {
  flex: 1;
}

.irico-plan-card__name {
  font-weight: 600;
  font-size: 15px;
  color: #333;
}

.irico-plan-card__capacity {
  font-weight: 400;
  font-size: 13px;
  color: #888;
}

.irico-plan-card__price {
  font-size: 18px;
  font-weight: 700;
  color: #d85a30;
  margin-top: 2px;
}

/* ▶ ほかのプランも見る（クリック可能） */
.irico-plan-alt-toggle {
  cursor: pointer;
  color: #555;
  font-size: 0.9rem;
  padding: 6px 0;
  user-select: none;
}

.irico-plan-alt-toggle:hover {
  color: #333;
}

.irico-alt-arrow {
  font-size: 0.75rem;
  font-family: 'Arial', 'Helvetica', sans-serif;
}

/* 候補なし注記（クリック不可・淡色） */
.irico-plan-no-alt {
  color: #bbb;
  font-size: 0.9rem;
  padding: 6px 0;
}

/* 追加候補コンテナ */
.irico-plan-alternatives {
  margin-top: 4px;
}

/* 個別案内 */
.irico-plan-unavailable {
  background: #f8f0f0;
  border: 1px solid #e0c0c0;
  border-radius: 8px;
  padding: 16px;
  color: #333;
  line-height: 1.7;
}

.irico-plan-unavailable p {
  margin: 0 0 10px;
}

.irico-plan-unavailable p:last-child {
  margin-bottom: 0;
}

.irico-plan-unavailable a {
  color: #d85a30;
}

.irico-guidance-example {
  font-size: 0.9rem;
  color: #555;
  padding-left: 0.5em;
}

/* --- 食事セクション --- */
.irico-meal-area {
  margin: 16px 0;
  padding: 12px 0;
  border-top: 1px solid #eee;
}

.irico-meal-label {
  font-size: 15px;
  font-weight: 600;
  margin-bottom: 8px;
  color: #333;
}

.irico-meal-option {
  display: inline-block;
  margin-right: 16px;
  cursor: pointer;
}

.irico-meal-option input[type="radio"] {
  margin-right: 4px;
}

.irico-meal-hint {
  font-size: 0.85rem;
  color: #888;
  margin-top: 8px;
}

.irico-meal-counter {
  margin-top: 10px;
}

.irico-meal-counter label {
  display: block;
  font-size: 0.85rem;
  color: #666;
  margin-bottom: 4px;
}

/* --- 合計金額 --- */
.irico-price-area {
  margin: 16px 0;
  padding: 16px;
  background: #f9f9f7;
  border-radius: 8px;
  border: 1px solid #eee;
}

.irico-price-table {
  width: 100%;
  border-collapse: collapse;
}

.irico-price-table td {
  padding: 4px 0;
  font-size: 14px;
  border: none;
}

.irico-price-value {
  text-align: right;
  font-weight: 500;
}

.irico-price-total td {
  padding-top: 8px;
  border-top: 1px solid #ccc;
  font-size: 18px;
  font-weight: 700;
}

.irico-price-total .irico-price-value {
  color: #d85a30;
}

/* --- モバイル --- */
@media screen and (max-width: 640px) {
  .irico-plan-card {
    padding: 10px 12px;
  }

  .irico-plan-card__price {
    font-size: 16px;
  }

  /* 成人/未成年ラベル：年齢注記を改行して2段表示 */
  .input-number.mtssb-people-item .age-note {
    display: block;
    font-size: 0.85rem;
    color: #888;
    line-height: 1.3;
  }

  /* 補足文：th 領域（5.2em）まではみ出させて幅いっぱい使う */
  .irico-people-note {
    margin-left: -5.2em;
  }
}
