/* ==========================================================================
   home-2026.css — and-u.jp 寄せのトップページ (信頼感 × 選択肢の豊かさ)
   大型ヒーロー / 3つのこだわり / ランキング / 年代別 / フロー / 信頼バナー / マガジン
   ========================================================================== */

/* ==========================================================================
   1. Hybrid Hero — 左コピー (45%) × 右写真 (55%) + 刷り物オーバーレイ
   ========================================================================== */
.home-hero {
  position: relative;
  min-height: min(86vh, 780px);
  overflow: hidden;
  display: grid;
  place-items: center;
  padding: var(--space-9) 0 var(--space-8);
  background:
    radial-gradient(ellipse 80% 60% at 15% 15%, rgba(217, 149, 101, 0.14) 0%, transparent 55%),
    radial-gradient(ellipse 70% 60% at 85% 90%, var(--c-primary-soft) 0%, transparent 50%),
    radial-gradient(ellipse 60% 80% at 92% 8%, rgba(217, 184, 106, 0.14) 0%, transparent 50%),
    linear-gradient(180deg, #fffcf7 0%, var(--c-bg-alt) 60%, var(--c-primary-veil) 100%);
  isolation: isolate;
}
/* 微細グレイン */
.home-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(20,20,20,0.035) 1px, transparent 0);
  background-size: 3px 3px;
  mix-blend-mode: multiply;
  pointer-events: none;
  opacity: 0.5;
}

.home-hero__inner {
  position: relative;
  z-index: 2;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: var(--space-7) var(--space-5);
  width: 100%;
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: var(--space-8);
  align-items: center;
}
.home-hero--split .home-hero__content { text-align: left; }
.home-hero__content { display: block; }

.home-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-display);
  font-size: var(--fz-sm);
  color: var(--c-text);
  font-weight: var(--fw-medium);
  margin-bottom: var(--space-5);
  padding: var(--space-2) var(--space-4);
  background: rgba(255,255,255,0.7);
  border: 1px solid var(--c-line);
  border-radius: var(--radius-full);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  letter-spacing: 0.02em;
}
.home-hero__eyebrow strong {
  font-weight: var(--fw-bold);
  color: var(--c-primary-ink);
  letter-spacing: 0.08em;
}
.home-hero__hi { color: var(--c-text-muted); }

.home-hero__title {
  font-family: var(--font-display);
  font-size: clamp(30px, 3.6vw, 48px);
  line-height: 1.24;
  color: var(--c-text);
  margin: 0 0 var(--space-5);
  font-weight: var(--fw-bold);
  letter-spacing: var(--lt-tight);
  max-width: 14ch;
}
.home-hero--split .home-hero__title { max-width: none; }
.home-hero__title em {
  font-style: normal;
  color: var(--c-primary-ink);
  position: relative;
  display: inline-block;
  padding: 0 .1em;
}
.home-hero__title em::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: .08em;
  height: .22em;
  background: var(--c-primary-soft);
  z-index: -1;
  border-radius: 2px;
}

.home-hero__sub {
  font-size: var(--fz-md);
  color: var(--c-text-muted);
  line-height: 1.9;
  margin: 0 0 var(--space-6);
  max-width: 52ch;
  font-feature-settings: "palt";
}
.home-hero__sub strong {
  color: var(--c-text);
  font-weight: var(--fw-semibold);
  background: linear-gradient(transparent 62%, var(--c-yellow-soft) 62%);
  padding: 0 2px;
}

.home-hero__ctas {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  justify-content: flex-start;
  margin-bottom: var(--space-5);
}
/* Hero 下部の信頼バッジ列 */
.home-hero__badges {
  list-style: none;
  margin: 0;
  padding: var(--space-4) 0 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: var(--space-3) var(--space-5);
  border-top: 1px dashed rgba(26,26,32,0.15);
  width: 100%;
}
.home-hero__badges li {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fz-sm);
  color: var(--c-text);
  font-weight: var(--fw-medium);
}
.home-hero__badges svg {
  color: var(--c-primary);
  flex-shrink: 0;
}

/* ---------- 背景ステージ (ハイブリッド版: 控えめデコ) ---------- */
.home-hero__stage-bg {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}

/* ---------- 右側ビジュアル枠 ---------- */
.home-hero__visual {
  position: relative;
  aspect-ratio: 4 / 5;
  width: 100%;
  max-height: 620px;
  justify-self: end;
  max-width: 560px;
}
.home-hero__photo-wrap {
  position: absolute;
  inset: 0;
  overflow: hidden;
  border-radius: 4px;
  background: linear-gradient(145deg, var(--c-primary-veil) 0%, var(--c-bg-warm) 100%);
  box-shadow:
    0 40px 80px -30px rgba(0,0,0,0.22),
    0 18px 40px -18px rgba(0,0,0,0.12);
  z-index: 1;
}
.home-hero__photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 2;
  opacity: 0;
  animation: hero-photo-in 600ms var(--ease-out) 100ms forwards;
}
@keyframes hero-photo-in {
  from { opacity: 0; transform: scale(1.03); }
  to   { opacity: 1; transform: scale(1); }
}

/* 写真フォールバック (ファイル未配置時に表示) */
.home-hero__photo-fallback {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  align-content: center;
  gap: var(--space-2);
  text-align: center;
  color: var(--c-primary-ink);
  font-family: var(--font-display);
  z-index: 1;
  background-image:
    repeating-linear-gradient(45deg, rgba(199,139,139,0.12) 0 14px, transparent 14px 28px);
}
.home-hero__photo-fallback-label {
  font-size: var(--fz-sm);
  letter-spacing: var(--lt-x-wide);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
}
.home-hero__photo-fallback-sub {
  font-size: 11px;
  color: var(--c-text-muted);
  font-family: var(--font-sans);
}
/* 画像ロード成功時は fallback を隠す */
.home-hero__photo-wrap:has(.home-hero__photo:not([hidden])) .home-hero__photo-fallback {
  display: none;
}

/* ピンクのずれた装飾枠 */
.home-hero__photo-accent {
  position: absolute;
  z-index: 0;
  top: 24px;
  left: 24px;
  right: -24px;
  bottom: -24px;
  border: 1.5px solid var(--c-primary);
  border-radius: 4px;
  pointer-events: none;
}

/* ---------- 写真の縁から飛び出す刷り物 (オーバーレイ版) ---------- */
.home-hero__visual .hero-paper--overlay {
  position: absolute;
  z-index: 3;
  animation-duration: 18s;
}
.home-hero__visual .hero-paper--overlay.hero-paper--card {
  width: 170px;
  aspect-ratio: 91 / 55;
  top: 10%;
  left: -16%;
  transform: rotate(-10deg);
  animation-delay: -4s;
}
.home-hero__visual .hero-paper--overlay.hero-paper--shopcard {
  width: 150px;
  aspect-ratio: 91 / 55;
  bottom: 12%;
  left: -12%;
  transform: rotate(12deg);
  animation-delay: -2s;
}
.home-hero__visual .hero-paper--overlay.hero-paper--flyer {
  width: 140px;
  aspect-ratio: 210 / 297;
  top: 50%;
  right: -10%;
  transform: translateY(-50%) rotate(8deg);
  animation-delay: -6s;
}
@keyframes hero-float-h {
  0%, 100% { translate: 0 0; }
  50% { translate: -6px -8px; }
}
.home-hero__visual .hero-paper--overlay {
  animation-name: hero-float-h;
}
.hero-paper {
  position: absolute;
  display: block;
  background: #fff;
  box-shadow:
    0 28px 60px -20px rgba(20,16,12,0.28),
    0 10px 24px -10px rgba(20,16,12,0.14);
  will-change: transform;
  animation: hero-float 14s ease-in-out infinite;
}
.hero-paper > .hero-paper__inner {
  display: block;
  padding: 14% 12%;
  box-sizing: border-box;
  height: 100%;
}

