@charset "utf-8";
/* =====================
   全体設定
===================== */
#contents {
  background-color: #dcedc8;
  background-image: repeating-linear-gradient(90deg, #dcedc8, #dcedc8 5px, #e6f2d8 5px, #e6f2d8 10px);
}
#onebuy145th_cp_2606 {
  font-family: "Lexend Deca", 'Noto Sans JP', sans-serif;
}
#onebuy145th_cp_2606 img {
  width: 100%;
  height: auto;
}
#onebuy145th_cp_2606 {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0;
}
#onebuy145th_cp_2606 .cp-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0;
}
/*--------KVarea-------------*/
/* 親要素を可変＆比率固定にする */
#onebuy145th_cp_2606 .kv_area {
  position: relative;
  max-width: 1200px;
  width: 100%; /* 画面幅に合わせて縮小させる */
  margin: 0 auto;
  aspect-ratio: 1200 / 630; /* heightの代わりにアスペクト比で高さを維持 */
  overflow: hidden;
}
@media screen and (max-width: 736px) {
  /* 親要素を可変＆比率固定にする */
  #onebuy145th_cp_2606 .kv_area {
    position: relative;
    max-width: 1040px;
    width: 100%; /* 画面幅に合わせて縮小させる */
    margin: 0 auto;
    aspect-ratio: 1040 / 1040; /* heightの代わりにアスペクト比で高さを維持 */
  }
}
/* KV内の画像が枠に合わせて可変するように設定 */
#onebuy145th_cp_2606 .kv_area img {
  width: 100%;
  height: auto;
  display: block;
}
/* --- 子要素の絶対配置 --- */
.kv_img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1;
}
/* pxから％に変換 （例: 222px / 1200px * 100 = 約17.07%） */
.L01 {
  position: absolute;
  top: 2%;
  width: 9.25%; /* 元222px */
  left: -1%;
  z-index: -1;
}
.L02 {
  position: absolute;
  top: 21%;
  width: 19.416%; /* 元222px */
  left: -2%;
  z-index: -1;
}
.L03 {
  position: absolute;
  top: 1%;
  width: 14.16%; /* 元222px */
  left: 16%;
  z-index: -1;
}
.L04 {
  position: absolute;
  top: 5%;
  width: 12.75%; /* 元222px */
  left: 32%;
  z-index: -1;
}
.R04 {
  position: absolute;
  top: 30%;
  width: 12.5%; /* 元222px */
  right: 1.5%;
  z-index: -1;
}
.R03 {
  position: absolute;
  top: 13%;
  width: 8.6%; /* 元222px */
  right: 0%;
  z-index: -1;
}
.R02 {
  position: absolute;
  top: 3%;
  width: 19.3%; /* 元222px */
  right: 11%;
  z-index: -1;
}
.R01 {
  position: absolute;
  top: 1%;
  width: 18.916%; /* 元222px */
  right: 33%;
  z-index: -1;
}
@media screen and (max-width: 736px) {
  .L01 {
    position: absolute;
    top: 1%;
    width: 9.25%; /* 元222px */
    left: 3%;
    z-index: -1;
  }
  .L02 {
    position: absolute;
    top: 13%;
    width: 20%; /* 元222px */
    left: -2%;
    z-index: -1;
  }
  .L03 {
    position: absolute;
    top: 2%;
    width: 15%; /* 元222px */
    left: 15%;
    z-index: -1;
  }
  .L04 {
    position: absolute;
    top: 10%;
    width: 16%; /* 元222px */
    left: 30%;
    z-index: -1;
  }
  .R04 {
    position: absolute;
    top: 18%;
    width: 12.5%; /* 元222px */
    right: 3%;
    z-index: -1;
  }
  .R03 {
    position: absolute;
    top: 8%;
    width: 8.6%; /* 元222px */
    right: 2%;
    z-index: -1;
  }
  .R02 {
    position: absolute;
    top: 1%;
    width: 21%; /* 元222px */
    right: 13%;
    z-index: -1;
  }
  .R01 {
    position: absolute;
    top: 4%;
    width: 20%; /* 元222px */
    right: 34%;
    z-index: -1;
  }
}
/* ▼修正：対象商品がないブロックのテキストを上下中央に配置 */
#onebuy145th_cp_2606 .big-siro {
  font-size: 3rem;
  font-weight: 800;
  color: #fff;
  text-align: center;
  margin: auto; /* ★追加：親のFlexboxに対して上下左右の中央に自動配置 */
  padding: 80px 0; /* ★追加：以前のline-heightの代わりに余白で箱の高さを確保 */
  line-height: 1.2; /* ★変更：5.5emをリセットして標準的な行間に */
}
/* スクリーンリーダーには読み上げさせるが、画面上からは見えなくする汎用クラス */
#onebuy145th_cp_2606 .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
/* =====================
   タブのスタイル (SPでも3カラム維持)
===================== */
#onebuy145th_cp_2606 .cp-tabs {
  display: flex;
  list-style: none;
  padding: 0;
  margin-top: clamp(1rem, -1.379rem + 5.17vw, 2.5rem);
  margin-bottom: clamp(1.25rem, 0.259rem + 2.16vw, 1.875rem);
  gap: 10px;
}
#onebuy145th_cp_2606 .tabs-bottom {
  margin: 20px 0;
}
#onebuy145th_cp_2606 .cp-tabs li {
  flex: 1;
  position: relative;
}
#onebuy145th_cp_2606 .tab-btn {
  width: 100%;
  display: block;
  appearance: none;
  border: none;
  background-color: #ddd;
  color: #666;
  padding: 15px 5px;
  text-align: center;
  font-weight: bold;
  border-radius: 8px 8px 0 0;
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
}
#onebuy145th_cp_2606 .tabs-bottom .tab-btn {
  border-radius: 0 0 8px 8px;
}
#onebuy145th_cp_2606 .tab-btn[aria-selected="false"] {
  background-color: #757575;
  color: #fff;
}
#onebuy145th_cp_2606 .tab-btn.active {
  background-color: #0066cc;
  color: #fff;
  opacity: 1;
}
/* =====================
   タブの三角アイコン形状（共通）
===================== */
/* 上部タブの三角の形 */
#onebuy145th_cp_2606 .tabs-top .tab-btn::after {
  content: "";
  position: absolute;
  bottom: -15px;
  left: 50%;
  transform: translateX(-50%);
  border-width: 15px 15px 0 15px;
  border-style: solid;
  z-index: 10;
}
/* 下部タブの三角の形（上向き） */
#onebuy145th_cp_2606 .tabs-bottom .tab-btn::after {
  content: "";
  position: absolute;
  top: -15px;
  left: 50%;
  transform: translateX(-50%);
  border-width: 0 15px 15px 15px;
  border-style: solid;
  z-index: 10;
}
/* =====================
   タブの状態による三角アイコンの色変更
===================== */
/* アクティブ時（青色） */
#onebuy145th_cp_2606 .tabs-top .tab-btn.active::after {
  border-color: #0066cc transparent transparent transparent;
}
#onebuy145th_cp_2606 .tabs-bottom .tab-btn.active::after {
  border-color: transparent transparent #0066cc transparent;
}
/* 非アクティブ時（グレー） */
#onebuy145th_cp_2606 .tabs-top .tab-btn[aria-selected="false"]::after {
  border-color: #757575 transparent transparent transparent;
}
#onebuy145th_cp_2606 .tabs-bottom .tab-btn[aria-selected="false"]::after {
  border-color: transparent transparent #757575 transparent;
}
/* タブ内のバッジ（第1弾など） */
#onebuy145th_cp_2606 .tab-badge {
  /* display: inline-block;*/
  font-size: 1.5rem;
  margin-right: 10px;
  vertical-align: middle;
}
/* ▼修正：タブボタン内の要素を中央揃え・縦並びにする */
#onebuy145th_cp_2606 .tab-btn {
  flex-direction: column; /* バッジと日付エリアを縦に並べる */
  align-items: center;
  justify-content: center;
  gap: 5px; /* 上下の隙間 */
}
/* ▼追加：日付と曜日のデザイン（タブ用） */
#onebuy145th_cp_2606 .cp-tabs .date-num {
  font-size: clamp(1rem, 0.207rem + 1.72vw, 1.5rem);
  margin: 0;
  vertical-align: middle;
}
#onebuy145th_cp_2606 .cp-tabs .day-circle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.3em;
  height: 1.3em;
  border-radius: 50%;
  background-color: #fff;
  color: #0066cc;
  font-size: 1.0rem;
  margin: 0 2px;
  vertical-align: middle; /* ★追加：曜日も縦中央に指定 */
}
#onebuy145th_cp_2606 .tab-btn[aria-selected="false"] .day-circle {
  color: #757575;
}
#onebuy145th_cp_2606 .cp-tabs .date-num:nth-of-type(4)::before {
  content: "▶︎";
  display: inline-block;
  vertical-align: middle;
  margin: 0 3px;
  color: #fff;
  font-size: 1.3rem;
  transform: translateY(-9%) scaleX(0.6);
}
/* ▼修正：クラス指定で「▶︎」を追加（パネル用とタブ用で共通） */
/* パネル内の3番目のspan、またはタブ内で has-arrow クラスがついたspan */
#onebuy145th_cp_2606 .dates .date-num:nth-of-type(3)::before, #onebuy145th_cp_2606 .cp-tabs .has-arrow::before {
  content: "▶︎";
  display: inline-block;
  vertical-align: middle;
  margin: 0 10px; /* PC用：左右の余白 */
  color: #fff;
  font-size: 1.0rem;
  transform: translateY(-5%) scaleX(0.6);
}
@media screen and (max-width: 736px) {
  #onebuy145th_cp_2606 .cp-tabs .day-circle {
    width: 1.4em;
    height: 1.4em;
    border-radius: 50%;
    background-color: #fff;
    color: #0066cc;
    font-size: 0.6rem;
    margin: 0 1px;
  }
}
/* =====================
   パネルと枠線
===================== */
#onebuy145th_cp_2606 .panel-inner-box {
  background-color: #fff;
  border: 1px solid #0066cc;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}
