/* =============================================
   Application Form — 偏愛リノベーション
   元のフォーム構成をベースに配色のみ調整
   ============================================= */

.app-wrap {
  max-width: 840px;
  margin: 0 auto;
  padding: 48px 5vw 100px;
}

/* ── ステップバー */
.app-flow { margin: 0 0 40px; }
.app-flow__list {
  display: flex;
  list-style: none;
  padding: 0; margin: 0;
  border: 1px solid var(--line);
}
.app-flow__item {
  flex: 1;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .04em;
  color: var(--muted);
  padding: 13px 6px;
  border-right: 1px solid var(--line);
  line-height: 1.4;
}
.app-flow__item:last-child { border-right: none; }
.app-flow__item.item-current {
  background: var(--green);
  color: var(--white);
}

/* ── リード文 */
.app-lead { margin: 0 0 32px; }
.app-lead--center { text-align: center; }
.app-lead__main {
  font-size: clamp(15px, 2vw, 18px);
  font-weight: 800;
  line-height: 1.7;
  color: var(--ink);
  margin: 0 0 8px;
}
.app-lead__main .u-red { color: var(--red); }
.app-lead__small { font-size: 14px; color: var(--muted); margin: 0; }
.app-lead__small a { color: var(--green); text-decoration: underline; }
.app-lead__result {
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 900;
  color: var(--red);
  margin: 0 0 12px;
  letter-spacing: .02em;
}
.app-lead__alert {
  margin: 16px 0 0;
  padding: 14px 18px;
  background: var(--bg-2, #ede9e3);
  border-left: 3px solid var(--green);
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.8;
}

/* ── フォームブロック */
.app-block {
  background: transparent;
}
/* 入力ページのフォームをカード化（確認ページ・重要事項ページは除外） */
.app-block:not(.app-block--confirm):not(.app-block--plain) {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 8px 40px 30px;
  box-shadow: 0 2px 14px rgba(0, 0, 0, .05);
}
@media (max-width: 560px) {
  .app-block:not(.app-block--confirm):not(.app-block--plain) { padding: 4px 18px 22px; }
}
.app-block__title {
  font-size: 14px;
  font-weight: 800;
  letter-spacing: .08em;
  color: var(--green);
  padding: 14px 0;
  margin: 0 0 8px;
}

/* ── フォーム行 */
.app-row {
  display: flex;
  gap: 24px;
  padding: 24px 0;
}
.app-row__head {
  width: 280px;
  min-width: 280px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.app-row__body {
  flex: 1;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  justify-content: center;
}
.app-row__label {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.app-row__note { font-size: 14px; color: var(--muted); }

/* 必須バッジ */
.app-required {
  font-size: 14px; font-weight: 800;
  color: var(--white);
  background: var(--red);
  padding: 2px 7px;
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── inputs */
.app-input, .app-select, .app-textarea {
  width: 100%;
  padding: 9px 12px;
  border: 1px solid var(--line);
  background: var(--white);
  font-size: 14px;
  font-family: inherit;
  color: var(--ink);
  appearance: none;
  border-radius: 6px;
  box-sizing: border-box;
}
.app-input:focus, .app-select:focus, .app-textarea:focus {
  outline: none;
  border-color: var(--green);
}
.app-input--sm { max-width: 120px; }
.app-input--md { max-width: 220px; }
.app-input--lg { max-width: 320px; }
.app-select-wrap--md { max-width: 320px; }

/* 郵便番号 */
.app-postal-wrap {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.postal-symbol { font-size: 16px; color: var(--muted); }
.app-postal-link {
  font-size: 14px;
  color: var(--green);
  text-decoration: underline;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.app-postal-link::after {
  content: "";
  display: inline-block;
  width: 11px;
  height: 11px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230F2A23' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M14 5h5v5'/><path d='M19 5l-9 9'/><path d='M19 13v6H5V5h6'/></svg>");
  background-repeat: no-repeat;
  background-size: contain;
}

/* セレクト */
.app-select-wrap { position: relative; }
.app-select-wrap::after {
  content: '▾'; position: absolute; right: 10px; top: 50%;
  transform: translateY(-50%); pointer-events: none;
  color: var(--muted); font-size: 14px;
}
.app-selects { display: flex; flex-direction: column; gap: 8px; }

/* 予算・横並び入力 */
.app-inline {
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap; font-size: 14px; color: var(--ink);
}

/* ラジオ・チェックボックス */
.app-radio-list, .app-checkbox-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 6px 16px;
}
.app-radio-item, .app-checkbox-item {
  display: flex; align-items: center; gap: 6px;
}
.app-radio-item input[type="radio"],
.app-checkbox-item input[type="checkbox"],
.app-inline-check {
  width: 20px; height: 20px;
  accent-color: var(--green); cursor: pointer; flex-shrink: 0;
}
.app-radio-item label, .app-checkbox-item label {
  font-size: 14px; color: var(--ink); cursor: pointer;
}

/* デザイン参考画像 — 左カラム（ラベルの下）に表示。選択スタイルに応じてJSで差し替え */
.app-design-img {
  width: 100%;
  max-width: 240px;
  margin: 14px 0 0;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border: none;
  border-radius: 8px;
  display: block;
}

/* スタイル選択肢：ラジオは縦1列 */
.app-radio-list--stack {
  flex-direction: column;
  gap: 10px;
}
/* 偏愛スタイル：運用上ラインナップから除外する項目を非表示 */
.app-radio-list--stack .app-radio-item:has(input[value="ミニマリスト"]),
.app-radio-list--stack .app-radio-item:has(input[value="エディトリアル"]),
.app-radio-list--stack .app-radio-item:has(input[value="キャットラバー"]) {
  display: none;
}

/* テキストエリア */
.app-textarea { resize: vertical; min-height: 120px; }

/* 注意テキスト */
.app-caution { font-size: 14px; color: var(--muted); margin: 4px 0 0; line-height: 1.6; }

/* 免責リスト */
.app-disclaimer-box {
  border: 1px solid var(--line);
  background: var(--bg-2, #ede9e3);
  border-radius: 8px;
  padding: 20px 26px 16px;
  margin: 0 auto 8px;
  max-width: 760px;
  text-align: left;
}
.app-disclaimer-title {
  font-size: 15px;
  font-weight: 800;
  color: var(--green);
  text-align: center;
  letter-spacing: .1em;
  margin: 0 0 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
}
.app-disclaimer-intro {
  font-size: 14px; line-height: 1.95; color: var(--ink);
  margin: 0 0 12px;
}
.app-disclaimer-note {
  font-size: 13px; line-height: 1.9; color: var(--muted);
  margin: 16px 0 0; padding-top: 14px;
  border-top: 1px solid var(--line);
}
.app-disclaimer-intro a,
.app-disclaimer-note a { color: var(--green); text-decoration: underline; }
.app-disclaimer {
  list-style: none; padding: 0; margin: 0;
  counter-reset: disclaimer;
  text-align: left;
}
.app-disclaimer li {
  counter-increment: disclaimer;
  display: flex; gap: 10px;
  padding: 8px 0;
  font-size: 14px; line-height: 1.9; color: var(--ink);
}
.app-disclaimer li::before {
  content: counter(disclaimer) '.';
  font-weight: 800; color: var(--green);
  flex-shrink: 0; min-width: 18px;
}

/* プライバシーポリシー */
.app-pp-box {
  padding: 18px 0;
  display: flex; align-items: center; gap: 10px;
  width: fit-content;
  margin: 0 auto;
}
.app-pp-box input[type="checkbox"] {
  width: 20px; height: 20px;
  accent-color: var(--green); cursor: pointer; flex-shrink: 0;
}
.app-pp-box label { font-size: 14px; color: var(--ink); cursor: pointer; }
.app-pp-box label a { color: var(--green); text-decoration: underline; }

/* ── ボタンエリア */
.app-btn-area {
  padding: 28px 0 32px;
  display: flex; flex-direction: column; align-items: center; gap: 14px;
}
.app-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 100%; max-width: 360px;
  padding: 16px 24px;
  background: var(--green); color: var(--white);
  font-size: 14px; font-weight: 800; letter-spacing: .06em;
  border: none; cursor: pointer; font-family: inherit;
  transition: opacity .25s; text-decoration: none; text-align: center;
  box-sizing: border-box;
}
.app-btn:hover { opacity: .8; }
.app-btn:disabled { opacity: .35; cursor: not-allowed; }
.app-btn:disabled:hover { opacity: .35; }
.app-btn--outline {
  background: transparent; color: var(--ink);
  border: 1px solid var(--line); font-weight: 500; max-width: 200px;
}

/* ── 確認ページ */
.app-confirm-val {
  font-size: 14px; color: var(--ink); line-height: 1.7;
}
.app-confirm-val .sub { font-size: 14px; color: var(--muted); margin: 4px 0 0; }

.app-btn-area--inline {
  display: flex; justify-content: flex-end;
  padding: 10px 0;
}

/* ── 確認ページ専用（application4.php） */
.app-block--confirm {
  background: var(--white);
  border: 1px solid var(--line);
}
.app-block--confirm .app-block__title {
  background: var(--bg-2, #ede9e3);
  border-bottom: 1px solid var(--line);
  padding: 14px 20px;
  margin: 0;
}
.app-block--confirm .app-row {
  border-bottom: 1px solid var(--line);
  padding: 16px 20px;
}
.app-block--confirm .app-btn-area--inline {
  background: var(--bg-2, #ede9e3);
  border-bottom: 1px solid var(--line);
  padding: 10px 20px;
}
.app-block--confirm .app-btn-area {
  border-top: 1px solid var(--line);
  padding: 28px 20px 32px;
}

/* ── 完了ページ */
.app-thanks {
  text-align: center; padding: 60px 5vw;
}
.app-thanks__title {
  font-size: clamp(20px, 3vw, 28px); font-weight: 900;
  color: var(--ink); margin: 0 0 20px;
}
.app-thanks__text {
  font-size: 14px; line-height: 2.2; color: var(--muted); margin: 0 0 40px;
}
.app-thanks__back {
  display: inline-block; padding: 14px 40px;
  border: 1px solid var(--green); color: var(--green);
  font-size: 14px; font-weight: 700; letter-spacing: .08em;
  text-decoration: none; transition: all .25s;
}
.app-thanks__back:hover { background: var(--green); color: var(--white); }

/* ── コーディネーター紹介 */
.app-coordinator-list {
  display: flex;
  flex-direction: column;
  gap: 36px;
  padding: 28px 24px 36px;
}
.app-coordinator {
  display: flex;
  gap: 28px;
  align-items: flex-start;
}
.app-coordinator-img {
  width: 200px;
  flex-shrink: 0;
  display: block;
  object-fit: cover;
  aspect-ratio: 1 / 1;
  background: var(--bg-2, #ede9e3);
}
.app-coordinator-info { flex: 1; min-width: 0; }
.app-coordinator-name {
  font-size: 18px;
  font-weight: 800;
  color: var(--ink);
  margin: 0 0 10px;
  line-height: 1.4;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--line);
}
.app-coordinator-name span {
  font-size: 12px;
  font-weight: 500;
  color: var(--muted);
  margin-left: 10px;
  letter-spacing: .06em;
}
.app-coordinator-career {
  font-size: 13px;
  font-weight: 700;
  color: var(--green);
  margin: 0 0 12px;
  line-height: 1.7;
}
.app-coordinator-message {
  font-size: 14px;
  color: var(--ink);
  line-height: 1.9;
  margin: 0 0 12px;
}
.app-coordinator-profile {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.9;
  margin: 0 0 16px;
}
.app-coordinator-profile a {
  color: var(--green);
  text-decoration: underline;
}
.app-coordinator-review {
  background: var(--bg-2, #ede9e3);
  padding: 14px 18px;
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.app-coordinator-review-name {
  font-size: 12px;
  font-weight: 800;
  color: var(--white);
  background: var(--green);
  white-space: nowrap;
  padding: 4px 10px;
  letter-spacing: .04em;
  align-self: flex-start;
}
.app-coordinator-review-name--yano    { background: #5b7561; }
.app-coordinator-review-name--yatagai { background: #b96a3a; }
.app-coordinator-review-name--kawamura{ background: #8b6f47; }
.app-coordinator-review p {
  font-size: 13px;
  line-height: 1.8;
  color: var(--ink);
  margin: 0;
  flex: 1;
}

/* ── レスポンシブ */
@media (max-width: 560px) {
  .app-row { flex-direction: column; gap: 12px; padding: 18px 0; }
  .app-row__head {
    width: 100%; min-width: 0;
    padding: 0;
  }
  .app-row__body { padding: 0; }
  .app-flow__item { font-size: 14px; padding: 10px 4px; }
  .app-btn-area--inline { justify-content: center; }

  .app-coordinator-list { padding: 20px 16px 28px; gap: 28px; }
  .app-coordinator { flex-direction: column; gap: 14px; }
  .app-coordinator-img { width: 160px; margin: 0 auto; }
  .app-coordinator-name { text-align: center; }
  .app-coordinator-name span { display: block; margin: 4px 0 0; }
  .app-coordinator-review { flex-direction: column; gap: 6px; }
}

/* タブレット以下：偏愛スタイルの画像をラジオの上に */
@media (max-width: 900px) {
  /* SP/タブレットでの入力時オートズーム防止（iOSは16px未満でズームする） */
  .app-input, .app-select, .app-textarea { font-size: 16px; }
}

/* ===== お申込みフォーム：基本フォントサイズを16pxに統一 ===== */
.app-row__label { font-size: 16px; }
.app-row__note { font-size: 16px; }
.app-input, .app-select, .app-textarea { font-size: 16px; }
.app-inline { font-size: 16px; }
.app-radio-item label, .app-checkbox-item label { font-size: 16px; }
.app-postal-link { font-size: 16px; }
.app-lead__small { font-size: 16px; }
.app-block__title { font-size: 16px; }
.app-btn { font-size: 16px; }
.app-flow__item { font-size: 16px; }
.app-pp-box label { font-size: 16px; }
.app-caution { font-size: 16px; }
.postal-symbol { font-size: 16px; }

/* ===== 郵便番号ページ：スタイル下層から来た時の「〇〇をご選択」表示 ===== */
.app-style-chosen-wrap { margin: 0 0 24px; }
.app-style-chosen {
  display: block;
  width: 100%;
  margin: 0;
  padding: 14px 40px;
  background: var(--red);
  color: #fff;
  text-align: center;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: .04em;
  border: none;
  border-radius: 0;
  box-sizing: border-box;
  /* ロゴのスラッシュ（/）と同じ、右に傾いた平行四辺形の帯 */
  clip-path: polygon(4% 0, 100% 0, 96% 100%, 0 100%);
}
.app-style-chosen__name {
  color: #fff;
  font-size: 19px;
}

/* ===== 重要事項ボックス：本文を高さ制限してスクロール ===== */
.app-disclaimer-scroll {
  max-height: 300px;
  overflow-y: auto;
  padding-right: 14px;
  margin-top: 4px;
}
.app-disclaimer-scroll::-webkit-scrollbar { width: 8px; }
.app-disclaimer-scroll::-webkit-scrollbar-track { background: transparent; }
.app-disclaimer-scroll::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.2);
  border-radius: 4px;
}
