/* ===========================
   Osechi – Order / Info Section
   =========================== */
:root{
  --gold: #d0a933;         /* ご指定の金色 */
  --bg: #0b0b0b;
  --ink: #ffffff;
  --ink-mute: #c9c9c9;
  --line: rgba(208,169,51,.38);
}

.osechi-info{
  position: relative;
  color: var(--ink);
  background: radial-gradient(1000px 360px at 12% -10%, rgba(208,169,51,.28), transparent 60%), var(--bg);
  padding: clamp(24px,4.8vw,60px);
  overflow: hidden;
  box-shadow: 0 40px 80px rgba(0,0,0,.45);
}

/* ほんのり金の枠（アニメする光の筋） */
.osechi-info::after{
  content:"";
  position:absolute; inset:0;
  pointer-events:none;
  background:
    conic-gradient(from 30deg at 0% 0%, rgba(208,169,51,.22), transparent 20%, rgba(208,169,51,.12) 50%, transparent 80% 100%);
  mix-blend-mode:screen;
  opacity:.28;
  animation: sheen 12s linear infinite;
}
@keyframes sheen{
  0%{ transform: translateX(-15%) translateY(-10%) rotate(0deg); }
  100%{ transform: translateX(15%) translateY(10%) rotate(1turn); }
}

/* 見出し */
.osechi-info__head{
  display:flex; align-items:center; gap:12px;
  margin: 0 0 clamp(18px,2.8vw,30px);
}
.osechi-info__title{
  margin: 0;
  font-size: clamp(18px,2.4vw,24px);
  line-height: 1.6;
  letter-spacing: .04em;
  padding-left: 14px;
  border-left: 3px solid var(--gold);
  text-shadow: 0 1px 0 rgba(0,0,0,.45);
}

/* 2カラム */
.osechi-info__grid{
  display:grid;
  grid-template-columns: minmax(0,1.3fr) minmax(320px,520px);
  gap: clamp(18px,4vw,40px);
  align-items: stretch;
}

/* 左カラム */
.osechi-info__lead{
  font-size: clamp(14px,1.9vw,16px);
  color: var(--ink);
  margin: 0 0 10px;
}

.badge{
  display:inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: .08em;
  border: 1px solid var(--line);
  background: rgba(208,169,51,.14);
  color: var(--gold);
}
.badge--frozen::before{
  content:"冷凍"; font-weight: 800; margin-right: .2em;
}

.osechi-steps{
  counter-reset: step;
  list-style: none;
  margin: 6px 0 14px;
  padding: 0;
  display: grid; gap: 10px;
}
.osechi-steps li{
  position: relative;
  padding-left: 44px;
  line-height: 1.9;
  color: var(--ink-mute);
  border-bottom: 1px dashed var(--line);
  padding-bottom: 10px;
}
.osechi-steps li:last-child{ border-bottom: 0; }
.osechi-steps li::before{
  counter-increment: step;
  content: counter(step);
  position: absolute; left: 0; top: 2px;
  width: 30px; height: 30px;
  display:grid; place-items:center;
  border-radius: 6px;
  font-weight: 800;
  color: var(--gold);
  background: rgba(208,169,51,.16);
  border: 1px solid var(--line);
  text-shadow: 0 1px 0 rgba(0,0,0,.25);
}

.osechi-notes{
  list-style: none; padding: 0; margin: 6px 0 0;
  color: var(--ink-mute);
  display: grid; gap: 6px;
  font-size: 13px;
}
.osechi-notes li::before{
  content:"※"; color: var(--gold); margin-right: .4em;
}

