@media screen and (max-width: 1201px) {
    @media screen and (max-width: 850px) {
        .cb_box_content .item {
            height: 500px;
            padding-top: 0;
        }

        .cb_box_content {
            background-color: #000;
        }
    }
}


/* --- SP対応：レイアウトを1カラムに、余白と文字も最適化 --- */
@media (max-width: 960px){
  .osechi-two__bar{
    grid-template-columns: 1fr;        /* 見出しを1列に */
    gap: 6px;
    text-align: center;
    padding: 16px 16px 0;
  }
  .osechi-two__label{
    margin: 0 auto 4px;
    border-left: none;
    border-bottom: 2px solid var(--osechi-gold, #d0a933);
    padding: 0 0 4px;
    display: inline-block;
  }
  .osechi-two__title{
    font-size: clamp(18px, 5vw, 22px);
    line-height: 1.5;
  }

  .osechi-two__grid{
    grid-template-columns: 1fr;        /* 画像→メニューの縦積み */
    gap: 14px;
    padding: 16px;
  }
  .osechi-two__photo{ order: 1; }
  .osechi-two__menu{  order: 2; }

  .osechi-two__menu{
    padding: 12px;
    border-radius: 12px;
  }
}

/* --- 縦書きメニュー：スマホでは1段に（読みやすく） --- */
@media (max-width: 560px){
  .osechi-list--tategaki{
    column-count: 1;        /* 2段→1段 */
    column-gap: 18px;
    line-height: 1.8;
  }
  .osechi-list--tategaki li::before{
    width: 24px; height: 24px;
    margin-block-end: 4px;
  }
}

/* --- さらに狭い幅（例：≤360px）は横書き2列に切替（可読性優先） --- */
@media (max-width: 360px){
  .osechi-list--tategaki{
    writing-mode: horizontal-tb;    /* 縦→横に */
    column-count: 2;                /* 2列 */
    line-height: 1.7;
  }
  .osechi-list--tategaki li{
    display: flex; align-items: center; gap: 8px;
    padding: 6px 4px;
  }
  .osechi-list--tategaki li::before{
    margin: 0 6px 0 0;              /* 数字バッジを左に */
  }
}

/* 画像の角丸と影は維持（SPでもオーバーフロー防止） */
.osechi-two__photo{
  border-radius: 14px; overflow: hidden;
}
.osechi-two__photo img{ display:block; width:100%; height:auto; }



/* --- 画像・品書きが切れる対策（最優先パッチ） --- */

/* Gridの子を縮められるように：横切れ防止 */
.osechi-two__photo,
.osechi-two__menu{
  min-width: 0;      /* ← これ大事（Gridの子はデフォルトで縮まらない） */
  min-height: 0;
}

/* どこかで overflow:hidden が効いていた場合の保険（外枠側は可視） */
.osechi-two,
.osechi-two__grid,
.osechi-two__menu{
  overflow: visible !important;
}

/* 画像は角丸のためだけにクリップ、サイズは自由 */
.osechi-two__photo{
  overflow: hidden;
  border-radius: 14px;
}
.osechi-two__photo img{
  display:block;
  width:100%;
  height:auto;
}

/* （もしフェード演出CSSを使っている場合）SPでは強制解除して検証 */
@media (max-width: 960px){
  .osechi-two__photo img{
    clip-path: none !important;
    transform: none !important;
    filter: none !important;
    opacity: 1 !important;
  }
}

/* --- SP最適化（レイアウト＆縦書きの収まり） --- */
@media (max-width: 960px){
  .osechi-two__grid{
    grid-template-columns: 1fr;   /* 画像→品書きの縦積み */
    gap: 14px;
    padding: 16px;
    align-items: start;            /* 子要素の高さ合わせをやめて自然な高さに */
  }
}

/* 縦書き2段が高すぎる時の逃がし（幅が狭い端末向け） */
@media (max-width: 560px){
  .osechi-list--tategaki{ column-count: 1; }  /* まず1段に */
}
@media (max-width: 380px){
  /* さらに狭い端末では横書き2列に切替（確実に収める） */
  .osechi-list--tategaki{
    writing-mode: horizontal-tb;
    column-count: 2;
    column-gap: 12px;
    line-height: 1.7;
  }
  .osechi-list--tategaki li{ display:flex; align-items:center; gap:6px; padding:6px 0; }
  .osechi-list--tategaki li::before{ margin:0 6px 0 0; width:22px; height:22px; }
}


/* ==== 縦書きメニューの切れ対策（最優先） ==== */

/* グリッドの子要素は縮められるように */
.osechi-two__menu{ min-width:0; overflow:visible; }

/* ベースの grid を確実に打ち消し、列の左側に余白を確保 */
.osechi-list.osechi-list--tategaki{
  display:block !important;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  column-count: 2;
  column-gap: 24px;
  padding-inline-start: 34px;   /* ← 数字バッジぶんの逃がし */
  max-width: 100%;
  overflow: visible;
  margin: 0 auto;
}

/* 各項目：番号バッジをレイアウトに影響させない（絶対配置） */
.osechi-list--tategaki li{
  display:block !important;     /* grid を無効化 */
  position: relative;
  padding: 4px 0;
  break-inside: avoid;
  border-bottom: none;           /* 罫線があれば消す */
  margin-bottom: 20px;
}
.osechi-list--tategaki li::before{
  position: absolute;
  writing-mode: horizontal-tb;   /* 数字は横組で読みやすく */
  inset-inline-start: 0px;     /* ← 列の外側に出す（はみ出し分は上の padding で吸収） */
  inset-block-start: -2em;
  width: 22px; height: 22px;
  display: grid; place-items: center;
  border-radius: 4px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: #d0a933;
  background: rgba(208,169,51,.18);
  border: 1px solid rgba(208,169,51,.45);
  box-shadow: 0 1px 0 rgba(0,0,0,.2);
}

/* --- 画面幅が狭いときの段組み調整 --- */
@media (max-width: 560px){
  .osechi-list--tategaki{
    column-count: 1;            /* 2段→1段に（確実に収める） */
    padding-inline-start: 34px;
  }
}
@media (max-width: 380px){
  /* さらに狭い端末では横書き2列に切替（可読性最優先） */
  .osechi-list--tategaki{
    writing-mode: horizontal-tb;
    column-count: 2;
    column-gap: 12px;
    padding-inline-start: 0;
    line-height: 1.7;
  }
  .osechi-list--tategaki li{
    display: flex !important; align-items: center; gap: 8px; padding: 6px 0;
  }
  .osechi-list--tategaki li::before{
    position: static; margin-right: 6px; width: 22px; height: 22px;
  }
}

/* 基本配置（PC時）：左→右 */
.osechi-info__grid{
  display: grid;
  grid-template-columns: minmax(0,1.3fr) minmax(320px,520px);
  grid-template-areas: "left right";
}

/* 子要素にエリア名を付与 */
.osechi-info__left  { grid-area: left;  min-width:0; }
.osechi-info__right { grid-area: right; min-width:0; }

/* SP時は1カラムで「右 → 左」の順に */
@media (max-width: 980px){
  .osechi-info__grid{
    grid-template-columns: 1fr;
    grid-template-areas:
      "right"
      "left";
  }

  .osechi-info__grid{
    gap: clamp(52px,4vw,40px);
    }


    #header_slider .caption{
        top: 40%;
    }

    .hero-kv__label {
        font-size: 15px;
    }
    
    .hero-kv__price .price-sub {
        font-size: 11px;
    }

    .design_button {
        display: inline-block;
        color: #ffffff !important;
        border-color: rgb(255 255 255);
        background: #846a3f;
    }

    .common_headline {
        font-size: 18px !important;
    }

    .cb_design_content .catch {
        margin: -5px 0 0px;
    }

    .cb_design_content .center_image {
        display: block;
        margin: 10px auto 10px;
    }

    .cb_design_content .desc {
        margin: -10px 0 33px;
        font-size: 0.9em;
    }

    .hero-kv__inner {
        width: 100%;
        margin: 0 auto;
        padding: 0px;
        margin-top: 10%;
    }

    .goldflakes-wrap .content {
          position: relative;
          z-index: 1;
          height: 300px;
      }

      .cb_design_content .catch {
          margin-bottom: 30px;
          font-weight: 900;
      }

      .cb_design_content .bg_image {
          height: 115%;
      }

}

/* デフォルト：PCは pc-br を効かせ、sp-br は無効 */
.pc-br{ display:inline; }
.sp-br{ display:none; }

/* SPだけ sp-br を改行にして、pc-br を消す */
@media (max-width: 560px){
  .pc-br{ display:none; }
  .sp-br{ display:block; height:0; line-height:0; } /* 実質改行 */
}