/* A: チラシ (A4縦) 左上 */
.hero-paper--flyer {
  width: 180px;
  aspect-ratio: 210 / 297;
  top: 8%;
  left: -3%;
  transform: rotate(-13deg);
  background: linear-gradient(160deg, #fff 0%, var(--c-primary-veil) 100%);
  animation-delay: -2s;
}
.hero-paper--flyer .hero-paper__title-bar {
  display: block;
  width: 70%;
  height: 10px;
  background: var(--c-primary);
  margin-bottom: 10px;
}
.hero-paper--flyer .hero-paper__line {
  display: block;
  width: 100%;
  height: 3px;
  background: #d8d2c9;
  margin-bottom: 6px;
}
.hero-paper--flyer .hero-paper__line:nth-of-type(2) { width: 88%; }
.hero-paper--flyer .hero-paper__block {
  display: block;
  margin-top: 12px;
  width: 60%;
  aspect-ratio: 1 / 1;
  background: linear-gradient(135deg, var(--c-orange-soft), var(--c-yellow-soft));
}

/* B: 名刺 右上 */
.hero-paper--card {
  width: 170px;
  aspect-ratio: 91 / 55;
  top: 14%;
  right: -2%;
  transform: rotate(9deg);
  background: linear-gradient(145deg, #fff 0%, var(--c-bg-alt) 100%);
  padding: 14px 18px;
  animation-delay: -5s;
}
.hero-paper--card .hero-paper__name {
  display: block;
  width: 60%;
  height: 10px;
  background: var(--c-text);
  margin-top: 20%;
  margin-bottom: 8px;
}
.hero-paper--card .hero-paper__meta {
  display: block;
  width: 80%;
  height: 4px;
  background: var(--c-text-muted);
  opacity: 0.45;
}

/* C: チケット 右中 */
.hero-paper--ticket {
  width: 220px;
  aspect-ratio: 7 / 2.4;
  top: 50%;
  right: 2%;
  transform: rotate(-7deg);
  background: var(--c-primary);
  color: #fff;
  padding: 10px 16px;
  animation-delay: -8s;
  overflow: hidden;
}
.hero-paper--ticket::before {
  content: "";
  position: absolute;
  top: 10%;
  bottom: 10%;
  right: 28%;
  width: 1px;
  background-image: linear-gradient(to bottom, #fff 0, #fff 4px, transparent 4px, transparent 8px);
  background-size: 1px 8px;
}
.hero-paper--ticket .hero-paper__ticket-stub {
  display: block;
  position: absolute;
  right: 8%;
  top: 50%;
  transform: translateY(-50%);
  font-size: 10px;
  letter-spacing: 0.15em;
  color: #fff;
  font-weight: 700;
}
.hero-paper--ticket .hero-paper__ticket-stub::before {
  content: "TICKET";
}

/* D: ショップカード 左中 */
.hero-paper--shopcard {
  width: 150px;
  aspect-ratio: 91 / 55;
  top: 55%;
  left: 3%;
  transform: rotate(14deg);
  background: linear-gradient(135deg, var(--c-primary-veil), #fff);
  padding: 16px;
  animation-delay: -3s;
}
.hero-paper--shopcard .hero-paper__shop-dot {
  display: block;
  width: 20px;
  height: 20px;
  background: var(--c-primary);
  border-radius: 50%;
  margin-bottom: 10px;
}
.hero-paper--shopcard .hero-paper__line {
  display: block;
  width: 70%;
  height: 4px;
  background: var(--c-text);
  opacity: 0.55;
}

/* E: CDジャケット 左下 */
.hero-paper--cd {
  width: 150px;
  aspect-ratio: 1 / 1;
  bottom: 4%;
  left: 8%;
  transform: rotate(-10deg);
  background:
    radial-gradient(circle at center, #fff 30%, transparent 32%),
    linear-gradient(135deg, var(--c-blue-soft) 0%, var(--c-bg-warm) 100%);
  animation-delay: -6s;
}
.hero-paper--cd .hero-paper__cd-hole {
  position: absolute;
  top: 50%; left: 50%;
  width: 18px; height: 18px;
  background: var(--c-text);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.8);
}

/* F: ポスター (大・奥) 右下 */
.hero-paper--poster {
  width: 200px;
  aspect-ratio: 3 / 4;
  bottom: 2%;
  right: 5%;
  transform: rotate(5deg);
  background: linear-gradient(180deg, var(--c-yellow-soft) 0%, #fff 100%);
  padding: 16px;
  animation-delay: -11s;
  opacity: 0.85;
}
.hero-paper--poster .hero-paper__poster-title {
  display: block;
  width: 80%;
  height: 14px;
  background: var(--c-primary-ink);
  margin-bottom: 8px;
}
.hero-paper--poster::after {
  content: "";
  position: absolute;
  left: 16px;
  top: 50%;
  width: 60%;
  height: 30%;
  background: linear-gradient(135deg, var(--c-orange-soft) 0%, var(--c-primary-soft) 100%);
  border-radius: 999px;
  transform: rotate(15deg);
}

/* きらめき (小さな丸) */
.hero-sparkle {
  position: absolute;
  width: 8px;
  height: 8px;
  background: var(--c-primary);
  border-radius: 50%;
  opacity: 0.55;
  animation: hero-sparkle 4s ease-in-out infinite;
}
.hero-sparkle--1 { top: 22%; left: 30%; width: 10px; height: 10px; animation-delay: 0s; }
.hero-sparkle--2 { top: 40%; right: 25%; background: var(--c-yellow); width: 6px; height: 6px; animation-delay: -1.5s; }
.hero-sparkle--3 { bottom: 25%; left: 22%; background: var(--c-orange); width: 8px; height: 8px; animation-delay: -3s; }
.hero-sparkle--4 { top: 15%; right: 15%; background: var(--c-primary-ink); width: 5px; height: 5px; opacity: 0.8; animation-delay: -2s; }
.hero-sparkle--5 { top: 70%; right: 38%; background: var(--c-green); width: 7px; height: 7px; animation-delay: -2.5s; }
.hero-sparkle--6 { bottom: 30%; right: 12%; background: var(--c-primary); width: 9px; height: 9px; animation-delay: -0.5s; }
.hero-sparkle--7 { top: 50%; left: 18%; background: var(--c-accent); width: 6px; height: 6px; animation-delay: -3.5s; }

/* G: ポストカード 中下 */
.hero-paper--postcard {
  width: 130px;
  aspect-ratio: 148 / 100;
  bottom: 20%;
  right: 18%;
  transform: rotate(11deg);
  background: linear-gradient(160deg, #fff 0%, var(--c-accent-soft) 100%);
  animation-delay: -9s;
}
.hero-paper--postcard::before {
  content: "";
  position: absolute;
  top: 14%;
  left: 14%;
  right: 50%;
  height: 2px;
  background: var(--c-text-muted);
  opacity: 0.35;
  box-shadow: 0 6px 0 rgba(106,106,114,0.3), 0 12px 0 rgba(106,106,114,0.25);
}
.hero-paper--postcard .hero-paper__stamp {
  position: absolute;
  top: 12%;
  right: 12%;
  width: 22px;
  height: 28px;
  background: var(--c-primary);
  border: 2px dashed #fff;
  box-shadow: 0 0 0 1px var(--c-primary);
}

/* H: 封筒 (大型、斜めに奥) 右下 */
.hero-paper--envelope {
  width: 160px;
  aspect-ratio: 3 / 2;
  bottom: 30%;
  left: 17%;
  transform: rotate(-6deg);
  background: linear-gradient(180deg, var(--c-bg-warm) 0%, #fff 100%);
  overflow: hidden;
  animation-delay: -12s;
}
.hero-paper--envelope::before,
.hero-paper--envelope::after {
  content: "";
  position: absolute;
  background: rgba(199, 139, 139, 0.3);
}
.hero-paper--envelope::before {
  top: 0; left: 0; right: 0; height: 50%;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background: rgba(199, 139, 139, 0.15);
}
.hero-paper--envelope::after {
  top: 0; left: 0; right: 0; height: 50%;
  clip-path: polygon(0 0, 50% 98%, 100% 0, 100% 2%, 50% 100%, 0 2%);
  background: var(--c-primary);
  opacity: 0.35;
}

/* I: 商品タグ 上中 */
.hero-paper--tag {
  width: 64px;
  aspect-ratio: 3 / 4;
  top: 8%;
  left: 48%;
  transform: rotate(-18deg);
  background:
    radial-gradient(circle at 50% 10%, var(--c-text) 0 5px, transparent 5px),
    linear-gradient(180deg, var(--c-yellow-soft) 0%, #fff 100%);
  clip-path: polygon(50% 0, 100% 15%, 100% 100%, 0 100%, 0 15%);
  animation-delay: -7s;
}
.hero-paper--tag::before {
  content: "";
  position: absolute;
  inset: 25% 15% 15%;
  border-top: 1.5px dashed var(--c-accent-ink);
  opacity: 0.5;
}

/* 手描き装飾ライン */
.hero-scribble {
  position: absolute;
  pointer-events: none;
  z-index: 1;
}
.hero-scribble--1 { top: 30%; left: 8%; transform: rotate(-8deg); opacity: 0.6; }
.hero-scribble--2 { bottom: 18%; right: 25%; opacity: 0.55; }

@keyframes hero-float {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -10px; }
}
@keyframes hero-sparkle {
  0%, 100% { transform: scale(0.6); opacity: 0.3; }
  50% { transform: scale(1); opacity: 0.8; }
}
@media (prefers-reduced-motion: reduce) {
  .hero-paper, .hero-sparkle { animation: none; }
}

/* タブレット以下: 縦積み + 刷り物間引き */
@media (max-width: 991px) {
  .home-hero { min-height: auto; padding: var(--space-7) 0 var(--space-6); }
  .home-hero__inner {
    grid-template-columns: 1fr;
    gap: var(--space-6);
    padding: var(--space-5);
  }
  .home-hero--split .home-hero__content { order: 1; text-align: left; }
  .home-hero__visual { order: 2; max-width: 460px; justify-self: center; aspect-ratio: 5 / 4; }
  .home-hero__visual .hero-paper--overlay.hero-paper--card { width: 130px; top: -8%; left: -4%; }
  .home-hero__visual .hero-paper--overlay.hero-paper--shopcard { width: 120px; bottom: -6%; left: 4%; }
  .home-hero__visual .hero-paper--overlay.hero-paper--flyer { width: 110px; top: 58%; right: -3%; }
  .home-hero__photo-accent { top: 16px; left: 16px; right: -16px; bottom: -16px; }
  .hero-scribble { display: none; }
}
@media (max-width: 767px) {
  .home-hero::before { opacity: 0.3; }
  .home-hero__visual { max-width: 340px; aspect-ratio: 4 / 5; }
  .home-hero__visual .hero-paper--overlay.hero-paper--card { width: 100px; top: -6%; left: -6%; }
  .home-hero__visual .hero-paper--overlay.hero-paper--shopcard { width: 90px; bottom: -5%; left: 6%; }
  .home-hero__visual .hero-paper--overlay.hero-paper--flyer { width: 85px; top: 62%; right: -5%; }
  .home-hero__photo-accent { top: 10px; left: 10px; right: -10px; bottom: -10px; }
  .hero-sparkle { opacity: 0.4; }
  .home-hero__title {
    font-size: clamp(28px, 8vw, 36px);
    line-height: 1.3;
    max-width: 100%;
    letter-spacing: -0.02em;
  }
  .home-hero__eyebrow {
    font-size: var(--fz-xs);
    padding: var(--space-1) var(--space-3);
  }
  .home-hero__sub { font-size: var(--fz-sm); line-height: 1.85; }
  .home-hero__ctas { flex-direction: column; width: 100%; }
  .home-hero__ctas .cta { width: 100%; justify-content: center; }
  .home-hero__badges {
    padding: var(--space-3) 0 0;
    gap: var(--space-2) var(--space-3);
    justify-content: flex-start;
    flex-wrap: wrap;
  }
  .home-hero__badges li { font-size: var(--fz-xs); }
  .home-hero__badges svg { width: 14px; height: 14px; }
}

/* ==========================================================================
   2. 3つのこだわり (Why ANDYOU 風セクション)
   ========================================================================== */
.home-commit {
  padding: var(--space-10) 0;
  background: var(--c-surface);
}
.home-commit__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-7);
  margin-top: var(--space-8);
}
.commit-item {
  text-align: center;
  padding: 0 var(--space-4);
  position: relative;
}
.commit-item__num {
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--fz-5xl);
  font-weight: var(--fw-regular);
  color: var(--c-primary-soft);
  line-height: 1;
  letter-spacing: -0.04em;
  margin-bottom: var(--space-3);
}
.commit-item__title {
  font-family: var(--font-display);
  font-size: var(--fz-xl);
  font-weight: var(--fw-semibold);
  color: var(--c-text);
  margin: 0 0 var(--space-3);
  line-height: 1.4;
}
.commit-item__title strong {
  color: var(--c-primary-ink);
}
.commit-item__body {
  font-size: var(--fz-sm);
  color: var(--c-text-muted);
  line-height: var(--lh-base);
  margin-bottom: var(--space-4);
}
.commit-item__metric {
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--fz-lg);
  font-weight: var(--fw-bold);
  color: var(--c-primary-ink);
  padding: var(--space-2) var(--space-4);
  background: var(--c-primary-veil);
  letter-spacing: var(--lt-tight);
}
@media (max-width: 767px) {
  .home-commit__grid { grid-template-columns: 1fr; gap: var(--space-6); }
}

/* ==========================================================================
   3. ランキング (番号バッジ付きカード)
   ========================================================================== */
.home-ranking {
  padding: var(--space-10) 0;
  background: var(--c-bg-alt);
}
.ranking-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-7);
}
.ranking-card {
  background: var(--c-surface);
  text-decoration: none;
  color: inherit;
  position: relative;
  transition: transform var(--dur-base);
}
.ranking-card:hover { transform: translateY(-3px); color: inherit; text-decoration: none; }
.ranking-card__rank {
  position: absolute;
  top: 0;
  left: 0;
  width: 48px;
  height: 48px;
  background: var(--c-text);
  color: #fff;
  font-family: var(--font-display);
  font-size: var(--fz-xl);
  font-weight: var(--fw-bold);
  display: grid;
  place-items: center;
  z-index: 2;
  letter-spacing: -0.02em;
}
.ranking-card__rank small {
  display: block;
  font-size: 8px;
  letter-spacing: 0.15em;
  opacity: 0.7;
  margin-top: -2px;
  font-weight: var(--fw-regular);
}
/* TOP3 はピンクバッジ */
.ranking-card:nth-child(1) .ranking-card__rank,
.ranking-card:nth-child(2) .ranking-card__rank,
.ranking-card:nth-child(3) .ranking-card__rank {
  background: var(--c-primary);
}
.ranking-card__photo {
  aspect-ratio: 4 / 5;
  background: var(--c-bg-warm);
}
.ranking-card__body {
  padding: var(--space-4);
}
.ranking-card__name {
  font-family: var(--font-display);
  font-size: var(--fz-md);
  font-weight: var(--fw-semibold);
  color: var(--c-text);
  margin: 0 0 var(--space-2);
  line-height: 1.4;
}
.ranking-card__desc {
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  margin: 0 0 var(--space-3);
  line-height: 1.5;
}
.ranking-card__price {
  font-family: var(--font-display);
  font-size: var(--fz-md);
  color: var(--c-text);
  font-weight: var(--fw-semibold);
}
.ranking-card__price small {
  font-family: var(--font-sans);
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  font-weight: var(--fw-regular);
  margin-right: 2px;
}
@media (max-width: 991px) {
  .ranking-grid { grid-template-columns: repeat(3, 1fr); }
  .ranking-card:nth-child(4),
  .ranking-card:nth-child(5) { display: none; }
}
@media (max-width: 767px) {
  .ranking-grid { grid-template-columns: 1fr 1fr; }
  .ranking-card:nth-child(n) { display: block; }
  .ranking-card:nth-child(5) { display: none; }
}

/* ==========================================================================
   4. 業種/用途から選ぶ (大きな画像カード)
   ========================================================================== */
.home-segment {
  padding: var(--space-10) 0;
  background: var(--c-surface);
}
.segment-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-top: var(--space-7);
}
.segment-card {
  background: var(--c-bg-alt);
  aspect-ratio: 4 / 3;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  color: var(--c-text);
  display: flex;
  align-items: flex-end;
  padding: var(--space-5);
  transition: transform var(--dur-base);
}
.segment-card:hover {
  transform: translateY(-3px);
  color: var(--c-text);
  text-decoration: none;
}
.segment-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.35));
  z-index: 1;
}
.segment-card__bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--c-primary-soft) 0%, var(--c-bg-warm) 100%);
  z-index: 0;
}
/* 実画像。ファイルがない間は onerror で自ら抜ける */
.segment-card__photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
  transition: transform var(--dur-slow) var(--ease-out);
}
.segment-card:hover .segment-card__photo { transform: scale(1.04); }

