/* ========== Checkout Confirmation: Mobile-first enhancements ========== */

/* ベース色・余白（必要に応じて調整） */
#checkoutConfirmDefault {
  --cc-gap: 14px;
  --cc-radius: 10px;
  --cc-soft: #f7f7f7;
  --cc-line: #e9e9e9;
  --cc-ink: #222;
  color: var(--cc-ink);
}

#checkoutConfirmDefault h1 {
  font-size: clamp(20px, 4.5vw, 28px);
  line-height: 1.3;
  margin: 0 0 14px;
}

#checkoutConfirmDefault h2 {
  font-size: clamp(16px, 3.8vw, 22px);
  margin: 0 0 8px;
}

#checkoutConfirmDefault h3,
#checkoutConfirmDefault h4 {
  margin: 6px 0;
}

/* メッセージ類 */
#checkoutConfirmDefault .messageStackError {
  background: #fff3f3;
  border: 1px solid #f6c8c8;
  border-radius: var(--cc-radius);
  padding: 10px 12px;
  margin: 10px 0;
}

/* 住所・支払・配送カード */
#checkoutBillto,
#checkoutShipto,
#order-comments {
  background: var(--cc-soft);
  border: 1px solid var(--cc-line);
  border-radius: var(--cc-radius);
  padding: 12px;
  margin-bottom: var(--cc-gap);
  position: relative;
}

/* 「編集」ボタン行を右上にフロートさせて押しやすく */
#checkoutBillto .buttonRow.forward,
#checkoutShipto .buttonRow.forward,
#order-comments .buttonRow.forward {
  position: absolute;
  top: 10px;
  right: 10px;
}

#checkoutConfirmDefault .buttonRow.forward a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--cc-line);
}

.address_verification {
  line-height: 1.6;
  font-size: 14px;
}

/* 「最短でお届け」を視認性UP */
#checkoutShipto h4 {
  font-weight: 600;
}
#checkoutShipto h4:has(> :not(*) ){} /* no-op for compatibility */
#checkoutShipto h4:contains("最短でお届け") { /* 非対応ブラウザ用フォールバック不可 */
  /* ↑:contains は未実装ブラウザが多いため下の一般スタイルで代替 */
}
#checkoutShipto h3 + .buttonRow.forward + h4 {
  padding: 8px 10px;
  background: #fff;
  border: 1px dashed var(--cc-line);
  border-radius: 8px;
}

/* 注文コメント */
#order-comments div:last-child {
  white-space: pre-wrap;
  word-break: break-word;
  font-size: 14px;
}

/* 「カート」見出しエリア */
#checkoutConfirmDefaultHeadingCart + .buttonRow.forward {
  margin-top: 6px;
}
#checkoutConfirmDefault .clearBoth {
  clear: both;
}

/* ========== 商品リスト（テーブルをスマホでカード化） ========== */

#cartContentsDisplay {
  width: 100%;
  border-collapse: collapse;
  margin-top: 8px;
}

/* 見出しはスマホで非表示→カード内で情報を再構成 */
@media (max-width: 768px) {
  #cartContentsDisplay thead,
  #cartContentsDisplay tr.cartTableHeading {
    display: none;
  }
  #cartContentsDisplay tr {
    display: block;
    background: #fff;
    border: 1px solid var(--cc-line);
    border-radius: var(--cc-radius);
    padding: 10px;
    margin-bottom: 10px;
  }

  /* 税カラム（ある場合）は非表示にして情報量を整理 */
  #ccTaxHeading,
  #cartContentsDisplay td:nth-child(3):has(+ td), /* 4列構成時の3列目=税 */
  #cartContentsDisplay td#ccTaxHeading,
  #cartContentsDisplay th#ccTaxHeading {
    display: none !important;
  }

  /* 各セルをブロックにして再配置 */
  #cartContentsDisplay td {
    display: block;
    padding: 4px 0;
    border: 0;
  }

  /* 商品名（2列目）を先頭に大きめ表示 */
  #cartContentsDisplay td.cartProductDisplay {
    order: 1;
    font-weight: 600;
    line-height: 1.4;
    margin-bottom: 4px;
  }

  /* 数量（1列目） */
  #cartContentsDisplay td.cartQuantity {
    order: 2;
    font-size: 13px;
    opacity: 0.9;
  }
  #cartContentsDisplay td.cartQuantity::before {
    content: "数量：";
    margin-right: 6px;
    font-weight: 500;
  }

  /* 合計（最終列）を一番下・右寄せ・強調 */
  #cartContentsDisplay td.cartTotalDisplay {
    order: 3;
    text-align: right;           /* 金額右寄せ（ご要望） */
    font-weight: 700;
    margin-top: 6px;
  }
  #cartContentsDisplay td.cartTotalDisplay::before {
    content: "小計：";
    float: left;
    font-weight: 500;
  }

  /* 属性リストをコンパクトに */
  .cartAttribsList {
    margin: 6px 0 0 0;
    padding-left: 1em;
  }
  .cartAttribsList li {
    font-size: 13px;
    line-height: 1.5;
  }
}

/* PC/タブレットでは従来のテーブル。金額は常に右寄せ */
#cartContentsDisplay td.cartTotalDisplay {
  text-align: right; /* スマホ・PC共通で右寄せ */
}


/* 在庫関連メッセージ */
#checkoutConfirmDefault .messageStackError + #cartContentsDisplay {
  margin-top: 8px;
}

/* ========== 注文合計（orderTotals） ========== */

#orderTotals {
  margin-top: 12px;
  padding: 12px;
  background: #fff;
  border: 1px solid var(--cc-line);
  border-radius: var(--cc-radius);
}

#orderTotals * {
  line-height: 1.6;
}
@media (max-width: 768px) {
  #orderTotals {
    font-size: 15px;
  }
  #orderTotals [class*="total"] {
    font-weight: 700;
  }
}

/* ========== 確認ボタン（フル幅＆タップしやすく） ========== */

/* 元の画像ボタンを“押しやすい”カードに */
.confirm-order {
  margin-top: 16px;
}

.confirm-order form,
#checkout_confirmation .confirm-order {
  width: 100%;
}

.confirm-order .image-button {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border: 0;
  border-radius: 12px;
  padding: 14px 16px;
  background: #1f7a5c; /* お好みで変更 */
  transition: filter .15s ease, transform .02s ease;
}

.confirm-order .image-button:active {
  transform: translateY(1px);
}

.confirm-order .image-button img {
  width: 100%;
  max-width: 520px;      /* 画像が大きすぎる場合の上限 */
  height: auto;
  display: block;
  filter: invert(0) brightness(1.05) contrast(1.05);
}

@media (max-width: 768px) {
  .confirm-order .image-button {
    padding: 12px;
    border-radius: 14px;
  }
}

/* 「次の手順へ」説明文の見やすさ */
#checkoutConfirmDefault .buttonRow.back {
  margin-top: 10px;
  font-size: 13px;
  opacity: .9;
}

/* ========== 細かな並び替え（スマホ） ========== */
@media (max-width: 768px) {
  /* 左右2カラムの“back/forward”は縦並びへ */
  #checkoutBillto.back,
  #checkoutShipto.forward {
    float: none !important;
    width: 100% !important;
  }
}

/* ========== ダークモード（任意） ========== */
@media (prefers-color-scheme: dark) {
  #checkoutConfirmDefault {
    --cc-soft: #1c1c1c;
    --cc-line: #2a2a2a;
    --cc-ink: #f1f1f1;
  }
  .confirm-order .image-button {
    background: #2aa17a;
  }
}