#onebuy145th_cp_2606 .campaign-title {
  background-color: #cce0f5;
  /*border: 4px solid #0066CC;
	border-top-left-radius: 10px;
	border-top-right-radius: 10px;*/
  color: #0060BF;
  font-size: clamp(1.3rem, 0.666rem + 1.38vw, 1.7rem);
  text-align: center;
  padding: clamp(0.8rem, 0.483rem + 0.69vw, 1rem);
  margin: 0;
}
#onebuy145th_cp_2606 .campaign-title > span {
  font-size: 85%;
  margin: 0 15px;
}
/* =====================
   発券・引換期間エリア
===================== */
#onebuy145th_cp_2606 .campaign-periods {
  display: flex;
  gap: 40px; /* ★変更：間を空ける */
  padding: 30px 20px 10px;
}
#onebuy145th_cp_2606 .period-buy-block, #onebuy145th_cp_2606 .period-get-block {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}
/* ▼修正：箱の高さが自動で揃うように flex-grow を追加 */
#onebuy145th_cp_2606 .period-box {
  width: 85%;
  /* text-align: center; （flexにしたので削除またはそのままでも可）*/
  border-radius: 8px;
  padding: 20px;
  position: relative;
  margin-bottom: 25px;
  /* 以下3行を追加 */
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  flex-grow: 1; /* ★これによって青箱と赤箱の高さが揃う */
}
#onebuy145th_cp_2606 .period-box::after {
  content: "";
  position: absolute;
  bottom: -15px;
  left: 50%;
  transform: translateX(-50%);
  border-width: 15px 15px 0 15px;
  border-style: solid;
}
#onebuy145th_cp_2606 .blue-box {
  background-color: #0066cc;
  color: #fff;
}
#onebuy145th_cp_2606 .blue-box::after {
  border-color: #0066cc transparent transparent transparent;
}
#onebuy145th_cp_2606 .red-box {
  background-color: #e60012;
  color: #fff;
}
#onebuy145th_cp_2606 .red-box::after {
  border-color: #e60012 transparent transparent transparent;
}
#onebuy145th_cp_2606 .pill {
  display: inline-block;
  width: 100%;
  background-color: #ffea00;
  color: #333;
  text-align: center;
  font-size: clamp(0.95rem, 0.078rem + 1.9vw, 1.5rem);
  font-weight: bold;
  padding: 2px 0px;
  border-radius: 20px;
  margin-bottom: clamp(0.625rem, 0.129rem + 1.08vw, 0.938rem);
}
#onebuy145th_cp_2606 .dates {
  font-size: 2.8rem;
  font-weight: bold;
  line-height: 1.1;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}
