@charset "utf-8";

/* howto_konpo 追加分（2026-04）— KV 以降のブロックもここへ足していく */

/* 袋で送る：ファーストビュー直下の YouTube は非表示 */
.howto-konpo-bag-postkv-video {
  display: none !important;
}

@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}

/* KV（オレンジCTA .btn-orange-primary は individual/css/2020/common.css） */

.howto-konpo-kv {
  box-sizing: border-box;
  margin-bottom: 2rem;
  max-width: none;
  width: 100%;
}

.howto-konpo-kv__img {
  display: block;
  height: auto;
  max-width: 100%;
  width: 100%;
}

.howto-konpo-freelink {
  margin: 1rem 0 0;
  text-align: center;
}

.howto-konpo-freelink a {
  color: #fa7500;
  font-size: 18px;
  text-decoration: underline;
}

.howto-konpo-freelink a:hover,
.howto-konpo-freelink a:focus {
  color: #fa7500;
}

.howto-konpo-caution {
  align-items: center;
  border: 3px solid #fa7500;
  border-radius: 12px;
  box-sizing: border-box;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 1.5rem;
  justify-content: center;
  margin-top: 1.25rem;
  padding: 1.25rem 1rem;
}

.howto-konpo-caution__aside {
  align-items: center;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  gap: 0.35em;
  text-align: center;
}

.howto-konpo-caution__icon {
  display: block;
  height: auto;
  max-width: 120px;
  width: 100%;
}

.howto-konpo-caution__label {
  color: #000;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.3;
  margin: 0;
}

.howto-konpo-caution__bullets {
  box-sizing: border-box;
  flex: 1 1 280px;
  list-style: disc;
  list-style-position: outside;
  margin: 0;
  min-width: 0;
  padding: 0 0 0 1.35em;
  text-align: left;
}

.howto-konpo-caution__bullets li {
  color: #000;
  font-size: 40px;
  font-weight: bold;
  line-height: 1.35;
  margin: 0 0 0.75em;
  padding-left: 0.15em;
}

.howto-konpo-caution__bullets li:last-child {
  margin-bottom: 0;
}

@media screen and (min-width: 768px) {
  .howto-konpo-caution {
    padding: 0.25rem 9rem;
  }

  .howto-konpo-caution__icon {
    max-width: 85px;
  }

  .howto-konpo-caution__label {
    font-size: 16px;
  }

  .howto-konpo-caution__bullets li {
    font-size: 28px;
    margin: 0 0 0.25em;
  }
}

/* 法人・企業向けプロモ（コンビニ渡す 直下） */
.konpo-corp-promo {
  border: 5px solid #fa7500;
  border-radius: 18px;
  box-sizing: border-box;
  margin: 2rem auto 0;
  max-width: 100%;
  padding: 2rem 2.25rem 2rem;
}

.konpo-corp-promo__header {
  align-items: center;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  margin-bottom: 1.75rem;
  text-align: center;
  width: 100%;
}

.konpo-corp-promo__header-row {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.65rem;
  justify-content: center;
  max-width: 100%;
}

.konpo-corp-promo__header-icon {
  display: block;
  flex-shrink: 0;
  height: auto;
  width: 44px;
}

.konpo-corp-promo__title {
  color: #000;
  font-size: 38px;
  font-weight: bold;
  line-height: 1.2;
  margin: 0;
  text-align: center;
}

.konpo-corp-promo__subtitle {
  color: #000;
  font-size: 30px;
  font-weight: bold;
  line-height: 1.45;
  margin: 0.85rem 0 0;
  max-width: 36em;
  text-align: center;
}

/* 特長 2×2（行間の区切り線なし／下線はテキスト列のみ 7px） */
.konpo-corp-promo__features {
  box-sizing: border-box;
  margin: 0 0 1.75rem;
  width: 100%;
}

.konpo-corp-promo__grid {
  box-sizing: border-box;
  column-gap: 1.75rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  row-gap: 1.35rem;
}

.konpo-corp-promo__cell {
  box-sizing: border-box;
  min-width: 0;
}

.konpo-corp-promo__cell-inner {
  align-items: center;
  box-sizing: border-box;
  display: flex;
  gap: 0.5rem 0.65rem;
  max-width: 100%;
}

.konpo-corp-promo__cell-copy {
  border-bottom: 7px solid #fa7500;
  box-sizing: border-box;
  max-width: 100%;
  padding-bottom: 0.2em;
  width: fit-content;
}