/* 画像配置前の提案プレースホルダ (画像 <img> が onerror で抜けた時に自然に見える) */
.segment-card__placeholder {
  position: absolute;
  top: var(--space-4);
  left: var(--space-4);
  right: var(--space-4);
  z-index: 0;
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px dashed var(--c-primary);
  border-radius: var(--radius-sm);
  color: var(--c-text);
  max-width: calc(100% - var(--space-4) * 2);
}
.segment-card__placeholder svg {
  color: var(--c-primary-ink);
  flex-shrink: 0;
  margin-top: 2px;
}
.segment-card__placeholder-text {
  display: block;
  font-size: 11px;
  line-height: 1.55;
  color: var(--c-text-muted);
}
.segment-card__placeholder-text b {
  display: block;
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: var(--lt-wide);
  color: var(--c-primary-ink);
  font-weight: var(--fw-bold);
  margin-bottom: 2px;
  text-transform: uppercase;
}
.segment-card__inner {
  position: relative;
  z-index: 2;
  color: #fff;
}
.segment-card__label {
  font-size: var(--fz-xs);
  letter-spacing: var(--lt-x-wide);
  opacity: 0.9;
  display: block;
  margin-bottom: 4px;
}
.segment-card__name {
  font-family: var(--font-display);
  font-size: var(--fz-xl);
  font-weight: var(--fw-semibold);
  line-height: 1.3;
}
.segment-card__arrow {
  position: absolute;
  top: var(--space-5);
  right: var(--space-5);
  z-index: 2;
  color: #fff;
  font-size: 18px;
}
@media (max-width: 767px) {
  .segment-grid { grid-template-columns: 1fr 1fr; gap: var(--space-3); }
}

/* ==========================================================================
   5. 使い方フロー (3ステップ)
   ========================================================================== */
.home-flow {
  padding: var(--space-10) 0;
  background: var(--c-bg-alt);
}
.flow-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin-top: var(--space-7);
  position: relative;
}
.flow-step {
  background: var(--c-surface);
  padding: var(--space-7) var(--space-5);
  text-align: center;
  position: relative;
}
.flow-step + .flow-step { border-left: 1px solid var(--c-line); }
.flow-step__num {
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--fz-xs);
  color: var(--c-primary-ink);
  letter-spacing: var(--lt-wide);
  margin-bottom: var(--space-3);
  padding: 3px 10px;
  border: 1px solid var(--c-primary);
  font-weight: var(--fw-semibold);
}
.flow-step__icon {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--space-4);
  background: var(--c-primary-veil);
  display: grid;
  place-items: center;
  font-size: 24px;
  color: var(--c-primary-ink);
}
.flow-step__title {
  font-family: var(--font-display);
  font-size: var(--fz-lg);
  font-weight: var(--fw-semibold);
  margin: 0 0 var(--space-3);
}
.flow-step__desc {
  font-size: var(--fz-sm);
  color: var(--c-text-muted);
  line-height: var(--lh-base);
  max-width: 24ch;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .flow-steps { grid-template-columns: 1fr; }
  .flow-step + .flow-step { border-left: 0; border-top: 1px solid var(--c-line); }
}

/* ==========================================================================
   6. 信頼バー (送料無料・翌日・後払い・相談無料)
   ========================================================================== */
.trust-bar {
  padding: var(--space-7) 0;
  background: var(--c-surface);
  border-top: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
}
.trust-bar__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
}
.trust-bar__item {
  padding: 0 var(--space-5);
  text-align: center;
  position: relative;
}
.trust-bar__item + .trust-bar__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 60%;
  background: var(--c-line);
}
.trust-bar__icon {
  font-size: 28px;
  color: var(--c-primary-ink);
  margin-bottom: var(--space-3);
  display: block;
}
.trust-bar__title {
  font-family: var(--font-display);
  font-size: var(--fz-md);
  font-weight: var(--fw-semibold);
  color: var(--c-text);
  margin: 0 0 var(--space-1);
}
.trust-bar__desc {
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  line-height: 1.5;
}
@media (max-width: 767px) {
  .trust-bar__list { grid-template-columns: 1fr 1fr; gap: var(--space-5) 0; }
  .trust-bar__item:nth-child(odd)::before { display: none; }
}

/* ==========================================================================
   7. マガジン / お役立ちコラム (and-u wp 寄せ)
   ========================================================================== */
.home-magazine {
  padding: var(--space-10) 0;
  background: var(--c-surface);
}
.magazine-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-7);
}
.mag-card {
  text-decoration: none;
  color: inherit;
  display: block;
}
.mag-card:hover { color: inherit; text-decoration: none; }
.mag-card:hover .mag-card__thumb { transform: scale(1.02); }
.mag-card__thumb {
  aspect-ratio: 4 / 3;
  background: var(--c-bg-alt);
  margin-bottom: var(--space-3);
  position: relative;
  overflow: hidden;
  transition: transform var(--dur-base);
}
.mag-card__cat {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  font-size: 10px;
  color: #fff;
  background: var(--c-text);
  padding: 3px 8px;
  letter-spacing: 0.08em;
  font-weight: var(--fw-semibold);
  z-index: 1;
}
.mag-card__date {
  font-family: var(--font-display);
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-2);
  display: block;
}
.mag-card__title {
  font-family: var(--font-display);
  font-size: var(--fz-md);
  font-weight: var(--fw-semibold);
  color: var(--c-text);
  margin: 0 0 var(--space-2);
  line-height: 1.5;
}
.mag-card__excerpt {
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  line-height: 1.6;
}
@media (max-width: 991px) {
  .magazine-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 767px) {
  .magazine-grid { grid-template-columns: 1fr 1fr; gap: var(--space-4); }
}

/* ==========================================================================
   共通セクションヘッダ (and-u 風の中央見出し)
   ========================================================================== */
.section-heading {
  text-align: center;
  margin-bottom: var(--space-7);
}
.section-heading__en {
  display: block;
  font-family: var(--font-display);
  font-size: var(--fz-xs);
  letter-spacing: var(--lt-x-wide);
  color: var(--c-primary-ink);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--space-3);
  text-transform: uppercase;
}
.section-heading__en::before,
.section-heading__en::after {
  content: "";
  display: inline-block;
  width: 24px;
  height: 1px;
  background: var(--c-primary);
  vertical-align: middle;
  margin: 0 var(--space-3);
}
.section-heading__ja {
  font-family: var(--font-display);
  font-size: var(--fz-2xl);
  font-weight: var(--fw-medium);
  color: var(--c-text);
  margin: 0 0 var(--space-3);
  letter-spacing: var(--lt-tight);
}
.section-heading__desc {
  font-size: var(--fz-sm);
  color: var(--c-text-muted);
  max-width: 52ch;
  margin: 0 auto;
  line-height: var(--lh-base);
}
.section-heading__more {
  display: inline-block;
  margin-top: var(--space-4);
  font-family: var(--font-display);
  font-size: var(--fz-xs);
  letter-spacing: var(--lt-wide);
  color: var(--c-text);
  border-bottom: 1px solid var(--c-text);
  padding-bottom: 2px;
  text-decoration: none;
}
.section-heading__more:hover { color: var(--c-primary-ink); border-bottom-color: var(--c-primary); text-decoration: none; }