#onebuy145th_cp_2606 .dates small {
  font-size: 1.1rem;
  margin: 0 5px;
}
/* ▼追加：日付と曜日のデザイン */
#onebuy145th_cp_2606 .date-num {
  margin-top: -4px;
  margin-right: 5px;
}
#onebuy145th_cp_2606 .day-circleB {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5em;
  height: 1.5em;
  border-radius: 50%;
  background-color: #fff;
  color: #0066cc; /* またはそれぞれの箱の色に合わせて変更 */
  font-size: 1.4rem;
}
#onebuy145th_cp_2606 .day-circleR {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5em;
  height: 1.5em;
  border-radius: 50%;
  background-color: #fff;
  color: #e60012; /* またはそれぞれの箱の色に合わせて変更 */
  font-size: 1.4rem;
}
/* ▼追加：疑似要素で「▶︎」を追加 */
#onebuy145th_cp_2606 .dates .date-num:nth-of-type(3)::before {
  content: "▶︎";
  display: inline-block;
  vertical-align: middle;
  margin: 0 5px 0 5px;
  color: #fff;
  font-size: 2rem;
  transform: translateY(-15%) scaleX(0.6);
}
/* ▼追加：新しく追加したラッパー要素にもFlexboxを適用し、縦中央揃えを復活させる */
#onebuy145th_cp_2606 .dates [aria-hidden="true"] {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}
#onebuy145th_cp_2606 .big-text {
  font-size: 5rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -2px;
}
#onebuy145th_cp_2606 .blue-text {
  color: #0066cc;
}
#onebuy145th_cp_2606 .green-text {
  color: #00a040;
}
#onebuy145th_cp_2606 .receipt-note {
  text-align: right;
  font-size: clamp(0.75rem, 0.434rem + 0.69vw, 0.95rem);
  color: #333;
  margin-right: 10px;
}
/* =====================
   対象商品タイトル (h3)
===================== */
#onebuy145th_cp_2606 .target-products-title {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(1.2rem, 0.726rem + 1.03vw, 1.5rem);
  color: #333;
  margin: 10px 20px 20px;
}
#onebuy145th_cp_2606 .target-products-title::before, #onebuy145th_cp_2606 .target-products-title::after {
  content: "";
  flex-grow: 1;
  height: 1px;
  background-color: #999;
}
#onebuy145th_cp_2606 .target-products-title span {
  padding: 0 15px;
}
/* =====================
   レイアウト (PC 2カラム / SP 1カラム)
===================== */
#onebuy145th_cp_2606 .item-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  padding: 0 20px 20px;
}
/* =====================
   買う・もらえる アイテムデザイン
===================== */
#onebuy145th_cp_2606 .cp-item {
  display: flex;
  align-items: stretch;
  width: 100%;
  height: 100%;
  gap: 0;
}
/* 買う（青） */
#onebuy145th_cp_2606 .item-buy {
  background-color: #0066cc;
  clip-path: polygon(0 0, 92% 0, 100% 50%, 92% 100%, 0 100%);
  width: 54%;
  padding: 15px 7% 15px 15px;
  display: flex;
  flex-direction: column;
  z-index: 2;
  min-width: 0;
  border-radius: 8px;
}
/* もらえる（緑） */
#onebuy145th_cp_2606 .item-get {
  background-color: #00a040;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%, 8% 50%);
  width: 54%;
  margin-left: -3.5%;
  padding: 15px 15px 15px 7%;
  display: flex;
  flex-direction: column;
  z-index: 1;
  min-width: 0;
  border-top-right-radius: 8px;
  border-bottom-right-radius: 8px;
}
#onebuy145th_cp_2606 .item-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: drop-shadow(4px 4px 4px #333);
}
/* テキスト詳細エリア */
#onebuy145th_cp_2606 .item-details {
  background-color: #fff;
  border-radius: 6px;
  padding: clamp(0.438rem, 0.141rem + 0.65vw, 0.625rem);
  margin-top: 15px;
  flex-grow: 1; /* ★変更：親の高さに合わせて伸びる */
  display: flex;
  flex-direction: column;
  min-width: 0;
  height: 100%; /* ★追加：高さを100%にする */
  letter-spacing: -0.03em;
  font-feature-settings: "halt";
}
#onebuy145th_cp_2606 .maker-name {
  font-size: clamp(0.75rem, 0.592rem + 0.34vw, 0.85rem);
  font-weight: bold;
  margin: 0 0 3px 0;
}
#onebuy145th_cp_2606 .product-name {
  font-size: clamp(0.9rem, 0.821rem + 0.17vw, 0.95rem);
  font-weight: bold;
  margin: 0 0 8px 0;
  line-height: 1.3;
}
/* 商品の種類 */
#onebuy145th_cp_2606 .product-types {
  list-style: none;
  padding: 0;
  margin: 0 0 8px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