.konpo-corp-promo__cell--jp .konpo-corp-promo__feature-text {
  align-items: baseline;
  display: flex;
  flex-wrap: wrap;
  gap: 0.15em 0.35em;
}

.konpo-corp-promo__feature-icon {
  align-self: center;
  display: block;
  flex-shrink: 0;
  height: auto;
}

.konpo-corp-promo__feature-icon--w43 {
  width: 43px;
}

.konpo-corp-promo__feature-icon--w39 {
  width: 39px;
}

.konpo-corp-promo__feature-icon--w36 {
  width: 36px;
}

.konpo-corp-promo__feature-icon--w34 {
  width: 34px;
}

.konpo-corp-promo__feature-text {
  box-sizing: border-box;
  color: #000;
  font-size: 25px;
  font-weight: bold;
  line-height: 1.35;
  margin: 0;
  min-width: 0;
  text-align: left;
}

.konpo-corp-promo__feature-note {
  color: #000;
  font-size: 11px;
  font-weight: normal;
  line-height: 1.35;
  white-space: nowrap;
}

.konpo-corp-promo__actions {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1.5rem;
  width: 100%;
}

.konpo-corp-promo__btn {
  align-items: center;
  border-radius: 20px;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.1);
  box-sizing: border-box;
  display: flex;
  font-size: 24px;
  font-weight: bold;
  height: 85px;
  justify-content: center;
  line-height: 1.25;
  margin-left: auto;
  margin-right: auto;
  max-width: 570px;
  min-height: 85px;
  padding: 0 3.5rem 0 1.5rem;
  position: relative;
  text-align: center;
  text-decoration: none;
  transition: filter 0.2s ease, opacity 0.2s ease;
  width: 100%;
}

.konpo-corp-promo__btn:hover,
.konpo-corp-promo__btn:focus {
  filter: brightness(0.97);
}

.konpo-corp-promo__btn:focus {
  outline: 3px solid #16a;
  outline-offset: 2px;
}

.konpo-corp-promo__btn--primary {
  background-color: #fa7500;
  color: #fff;
}

.konpo-corp-promo__btn--primary .konpo-corp-promo__btn-arrow {
  display: block;
  height: auto;
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  width: 17px;
}

.konpo-corp-promo__btn--outline {
  background-color: #fff;
  border: 3px solid #fa7500;
  color: #fa7500;
}

.konpo-corp-promo__btn--outline .konpo-corp-promo__btn-icon {
  height: auto;
  position: absolute;
  right: 1.1rem;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
}

.konpo-corp-promo__foot {
  align-items: center;
  box-sizing: border-box;
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem 0.85rem;
  justify-content: center;
  max-width: 100%;
  width: 100%;
}

.konpo-corp-promo__foot-icon {
  display: block;
  flex-shrink: 0;
  height: auto;
  width: 56px;
}

.konpo-corp-promo__foot-list {
  color: #fa7500;
  flex: 0 1 auto;
  font-size: 17px;
  font-weight: bold;
  line-height: 1.5;
  list-style: none;
  margin: 0;
  max-width: 100%;
  min-width: 0;
  padding: 0;
  text-align: left;
  width: fit-content;
}

.konpo-corp-promo__foot-list li {
  margin: 0;
}

@media screen and (max-width: 767px) {
  .konpo-corp-promo {
    border-radius: 16px;
    border-width: 5px;
    padding: 1.35rem 1rem 1.5rem;
  }

  .konpo-corp-promo__header-icon {
    width: 44px;
  }

  .konpo-corp-promo__title {
    font-size: 26px;
  }

  .konpo-corp-promo__subtitle {
    font-size: 20px;
    margin-top: 0.65rem;
  }

  .konpo-corp-promo__header-row {
    flex-direction: column;
    gap: 0.35rem;
  }

  .konpo-corp-promo__grid {
    grid-template-columns: 1fr;
    row-gap: 1.25rem;
  }

  .konpo-corp-promo__feature-text {
    font-size: 20px;
  }

  .konpo-corp-promo__feature-note {
    font-size: 11px;
    white-space: normal;
  }

  .konpo-corp-promo__btn {
    font-size: 18px;
    height: 85px;
    max-width: 100%;
    min-height: 85px;
    padding-left: 1rem;
    padding-right: 2.75rem;
  }

  .konpo-corp-promo__foot-list {
    font-size: 15px;
  }

  .konpo-corp-promo__foot-icon {
    width: 48px;
  }
}