/* ==========================================================================
   CTA Band (最下部の強いCTA)
   ========================================================================== */
.cta-band {
  padding: var(--space-10) 0;
  background: var(--c-text);
  color: #fff;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-band::before,
.cta-band::after {
  content: "";
  position: absolute;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  opacity: 0.1;
  background: var(--c-primary);
}
.cta-band::before { top: -150px; left: -100px; }
.cta-band::after { bottom: -150px; right: -100px; }
.cta-band__inner {
  position: relative;
  z-index: 1;
  max-width: 700px;
  margin: 0 auto;
  padding: 0 var(--space-5);
}
.cta-band__eyebrow {
  font-family: var(--font-display);
  font-size: var(--fz-xs);
  letter-spacing: var(--lt-x-wide);
  color: var(--c-primary);
  text-transform: uppercase;
  font-weight: var(--fw-semibold);
  display: block;
  margin-bottom: var(--space-4);
}
.cta-band__title {
  font-family: var(--font-display);
  font-size: var(--fz-3xl);
  color: #fff;
  margin: 0 0 var(--space-5);
  font-weight: var(--fw-medium);
  line-height: 1.3;
}
.cta-band__desc {
  font-size: var(--fz-md);
  color: rgba(255,255,255,0.75);
  line-height: var(--lh-base);
  margin: 0 0 var(--space-7);
}
.cta-band__actions {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
}
.cta-band .cta--secondary {
  background: transparent;
  color: #fff;
  border-color: #fff;
}
.cta-band .cta--secondary:hover {
  background: #fff;
  color: var(--c-text);
}

/* ==========================================================================
   Utilities
   ========================================================================== */
.is-pc { display: inline; }
.is-sp { display: none; }
@media (max-width: 767px) {
  .is-pc { display: none; }
  .is-sp { display: inline; }
}

.section-heading__more-wrap {
  text-align: center;
  margin-top: var(--space-7);
}

/* ==========================================================================
   Hero - CVR variant (右側の商品タイルグリッド)
   ========================================================================== */
.home-hero--cvr .home-hero__inner {
  padding: var(--space-9) var(--space-5) var(--space-8);
}
.home-hero__title em {
  /* ダスティピンクの下敷きを既存仕様より少し控えめに */
}
.home-hero__sub strong {
  color: var(--c-text);
  font-weight: var(--fw-semibold);
  background: linear-gradient(transparent 60%, var(--c-primary-veil) 60%);
  padding: 0 2px;
}
.home-hero__meta {
  list-style: none;
  margin: 0;
  padding-top: var(--space-5);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  border-top: 1px solid var(--c-line);
}
.home-hero__meta li {
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  line-height: 1.4;
}
.home-hero__meta strong {
  display: block;
  font-family: var(--font-display);
  font-size: var(--fz-xl);
  color: var(--c-text);
  font-weight: var(--fw-semibold);
  margin-bottom: 2px;
  letter-spacing: -0.01em;
}

/* 右側タイルグリッド (2列 × 3段) */
.home-hero__tiles {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  position: relative;
}
.home-hero__tiles::before {
  content: "";
  position: absolute;
  top: -16px; left: -16px;
  right: 16px; bottom: 16px;
  border: 1px solid var(--c-primary);
  z-index: -1;
  pointer-events: none;
}
.hero-tile {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-5);
  aspect-ratio: 1 / 1;
  background: var(--c-surface);
  box-shadow: var(--shadow-card);
  text-decoration: none;
  color: var(--c-text);
  position: relative;
  overflow: hidden;
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base);
}
.hero-tile:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover);
  color: var(--c-text);
  text-decoration: none;
}
.hero-tile::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(145deg, var(--c-bg-alt) 0%, var(--c-surface) 70%);
  z-index: 0;
}
.hero-tile > * { position: relative; z-index: 1; }
.hero-tile__cat {
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: var(--lt-x-wide);
  color: var(--c-primary-ink);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
}
.hero-tile__name {
  font-family: var(--font-display);
  font-size: var(--fz-md);
  font-weight: var(--fw-semibold);
  line-height: 1.4;
  color: var(--c-text);
  margin-top: auto;
}
.hero-tile__price {
  font-family: var(--font-display);
  font-size: var(--fz-lg);
  font-weight: var(--fw-bold);
  color: var(--c-primary-ink);
  letter-spacing: -0.01em;
}
/* ALL タイル (右下・最後) は濃色で反転 */
.hero-tile--all {
  background: var(--c-text);
  color: #fff;
}
.hero-tile--all::before {
  background: linear-gradient(145deg, var(--c-text) 0%, #2d2d35 100%);
}
.hero-tile--all .hero-tile__all {
  font-family: var(--font-display);
  font-size: var(--fz-xl);
  letter-spacing: var(--lt-wide);
  color: var(--c-primary);
  font-weight: var(--fw-bold);
}
.hero-tile--all .hero-tile__name {
  color: #fff;
  font-size: var(--fz-sm);
  line-height: 1.5;
}
.hero-tile--all .hero-tile__arrow {
  font-family: var(--font-display);
  font-size: var(--fz-2xl);
  color: var(--c-primary);
  align-self: flex-end;
  line-height: 1;
}
.hero-tile--all:hover { color: #fff; }

@media (max-width: 991px) {
  .home-hero__meta { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
  .home-hero__tiles { grid-template-columns: 1fr 1fr 1fr; }
  .home-hero__tiles::before { display: none; }
  .hero-tile { aspect-ratio: 1 / 1; padding: var(--space-4); }
}
@media (max-width: 767px) {
  .home-hero__tiles { grid-template-columns: 1fr 1fr; gap: var(--space-2); }
  .hero-tile { padding: var(--space-3); }
  .hero-tile__name { font-size: var(--fz-sm); }
  .hero-tile__price { font-size: var(--fz-md); }
}

/* ==========================================================================
   Ranking card (CVR強化: 価格+CTA行を追加)
   ========================================================================== */
.ranking-card__photo {
  position: relative;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--c-bg-warm) 0%, var(--c-primary-veil) 100%);
}
.ranking-card__ph-label {
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: var(--lt-x-wide);
  color: var(--c-primary-ink);
  font-weight: var(--fw-semibold);
  opacity: 0.55;
}
.ranking-card__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--c-line-soft);
}
.ranking-card__price span {
  font-family: var(--font-sans);
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  font-weight: var(--fw-regular);
  margin-left: 2px;
}
.ranking-card__cta {
  font-family: var(--font-display);
  font-size: var(--fz-xs);
  letter-spacing: var(--lt-wide);
  color: var(--c-primary-ink);
  font-weight: var(--fw-semibold);
  white-space: nowrap;
}
.ranking-card:hover .ranking-card__cta { color: var(--c-primary-hover); }

/* ==========================================================================
   Segment card - chip 追加 (CVR)
   ========================================================================== */
.segment-card {
  aspect-ratio: 4 / 3.2;
  padding: var(--space-5);
  align-items: stretch;
}
.segment-card__inner {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  width: 100%;
}
.segment-card__chips {
  list-style: none;
  margin: var(--space-3) 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.segment-card__chips li {
  font-size: 10px;
  letter-spacing: 0.02em;
  color: #fff;
  background: rgba(255,255,255,0.18);
  padding: 3px 8px;
  border-radius: var(--radius-sm);
  backdrop-filter: blur(4px);
  border: 1px solid rgba(255,255,255,0.25);
}

/* ==========================================================================
   Price card (新規セクション / CVR加速)
   ========================================================================== */
.home-price {
  padding: var(--space-10) 0;
  background: var(--c-bg-alt);
}
.price-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-7);
}
.price-card {
  background: var(--c-surface);
  padding: var(--space-6) var(--space-5);
  display: flex;
  flex-direction: column;
  position: relative;
  box-shadow: var(--shadow-card);
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base);
}
.price-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover);
}
.price-card__head {
  padding-bottom: var(--space-4);
  border-bottom: 2px solid var(--c-primary);
  margin-bottom: var(--space-4);
}
.price-card__cat {
  display: inline-block;
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: var(--lt-x-wide);
  color: var(--c-primary-ink);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--space-2);
}
.price-card__name {
  font-family: var(--font-display);
  font-size: var(--fz-xl);
  font-weight: var(--fw-semibold);
  color: var(--c-text);
  margin: 0 0 var(--space-2);
  letter-spacing: var(--lt-tight);
}
.price-card__meta {
  display: block;
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  line-height: 1.5;
}
.price-card__rows {
  list-style: none;
  margin: 0 0 var(--space-5);
  padding: 0;
  flex: 1;
}
.price-card__rows li {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: baseline;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--c-line-soft);
}
.price-card__rows li:last-child { border-bottom: 0; }
.price-card__rows li span {
  font-size: var(--fz-sm);
  color: var(--c-text-muted);
}
.price-card__rows li strong {
  font-family: var(--font-display);
  font-size: var(--fz-xl);
  color: var(--c-text);
  font-weight: var(--fw-semibold);
  letter-spacing: -0.01em;
}
.price-card__rows li em {
  font-style: normal;
  font-size: 10px;
  letter-spacing: var(--lt-wide);
  color: var(--c-primary-ink);
  background: var(--c-primary-veil);
  padding: 2px 6px;
  font-weight: var(--fw-semibold);
}
.price-card__rows li.is-pop {
  background: var(--c-primary-veil);
  margin: 0 calc(var(--space-5) * -1);
  padding-left: var(--space-5);
  padding-right: var(--space-5);
  border-bottom: 0;
  position: relative;
}
.price-card__rows li.is-pop strong { color: var(--c-primary-ink); }
.price-card__cta {
  display: block;
  text-align: center;
  padding: var(--space-4);
  background: var(--c-text);
  color: #fff;
  text-decoration: none;
  font-family: var(--font-display);
  font-size: var(--fz-sm);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--lt-tight);
  transition: background var(--dur-base);
}
.price-card__cta:hover {
  background: var(--c-primary);
  color: #fff;
  text-decoration: none;
}
.home-price__note {
  margin: var(--space-7) auto 0;
  max-width: 720px;
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  text-align: center;
  line-height: 1.8;
}
.home-price__note a {
  color: var(--c-primary-ink);
  border-bottom: 1px solid var(--c-primary);
  padding-bottom: 1px;
  text-decoration: none;
}
@media (max-width: 991px) {
  .price-grid { grid-template-columns: 1fr; gap: var(--space-5); }
  .price-card { max-width: 560px; margin: 0 auto; width: 100%; }
}