#onebuy145th_cp_2606 .date {
  color: #e30000;
  font-size: font-size: clamp(0.9rem, 0.821rem + 0.17vw, 0.95rem);
  font-weight: bold;
  margin-right: 5px;
}
#onebuy145th_cp_2606 .product-types li {
  font-size: clamp(0.9rem, 0.821rem + 0.17vw, 0.95rem);
  line-height: 1.1;
  font-weight: bold;
  white-space: normal;
  word-break: break-word;
}
#onebuy145th_cp_2606 .product-types li::before {
  content: '●';
  margin-right: 2px;
  font-size: 0.6rem;
}
#onebuy145th_cp_2606 .product-notes {
  list-style: none;
  padding: 0;
  margin: auto 0 0 0;
}
#onebuy145th_cp_2606 .product-notes li {
  font-size: 0.7rem;
  line-height: 1.4;
  padding-left: 1em;
  text-indent: -1em;
}
#onebuy145th_cp_2606 .product-notes li::before {
  content: '※';
}
/* =====================
   ブレイクポイント (SP対応)
===================== */
@media screen and (max-width: 736px) {
  #onebuy145th_cp_2606 {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    padding: 0;
    margin-top: -10px;
  }
  #onebuy145th_cp_2606 .cp-container {
    max-width: 100%;
    margin: 0 auto;
    padding: 0;
  }
  #onebuy145th_cp_2606 .item-grid {
    grid-template-columns: 1fr;
    padding: 0 10px 20px;
  }
  #onebuy145th_cp_2606 .cp-tabs {
    gap: 5px;
  }
  #onebuy145th_cp_2606 .tab-btn {
    padding: 5px 2px 10px;
  }
  #onebuy145th_cp_2606 .tab-badge, #onebuy145th_cp_2606 .tab-date {
    /*display: block;*/
    font-size: 0.95rem;
    margin: 0 auto;
  }
  /* 期間エリアの調整 */
  #onebuy145th_cp_2606 .campaign-periods {
    padding: 20px 10px 10px;
    gap: 20px; /* ★変更：SP時も少し間を空ける */
  }
  #onebuy145th_cp_2606 .dates {
    font-size: 1rem;
  }
  #onebuy145th_cp_2606 .big-text {
    font-size: 2.4rem;
  }
  /* アイテムの矢印の微調整 */
  #onebuy145th_cp_2606 .item-buy {
    padding: 10px 7% 10px 10px;
  }
  #onebuy145th_cp_2606 .item-get {
    padding: 10px 10px 10px 7%;
  }
  /* =====================
   発券・引換期間エリア
===================== */
  #onebuy145th_cp_2606 .campaign-periods {
    display: flex;
    gap: 20px; /* ★変更：間を空ける */
    padding: 20px 20px 10px;
  }
  #onebuy145th_cp_2606 .period-buy-block, #onebuy145th_cp_2606 .period-get-block {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
  }
  /* ▼修正：SP用の指定にも追記 */
  #onebuy145th_cp_2606 .period-box {
    width: 95%;
    border-radius: 8px;
    padding: 10px;
    position: relative;
    margin-bottom: 25px;
    /* 以下3行を追加 */
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    flex-grow: 1; /* ★これによって青箱と赤箱の高さが揃う */
  }
  #onebuy145th_cp_2606 .period-box::after {
    content: "";
    position: absolute;
    bottom: -15px;
    left: 50%;
    transform: translateX(-50%);
    border-width: 15px 15px 0 15px;
    border-style: solid;
  }
  #onebuy145th_cp_2606 .blue-box {
    background-color: #0066cc;
    color: #fff;
  }
  #onebuy145th_cp_2606 .blue-box::after {
    border-color: #0066cc transparent transparent transparent;
  }
  #onebuy145th_cp_2606 .red-box {
    background-color: #e60012;
    color: #fff;
  }
  #onebuy145th_cp_2606 .red-box::after {
    border-color: #e60012 transparent transparent transparent;
  }
  #onebuy145th_cp_2606 .dates {
    font-size: 1.1rem;
    font-weight: bold;
    line-height: 1.1;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
  }
  #onebuy145th_cp_2606 .dates small {
    font-size: 0.8rem;
    margin-left: 2px;
    margin-right: 0;
  }
  /* ▼追加：日付と曜日のデザイン */
  #onebuy145th_cp_2606 .date-num {
    font-size: 1.2rem;
    margin: 0 3px 0 0;
  }
  #onebuy145th_cp_2606 .day-circleB {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.0rem;
    height: 1.0rem;
    border-radius: 50%;
    background-color: #fff;
    color: #0066cc; /* またはそれぞれの箱の色に合わせて変更 */
    font-size: .7rem;
  }
  #onebuy145th_cp_2606 .day-circleR {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.0rem;
    height: 1.0rem;
    border-radius: 50%;
    background-color: #fff;
    color: #e60012; /* またはそれぞれの箱の色に合わせて変更 */
    font-size: .7rem;
  }
  /* ▼追加：疑似要素で「▶︎」を追加 */
  #onebuy145th_cp_2606 .dates .date-num:nth-of-type(3)::before, #onebuy145th_cp_2606 .cp-tabs .has-arrow::before {
    content: "▶︎";
    display: inline-block; /* ★追加：余白や縦位置の調整を有効にする */
    vertical-align: middle; /* ★追加：縦方向の中央に揃える */
    margin: 0; /* 左右の余白（少し右の余白を広げて均等に見せています） */
    color: #fff;
    font-size: .8rem;
    transform: translateY(-20%) scaleX(0.6);
  }
  /* ▼修正：スマホ表示時のタブ内の「▶︎」サイズ調整 */
  #onebuy145th_cp_2606 .cp-tabs .has-arrow::before {
    margin: 0 5px; /* SP用：左右の余白を少し狭める */
    font-size: 0.8rem; /* スマホサイズに合わせて微調整 */
  }
  #onebuy145th_cp_2606 .cp-tabs .date-num:nth-of-type(4)::before {
    content: "▶︎";
    display: inline-block;
    vertical-align: middle;
    margin: 0;
    color: #fff;
    font-size: 0.7rem;
    transform: translateY(-5%) scaleX(0.6);
  }
}
/* タブの非表示属性(hidden)を確実に機能させるための強制設定 */
#onebuy145th_cp_2606 [hidden] {
  display: none !important;
}
/* =====================
   花火アニメーション（キーフレーム）
===================== */
@keyframes hanabi-burst {
  0% {
    opacity: 0;
    transform: translateY(50px) scale(0); /* 下の方から極小サイズで現れる */
  }
  40% {
    opacity: 0.8;
    transform: translateY(0) scale(0.1); /* 打ち上がりきった状態（まだ開いていない） */
  }
  70% {
    opacity: 1;
    transform: translateY(0) scale(1.1); /* パーン！と少し大きめに弾ける */
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1); /* 本来のサイズでピタッと定着する */
  }
}
/* =====================
   花火の共通設定
===================== */
.firework-anim {
  opacity: 0; /* アニメーション開始前は見えないようにする */
  transform-origin: center center;
  /* ★変更：infinite(無限ループ)を forwards(最後の状態で止まる) に変更 */
  animation: hanabi-burst 1.5s ease-out forwards;
}
/* =====================
   8つの花火の時間差（ディレイ）設定
===================== */
/* ★ここは前回から変更なしです。そのまま残してください */
.fw-delay-1 {
  animation-delay: 0s;
}
.fw-delay-2 {
  animation-delay: 0.4s;
}
.fw-delay-3 {
  animation-delay: 1.2s;
}
.fw-delay-4 {
  animation-delay: 0.8s;
}
.fw-delay-5 {
  animation-delay: 1.6s;
}
.fw-delay-6 {
  animation-delay: 2.2s;
}
.fw-delay-7 {
  animation-delay: 2.6s;
}
.fw-delay-8 {
  animation-delay: 1.8s;
}