/* ②梱包する / ③送る — タブ＋アコーディオン（2026-05） */
.konpo-pack__caution {
  font-size: 20px;
  margin: 0 0 0.35em;
}

.konpo-pack__points-title {
  font-size: 30px;
  font-weight: bold;
  margin: 1.5rem 0 1rem;
  text-align: center;
}

.konpo-pack__points {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  list-style: none;
  margin: 0 0 1.75rem;
  padding: 0;
}

.konpo-pack__point {
  align-items: center;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.08);
  box-sizing: border-box;
  display: flex;
  flex-direction: row;
  gap: 0.75rem 1rem;
  justify-content: flex-start;
  min-height: 0;
  padding: 1rem 1.1rem;
  text-align: left;
}

.konpo-pack__point-icon {
  display: block;
  flex-shrink: 0;
  height: auto;
  max-width: 50px;
  width: auto;
}

.konpo-pack__point-text {
  color: #000;
  flex: 1;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.35;
  margin: 0;
  min-width: 0;
  text-align: left;
}

.konpo-pack__bag-note {
  font-size: 22px;
  font-weight: bold;
  margin: 0 0 1rem;
  text-align: center;
}

.konpo-pack-bundle {
  margin-bottom: 1.5rem;
}

/* 同梱物 STEP（ダンボール STEP4／袋 STEP3）：2列グリッド */
.konpo-acc__body:has(> .konpo-pack-bundle:nth-child(5)) {
  column-gap: 1.25rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  row-gap: 1.25rem;
}

.konpo-acc__body:has(> .konpo-pack-bundle:nth-child(5)) > .konpo-acc__lead {
  grid-column: 1 / -1;
  margin-bottom: 0.25rem;
}

.konpo-acc__body:has(> .konpo-pack-bundle:nth-child(5)) > .konpo-pack-bundle {
  margin-bottom: 0;
  min-width: 0;
}

.konpo-acc__body:has(> .konpo-pack-bundle:nth-child(5)) .konpo-pack-bundle__heading {
  font-size: 20px;
  margin-bottom: 0.5rem;
}

.konpo-acc__body:has(> .konpo-pack-bundle:nth-child(5)) .konpo-photo-card__caption {
  font-size: 16px;
  padding: 10px 8px 14px;
}

.konpo-pack-bundle__heading {
  font-size: 24px;
  font-weight: bold;
  margin: 0 0 0.75rem;
}

.konpo-pack-bundle__figure {
  background: #fff;
  border: 1px solid #e8e8e8;
  border-radius: 6px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  box-sizing: border-box;
  margin: 0;
  overflow: hidden;
}

.konpo-pack-bundle__figure .konpo-pack-bundle__media {
  border: none;
  border-radius: 0;
  box-shadow: none;
  margin-bottom: 0;
  padding: 10px 10px 0;
}

.konpo-pack-bundle__figure .konpo-photo-card__caption {
  border: none;
  border-radius: 0;
  border-top: 1px solid #e8e8e8;
  box-shadow: none;
  margin-top: 0;
  min-height: 0;
  padding: 12px 10px 16px;
}

.konpo-pack-bundle__media {
  position: relative;
}

.konpo-pack .konpo-pack-bundle__media .balloon-left,
.konpo-pack .konpo-pack-bundle__media .balloon-right {
  display: none;
}

.konpo-method {
  --konpo-orange: #fa7500;
  --konpo-line: 2px;
  --konpo-tab-radius: 12px;
  --konpo-panel-radius: 16px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  margin-top: 0.5rem;
}

.konpo-method__input {
  height: 0;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
  position: absolute;
  width: 0;
}

.konpo-method__tabrow {
  display: grid;
  grid-template-columns: 1fr 1fr;
  width: 100%;
}