/* 右カラム（商品カード） */
.osechi-product{
  position: relative;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: clamp(14px,2.6vw,22px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.osechi-product__ribbon{
  position: absolute;
  top: -10px; left: -22px;
  transform: rotate(-8deg);
  background: linear-gradient(90deg, #b98e1e, #e5cf7a);
  color:#222;
  font-weight: 800;
  padding: 6px 14px;
  border-radius: 8px;
  box-shadow: 0 6px 18px rgba(208,169,51,.45);
}
.osechi-product__name{
  margin: 0 0 12px;
  font-size: clamp(18px,2.3vw,22px);
  line-height: 1.5;
}
.osechi-product__name small{
  font-size: .9em; opacity: .85; margin-right: .4em;
}

.osechi-meta{
  display:flex; flex-wrap:wrap; gap:8px;
  margin: 0 0 12px; padding: 0; list-style:none;
}
.chip{
  padding: 4px 10px;
  border: 1px solid var(--line);
  color: var(--gold);
  border-radius: 999px;
  font-size: 12px;
  background: rgba(208,169,51,.10);
}
.chip--line{
  background: transparent;
}

/* 寸法図 */
.osechi-dim
 {
    background: #ffffff;
    border: 1px solid rgba(255, 255, 255, .06);
    border-radius: 10px;
    padding: 8px;
    margin: 4px 0 12px;
    text-align: center;
}
.osechi-dim svg{
  display:block; width:100%; height:auto;
}

/* 価格 */
.osechi-price{
  display:flex; align-items: baseline; gap:6px;
  margin: 2px 0 12px;
}
.osechi-price__num{
  font-size: clamp(28px,4vw,40px);
  font-weight: 900;
  letter-spacing: .04em;
  background: linear-gradient(180deg, #fff, #e0e0e0);
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
  text-shadow: 0 8px 30px rgba(0,0,0,.45);
  position: relative;
}
.osechi-price__num::after{
  /* さりげない金のハイライト */
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(125deg, rgba(208,169,51,.35), transparent 40%);
  mix-blend-mode: screen; opacity:.35; pointer-events:none;
}
.osechi-price__yen{ font-weight: 700; }
.osechi-price__tax{ color: var(--ink-mute); font-size: 13px; }

/* 日付ボックス */
.osechi-dates{
  display:grid; gap:8px;
}
.osechi-date{
  display:grid; grid-template-columns: 1fr;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-left: 3px solid var(--gold);
  border-radius: 8px;
  padding: 10px 12px;
}
.osechi-date dt{
  font-weight: 800; color:#fff; margin:0 0 4px;
}
.osechi-date dd{
  margin:0; color: var(--ink-mute);
}
.osechi-date .note{ color: #e6d28a; }

/* レスポンシブ */
@media (max-width: 980px){
  .osechi-info__grid{ grid-template-columns: 1fr; }
  .osechi-product__ribbon{ position: static; transform:none; display:inline-block; margin-bottom:8px; }
}
@media (prefers-reduced-motion: reduce){
  .osechi-info::after{ animation: none; opacity:.16; }
}


/* === 高さを揃える（グリッドの各列を同じ行高に） === */
.osechi-info__grid{ align-items: stretch; }           /* すでに指定済ならOK */
.osechi-info__left,
.osechi-info__right{ display:flex; }                  /* 子パネルを伸ばす器に */
.osechi-leftpanel,
.osechi-product{
  width:100%;
  height:100%;
  display:flex;
  flex-direction:column;                               /* 中身を縦積み、CTAを下へ */
}

/* 左パネルを右カードと揃えた意匠に */
.osechi-leftpanel{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border: 1px solid rgba(208,169,51,.38);
  border-radius: 16px;
  padding: clamp(14px,2.6vw,22px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

/* === 大きい“お申込み”ボタン === */
.osechi-cta{
  margin-top: 15%;                                    /* ← 一番下に固定 */
  display:block;
  text-align:center;
  text-decoration:none;
  font-weight: 900;
  letter-spacing: .12em;
  font-size: clamp(16px,2vw,30px);
  padding: 16px 18px;
  border-radius: 12px;
  color: #1f1400;
  background:
    linear-gradient(90deg, #f7eeb8, #d0a933 40%, #b88e1c);
  border: 1px solid #dbc06a;
  box-shadow:
    0 14px 30px rgba(208,169,51,.35),
    inset 0 1px 0 rgba(255,255,255,.45);
  position: relative;
  overflow: hidden;
}
.osechi-cta small{
  display:block;
  font-size: 16px;
  letter-spacing: .06em;
  opacity: .9;
  margin-top: 2px;
  color: #3a2a07;
}

/* ボタンの“シーン”演出（高級感の光の筋） */
.osechi-cta::after{
  content:"";
  position:absolute; top:0; bottom:0; left:-25%;
  width:20%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.5), transparent);
  transform: skewX(-20deg);
  animation: btn-sheen 3.2s linear infinite;
  mix-blend-mode: screen;
}
@keyframes btn-sheen{
  0% { left:-30%; }
  100% { left:130%; }
}
.osechi-cta:hover{
  transform: translateY(-1px);
  box-shadow: 0 20px 40px rgba(208,169,51,.45), inset 0 1px 0 rgba(255,255,255,.55);
}
.osechi-cta:active{ transform: translateY(0); }

/* アニメ配慮 */
@media (prefers-reduced-motion: reduce){
  .osechi-cta::after{ animation: none; opacity: .25; }
}