/* ==========================================================================
   Voice card (新規 / お客様の声)
   ========================================================================== */
.home-voice {
  padding: var(--space-10) 0;
  background: var(--c-surface);
}
.voice-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-7);
}
.voice-card {
  background: var(--c-bg-alt);
  padding: var(--space-6) var(--space-5);
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  position: relative;
}
.voice-card::before {
  content: "\201C";
  position: absolute;
  top: var(--space-2);
  right: var(--space-4);
  font-family: var(--font-serif);
  font-size: 72px;
  line-height: 1;
  color: var(--c-primary-soft);
  font-weight: var(--fw-bold);
  z-index: 0;
}
.voice-card > * { position: relative; z-index: 1; }
.voice-card__head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.voice-card__avatar {
  width: 64px;
  height: 64px;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
  border-radius: 50%;
  background: linear-gradient(145deg, var(--c-primary-soft) 0%, var(--c-bg-warm) 100%);
  box-shadow:
    0 4px 12px -4px rgba(0,0,0,0.15),
    0 0 0 3px #fff,
    0 0 0 4px var(--c-line-soft);
}
.voice-card__illust {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.voice-card__rating {
  font-size: var(--fz-md);
  color: var(--c-primary);
  letter-spacing: 0.05em;
}
.voice-card__body {
  margin: 0;
  font-size: var(--fz-sm);
  line-height: var(--lh-base);
  color: var(--c-text);
  quotes: none;
  font-feature-settings: "palt";
}
.voice-card__meta {
  margin-top: auto;
  padding-top: var(--space-3);
  border-top: 1px solid var(--c-line);
}
.voice-card__name {
  display: block;
  font-family: var(--font-display);
  font-size: var(--fz-sm);
  font-weight: var(--fw-semibold);
  color: var(--c-text);
  margin-bottom: 2px;
}
.voice-card__product {
  display: block;
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
}
@media (max-width: 991px) {
  .voice-grid { grid-template-columns: 1fr; gap: var(--space-4); }
  .voice-card { max-width: 560px; margin: 0 auto; width: 100%; }
}

/* ==========================================================================
   Magazine thumb — グラデフォールバック + 実画像 (あれば)
   ========================================================================== */
.mag-card__thumb {
  background: linear-gradient(135deg, var(--c-bg-warm) 0%, var(--c-primary-veil) 100%);
  position: relative;
  overflow: hidden;
}
.mag-card__photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease-out);
  z-index: 1;
}
.mag-card:hover .mag-card__photo { transform: scale(1.04); }
.mag-card__cat { z-index: 3; }

/* 画像配置前の提案プレースホルダ */
.mag-card__placeholder {
  position: absolute;
  inset: auto var(--space-3) var(--space-3);
  z-index: 0;
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  padding: var(--space-3);
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px dashed var(--c-primary);
  border-radius: var(--radius-sm);
  font-size: 10px;
  line-height: 1.55;
  color: var(--c-text-muted);
}
.mag-card__placeholder svg {
  color: var(--c-primary-ink);
  flex-shrink: 0;
  margin-top: 1px;
}
.mag-card__placeholder b {
  display: block;
  font-family: var(--font-display);
  font-size: 9px;
  letter-spacing: var(--lt-wide);
  color: var(--c-primary-ink);
  font-weight: var(--fw-bold);
  margin-bottom: 2px;
  text-transform: uppercase;
}

/* ==========================================================================
   Coupon Banner — 初回クーポン訴求 (ヒーロー直下)
   ========================================================================== */
.coupon-banner {
  position: relative;
  padding: 0 0 var(--space-8);
  margin-top: calc(var(--space-7) * -1);
  z-index: 3;
}
.coupon-banner > .container-2026 {
  padding-left: var(--space-5);
  padding-right: var(--space-5);
}
.coupon-banner__card {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  align-items: center;
  gap: var(--space-7);
  padding: var(--space-7) var(--space-8);
  background:
    linear-gradient(135deg, #fff6f1 0%, #fff 60%),
    #fff;
  position: relative;
  overflow: hidden;
  box-shadow:
    0 30px 60px -24px rgba(199, 139, 139, 0.35),
    0 14px 28px -10px rgba(0,0,0,0.08);
  border-radius: 4px;
}
/* 両サイドのチケット切り込み */
.coupon-banner__card::before,
.coupon-banner__card::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--c-bg-alt);
  box-shadow: inset 0 0 0 1px var(--c-line);
}
.coupon-banner__card::before { left: -14px; }
.coupon-banner__card::after { right: -14px; }

/* 左: 訴求 */
.coupon-banner__left {
  padding-right: var(--space-6);
  border-right: 1px dashed rgba(199, 139, 139, 0.4);
}
.coupon-banner__badge {
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--fz-xs);
  letter-spacing: var(--lt-wide);
  color: var(--c-primary-ink);
  font-weight: var(--fw-semibold);
  padding: 4px 12px;
  background: var(--c-primary-veil);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-3);
}
.coupon-banner__headline {
  margin: 0 0 var(--space-3);
  font-family: var(--font-display);
  color: var(--c-text);
  line-height: 1;
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.coupon-banner__amount {
  font-size: clamp(44px, 5vw, 64px);
  font-weight: var(--fw-bold);
  color: var(--c-primary-ink);
  letter-spacing: -0.02em;
}
.coupon-banner__headline > span:not(.coupon-banner__amount-en) {
  /* the OFF text */
  font-size: var(--fz-2xl);
  font-weight: var(--fw-semibold);
  color: var(--c-text);
}
.coupon-banner__amount-en {
  font-size: var(--fz-xs);
  letter-spacing: var(--lt-x-wide);
  color: var(--c-text-muted);
  font-weight: var(--fw-semibold);
  flex-basis: 100%;
  margin-top: var(--space-2);
}
.coupon-banner__desc {
  margin: 0;
  font-size: var(--fz-sm);
  line-height: 1.7;
  color: var(--c-text-muted);
}

/* 右: コードとCTA */
.coupon-banner__right {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding-left: var(--space-3);
}

/* バッジに星アイコンを入れる調整 */
.coupon-banner__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.coupon-banner__badge svg { color: var(--c-yellow); }

/* ヘッドラインの「今だけ」小ラベル */
.coupon-banner__amount-label {
  font-size: var(--fz-xs);
  letter-spacing: var(--lt-wide);
  color: var(--c-text-muted);
  font-weight: var(--fw-semibold);
  padding: 3px 8px;
  background: #fff;
  border: 1px solid var(--c-primary-soft);
  border-radius: var(--radius-full);
  align-self: flex-start;
}
.coupon-banner__off {
  font-size: var(--fz-2xl);
  font-weight: var(--fw-semibold);
  color: var(--c-text);
  letter-spacing: var(--lt-wide);
  margin-left: 4px;
}

/* ---- メール登録フォーム ---- */
.coupon-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.coupon-form__label {
  font-size: var(--fz-sm);
  color: var(--c-text);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--lt-tight);
}
.coupon-form__row {
  display: flex;
  align-items: stretch;
  gap: var(--space-2);
  position: relative;
}
.coupon-form__icon {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--c-text-muted);
  pointer-events: none;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.coupon-form__input {
  flex: 1 1 auto;
  min-width: 0;
  padding: var(--space-3) var(--space-4) var(--space-3) 48px;
  font-size: var(--fz-md);
  font-family: var(--font-sans);
  color: var(--c-text);
  background: #fff;
  border: 1.5px solid var(--c-line);
  border-radius: var(--radius-md);
  transition: border-color var(--dur-base), box-shadow var(--dur-base);
}
.coupon-form__input:focus {
  outline: none;
  border-color: var(--c-primary);
  box-shadow: 0 0 0 3px var(--c-primary-veil);
}
.coupon-form__input::placeholder {
  color: var(--c-text-weak);
  font-size: var(--fz-sm);
}
.coupon-form__submit {
  flex-shrink: 0;
  white-space: nowrap;
  cursor: pointer;
  font-family: var(--font-sans);
}
.coupon-form__submit:disabled {
  opacity: 0.6;
  cursor: wait;
}
.coupon-form__consent {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  font-size: 11px;
  color: var(--c-text-muted);
  line-height: 1.6;
  cursor: pointer;
}
.coupon-form__consent input[type=checkbox] {
  flex-shrink: 0;
  width: 14px;
  height: 14px;
  margin-top: 2px;
  accent-color: var(--c-primary);
}
.coupon-form__consent a {
  color: var(--c-primary-ink);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.coupon-form__result {
  margin: 0;
  padding: var(--space-4);
  background: var(--c-green-soft);
  color: var(--c-green-ink);
  border-radius: var(--radius-md);
  font-size: var(--fz-sm);
  line-height: 1.7;
  border-left: 3px solid var(--c-green);
}
.coupon-form__result strong {
  display: block;
  margin-bottom: 4px;
  color: var(--c-green);
  font-size: var(--fz-md);
}

@media (max-width: 767px) {
  .coupon-form__row { flex-direction: column; gap: var(--space-2); }
  .coupon-form__submit { width: 100%; justify-content: center; }
}
@media (max-width: 767px) {
  .coupon-banner { padding: 0 var(--space-4) var(--space-7); margin-top: calc(var(--space-6) * -1); }
  .coupon-banner__card {
    grid-template-columns: 1fr;
    padding: var(--space-6) var(--space-5);
    gap: var(--space-5);
  }
  .coupon-banner__card::before,
  .coupon-banner__card::after { display: none; }
  .coupon-banner__left {
    padding-right: 0;
    padding-bottom: var(--space-4);
    border-right: 0;
    border-bottom: 1px dashed rgba(199, 139, 139, 0.4);
  }
  .coupon-banner__right { padding-left: 0; }
  .coupon-banner__headline { justify-content: flex-start; }
}

/* ==========================================================================
   Home Categories — ワイドな8カードグリッド (アクセント色で元気)
   ========================================================================== */
.home-categories {
  padding: var(--space-10) 0;
  background: var(--c-surface);
}
.cat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  margin-top: var(--space-7);
}
.cat-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-6) var(--space-5);
  min-height: 260px;
  text-decoration: none;
  color: var(--c-text);
  overflow: hidden;
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base);
  border-radius: 4px;
  box-shadow: 0 4px 12px -4px rgba(0,0,0,0.08);
  isolation: isolate;
}
.cat-card:hover {
  transform: translateY(-6px) rotate(-0.3deg);
  box-shadow: 0 24px 48px -16px rgba(0,0,0,0.22);
  color: var(--c-text);
  text-decoration: none;
}
.cat-card::before {
  content: "";
  position: absolute;
  inset: auto -25% -45% auto;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  opacity: 0.65;
  pointer-events: none;
  transition: transform var(--dur-slow) var(--ease-out);
  z-index: 0;
}
.cat-card::after {
  content: "";
  position: absolute;
  top: -30%;
  left: -10%;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  opacity: 0.35;
  pointer-events: none;
  z-index: 0;
}
.cat-card:hover::before { transform: scale(1.2) translate(-5%, -5%); }
.cat-card:hover::after { transform: scale(1.3); }