.konpo-method__tab {
  align-items: center;
  background-color: #fff;
  border: none;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  border-top-left-radius: var(--konpo-tab-radius);
  border-top-right-radius: var(--konpo-tab-radius);
  box-sizing: border-box;
  color: #000;
  cursor: pointer;
  display: flex;
  font-size: 24px;
  font-weight: bold;
  gap: 0.45rem;
  justify-content: center;
  line-height: 1.25;
  margin: 0;
  min-height: 56px;
  padding: 0.75rem 1rem;
  text-align: center;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.konpo-method__tab-icon {
  flex-shrink: 0;
  height: 32px;
  width: auto;
}

.konpo-method__tab-icon--on {
  display: none;
}

.konpo-method__tab-icon--off {
  display: block;
}

/* 非選択タブ：外側だけオレンジ枠（角丸が見える） */
#pack-method-craft:checked ~ .konpo-method__tabrow .konpo-method__tab--end,
#pack-method-bag:checked ~ .konpo-method__tabrow .konpo-method__tab--start,
#send-method-conbini:checked ~ .konpo-method__tabrow .konpo-method__tab--end,
#send-method-home:checked ~ .konpo-method__tabrow .konpo-method__tab--start {
  background-color: #fff;
  border: var(--konpo-line) solid var(--konpo-orange);
  border-bottom: none;
  border-top-left-radius: var(--konpo-tab-radius);
  border-top-right-radius: var(--konpo-tab-radius);
  color: #000;
}

/* 選択タブ */
#pack-method-craft:checked ~ .konpo-method__tabrow .konpo-method__tab--start,
#pack-method-bag:checked ~ .konpo-method__tabrow .konpo-method__tab--end,
#send-method-conbini:checked ~ .konpo-method__tabrow .konpo-method__tab--start,
#send-method-home:checked ~ .konpo-method__tabrow .konpo-method__tab--end {
  background-color: var(--konpo-orange);
  border: none;
  border-top-left-radius: var(--konpo-tab-radius);
  border-top-right-radius: var(--konpo-tab-radius);
  color: #fff;
  margin-bottom: calc(-1 * var(--konpo-line));
  padding-bottom: calc(0.75rem + var(--konpo-line));
  position: relative;
  z-index: 1;
}

#pack-method-craft:checked ~ .konpo-method__tabrow .konpo-method__tab--start .konpo-method__tab-icon--on,
#pack-method-bag:checked ~ .konpo-method__tabrow .konpo-method__tab--end .konpo-method__tab-icon--on,
#send-method-conbini:checked ~ .konpo-method__tabrow .konpo-method__tab--start .konpo-method__tab-icon--on,
#send-method-home:checked ~ .konpo-method__tabrow .konpo-method__tab--end .konpo-method__tab-icon--on {
  display: block;
}

#pack-method-craft:checked ~ .konpo-method__tabrow .konpo-method__tab--start .konpo-method__tab-icon--off,
#pack-method-bag:checked ~ .konpo-method__tabrow .konpo-method__tab--end .konpo-method__tab-icon--off,
#send-method-conbini:checked ~ .konpo-method__tabrow .konpo-method__tab--start .konpo-method__tab-icon--off,
#send-method-home:checked ~ .konpo-method__tabrow .konpo-method__tab--end .konpo-method__tab-icon--off {
  display: none;
}

/* 枠線はコンテンツ領域だけ（四方とも） */
.konpo-method__panels {
  background: #fff;
  border: var(--konpo-line) solid var(--konpo-orange);
  border-radius: 0 0 var(--konpo-panel-radius) var(--konpo-panel-radius);
  box-sizing: border-box;
  display: none;
  padding: 1.25rem 1.35rem 1.5rem;
  width: 100%;
}

.konpo-method__panel {
  display: none;
}

#pack-method-craft:checked ~ .konpo-method__panels #pack-method-craft-panel,
#pack-method-bag:checked ~ .konpo-method__panels #pack-method-bag-panel,
#send-method-conbini:checked ~ .konpo-method__panels #send-method-conbini-panel,
#send-method-home:checked ~ .konpo-method__panels #send-method-home-panel {
  display: block;
}

#pack-method-craft:checked ~ .konpo-method__panels,
#pack-method-bag:checked ~ .konpo-method__panels,
#send-method-conbini:checked ~ .konpo-method__panels,
#send-method-home:checked ~ .konpo-method__panels {
  display: block;
}

.konpo-acc-list {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.konpo-acc {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.08);
  overflow: hidden;
}

.konpo-acc__summary {
  align-items: center;
  cursor: pointer;
  display: flex;
  gap: 0.65rem;
  list-style: none;
  padding: 1rem 1.1rem;
}

.konpo-acc__summary::-webkit-details-marker {
  display: none;
}

.konpo-acc__marker {
  border-color: transparent transparent #333 transparent;
  border-style: solid;
  border-width: 0 7px 10px;
  flex-shrink: 0;
  height: 0;
  transform: rotate(180deg);
  transition: transform 0.2s ease;
  width: 0;
}

.konpo-acc:not([open]) .konpo-acc__marker {
  transform: rotate(0deg);
}

.konpo-acc__title {
  flex: 1;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.35;
  text-align: left;
}

.konpo-acc__chevron {
  border: solid #666;
  border-width: 0 3px 3px 0;
  display: inline-block;
  flex-shrink: 0;
  height: 12px;
  margin-right: 0.15rem;
  transform: rotate(45deg);
  transition: transform 0.2s ease;
  width: 12px;
}

.konpo-acc[open] .konpo-acc__chevron {
  margin-top: 0.35rem;
  transform: rotate(-135deg);
}

.konpo-acc__body {
  border-top: 1px solid #eee;
  padding: 1rem 1.1rem 1.25rem;
}

.konpo-acc__lead {
  margin-bottom: 1rem;
}

.konpo-acc__lead .summary-main {
  font-size: 20px;
  line-height: 1.55;
  margin: 0 0 0.35em;
}

.konpo-acc__lead-note {
  font-size: 20px;
  font-weight: normal;
  line-height: 1.55;
  margin: 0;
}

.konpo-acc__body .summary-main {
  font-size: 20px;
  line-height: 1.55;
}

.konpo-step1-boxes {
  margin-top: 1.25rem;
}

.konpo-acc__img-row {
  align-items: stretch;
  display: flex;
  gap: 1rem;
  margin-bottom: 1rem;
}

.konpo-acc__img-row .konpo-photo-card {
  flex: 1;
  margin: 0;
  min-width: 0;
}

.konpo-acc__img {
  margin-bottom: 0.75rem;
}

/* STEP内写真カード（白枠＋ボックスシャドウ＋下段キャプション） */
.konpo-step2 {
  align-items: stretch;
  display: flex;
  gap: 1.25rem;
}

.konpo-step2__col {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0;
}

.konpo-step2__col > .konpo-photo-card--fill {
  flex: 1;
}

.konpo-step2__stack {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-height: 0;
}

.konpo-step2__block-caption {
  font-size: 16px;
  font-weight: normal;
  line-height: 1.45;
  margin: 0.65rem 0 0;
  padding: 0 0.25rem;
  text-align: center;
}

.konpo-photo-grid {
  display: grid;
  flex: 1;
  gap: 0.65rem;
  grid-auto-rows: 1fr;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  list-style: none;
  margin: 0;
  min-height: 0;
  padding: 0;
}

.konpo-photo-grid > li {
  display: flex;
  min-height: 0;
}

.konpo-photo-grid .konpo-photo-card {
  display: flex;
  flex: 1;
  flex-direction: column;
  height: 100%;
  width: 100%;
}

.konpo-photo-grid .konpo-photo-card__media {
  flex: 1;
  min-height: 0;
}

.konpo-photo-grid .konpo-photo-card__caption {
  flex-shrink: 0;
}

.konpo-photo-card {
  background: #fff;
  border: 1px solid #e8e8e8;
  border-radius: 6px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  box-sizing: border-box;
  margin: 0;
  overflow: hidden;
  padding: 10px 10px 0;
}

.konpo-photo-card--plain {
  padding: 10px;
}

.konpo-photo-card--plain .konpo-photo-card__media {
  aspect-ratio: auto;
}

.konpo-photo-card--center {
  margin-left: auto;
  margin-right: auto;
  max-width: 420px;
}

/* 袋タブ STEP1：準備写真（中央・やや小さめ） */
.konpo-photo-card--center.konpo-bag-prep__figure {
  max-width: 320px;
}

.konpo-photo-card__media {
  aspect-ratio: 4 / 3;
  background: #fff;
  overflow: hidden;
  position: relative;
}

.konpo-photo-card__media img {
  display: block;
  height: 100%;
  left: 0;
  max-width: none;
  object-fit: cover;
  position: absolute;
  top: 0;
  width: 100%;
}

/* 通常表示（STEP1 等）— 絶対配置ルールより後に書く */
.konpo-photo-card__media.konpo-photo-card__media--static {
  aspect-ratio: auto;
  height: auto;
  overflow: visible;
  position: static;
}

.konpo-photo-card__media.konpo-photo-card__media--static img {
  display: block;
  height: auto;
  left: auto;
  max-width: 100%;
  object-fit: contain;
  position: static;
  top: auto;
  width: 100%;
}