/* ミニSVGグリフ (商品イメージ) */
.cat-card__glyph {
  position: absolute;
  right: var(--space-4);
  bottom: var(--space-4);
  width: 64px;
  height: 48px;
  color: var(--c-text);
  opacity: 0.2;
  z-index: 0;
  transition: transform var(--dur-slow) var(--ease-out), opacity var(--dur-slow);
  pointer-events: none;
}
.cat-card:hover .cat-card__glyph {
  opacity: 0.32;
  transform: scale(1.08) rotate(-3deg);
}

.cat-card__badge {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: var(--lt-wide);
  font-weight: var(--fw-bold);
  padding: 3px 9px;
  border-radius: var(--radius-full);
  z-index: 2;
  color: #fff;
}
.cat-card__badge--pop { background: var(--c-primary); }
.cat-card__badge--hot { background: var(--c-orange); }

.cat-card__en {
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: var(--lt-x-wide);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  opacity: 0.7;
  position: relative;
  z-index: 1;
}
.cat-card__name {
  font-family: var(--font-display);
  font-size: var(--fz-xl);
  font-weight: var(--fw-bold);
  margin: 0;
  line-height: 1.3;
  letter-spacing: var(--lt-tight);
  position: relative;
  z-index: 1;
}
.cat-card__desc {
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  line-height: 1.65;
  margin: var(--space-2) 0 auto;
  position: relative;
  z-index: 1;
}
.cat-card__foot {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px solid rgba(26,26,32,0.1);
  position: relative;
  z-index: 1;
}
.cat-card__from {
  font-family: var(--font-display);
  font-size: var(--fz-lg);
  font-weight: var(--fw-bold);
  letter-spacing: -0.01em;
}
.cat-card__arrow {
  font-family: var(--font-display);
  font-size: var(--fz-xl);
  font-weight: var(--fw-bold);
  line-height: 1;
  transition: transform var(--dur-base);
}
.cat-card:hover .cat-card__arrow { transform: translateX(4px); }