.konpo-photo-card--wide {
  display: flex;
  flex: 1;
  flex-direction: column;
  height: 100%;
}

.konpo-photo-card--wide .konpo-photo-card__media {
  align-items: center;
  aspect-ratio: auto;
  display: flex;
  flex: 1;
  justify-content: center;
  min-height: 0;
}

.konpo-photo-card--wide .konpo-photo-card__media img {
  display: block;
  height: auto;
  left: auto;
  max-height: 100%;
  max-width: 100%;
  object-fit: contain;
  position: static;
  top: auto;
  width: 100%;
}

.konpo-photo-card--fill.konpo-photo-card--wide .konpo-photo-card__caption {
  flex-shrink: 0;
}

.konpo-acc__body .konpo-pack-bundle__media {
  background: #fff;
  border: 1px solid #e8e8e8;
  border-radius: 6px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  box-sizing: border-box;
  padding: 10px;
  position: relative;
}

.konpo-acc__body .konpo-pack-bundle__figure .konpo-pack-bundle__media {
  background: transparent;
  border: none;
  border-radius: 0;
  box-shadow: none;
}

.konpo-acc__body .konpo-pack-bundle__media > img {
  display: block;
  height: auto;
  max-width: 100%;
  width: 100%;
}

.konpo-pack .box-protect-img-frame {
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  box-sizing: border-box;
  margin-left: 0;
  max-width: 100%;
  width: 100%;
}

.konpo-pack .box-protect-img-position {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

@media screen and (min-width: 560px) {
  .konpo-pack .box-protect-img-position {
    flex-direction: row;
    align-items: flex-start;
  }

  .konpo-pack .box-protect-img-position > .box-protect-img-frame {
    flex: 1;
    min-width: 0;
  }
}

.konpo-acc__body .t-c.konpo-pack-bundle__media {
  display: inline-block;
  max-width: 100%;
}

.konpo-photo-card__caption {
  align-items: center;
  background: #fff;
  box-sizing: border-box;
  display: flex;
  font-size: 18px;
  font-weight: bold;
  justify-content: center;
  line-height: 1.45;
  margin: 0;
  min-height: 3.25em;
  padding: 12px 10px 16px;
  text-align: center;
}

/* STEP 3：送れるものを入れる（左右2カラム） */
.konpo-step3 {
  align-items: stretch;
  display: flex;
  gap: 1.25rem;
}

.konpo-step3__col {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0;
}

.konpo-step3__col > .konpo-photo-card--fill {
  flex: 1;
}

.konpo-step3__target {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.45;
  margin: 0 0 0.65rem;
  text-align: left;
}

.konpo-step3__target-note {
  font-size: 16px;
  font-weight: normal;
}

.konpo-photo-card__caption + .konpo-photo-card__subcaptions {
  margin-top: -0.35rem;
}

.konpo-photo-card__caption:has(+ .konpo-photo-card__subcaptions) {
  min-height: 0;
  padding-bottom: 0.35rem;
}

.konpo-photo-card__subcaptions {
  background: #fff;
  box-sizing: border-box;
  padding: 0 10px 14px;
  text-align: center;
}

.konpo-photo-card__subcaptions p {
  font-size: 16px;
  font-weight: normal;
  line-height: 1.5;
  margin: 0 0 0.2em;
}

.konpo-photo-card__subcaptions p:last-child {
  margin-bottom: 0;
}

/* 梱包エリア：旧固定幅・absolute を解除（右端切れ防止） */
.konpo-pack .konpo-acc {
  overflow: visible;
}

.konpo-pack .konpo-method,
.konpo-pack .konpo-method__panels,
.konpo-pack .konpo-acc__body,
.konpo-pack .accrodion-contents {
  box-sizing: border-box;
  max-width: 100%;
  overflow: visible;
}

.konpo-pack .detail-width,
.konpo-pack .accrodion-contents {
  margin: 0;
  width: 100%;
}

.konpo-pack a.konpo-acc__motobarai-link,
.konpo-pack a.konpo-acc__motobarai-link:hover,
.konpo-pack a.konpo-acc__motobarai-link:focus,
.konpo-pack a.konpo-acc__motobarai-link:visited,
.konpo-pack a.konpo-acc__motobarai-link * {
  color: inherit;
  text-decoration: none;
}

.konpo-pack .konpo-acc__body img,
.konpo-pack .accrodion-contents img {
  height: auto;
  max-width: 100%;
}

.konpo-pack .konpo-acc__body > .grid {
  margin: 0;
  overflow: visible;
  padding: 0;
}

.konpo-pack .konpo-acc__body > .grid > li {
  box-sizing: border-box;
  float: none;
  margin-right: 0;
  width: 100%;
}

.konpo-pack .konpo-acc__body > .grid > li.two {
  width: 100%;
}

@media screen and (min-width: 560px) {
  .konpo-pack .konpo-acc__body > .grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr 1fr;
  }

  .konpo-pack .konpo-acc__body > .grid > li,
  .konpo-pack .konpo-acc__body > .grid > li.two {
    width: auto;
  }
}

/* 160サイズ／発払いボックス（flex で再構成） */
.konpo-pack .send-prepayment-box,
.konpo-pack .send-prepayment-box-adjust {
  padding: 0.65rem 0.5rem 0.55rem;
}

.konpo-pack .send-prepayment-box .grid {
  align-items: center;
  display: flex;
  gap: 0.5rem;
  margin: 0;
  overflow: visible;
  padding: 0;
}

.konpo-pack .send-prepayment-box .grid li {
  box-sizing: border-box;
  display: block;
  float: none;
  list-style: none;
  margin: 0;
  width: auto;
}

.konpo-pack .send-prepayment-box .grid li.six {
  flex: 0 0 72px;
}

.konpo-pack .send-prepayment-box .grid li.five-six {
  flex: 1 1 0;
  height: auto;
  min-height: 0;
  min-width: 0;
  position: static;
}

.konpo-pack .send-prepayment-box .img-send-prepayment-caution-left {
  display: block;
  height: auto;
  margin: 0;
  width: 100%;
}

.konpo-pack .konpo-prepay-main {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  width: 100%;
}

.konpo-pack .konpo-prepay-row {
  align-items: center;
  display: flex;
  flex-wrap: nowrap;
  gap: 0.5rem;
}

.konpo-pack .konpo-prepay-row--bottom {
  justify-content: space-between;
}

.konpo-pack .send-prepayment-box .send-prepayment-size {
  background: #1764a3;
  border-radius: 5px;
  color: #fff;
  flex-shrink: 0;
  padding: 0.4rem 0.75rem;
  position: static;
}

.konpo-pack .send-prepayment-box .send-prepayment-size .box-size-small-text-adjust,
.konpo-pack .send-prepayment-box .send-prepayment-size .box-size-small-text-adjust span {
  color: #fff;
}

.konpo-pack .send-prepayment-box .box-size-small-text-adjust {
  margin: 0;
  text-align: center;
  white-space: nowrap;
}

.konpo-pack .send-prepayment-box .send-prepayment-big {
  line-height: 1.45;
  margin: 0;
}

.konpo-pack .send-prepayment-box .send-prepayment-text-left {
  flex: 0 0 auto;
  white-space: nowrap;
}

.konpo-pack .send-prepayment-box .send-prepayment-text-right {
  flex: 1 1 auto;
  min-width: 0;
}

.konpo-pack .send-prepayment-box .mainbutton-motobarai {
  flex-shrink: 0;
  font-size: 19px;
  height: 37px;
  margin: 0;
  min-width: 4.75rem;
  position: static;
  right: auto;
  top: auto;
  width: auto;
}

.konpo-pack .bundle-position {
  position: relative;
  width: 100%;
}

.konpo-pack .box-bundle {
  bottom: auto;
  margin: 0.5rem auto 0;
  position: static;
  right: auto;
}

.konpo-pack .box-size-new,
.konpo-pack .box-size-new-adjust {
  bottom: auto;
  height: auto;
  max-width: 420px;
  min-height: 214px;
  position: relative;
  right: auto;
  top: auto;
  width: 100%;
}

.konpo-pack .send-prepayment-box,
.konpo-pack .send-prepayment-box-adjust {
  height: auto;
  max-width: 420px;
  min-height: 96px;
  position: relative;
  right: auto;
  top: auto;
  width: 100%;
}

.konpo-pack .send-prepayment-li-height {
  height: auto;
  min-height: 5rem;
}

.konpo-pack .konpo-step1-boxes.steps2-box,
.konpo-pack .steps2-box {
  align-items: stretch;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  height: auto !important;
  justify-content: center;
  left: auto !important;
  overflow: visible !important;
  position: relative !important;
}