/* アクセント色バリエーション (グラデーション + 強い装飾) */
.cat-card--pink   { background: linear-gradient(155deg, #fef3f3 0%, var(--c-primary-veil) 100%); }
.cat-card--pink::before   { background: var(--c-primary); opacity: 0.32; }
.cat-card--pink::after    { background: var(--c-primary-soft); }
.cat-card--pink .cat-card__en { color: var(--c-primary-ink); }
.cat-card--pink .cat-card__glyph { color: var(--c-primary-ink); opacity: 0.32; }

.cat-card--orange { background: linear-gradient(155deg, #fff5ec 0%, var(--c-orange-soft) 100%); }
.cat-card--orange::before { background: var(--c-orange); opacity: 0.32; }
.cat-card--orange::after  { background: var(--c-yellow-soft); }
.cat-card--orange .cat-card__en { color: var(--c-orange-ink); }
.cat-card--orange .cat-card__glyph { color: var(--c-orange-ink); opacity: 0.32; }

.cat-card--blue   { background: linear-gradient(155deg, #f1f5f9 0%, var(--c-blue-soft) 100%); }
.cat-card--blue::before   { background: var(--c-blue); opacity: 0.32; }
.cat-card--blue::after    { background: #d4e0ec; }
.cat-card--blue .cat-card__en { color: var(--c-blue-ink); }
.cat-card--blue .cat-card__glyph { color: var(--c-blue-ink); opacity: 0.32; }

.cat-card--green  { background: linear-gradient(155deg, #f3f7f3 0%, var(--c-green-soft) 100%); }
.cat-card--green::before  { background: var(--c-green); opacity: 0.32; }
.cat-card--green::after   { background: #d5e0d4; }
.cat-card--green .cat-card__en { color: var(--c-green-ink); }
.cat-card--green .cat-card__glyph { color: var(--c-green-ink); opacity: 0.32; }

.cat-card--yellow { background: linear-gradient(155deg, #fff8e4 0%, var(--c-yellow-soft) 100%); }
.cat-card--yellow::before { background: var(--c-yellow); opacity: 0.38; }
.cat-card--yellow::after  { background: var(--c-orange-soft); }
.cat-card--yellow .cat-card__en { color: var(--c-yellow-ink); }
.cat-card--yellow .cat-card__glyph { color: var(--c-yellow-ink); opacity: 0.32; }

.cat-card--plum   { background: linear-gradient(155deg, #f7eef1 0%, #e8d4dc 100%); }
.cat-card--plum::before   { background: #ba7794; opacity: 0.32; }
.cat-card--plum::after    { background: #e8d4dc; }
.cat-card--plum .cat-card__en { color: #7a3b52; }
.cat-card--plum .cat-card__glyph { color: #7a3b52; opacity: 0.32; }

.cat-card--cream  { background: linear-gradient(155deg, #fbf5ed 0%, var(--c-accent-soft) 100%); }
.cat-card--cream::before  { background: var(--c-accent); opacity: 0.32; }
.cat-card--cream::after   { background: #eaddd0; }
.cat-card--cream .cat-card__en { color: var(--c-accent-ink); }
.cat-card--cream .cat-card__glyph { color: var(--c-accent-ink); opacity: 0.32; }

.cat-card--dark   {
  background: linear-gradient(155deg, #1a1a20 0%, #2d2d38 100%);
  color: #fff;
}
.cat-card--dark::before   { background: var(--c-primary); opacity: 0.38; }
.cat-card--dark::after    { background: var(--c-orange); opacity: 0.22; }
.cat-card--dark:hover     { color: #fff; }
.cat-card--dark .cat-card__en   { color: var(--c-primary); opacity: 1; }
.cat-card--dark .cat-card__desc { color: rgba(255,255,255,0.7); }
.cat-card--dark .cat-card__foot { border-top-color: rgba(255,255,255,0.2); }
.cat-card--dark .cat-card__glyph { color: #fff; opacity: 0.35; }

@media (max-width: 991px) {
  .cat-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
  .cat-card { padding: var(--space-5) var(--space-4); min-height: 200px; }
  .cat-card__name { font-size: var(--fz-md); letter-spacing: -0.02em; }
  .cat-card__desc { font-size: 11px; }
  .cat-card__from { font-size: var(--fz-md); }
}
@media (max-width: 480px) {
  .cat-grid { grid-template-columns: 1fr; gap: var(--space-3); }
  .cat-card { min-height: 160px; padding: var(--space-5); }
  .cat-card__name { font-size: var(--fz-lg); }
}

/* ==========================================================================
   Global Site Search — ヘッダボタン + モーダルダイアログ
   ========================================================================== */

/* ヘッダの検索ボタン */
.site-header__search-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px var(--space-3);
  background: var(--c-surface);
  border: 1px solid var(--c-line);
  border-radius: var(--radius-full);
  color: var(--c-text-muted);
  font-size: var(--fz-xs);
  font-family: var(--font-sans);
  cursor: pointer;
  transition: all var(--dur-base);
  letter-spacing: var(--lt-tight);
}
.site-header__search-btn:hover {
  background: var(--c-bg-alt);
  border-color: var(--c-primary);
  color: var(--c-text);
}
.site-header__search-btn svg { color: var(--c-primary-ink); }
.site-header__search-kbd {
  margin-left: 2px;
  padding: 1px 6px;
  font-size: 10px;
  font-family: var(--font-sans);
  font-weight: var(--fw-semibold);
  background: var(--c-bg-alt);
  border: 1px solid var(--c-line);
  border-radius: 3px;
  color: var(--c-text-muted);
  line-height: 1.4;
}
@media (max-width: 991px) {
  .site-header__search-btn span:not(.is-hide),
  .site-header__search-kbd { display: none; }
  .site-header__search-btn {
    width: 40px;
    height: 40px;
    padding: 0;
    justify-content: center;
    gap: 0;
    border-radius: 50%;
  }
}

/* 検索モーダル */
.site-search {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal, 200);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--dur-base), visibility var(--dur-base);
}
.site-search.is-open {
  opacity: 1;
  visibility: visible;
}
.site-search__scrim {
  position: absolute;
  inset: 0;
  background: rgba(20, 18, 16, 0.6);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.site-search__panel {
  position: absolute;
  top: 10vh;
  left: 50%;
  transform: translateX(-50%) translateY(-20px);
  width: min(680px, calc(100% - var(--space-5) * 2));
  max-height: 80vh;
  background: var(--c-surface);
  border-radius: var(--radius-lg);
  box-shadow: 0 40px 80px -20px rgba(0,0,0,0.4);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--dur-base) var(--ease-out);
}
.site-search.is-open .site-search__panel {
  transform: translateX(-50%) translateY(0);
}

/* フォーム (上部固定) */
.site-search__form {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-5);
  border-bottom: 1px solid var(--c-line);
  background: var(--c-surface);
}
.site-search__icon {
  flex-shrink: 0;
  color: var(--c-primary-ink);
}
.site-search__input {
  flex: 1 1 auto;
  min-width: 0;
  border: 0;
  padding: var(--space-2) 0;
  font-size: var(--fz-lg);
  font-family: var(--font-sans);
  color: var(--c-text);
  background: transparent;
}
.site-search__input:focus { outline: none; }
.site-search__input::placeholder { color: var(--c-text-weak); }
.site-search__esc {
  font-size: 10px;
  padding: 2px 6px;
  background: var(--c-bg-alt);
  border: 1px solid var(--c-line);
  border-radius: 3px;
  color: var(--c-text-muted);
  font-weight: var(--fw-semibold);
  font-family: var(--font-sans);
}
.site-search__close {
  background: none;
  border: 0;
  font-size: 28px;
  color: var(--c-text-muted);
  cursor: pointer;
  line-height: 1;
  padding: 0 4px;
}
.site-search__close:hover { color: var(--c-text); }

/* 本体 (スクロール可能) */
.site-search__body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: var(--space-3) 0;
}
.site-search__results { padding: 0 var(--space-3); }
.site-search__empty {
  padding: var(--space-7) var(--space-5);
  text-align: center;
}
.site-search__empty-title {
  margin: 0 0 var(--space-2);
  font-family: var(--font-display);
  font-size: var(--fz-md);
  color: var(--c-text);
  font-weight: var(--fw-semibold);
}
.site-search__empty-sub {
  margin: 0;
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  line-height: 1.7;
}

/* 検索結果アイテム */
.search-result {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  text-decoration: none;
  color: var(--c-text);
  border-radius: var(--radius-sm);
  transition: background var(--dur-fast);
  cursor: pointer;
}
.search-result:hover,
.search-result.is-focused {
  background: var(--c-bg-alt);
  color: var(--c-text);
  text-decoration: none;
}
.search-result__cat {
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: var(--lt-wide);
  color: var(--c-primary-ink);
  font-weight: var(--fw-bold);
  padding: 3px 8px;
  background: var(--c-primary-veil);
  border-radius: var(--radius-full);
  white-space: nowrap;
}
.search-result__body { min-width: 0; }
.search-result__title {
  font-family: var(--font-display);
  font-size: var(--fz-md);
  font-weight: var(--fw-semibold);
  color: var(--c-text);
  margin: 0 0 2px;
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.search-result__title mark {
  background: var(--c-yellow-soft);
  color: var(--c-text);
  padding: 0 1px;
  font-weight: var(--fw-bold);
}
.search-result__desc {
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  margin: 0;
  line-height: 1.5;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.search-result__arrow {
  color: var(--c-text-muted);
  font-size: var(--fz-lg);
  font-family: var(--font-display);
}
.search-result.is-focused .search-result__arrow,
.search-result:hover .search-result__arrow { color: var(--c-primary-ink); }

.search-no-match {
  padding: var(--space-6) var(--space-5);
  text-align: center;
  color: var(--c-text-muted);
  font-size: var(--fz-sm);
}
.search-no-match strong {
  display: block;
  font-family: var(--font-display);
  color: var(--c-text);
  margin-bottom: var(--space-2);
}

/* 人気の検索 */
.site-search__popular {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--c-line);
  background: var(--c-bg-alt);
}
.site-search__popular-label {
  font-size: var(--fz-xs);
  color: var(--c-text-muted);
  font-weight: var(--fw-semibold);
  margin-right: var(--space-2);
}
.site-search__popular button {
  font-size: var(--fz-xs);
  padding: 4px 10px;
  background: var(--c-surface);
  border: 1px solid var(--c-line);
  border-radius: var(--radius-full);
  color: var(--c-text);
  cursor: pointer;
  font-family: var(--font-sans);
  transition: all var(--dur-fast);
}
.site-search__popular button:hover {
  border-color: var(--c-primary);
  color: var(--c-primary-ink);
  background: var(--c-primary-veil);
}

@media (max-width: 767px) {
  .site-search__panel { top: 5vh; max-height: 90vh; }
  .site-search__form { padding: var(--space-4); }
  .site-search__input { font-size: var(--fz-md); }
  .site-search__esc { display: none; }
  .search-result { grid-template-columns: 1fr auto; }
  .search-result__cat { display: none; }
}

/* ==========================================================================
   CTA 追加: cta--ghost (白ベース×枠線のセカンダリ)
   デフォルトは明色地想定。濃色地 (cta-band) では反転。
   ========================================================================== */
.cta--ghost {
  background: transparent;
  color: var(--c-text);
  border: 1px solid var(--c-text);
}
.cta--ghost:hover {
  background: var(--c-text);
  color: #fff;
  border-color: var(--c-text);
  text-decoration: none;
}
.cta-band .cta--ghost {
  color: #fff;
  border-color: rgba(255,255,255,0.5);
}
.cta-band .cta--ghost:hover {
  background: #fff;
  color: var(--c-text);
  border-color: #fff;
}

/* ==========================================================================
   Hero & Section Motion Enhancement (2026-04-22)
   - Hero コピーの順次フェードアップ (load 時)
   - タイトル em の下敷き draw-in
   - ピンク装飾枠の scale-in
   - スクロールパララックス受け皿 (JS が CSS変数を更新)
   - section-heading の EN ライン draw-in
   - CTA pink-strong の自動シマー
   - カード hover の質感向上
   - prefers-reduced-motion 完全対応
   ========================================================================== */

@keyframes hero-rise-in {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: none; }
}
@keyframes hero-em-draw {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}
@keyframes hero-accent-in {
  from { opacity: 0; transform: scale(0.94); }
  to   { opacity: 1; transform: none; }
}
@keyframes hero-eb-line {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}
@keyframes cta-auto-shimmer {
  0%   { left: -120%; }
  60%  { left: 130%; }
  100% { left: 130%; }
}
@keyframes cta-band-drift-1 {
  0%, 100% { transform: translate(0, 0); }
  50%      { transform: translate(40px, 30px); }
}
@keyframes cta-band-drift-2 {
  0%, 100% { transform: translate(0, 0); }
  50%      { transform: translate(-50px, -20px); }
}

/* ---- Hero コピー: 順次フェードアップ (load 即時) ---- */
.home-hero__content > .home-hero__eyebrow,
.home-hero__content > .home-hero__title,
.home-hero__content > .home-hero__sub,
.home-hero__content > .home-hero__ctas,
.home-hero__content > .home-hero__badges {
  opacity: 0;
  animation: hero-rise-in 800ms cubic-bezier(.16,.84,.3,1) forwards;
}
.home-hero__content > .home-hero__eyebrow { animation-delay:  80ms; }
.home-hero__content > .home-hero__title   { animation-delay: 220ms; }
.home-hero__content > .home-hero__sub     { animation-delay: 420ms; }
.home-hero__content > .home-hero__ctas    { animation-delay: 580ms; }
.home-hero__content > .home-hero__badges  { animation-delay: 720ms; }

/* タイトル em の下敷きが左→右に伸びる */
.home-hero__title em::after {
  transform-origin: left center;
  animation: hero-em-draw 700ms cubic-bezier(.7,.0,.3,1) 850ms backwards;
}

/* eyebrow 左ライン */
.home-hero__eyebrow::before {
  transform-origin: left center;
  animation: hero-eb-line 600ms cubic-bezier(.16,.84,.3,1) 200ms backwards;
}

/* ピンク装飾枠の入場 */
.home-hero__photo-accent {
  opacity: 0;
  transform-origin: bottom right;
  animation: hero-accent-in 1000ms cubic-bezier(.16,.84,.3,1) 350ms forwards;
}

/* ---- パララックス受け皿 (JS が CSS変数を毎フレーム更新) ---- */
.home-hero__photo-wrap {
  will-change: transform;
}
.home-hero__visual.is-parallaxed .home-hero__photo-wrap {
  transform: translate3d(0, var(--p-photo, 0px), 0);
}
.home-hero__visual.is-parallaxed .home-hero__photo-accent {
  /* 入場アニメ完了後はパララックス専用 transform に切替 */
  animation: none;
  opacity: 1;
  transform: translate3d(var(--p-accent-x, 0px), var(--p-accent-y, 0px), 0);
  transition: none;
}
/* 各 paper: 既存 rotate を維持しつつ Y 方向に流す */
.home-hero__visual.is-parallaxed .hero-paper--card {
  transform: rotate(-10deg) translate3d(0, var(--p-card, 0px), 0);
  animation: none;
}
.home-hero__visual.is-parallaxed .hero-paper--shopcard {
  transform: rotate(12deg) translate3d(0, var(--p-shop, 0px), 0);
  animation: none;
}
.home-hero__visual.is-parallaxed .hero-paper--flyer {
  transform: translateY(-50%) rotate(8deg) translate3d(0, var(--p-flyer, 0px), 0);
  animation: none;
}

/* ---- section-heading EN 両脇ライン draw-in (visible で発火) ---- */
.section-heading.reveal-up .section-heading__en::before,
.section-heading.reveal-up .section-heading__en::after {
  transform: scaleX(0);
  transition: transform 700ms cubic-bezier(.16,.84,.3,1) 250ms;
}
.section-heading.reveal-up .section-heading__en::before { transform-origin: right center; }
.section-heading.reveal-up .section-heading__en::after  { transform-origin: left center; }
.section-heading.reveal-up.is-visible .section-heading__en::before,
.section-heading.reveal-up.is-visible .section-heading__en::after {
  transform: scaleX(1);
}

/* ---- CTA pink-strong: 視認時に1回だけ自動シマー (注意喚起) ---- */
.home-hero__ctas .cta--pink-strong::after,
.cta-band .cta--pink::after {
  animation: cta-auto-shimmer 1800ms cubic-bezier(.7,.0,.3,1) 1400ms forwards;
}

/* ---- カード hover: 浮上 + シャドウ ---- */
.cat-card,
.price-card,
.flow-step,
.voice-card,
.mag-card,
.coupon-banner__card {
  transition: transform 360ms cubic-bezier(.16,.84,.3,1),
              box-shadow 360ms cubic-bezier(.16,.84,.3,1);
}
.cat-card:hover,
.mag-card:hover,
.voice-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 48px -18px rgba(20,16,12,0.18);
}
.price-card:hover { transform: translateY(-4px); }
.coupon-banner__card:hover { transform: translateY(-2px); }

/* ---- segment-card: hover で写真ズーム ---- */
.segment-card { isolation: isolate; }
.segment-card .segment-card__photo,
.segment-card .segment-card__bg {
  transition: transform 900ms cubic-bezier(.16,.84,.3,1);
  will-change: transform;
}
.segment-card:hover .segment-card__photo,
.segment-card:hover .segment-card__bg {
  transform: scale(1.06);
}

/* mag-card hover で写真ズーム */
.mag-card__thumb { overflow: hidden; }
.mag-card .mag-card__photo {
  transition: transform 900ms cubic-bezier(.16,.84,.3,1);
}
.mag-card:hover .mag-card__photo {
  transform: scale(1.06);
}

/* ---- CTA band 背景の薄ピンク円が漂う ---- */
.cta-band::before { animation: cta-band-drift-1 22s ease-in-out infinite; }
.cta-band::after  { animation: cta-band-drift-2 28s ease-in-out infinite; }

/* ---- ヒーロー写真の Ken Burns (継続的にゆっくりズーム) ---- */
@keyframes hero-photo-kenburns {
  0%   { transform: scale(1.00) translate(0, 0); }
  50%  { transform: scale(1.06) translate(-1.5%, -1%); }
  100% { transform: scale(1.00) translate(0, 0); }
}
.home-hero__photo {
  /* 既存の hero-photo-in (600ms) → 完了後に kenburns ループへ */
  animation:
    hero-photo-in 600ms var(--ease-out) 100ms forwards,
    hero-photo-kenburns 22s ease-in-out 800ms infinite;
}

/* ---- ピンク装飾枠: パララックス OFF のときだけ僅かに pulse ---- */
@keyframes hero-accent-breathe {
  0%, 100% { border-color: var(--c-primary); }
  50%      { border-color: var(--c-primary-ink); }
}
.home-hero__visual:not(.is-parallaxed) .home-hero__photo-accent {
  /* 入場アニメ完了後、SP 等パララックス OFF 環境では枠の色をゆっくり脈動 */
  animation:
    hero-accent-in 1000ms cubic-bezier(.16,.84,.3,1) 350ms forwards,
    hero-accent-breathe 6s ease-in-out 1500ms infinite;
}

/* ---- voice-card の評価★: visible で pop ---- */
@keyframes rating-pop {
  0%   { opacity: 0; transform: scale(0.6); }
  60%  { opacity: 1; transform: scale(1.15); }
  100% { transform: scale(1); }
}
.voice-grid.reveal-stagger.is-visible > .voice-card .voice-card__rating {
  animation: rating-pop 600ms cubic-bezier(.16,.84,.3,1) 500ms backwards;
}

/* ---- flow-step の番号: visible で letter-spacing が収束 ---- */
@keyframes flow-num-converge {
  0%   { letter-spacing: 0.5em; opacity: 0; }
  100% { letter-spacing: var(--lt-x-wide); opacity: 1; }
}
.flow-steps.reveal-stagger.is-visible > .flow-step .flow-step__num {
  animation: flow-num-converge 700ms cubic-bezier(.16,.84,.3,1) backwards;
}
.flow-steps.reveal-stagger.is-visible > .flow-step:nth-child(1) .flow-step__num { animation-delay: 200ms; }
.flow-steps.reveal-stagger.is-visible > .flow-step:nth-child(2) .flow-step__num { animation-delay: 350ms; }
.flow-steps.reveal-stagger.is-visible > .flow-step:nth-child(3) .flow-step__num { animation-delay: 500ms; }

/* ==========================================================================
   Lower content motion (2026-04-22 追加)
   - card grid reveal を scale + opacity に強化
   - cat-card SVG glyph の hover wobble
   - price-card 「人気/定番」バッジ pulse
   - magazine card title の slide-in on hover
   - CTA band 内コンテンツ: 段階的登場
   - trust-bar / foot-support の段階フェードイン
   - coupon-banner の amount に対応する transform 受け皿
   ========================================================================== */

/* ---- card grid reveal を「スケール感」付きにアップグレード ---- */
.cat-grid.reveal-stagger > *,
.segment-grid.reveal-stagger > *,
.price-grid.reveal-stagger > *,
.voice-grid.reveal-stagger > *,
.magazine-grid.reveal-stagger > *,
.flow-steps.reveal-stagger > * {
  opacity: 0;
  transform: translateY(28px) scale(0.96);
  filter: blur(2px);
  transition:
    opacity 700ms cubic-bezier(.16,.84,.3,1),
    transform 800ms cubic-bezier(.16,.84,.3,1),
    filter 600ms cubic-bezier(.16,.84,.3,1);
}
.cat-grid.reveal-stagger.is-visible > *,
.segment-grid.reveal-stagger.is-visible > *,
.price-grid.reveal-stagger.is-visible > *,
.voice-grid.reveal-stagger.is-visible > *,
.magazine-grid.reveal-stagger.is-visible > *,
.flow-steps.reveal-stagger.is-visible > * {
  opacity: 1;
  transform: none;
  filter: none;
}
/* cat-grid は子が9個あるので追加 delay ステップ */
.cat-grid.reveal-stagger.is-visible > *:nth-child(7) { transition-delay: 600ms; }
.cat-grid.reveal-stagger.is-visible > *:nth-child(8) { transition-delay: 700ms; }
.cat-grid.reveal-stagger.is-visible > *:nth-child(9) { transition-delay: 800ms; }

/* ---- cat-card SVG glyph: hover で微 wobble + scale ---- */
.cat-card .cat-card__glyph {
  transition: transform 500ms cubic-bezier(.16,.84,.3,1);
  transform-origin: center;
}
.cat-card:hover .cat-card__glyph {
  transform: scale(1.08) rotate(-3deg);
}

/* ---- price-card 「人気/定番」バッジ em の pulse ---- */
@keyframes price-pop-pulse {
  0%, 100% { transform: scale(1);   opacity: 0.95; }
  50%      { transform: scale(1.08); opacity: 1; }
}
.price-card .price-card__rows li.is-pop em {
  display: inline-block;
  animation: price-pop-pulse 2.4s ease-in-out infinite;
  transform-origin: center;
}

/* ---- magazine card hover で title が右へ少し ---- */
.mag-card .mag-card__title {
  transition: transform 400ms cubic-bezier(.16,.84,.3,1),
              color 400ms cubic-bezier(.16,.84,.3,1);
}
.mag-card:hover .mag-card__title {
  transform: translateX(4px);
  color: var(--c-primary-ink);
}

/* ---- CTA band: タイトル + desc + actions の段階登場 ---- */
@keyframes cta-band-rise {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: none; }
}
.cta-band__inner.reveal-up.is-visible .cta-band__eyebrow {
  animation: cta-band-rise 700ms cubic-bezier(.16,.84,.3,1) 100ms backwards;
}
.cta-band__inner.reveal-up.is-visible .cta-band__title {
  animation: cta-band-rise 700ms cubic-bezier(.16,.84,.3,1) 250ms backwards;
}
.cta-band__inner.reveal-up.is-visible .cta-band__desc {
  animation: cta-band-rise 700ms cubic-bezier(.16,.84,.3,1) 450ms backwards;
}
.cta-band__inner.reveal-up.is-visible .cta-band__actions {
  animation: cta-band-rise 700ms cubic-bezier(.16,.84,.3,1) 600ms backwards;
}

/* ---- trust-bar 段階フェードイン (4列、左から順に) ---- */
.trust-bar__list.reveal-stagger > .trust-bar__item {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 700ms cubic-bezier(.16,.84,.3,1),
    transform 700ms cubic-bezier(.16,.84,.3,1);
}
.trust-bar__list.reveal-stagger.is-visible > .trust-bar__item {
  opacity: 1;
  transform: none;
}
.trust-bar__list.reveal-stagger.is-visible > .trust-bar__item:nth-child(1) { transition-delay:   0ms; }
.trust-bar__list.reveal-stagger.is-visible > .trust-bar__item:nth-child(2) { transition-delay: 120ms; }
.trust-bar__list.reveal-stagger.is-visible > .trust-bar__item:nth-child(3) { transition-delay: 240ms; }
.trust-bar__list.reveal-stagger.is-visible > .trust-bar__item:nth-child(4) { transition-delay: 360ms; }
/* アイコンを軽く scale-in */
.trust-bar__list.reveal-stagger.is-visible > .trust-bar__item .trust-bar__icon {
  animation: rating-pop 600ms cubic-bezier(.16,.84,.3,1) 250ms backwards;
}

/* ---- foot-support 6項目: 段階フェードイン + アイコン scale ---- */
.foot-support__grid.reveal-stagger > .foot-support__item {
  opacity: 0;
  transform: translateY(18px) scale(0.97);
  transition:
    opacity 600ms cubic-bezier(.16,.84,.3,1),
    transform 700ms cubic-bezier(.16,.84,.3,1);
}
.foot-support__grid.reveal-stagger.is-visible > .foot-support__item {
  opacity: 1;
  transform: none;
}
.foot-support__grid.reveal-stagger.is-visible > .foot-support__item:nth-child(1) { transition-delay:   0ms; }
.foot-support__grid.reveal-stagger.is-visible > .foot-support__item:nth-child(2) { transition-delay:  90ms; }
.foot-support__grid.reveal-stagger.is-visible > .foot-support__item:nth-child(3) { transition-delay: 180ms; }
.foot-support__grid.reveal-stagger.is-visible > .foot-support__item:nth-child(4) { transition-delay: 270ms; }
.foot-support__grid.reveal-stagger.is-visible > .foot-support__item:nth-child(5) { transition-delay: 360ms; }
.foot-support__grid.reveal-stagger.is-visible > .foot-support__item:nth-child(6) { transition-delay: 450ms; }
/* hover でアイコンがふわっと上がる */
.foot-support__item .foot-support__icon {
  transition: transform 400ms cubic-bezier(.16,.84,.3,1);
}
.foot-support__item:hover .foot-support__icon {
  transform: translateY(-4px) scale(1.08);
}

/* ---- coupon ¥500: number カウントアップ用 (JS が data-target を見て中身書換) ---- */
.coupon-banner__amount {
  display: inline-block;
  font-variant-numeric: tabular-nums;
}

/* ---- prefers-reduced-motion 完全停止 ---- */
@media (prefers-reduced-motion: reduce) {
  .home-hero__content > *,
  .home-hero__title em::after,
  .home-hero__photo-accent,
  .home-hero__eyebrow::before,
  .home-hero__photo-wrap,
  .home-hero__photo,
  .home-hero__visual:not(.is-parallaxed) .home-hero__photo-accent,
  .section-heading.reveal-up .section-heading__en::before,
  .section-heading.reveal-up .section-heading__en::after,
  .cta-band::before, .cta-band::after,
  .home-hero__ctas .cta--pink-strong::after,
  .cta-band .cta--pink::after,
  .voice-grid.reveal-stagger.is-visible > .voice-card .voice-card__rating,
  .flow-steps.reveal-stagger.is-visible > .flow-step .flow-step__num,
  .cat-grid.reveal-stagger > *,
  .segment-grid.reveal-stagger > *,
  .price-grid.reveal-stagger > *,
  .voice-grid.reveal-stagger > *,
  .magazine-grid.reveal-stagger > *,
  .flow-steps.reveal-stagger > *,
  .price-card .price-card__rows li.is-pop em,
  .cta-band__inner.reveal-up.is-visible .cta-band__eyebrow,
  .cta-band__inner.reveal-up.is-visible .cta-band__title,
  .cta-band__inner.reveal-up.is-visible .cta-band__desc,
  .cta-band__inner.reveal-up.is-visible .cta-band__actions,
  .trust-bar__list.reveal-stagger > .trust-bar__item,
  .trust-bar__list.reveal-stagger.is-visible > .trust-bar__item .trust-bar__icon,
  .foot-support__grid.reveal-stagger > .foot-support__item {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
  }
  .home-hero__visual.is-parallaxed .hero-paper--card,
  .home-hero__visual.is-parallaxed .hero-paper--shopcard,
  .home-hero__visual.is-parallaxed .hero-paper--flyer {
    transform: none !important;
  }
}