.konpo-pack .accrodion-contents .steps2-box:not(.konpo-step1-boxes) {
  margin-top: 1rem;
}

.konpo-pack .steps2-box > a,
.konpo-pack .konpo-step1-boxes > .konpo-acc__motobarai-link {
  color: inherit;
  display: block;
  flex: 1 1 280px;
  max-width: 420px;
  text-decoration: none;
}

.konpo-pack .steps2-box > a *,
.konpo-pack .konpo-step1-boxes > .konpo-acc__motobarai-link * {
  text-decoration: none;
}

.konpo-pack .steps2-box > .box-size-new {
  flex: 1 1 280px;
  max-width: 420px;
}

.konpo-pack .steps2-box .send-prepayment-box {
  position: relative !important;
  right: auto !important;
  top: auto !important;
  width: 100% !important;
}

.konpo-acc--nested {
  box-shadow: none;
  margin-top: 1rem;
  max-width: 100%;
  overflow: hidden;
}

.konpo-pack .konpo-acc--nested > summary.konpo-acc__nested-summary {
  box-sizing: border-box;
  display: block !important;
  font-size: 22px;
  margin: 0;
  max-width: 100%;
  width: 100%;
}

.konpo-pack .konpo-acc--nested > .accrodion-contents {
  border: 1px solid #ddd;
  border-top: none;
  box-sizing: border-box;
}

.konpo-pack .konpo-meyasu-patch-row {
  margin: 0;
  overflow: visible;
  padding: 0;
}

@media screen and (min-width: 560px) {
  .konpo-pack .konpo-meyasu-patch-row {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr 1fr;
  }

  .konpo-pack .konpo-meyasu-patch-row > li {
    float: none;
    margin: 0;
    width: auto;
  }
}

.konpo-pack .konpo-meyasu-patch-row .konpo-photo-card {
  height: 100%;
}

.konpo-send-intro {
  margin-bottom: 1.5rem;
}

.konpo-send-intro__service {
  margin-bottom: 0.5rem;
}

.konpo-send-intro__sample-note {
  font-size: 22px;
  font-weight: bold;
  margin: 0 0 0.75rem;
}

.konpo-send-intro__sample img {
  height: auto;
  max-width: 100%;
}

.konpo-send-home .tabContent-blue {
  border: none;
  padding: 0;
}

@media screen and (max-width: 767px) {
  .konpo-pack__points {
    grid-template-columns: 1fr;
  }

  .konpo-pack__point {
    gap: 0.65rem 0.85rem;
    padding: 0.9rem 1rem;
  }

  .konpo-pack__point-icon {
    max-width: 40px;
  }

  .konpo-pack__point-text {
    font-size: 17px;
  }

  .konpo-method {
    --konpo-tab-radius: 10px;
    --konpo-panel-radius: 14px;
  }

  .konpo-method__tabrow {
    grid-template-columns: 1fr 1fr;
  }

  .konpo-method__tab {
    font-size: 17px;
    gap: 0.35rem;
    min-height: 50px;
    padding: 0.65rem 0.5rem;
  }

  .konpo-method__tab-icon {
    height: 28px;
  }

  .konpo-method__panels {
    padding: 0.85rem 0.75rem 1rem;
  }

  .konpo-acc__title {
    font-size: 17px;
  }

  .konpo-acc__lead .summary-main,
  .konpo-acc__lead-note,
  .konpo-acc__body .summary-main {
    font-size: 17px;
  }

  .konpo-acc__img-row {
    flex-direction: column;
    gap: 0.75rem;
  }

  .konpo-step2 {
    flex-direction: column;
    gap: 1.5rem;
  }

  .konpo-step3 {
    flex-direction: column;
    gap: 1.5rem;
  }

  .konpo-acc__body:has(> .konpo-pack-bundle:nth-child(5)) {
    grid-template-columns: 1fr;
  }

  .konpo-step2__block-caption {
    font-size: 15px;
  }

  .konpo-photo-card__caption {
    font-size: 17px;
    min-height: 2.75em;
    padding: 10px 8px 14px;
  }

  .konpo-photo-card__subcaptions p {
    font-size: 15px;
  }

  .konpo-acc__summary {
    padding: 0.85rem 0.75rem;
  }

  .konpo-acc__body {
    padding: 0.85rem 0.75rem 1rem;
  }
}
