/* =========================================================
   坂本トシカズ「THE喫茶店」LP v1
   Base = Framework v1.0 ／ Theme = CLASSIC ／ Heroパターン = A
   ========================================================= */

:root {
  /* Layer 1 — 固定スケール */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 16px;
  --space-4: 24px;
  --space-5: 40px;
  --space-6: 64px;
  --space-7: 96px;
  --space-8: 128px;
  --maxw: 1180px;

  /* Layer 2 — テーマトークン（CF映え配色） */
  --paper: #fafaf7;
  --paper-deep: #f3f1ec;
  --surface: #ffffff;
  --ink: #0e0e10;
  --ink-soft: #2b2b30;
  --ink-muted: #6b6b73;
  --rule: #e3e0d4;
  --rule-soft: #ededea;
  --accent: #e63b1a;          /* 鮮やかな朱赤 */
  --accent-deep: #b82e14;
  --accent-soft: #ffeadf;
  --inofine: #4361ee;         /* INO Fine 鮮やかブルー */
  --inofine-d: #2e49c4;
  --inofine-l: #eaefff;
  --gold: #e6a817;
  --leaf: #6b8e4e;
  --paper-dark: #12141c;      /* フッター背景 */
  --grad-warm: linear-gradient(135deg, #fff7f0 0%, #ffeadf 50%, #fff0e6 100%);
  --grad-cool: linear-gradient(135deg, #eaefff 0%, #f0f4ff 50%, #e5ecff 100%);
  --grad-dark: linear-gradient(135deg, #12141c 0%, #1a1d2e 100%);
  --grad-hero: linear-gradient(160deg, #0e0e10 0%, #1a1028 40%, #2a1020 100%);
  --magenta: #e040a0;

  /* タイプ */
  --serif: "Noto Serif JP", "Shippori Mincho", serif;
  --sans: "Noto Sans JP", system-ui, sans-serif;
  --mono: "JetBrains Mono", monospace;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html, body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-feature-settings: "palt";
  font-size: 16px;
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
  scroll-behavior: smooth;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; }
a { color: inherit; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }

/* dark variant — まずはペーパー基調のみ。INK背景はHero Bでのみ部分採用 */

/* ------------------------------- TopBar (legacy) ---------------------- */
.topbar { display: none; }
.topbar-inner {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 14px 28px;
  display: flex; align-items: center; justify-content: space-between;
}
.topbar .brand { display: flex; align-items: center; gap: 14px; }
.topbar .brand-name { font-family: var(--serif); font-weight: 900; font-size: 16px; letter-spacing: .04em; }
.topbar .brand-divider { width: 1px; height: 14px; background: var(--rule); }
.topbar .brand-meta { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; color: var(--ink-muted); }
.topbar nav { display: flex; gap: 22px; font-family: var(--mono); font-size: 11px; letter-spacing: .14em; color: var(--ink-muted); }
.topbar nav a { text-decoration: none; transition: color .15s; }
.topbar nav a:hover { color: var(--accent); }

/* ------------------------------- Hero ------------------------ */
.hero { padding: 48px 0 64px; position: relative; }
.hero-inner { display: grid; gap: 56px; align-items: stretch; }

/* Pattern A — Manga-led */
.hero[data-pattern="A"] .hero-inner { grid-template-columns: 1.15fr 1fr; }
.hero[data-pattern="A"] .hero-panel { aspect-ratio: 4/5; }
.hero[data-pattern="A"] .hero-side { padding-top: 12px; display: flex; flex-direction: column; justify-content: space-between; align-items: stretch; gap: 32px; min-width: 0; overflow: hidden; }

/* Pattern B — Character-led（INK背景） */
.hero[data-pattern="B"] { background: var(--ink); color: #f5efe4; padding: 0; }
.hero[data-pattern="B"] .topbar-bleed { display: none; }
.hero[data-pattern="B"] .hero-inner { grid-template-columns: 1fr 1fr; min-height: 760px; padding: 56px 0 56px; }
.hero[data-pattern="B"] .hero-title-mega { display: block; }
.hero[data-pattern="B"] .hero-title-default { display: none; }
.hero[data-pattern="B"] .hero-side .meta-eyebrow { color: #f5efe4; }
.hero[data-pattern="B"] .hero-side .copy-sub { color: rgba(245,239,228,0.78); }
.hero[data-pattern="B"] .hero-side .copy-meta { color: rgba(245,239,228,0.55); }
.hero[data-pattern="B"] .hero-panel { aspect-ratio: 3/4; }
.hero[data-pattern="B"] .funding-strip { color: #f5efe4; }
.hero[data-pattern="B"] .funding-strip .label { color: rgba(245,239,228,0.55); }
.hero[data-pattern="B"] .funding-strip .progress { background: rgba(245,239,228,0.18); }
.hero[data-pattern="B"] .btn-secondary { color: #f5efe4; border-color: rgba(245,239,228,0.85); }
.hero[data-pattern="B"] .btn-primary { box-shadow: 4px 4px 0 #000; }

/* Pattern C — キャッチ全幅 + 下部2カラム */
.hero[data-pattern="C"] .hero-inner { grid-template-columns: 1fr; gap: 0; padding-top: 24px; }
.hero[data-pattern="C"] .hero-title-mega { display: none; }
.hero[data-pattern="C"] .hero-title-msg { display: block; }
.hero[data-pattern="C"] .hero-title-default { display: none; }
.hero[data-pattern="C"] .hero-panel { aspect-ratio: 3/4; }

.hero-title-default { display: block; }
.hero-title-mega, .hero-title-msg { display: none; }

.meta-eyebrow {
  font-family: var(--mono); font-size: 11px; letter-spacing: .22em;
  color: var(--accent); margin-bottom: 22px; display: inline-block;
}

.hero-title {
  font-family: var(--serif); font-weight: 900;
  font-size: clamp(48px, 6vw, 72px);
  line-height: 1.05; letter-spacing: -0.005em; margin: 0;
  color: var(--ink);
}
.hero-title .dot { color: var(--accent); }

.hero-title-mega .hero-title {
  font-size: clamp(72px, 9vw, 120px);
  color: #f5efe4;
}

/* --- 作品名（喫茶店看板風） --- */
.hero-work-name {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0;
  margin-bottom: 22px;
  padding: 20px 36px 22px;
  background: #1a1410;
  border: 2px solid #3d3028;
  box-shadow: inset 0 0 0 4px #1a1410, inset 0 0 0 5.5px #5c4a38;
  position: relative;
  text-align: center;
  max-width: 100%;
  box-sizing: border-box;
}
.hero-work-name::before,
.hero-work-name::after {
  content: ""; position: absolute; left: 50%; transform: translateX(-50%);
  width: 60px; height: 1px; background: #5c4a38;
}
.hero-work-name::before { top: 10px; }
.hero-work-name::after { bottom: 10px; }
.hwn-the {
  font-family: var(--mono); font-weight: 700;
  font-size: clamp(28px, 3.5vw, 44px);
  letter-spacing: .12em; color: #a08c6e;
  line-height: 1;
}
.hwn-title {
  font-family: var(--serif); font-weight: 900;
  font-size: clamp(48px, 6.5vw, 80px);
  letter-spacing: .08em; line-height: 1;
  color: #ffffff;
  text-shadow: 0 2px 12px rgba(0,0,0,0.4);
}

/* ダークパターン — 背景が暗いのでボーダーを明るく */
.hero-work-name-dark {
  border-color: #5c4a38;
  box-shadow: inset 0 0 0 4px #1a1410, inset 0 0 0 5.5px #7a6650,
              0 8px 32px rgba(0,0,0,0.5);
}

/* Pattern C — メッセージコピー */
.hero-title-msg .hero-work-name {
  margin-bottom: 18px;
}
.hero-title-msg .hero-title {
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.25;
}
.hero-title-msg .underline {
  font-size: 1.3em;
  border-bottom: 5px solid var(--accent); padding-bottom: 3px;
}

@media (max-width: 560px) {
  .hero-work-name { padding: 16px 24px 18px; }
  .hwn-title { font-size: clamp(36px, 11vw, 48px); }
}

.hero-creator {
  margin-top: 24px;
  font-family: var(--serif); font-weight: 900;
  font-size: clamp(20px, 2.6vw, 28px);
  letter-spacing: .06em;
  color: var(--ink);
  display: flex; align-items: baseline; gap: 12px;
}
.hero-creator .hc-label {
  font-family: var(--mono); font-size: 10px; letter-spacing: .2em;
  color: var(--accent); font-weight: 600;
  border: 1px solid var(--accent); padding: 3px 8px;
  white-space: nowrap; position: relative; top: -2px;
}
.copy-author {
  margin-top: 18px;
  font-family: var(--serif); font-weight: 500;
  font-size: 19px; line-height: 1.5;
  color: var(--ink-soft);
}
.copy-sub {
  margin-top: 14px; font-size: 13.5px; line-height: 1.85;
  color: var(--ink-muted);
}
.copy-meta {
  margin-top: 12px; font-family: var(--mono); font-size: 11px;
  letter-spacing: .08em; color: var(--ink-muted);
}

/* manga panel - placeholder frame */
.hero-panel {
  position: relative;
  background: #f2e8d0;
  border: 2px solid var(--ink);
  box-shadow: 10px 10px 0 var(--accent-soft), 10px 10px 0 1.5px var(--accent);
  overflow: hidden;
}
.hero-panel img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.hero-panel .stamp {
  position: absolute; top: 14px; left: 14px;
  background: var(--paper);
  font-family: var(--mono); font-size: 9.5px; letter-spacing: .22em;
  color: var(--accent); border: 1.2px solid var(--accent);
  padding: 4px 9px; transform: rotate(-3deg);
  z-index: 3;
}
.hero-panel .bubble {
  position: absolute; right: 16px; top: 14%;
  background: var(--paper); color: var(--ink);
  border: 3px solid var(--ink);
  padding: 14px 18px; max-width: 240px;
  font-family: var(--serif); font-weight: 700; font-size: 19px;
  line-height: 1.4; box-shadow: 6px 6px 0 var(--ink);
  z-index: 3; transform: rotate(-1deg);
}

/* ============ Hero Gallery — あばちょLP準拠スライダー ============ */
.hero-gallery { display: flex; flex-direction: column; gap: 0; }
.hero-slider { position: relative; width: 100%; aspect-ratio: 16/9; max-height: 70vh; overflow: hidden; border-radius: 8px; background: var(--ink); }
.hero-slide { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; transition: opacity .6s ease; }
.hero-slide.active { opacity: 1; }
.hero-slide img { width: 100%; height: 100%; object-fit: contain; display: block; }
.hero-nav { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,.85); border: none; width: 36px; height: 36px; border-radius: 50%; cursor: pointer; font-size: 14px; color: var(--ink); z-index: 2; display: grid; place-items: center; transition: background .2s; }
.hero-nav:hover { background: #fff; }
.hero-prev { left: 10px; }
.hero-next { right: 10px; }
.hero-thumbs { display: flex; gap: 6px; padding: 10px 0; overflow-x: auto; scrollbar-width: none; }
.hero-thumbs::-webkit-scrollbar { display: none; }
.hero-thumb { flex-shrink: 0; width: 72px; height: 72px; border-radius: 6px; overflow: hidden; cursor: pointer; opacity: .5; border: 3px solid transparent; transition: opacity .3s, border-color .3s; }
.hero-thumb.active { opacity: 1; border-color: var(--accent); }
.hero-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ============ Hero Gallery — PC / Mobile 出し分け ============ */
.hero-gallery-mobile { display: none; }

/* scroll-snap カルーセル（mobile用） */
.hero-scroll-track {
  display: flex; overflow-x: auto; scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch; scrollbar-width: none;
  border-radius: 6px; background: var(--ink);
}
.hero-scroll-track::-webkit-scrollbar { display: none; }
.hero-scroll-slide {
  flex: 0 0 100%; aspect-ratio: 4/3; background: var(--ink);
  scroll-snap-align: center;
}
.hero-scroll-slide img { width: 100%; height: 100%; object-fit: contain; display: block; }
.hero-dots { display: flex; justify-content: center; gap: 8px; padding: 12px 0; }
.hero-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: rgba(26,20,16,0.25); border: none; cursor: pointer;
  transition: background 0.3s;
}
.hero-dot.active { background: var(--accent); }

/* mobile scroll-wrap（ナビボタン配置用） */
.hero-scroll-wrap { position: relative; }
.hero-scroll-wrap .hero-nav { display: none; }
@media (max-width: 880px) {
  .hero-scroll-wrap .hero-nav {
    display: grid; position: absolute; top: 50%; transform: translateY(-50%);
    width: 32px; height: 32px; font-size: 12px; z-index: 2;
    background: rgba(255,255,255,.85); border: none; border-radius: 50%;
    cursor: pointer; place-items: center; color: var(--ink);
  }
  .hero-scroll-wrap .hero-prev { left: 6px; }
  .hero-scroll-wrap .hero-next { right: 6px; }
}

/* ライトボックス（拡大プレビュー） */
.hero-lightbox {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,.92); z-index: 9999;
  display: flex; align-items: center; justify-content: center;
  cursor: zoom-out;
}
.hero-lightbox img {
  max-width: 92vw; max-height: 88vh; object-fit: contain; cursor: default;
}
.hlb-close {
  position: absolute; top: 16px; right: 16px;
  background: none; border: none; color: #fff; font-size: 28px;
  cursor: pointer; width: 40px; height: 40px; display: grid; place-items: center;
}
.hlb-prev, .hlb-next {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,.2); border: none; border-radius: 50%;
  width: 40px; height: 40px; color: #fff; font-size: 16px;
  cursor: pointer; display: grid; place-items: center;
  transition: background .2s;
}
.hlb-prev:hover, .hlb-next:hover { background: rgba(255,255,255,.4); }
.hlb-prev { left: 12px; }
.hlb-next { right: 12px; }
.hlb-counter {
  position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%);
  color: rgba(255,255,255,.7); font-family: var(--mono);
  font-size: 12px; letter-spacing: .1em;
}

/* funding strip */
.funding-strip { display: flex; gap: 36px; align-items: flex-end; }
.funding-strip .item { }
.funding-strip .label {
  font-family: var(--mono); font-size: 10px; letter-spacing: .18em;
  color: var(--ink-muted); margin-bottom: 6px;
}
.funding-strip .value {
  font-family: var(--serif); font-weight: 900; font-size: 28px;
  line-height: 1;
}
.funding-strip .value .small {
  font-family: var(--mono); font-weight: 400; font-size: 12px;
  color: var(--ink-muted); margin-left: 4px;
}
.funding-strip .progress {
  margin-top: 10px; height: 4px; width: 220px;
  background: rgba(26,20,16,0.12); position: relative;
}
.funding-strip .progress > div {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--accent);
}

/* CTAs */
.cta-row { display: flex; gap: 14px; flex-wrap: nowrap; }
.btn-primary {
  background: var(--accent); color: #fff; border: none;
  padding: 18px 32px;
  font-family: var(--serif); font-weight: 700; font-size: 17px;
  letter-spacing: .02em;
  box-shadow: 4px 4px 0 var(--accent-deep);
  transition: transform .12s, box-shadow .12s;
  display: inline-flex; align-items: center; gap: 14px;
}
.btn-primary:hover { transform: translate(2px, 2px); box-shadow: 2px 2px 0 var(--accent-deep); }
.btn-primary .arrow { font-family: var(--mono); font-size: 11px; opacity: .8; letter-spacing: .12em; }

.btn-secondary {
  background: transparent; color: var(--ink);
  border: 1.5px solid var(--ink);
  padding: 16px 24px;
  font-family: var(--serif); font-weight: 500; font-size: 14px;
  letter-spacing: .02em;
  display: inline-flex; flex-direction: column; align-items: flex-start; gap: 2px;
  text-align: left;
}
.btn-secondary .micro {
  font-family: var(--mono); font-size: 9.5px; letter-spacing: .14em;
  color: var(--ink-muted);
}

/* ------------------------------ Sections common ------------- */
section.lp { padding: 100px 0; border-top: none; position: relative; }
section.lp::before {
  content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: min(90%, 880px); height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--rule) 20%, var(--rule) 80%, transparent 100%);
}
section.lp:first-of-type::before { display: none; }
section.lp.alt { background: var(--paper-deep); }
section.lp.warm { background: var(--grad-warm); }
section.lp.dark { background: var(--ink); color: #f5efe4; }
section.lp.dark::before { background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.08) 20%, rgba(255,255,255,.08) 80%, transparent 100%); }
section.lp.dark .sec-num, section.lp.dark .sec-title .accent { color: var(--accent); }
section.lp.dark .sec-sub { color: rgba(245,239,228,0.72); }

.sec-head { margin-bottom: 56px; max-width: 880px; }
.sec-num {
  font-family: var(--mono); font-size: 13px; letter-spacing: .3em;
  color: var(--accent); margin-bottom: 16px;
  display: flex; align-items: center; gap: 14px;
  font-weight: 700;
  text-transform: uppercase;
}
.sec-num::before { content: ""; width: 40px; height: 3px; background: var(--accent); border-radius: 2px; }
.sec-title {
  font-family: var(--serif); font-weight: 900;
  font-size: clamp(32px, 4.2vw, 52px);
  line-height: 1.25; letter-spacing: -.01em;
  margin: 0 0 18px;
}
.sec-title .accent { color: var(--accent); }
.hl { background: linear-gradient(transparent 60%, rgba(230,168,23,0.18) 60%); padding: 0 2px; }
.hl-strong { background: linear-gradient(transparent 60%, rgba(230,59,26,0.15) 60%); padding: 0 2px; font-weight: 700; }
.sec-sub { font-size: 16px; line-height: 1.85; color: var(--ink-muted); max-width: 740px; }

/* 作品キャッチコピー（坂本さん原文） */
.work-catchcopy {
  font-family: var(--serif); font-weight: 700;
  font-size: 17px; line-height: 1.7;
  color: var(--ink-soft);
  margin-bottom: 12px;
  padding-left: 16px;
  border-left: 3px solid var(--accent);
}

/* 作家からのメッセージ（テキスト情報.txt原文） */
.creator-message {
  margin-top: 28px;
  padding: 20px 24px;
  background: var(--paper-deep);
  border-left: 3px solid var(--accent);
  border-radius: 0 6px 6px 0;
}
.creator-message p {
  font-family: var(--serif); font-weight: 500;
  font-size: 15px; line-height: 1.9;
  color: var(--ink-soft); margin: 0;
}

/* ------------------------------ PITCH (02) ------------------ */
.pitch-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  border: 1.5px solid var(--ink);
  background: var(--surface);
  box-shadow: 6px 6px 0 var(--accent-soft);
}
.pitch-cell {
  padding: 28px 32px;
  border-right: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.pitch-cell:nth-child(2n) { border-right: none; }
.pitch-cell:nth-last-child(-n+2) { border-bottom: none; }
.pitch-cell .k {
  font-family: var(--mono); font-size: 10px; letter-spacing: .24em;
  color: var(--accent); margin-bottom: 10px;
}
.pitch-cell .v {
  font-family: var(--serif); font-weight: 700; font-size: 20px;
  line-height: 1.5; color: var(--ink);
}
.pitch-cell .v .num { font-size: 32px; letter-spacing: -.01em; }

/* dual channel bar */
.channel-bar {
  margin-top: 28px;
  display: grid; grid-template-columns: 1fr auto 1fr;
  background: var(--paper-deep); border: 1px dashed var(--rule);
  padding: 18px 22px; align-items: center; gap: 20px;
}
.channel-bar .ch { display: flex; flex-direction: column; gap: 4px; }
.channel-bar .ch .lab { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; color: var(--ink-muted); }
.channel-bar .ch .nm { font-family: var(--serif); font-weight: 700; font-size: 16px; }
.channel-bar .plus { font-family: var(--serif); font-weight: 900; font-size: 28px; color: var(--accent); }

/* ------------------------------ READ (03) — manga viewer ---- */
.manga-viewer {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
}
.manga-page {
  background: #f2e8d0; border: 1.5px solid var(--ink);
  aspect-ratio: 3/4; overflow: hidden;
  box-shadow: 6px 6px 0 var(--accent-soft);
  position: relative;
  transition: transform .15s, box-shadow .15s;
}
.manga-page:hover { transform: translate(-2px, -2px); box-shadow: 8px 8px 0 var(--accent-soft); }
.manga-page img { width: 100%; height: 100%; object-fit: cover; }
.manga-page .lab {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: rgba(26,20,16,0.88); color: var(--paper);
  font-family: var(--mono); font-size: 10px; letter-spacing: .2em;
  padding: 8px 12px; text-align: center;
}
.read-cta {
  margin-top: 36px; text-align: center;
  font-family: var(--serif); font-size: 16px; color: var(--ink-soft);
}
.read-cta a {
  display: inline-block; margin-top: 14px;
  border: 1.5px solid var(--ink); padding: 14px 28px;
  text-decoration: none; font-family: var(--serif); font-weight: 700;
  font-size: 14px; transition: background .15s, color .15s;
}
.read-cta a:hover { background: var(--ink); color: var(--paper); }

/* old vs new compare */
.compare {
  margin-top: 56px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
  border-top: 1px solid var(--rule); padding-top: 40px;
}
.compare-col h4 {
  font-family: var(--mono); font-size: 11px; letter-spacing: .22em;
  color: var(--accent); margin-bottom: 14px;
}
.compare-col .ttl { font-family: var(--serif); font-weight: 700; font-size: 22px; margin-bottom: 14px; }
.compare-col .pic {
  background: #f2e8d0; border: 1.5px solid var(--ink); aspect-ratio: 1/1;
  overflow: hidden; box-shadow: 6px 6px 0 var(--accent-soft);
}
.compare-col .pic img { width: 100%; height: 100%; object-fit: cover; }
.compare-col p { margin-top: 14px; font-size: 14px; color: var(--ink-soft); line-height: 1.85; }

/* ------------------------------ CHARACTERS (04) -------------- */
.char-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.char-card { background: var(--surface); border: 1px solid var(--rule); padding: 28px; }
.char-card .pic {
  width: 100%; aspect-ratio: 1/1; background: var(--paper-deep);
  border: 1.5px solid var(--ink); margin-bottom: 18px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--mono); font-size: 10px; color: var(--ink-muted);
  letter-spacing: .18em;
}
.char-card .pic img { width: 100%; height: 100%; object-fit: cover; }
.char-card .role {
  font-family: var(--mono); font-size: 10px; letter-spacing: .22em;
  color: var(--accent); margin-bottom: 6px;
}
.char-card h4 { font-family: var(--serif); font-weight: 900; font-size: 22px; margin-bottom: 4px; }
.char-card .romaji { font-family: var(--mono); font-size: 11px; color: var(--ink-muted); margin-bottom: 14px; letter-spacing: .12em; }
.char-card p { font-size: 13.5px; line-height: 1.85; color: var(--ink-soft); }

/* ------------------------------ CREATOR (05) ----------------- */
.creator { display: grid; grid-template-columns: 320px 1fr; gap: 56px; align-items: start; }
.creator-aside { position: sticky; top: 80px; }
.creator-portrait {
  width: 100%; aspect-ratio: 4/5; background: var(--paper-deep);
  border: 1.5px solid var(--ink); box-shadow: 8px 8px 0 var(--accent-soft);
  overflow: hidden; margin-bottom: 18px;
}
.creator-portrait img { width: 100%; height: 100%; object-fit: cover; }
.creator-name { font-family: var(--serif); font-weight: 900; font-size: 24px; }
.creator-name-eng { font-family: var(--mono); font-size: 11px; letter-spacing: .18em; color: var(--ink-muted); margin-top: 4px; }
.creator-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.creator-tags .tag {
  font-family: var(--mono); font-size: 10px; letter-spacing: .14em;
  padding: 4px 10px; border: 1px solid var(--ink);
}
.creator-body .ch {
  margin-bottom: 36px; padding-bottom: 36px;
  border-bottom: 1px solid var(--rule);
}
.creator-body .ch:last-child { border-bottom: none; }
.creator-body .ch-num {
  font-family: var(--mono); font-size: 11px; letter-spacing: .24em;
  color: var(--accent); margin-bottom: 10px;
}
.creator-body h4 {
  font-family: var(--serif); font-weight: 900; font-size: 24px;
  line-height: 1.45; margin-bottom: 14px;
}
.creator-body p {
  font-size: 14.5px; line-height: 2; color: var(--ink-soft);
  margin-bottom: 12px;
}
.pull-quote {
  margin: 28px 0;
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  padding: 24px 0;
  font-family: var(--serif); font-weight: 500;
  font-size: 21px; line-height: 1.65; color: var(--ink);
}
.pull-quote .accent { color: var(--accent); }

/* ------------------------------ OFFER (06) — tiers ----------- */
.tier-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
/* v2 — compact 4-col cards (7 cards → 2 rows: 4+3) */
.tier-grid-v2 { grid-template-columns: repeat(4, 1fr); gap: 14px; align-items: stretch; }
.tier-grid-v2 .tier { padding: 0; overflow: hidden; min-height: 0; }
.tier-grid-v2 .tier.hero-tier { grid-column: span 1; background: #fff5dd; box-shadow: 6px 6px 0 var(--accent); }
.tier-grid-v2 .tier > .ribbon, .tier-grid-v2 .tier > .limit { position: absolute; top: 8px; right: 8px; z-index: 3; font-size: 10px; padding: 3px 8px; }
.tier-thumb {
  position: relative; background: var(--paper-deep);
  border-bottom: 1px solid var(--ink); overflow: hidden;
  line-height: 0;
}
.tier-thumb img { width: 100%; height: auto; display: block; transition: transform .4s; }
.tier:hover .tier-thumb img { transform: scale(1.04); }
.tier-thumb-tag { display: none; }
.tier-body { padding: 10px 12px 10px; display: flex; flex-direction: column; flex: 1; }
.tier-body .tier-head { margin-bottom: 4px; }
.tier-body .tier-h { font-family: var(--serif); font-weight: 800; font-size: 13px; line-height: 1.45; margin-bottom: 4px; min-height: 0; }
.tier-body .tagline { font-size: 11px; line-height: 1.55; color: var(--ink-soft); margin-bottom: 6px; min-height: 0; }
.tier-acc-toggle {
  display: flex; justify-content: space-between; align-items: center; width: 100%;
  background: transparent; border: 1px solid var(--ink); padding: 6px 10px;
  font-family: var(--mono); font-size: 9px; letter-spacing: .12em; color: var(--ink);
  margin-top: auto; transition: background .15s, color .15s;
}
.tier-acc-toggle:hover { background: var(--ink); color: var(--paper); }
.tier-acc-toggle svg { transition: transform .25s; }
.tier-acc-toggle.open svg { transform: rotate(180deg); }
.tier-acc {
  display: grid; grid-template-rows: 0fr; transition: grid-template-rows .3s ease;
}
.tier-acc > * { overflow: hidden; }
.tier-acc.open { grid-template-rows: 1fr; }
.tier-acc .perks { margin-top: 10px; list-style: none; padding: 0; }
.tier-acc .perks li { padding: 8px 0; border-bottom: 1px dashed var(--rule); font-size: 11.5px; line-height: 1.55; }
.tier-acc .perks li:last-child { border-bottom: none; }
.tier-acc .perks b { display: block; font-weight: 700; color: var(--ink); margin-bottom: 3px; }
.tier-acc .perk-note { display: block; font-size: 11px; color: var(--ink-muted); line-height: 1.6; }
.tier-acc .meta { display: flex; flex-direction: column; gap: 4px; margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--rule); }
.tier-acc .meta .m { font-size: 11px; color: var(--ink-soft); display: flex; gap: 8px; }
.tier-acc .meta .m b { font-family: var(--mono); font-size: 9px; letter-spacing: .16em; color: var(--ink-muted); min-width: 90px; }

/* ----- Offer Duo Cards (2枚並び) ----- */
.offer-duo {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
  margin-bottom: 48px;
}
.offer-card {
  display: flex; flex-direction: column; align-items: center; text-align: center;
  padding: 36px 24px 28px; border-radius: 12px;
  border: 2px solid var(--rule); background: #fff;
  cursor: pointer; transition: transform .2s, box-shadow .2s, border-color .2s;
}
.offer-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,0.08); }
.offer-card-cf:hover { border-color: #e85d3a; }
.offer-card-if:hover { border-color: var(--inofine); }
.offer-card-icon { width: 48px; height: 48px; margin-bottom: 14px; display: flex; align-items: center; justify-content: center; font-size: 28px; }
.offer-card-cf .offer-card-icon { color: #e85d3a; font-size: 34px; }
.offer-card h3 { font-family: var(--serif); font-size: 20px; font-weight: 800; margin-bottom: 8px; }
.offer-card-price { font-family: var(--mono); font-size: 16px; font-weight: 700; color: var(--accent); margin-bottom: 8px; }
.offer-card-desc { font-size: 13px; color: var(--ink-soft); line-height: 1.6; margin-bottom: 16px; }
/* offer-card horizontal layout (左画像＋右コンテンツ) */
.offer-duo-h { flex-direction: column; }
.offer-card-h {
  flex-direction: row !important;
  align-items: stretch;
  text-align: left;
  padding: 0 !important;
  overflow: hidden;
}
.oc-thumb {
  width: 257px; flex-shrink: 0;
  background: var(--paper-deep);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
}
.oc-thumb img { width: 100%; height: auto; object-fit: contain; display: block; }
.oc-body {
  flex: 1; padding: 24px 28px;
  display: flex; flex-direction: column; align-items: flex-start;
}
.oc-header { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.oc-header .offer-card-icon { margin-bottom: 0; flex-shrink: 0; }
.oc-header h3 { margin-bottom: 2px; }
.oc-header .offer-card-price { margin-bottom: 0; }
.oc-body .offer-card-desc { text-align: left; }
.oc-body .offer-card-action { margin-top: auto; }
.offer-card-cta { margin-top: 12px; width: 100%; text-align: center; font-size: 13px; padding: 10px 20px; }
@media (max-width: 560px) {
  .offer-card-h { flex-direction: column !important; }
  .oc-thumb { width: 100%; height: auto; padding: 20px; }
  .oc-body { padding: 20px; }
}
.btn-tier-toggle {
  display: inline-block; padding: 10px 24px;
  font-family: var(--sans); font-size: 13px; font-weight: 600;
  color: var(--ink-muted); background: var(--paper-deep);
  border: 1px solid var(--rule); border-radius: 6px;
  cursor: pointer; transition: background .15s, color .15s;
}
.btn-tier-toggle:hover { background: var(--ink); color: var(--paper); }

/* tier scroll hint — icon only */
.tier-scroll-hint {
  display: flex; align-items: center; justify-content: center; gap: 4px;
  color: var(--ink-muted); margin-bottom: 8px;
  animation: hint-slide 1.6s ease-in-out 3;
}
.tier-scroll-hint i:first-child,
.tier-scroll-hint i:last-child { font-size: 10px; opacity: .5; }
.tier-scroll-hint i:nth-child(2) { font-size: 14px; opacity: .35; }
@keyframes hint-slide {
  0%, 100% { transform: translateX(0); }
  30% { transform: translateX(-6px); }
  70% { transform: translateX(6px); }
}

/* tier-table — CAMPFIRE プラン表形式 */
.tier-table-wrap {
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  scrollbar-width: thin; scrollbar-color: var(--rule) transparent;
  margin: 0 -4px; padding: 0 4px;
  position: relative;
}
.tier-table-wrap::after {
  content: ""; position: sticky; right: 0; top: 0;
  width: 40px; height: 100%; flex-shrink: 0; float: right;
  background: linear-gradient(to right, transparent, rgba(255,255,255,.9));
  pointer-events: none; margin-left: -40px; z-index: 2;
}
/* 画像ライトボックス */
.tt-img-lightbox { position: fixed; inset: 0; z-index: 9999; background: rgba(0,0,0,.75); display: flex; align-items: center; justify-content: center; cursor: zoom-out; }
.tt-img-lightbox img { max-width: 90vw; max-height: 85vh; border-radius: 6px; box-shadow: 0 8px 40px rgba(0,0,0,.5); }
.tt-img { cursor: zoom-in; }
.tier-table {
  width: 100%; min-width: 900px; border-collapse: collapse;
  font-size: 13px; background: var(--surface);
}
.tier-table th {
  font-family: var(--mono); font-size: 10px; letter-spacing: .14em;
  color: var(--ink-muted); text-align: left;
  padding: 10px 14px; border-bottom: 2px solid var(--ink);
  white-space: nowrap;
}
.tier-table td {
  padding: 14px 14px; border-bottom: 1px solid var(--rule);
  vertical-align: top; line-height: 1.65;
}
.tier-table tbody tr:hover { background: rgba(230,59,26,0.02); }
.tt-col-img { width: 260px; }
.tt-col-plan { width: 110px; }
.tt-col-desc { width: 220px; }
.tt-col-perks { }
.tt-col-meta { width: 100px; }
.tt-img { padding: 10px 8px !important; vertical-align: middle !important; }
.tt-img img {
  width: 100%; height: auto; object-fit: contain;
  border-radius: 4px; border: 1px solid var(--rule);
  display: block;
}
.tt-code {
  font-family: var(--mono); font-size: 10px; letter-spacing: .14em;
  color: var(--accent); margin-bottom: 2px;
}
.tt-label { font-family: var(--serif); font-weight: 800; font-size: 14px; margin-bottom: 4px; }
.tt-price { font-family: var(--mono); font-weight: 700; font-size: 16px; color: var(--ink); }
.tt-limit {
  display: inline-block; margin-top: 4px;
  font-size: 10px; font-weight: 700; color: var(--accent);
  border: 1px solid var(--accent); border-radius: 3px;
  padding: 1px 6px;
}
.tt-title { font-family: var(--serif); font-weight: 700; font-size: 13px; margin-bottom: 4px; }
.tt-tagline { font-size: 12px; color: var(--ink-muted); line-height: 1.6; }
.tt-perks ul { list-style: none; padding: 0; margin: 0; }
.tt-perks li { margin-bottom: 6px; font-size: 12.5px; }
.tt-perks li:last-child { margin-bottom: 0; }
.tt-perks b { display: block; font-size: 12.5px; }
.tt-note { display: block; font-size: 11px; color: var(--ink-muted); margin-top: 1px; }
.tt-meta { font-size: 12px; white-space: nowrap; }
.tt-deliver { color: var(--ink-muted); margin-top: 4px; font-size: 11px; }
.offer-card-action {
  font-family: var(--mono); font-size: 11px; letter-spacing: .1em; font-weight: 600;
  color: var(--ink); border: 1px solid var(--ink); padding: 8px 20px; border-radius: 4px;
  transition: background .15s, color .15s;
}
.offer-card:hover .offer-card-action { background: var(--ink); color: var(--paper); }
@media (max-width: 600px) {
  .offer-duo { grid-template-columns: 1fr; }
}

/* ----- Offer Modal ----- */
.offer-modal-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,0.55); backdrop-filter: blur(4px);
  display: flex; align-items: flex-start; justify-content: center;
  padding: 40px 16px; overflow-y: auto;
}
.offer-modal {
  background: var(--paper); border-radius: 14px; width: 100%; max-width: 920px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.25);
}
.offer-modal-bar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 18px 24px; border-bottom: 1px solid var(--rule);
}
.offer-modal-title { font-family: var(--serif); font-weight: 800; font-size: 17px; }
.offer-modal-close {
  width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--rule);
  background: transparent; font-size: 20px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
.offer-modal-close:hover { background: var(--paper-deep); }
.offer-modal-body { padding: 24px; }
.offer-modal-intro { margin-bottom: 20px; font-size: 14px; color: var(--ink-soft); line-height: 1.6; }
.offer-modal-foot { margin-top: 28px; text-align: center; }

/* INO Fine 専用プラン */
.inofine-tier {
  margin-top: 40px; padding: 36px; border: 1.5px solid var(--inofine);
  background: var(--inofine-l); position: relative;
}
.inofine-tier::before {
  content: ""; position: absolute; left: 0; top: 0; width: 4px; height: 100%; background: var(--inofine);
}
.inofine-tier-head { display: flex; flex-wrap: wrap; align-items: baseline; gap: 18px; margin-bottom: 14px; }
.inofine-tier-head .badge {
  font-family: var(--mono); font-size: 10px; letter-spacing: .22em;
  background: var(--inofine); color: #fff; padding: 6px 12px;
}
.inofine-tier-head h3 { font-family: var(--serif); font-weight: 900; font-size: 22px; flex: 1; }
.inofine-tier-head .inofine-price { font-family: var(--serif); font-weight: 900; font-size: 32px; color: var(--inofine); }
.inofine-tier-head .inofine-price .unit { font-size: 14px; color: var(--ink-muted); font-weight: 400; margin-left: 4px; }
.inofine-tier-lead { font-size: 14px; line-height: 1.85; color: var(--ink-soft); margin-bottom: 24px; }
.inofine-perks { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.ip { background: #fff; padding: 22px; border: 1px solid rgba(26,68,128,0.2); }
.ip-no { font-family: var(--mono); font-size: 10px; letter-spacing: .22em; color: var(--inofine); margin-bottom: 8px; }
.ip h5 { font-family: var(--serif); font-weight: 800; font-size: 15px; line-height: 1.55; margin-bottom: 10px; }
.ip p { font-size: 12.5px; line-height: 1.8; color: var(--ink-soft); }
.ip-link, .tb-link { color: var(--inofine); font-family: var(--mono); font-size: 10.5px; letter-spacing: .14em; text-decoration: none; border-bottom: 1px solid var(--inofine); display: inline-block; margin-top: 8px; padding-bottom: 1px; }
.tb-link { font-size: 11px; }

/* ---------- INO Fine Plan (redesigned) ---------- */
.if-plan {
  background: #fff;
  border: 1.5px solid var(--inofine);
  border-radius: 12px;
  overflow: hidden;
}
.if-plan-header {
  background: linear-gradient(135deg, #eaefff 0%, #f4f7ff 100%);
  padding: 32px 32px 24px;
  border-bottom: 1px solid rgba(67,97,238,0.15);
}
.if-plan-badge {
  display: inline-block;
  font-family: var(--mono); font-size: 10px; letter-spacing: .22em;
  background: var(--inofine); color: #fff; padding: 5px 14px;
  border-radius: 3px; margin-bottom: 14px;
}
.if-plan-title-row {
  display: flex; align-items: baseline; gap: 20px; flex-wrap: wrap;
  margin-bottom: 12px;
}
.if-plan-title {
  font-family: var(--serif); font-weight: 900; font-size: 22px;
  line-height: 1.4; flex: 1; min-width: 200px;
}
.if-plan-price {
  font-family: var(--serif); font-weight: 900; font-size: 36px;
  color: var(--inofine); white-space: nowrap;
}
.if-plan-unit { font-size: 14px; color: var(--ink-muted); font-weight: 400; margin-left: 4px; }
.if-plan-lead {
  font-size: 14px; line-height: 1.85; color: var(--ink-soft);
}
.if-plan-features {
  padding: 28px 32px;
  display: flex; flex-direction: column; gap: 0;
}
.if-feat {
  display: flex; gap: 20px; align-items: flex-start;
  padding: 24px 0;
  border-bottom: 1px solid var(--rule-soft);
}
.if-feat:last-child { border-bottom: none; }
.if-feat-main { padding-top: 0; }
.if-feat-icon {
  flex-shrink: 0; width: 44px; height: 44px;
  background: var(--inofine-l); color: var(--inofine);
  border-radius: 10px; display: flex; align-items: center; justify-content: center;
  font-size: 20px;
}
.if-feat-body { flex: 1; }
.if-feat-num {
  font-family: var(--mono); font-size: 10px; letter-spacing: .22em;
  color: var(--inofine); margin-bottom: 4px;
}
.if-feat-body h5 {
  font-family: var(--serif); font-weight: 800; font-size: 16px;
  line-height: 1.5; margin-bottom: 8px;
}
.if-feat-body p {
  font-size: 13px; line-height: 1.85; color: var(--ink-soft);
}
.if-feat-formula {
  display: inline-block;
  font-family: var(--mono); font-size: 11px; letter-spacing: .06em;
  background: var(--inofine-l); color: var(--inofine); padding: 4px 12px;
  border-radius: 4px; margin-bottom: 8px; font-weight: 600;
}
.if-feat-link {
  display: inline-block; margin-top: 10px;
  font-family: var(--mono); font-size: 11px; letter-spacing: .1em;
  color: var(--inofine); text-decoration: none;
  border-bottom: 1px solid var(--inofine); padding-bottom: 1px;
  transition: opacity .15s;
}
.if-feat-link:hover { opacity: 0.7; }
.if-feat-note { font-size: 11px; color: var(--ink-muted); margin-top: 4px; }
.if-plan-note {
  display: flex; align-items: flex-start; gap: 10px;
  margin: 0 32px 28px;
  padding: 14px 18px;
  background: var(--inofine-l);
  border-radius: 8px;
  font-size: 12px; line-height: 1.7; color: var(--ink-soft);
}
.if-plan-note i { color: var(--inofine); margin-top: 2px; flex-shrink: 0; }
.if-plan-notes-list {
  margin: 16px 32px 24px; padding: 16px 20px;
  background: var(--paper-deep); border-radius: 6px;
  font-size: 12px; line-height: 1.8; color: var(--ink-muted);
}
.if-plan-notes-list p { margin: 0; }
@media (max-width: 560px) {
  .if-plan-header { padding: 24px 20px 18px; }
  .if-plan-title-row { flex-direction: column; gap: 8px; }
  .if-plan-features { padding: 20px; }
  .if-plan-note { margin: 0 20px 20px; }
}
.tier {
  background: var(--surface); border: 1.5px solid var(--ink);
  padding: 28px 26px; display: flex; flex-direction: column;
  position: relative;
}
.tier.hero-tier {
  grid-column: span 3;
  background: #fff5dd;
  color: var(--ink);
  border: 1.5px solid var(--ink);
  padding: 36px 36px 32px;
  box-shadow: 10px 10px 0 var(--accent);
}
.tier.hero-tier .tagline { color: var(--ink-soft); }
.tier.hero-tier ul.perks li { border-bottom-color: rgba(42,31,23,0.18); }
.tier.hero-tier ul.perks li.inh { color: var(--ink-muted); }
.tier.hero-tier .meta { border-top-color: rgba(42,31,23,0.2); }
.tier.hero-tier .meta .m { color: var(--ink-muted); }
.tier.hero-tier .meta .m b { color: var(--ink); }
.tier .tier-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 16px; }
.tier .no { font-family: var(--mono); font-size: 10px; letter-spacing: .22em; color: var(--accent); }
.tier .price { font-family: var(--serif); font-weight: 900; font-size: 30px; }
.tier .price .unit { font-family: var(--mono); font-weight: 400; font-size: 11px; opacity: .65; margin-left: 4px; }
.tier .limit {
  position: absolute; top: 14px; right: -8px;
  background: var(--accent); color: #fff;
  font-family: var(--mono); font-size: 10px; letter-spacing: .14em;
  padding: 4px 10px; transform: rotate(2deg);
}
.tier h4 { font-family: var(--serif); font-weight: 900; font-size: 19px; line-height: 1.4; margin: 4px 0 6px; }
.tier .tagline { font-family: var(--serif); font-size: 14px; line-height: 1.75; color: var(--ink-muted); margin-bottom: 18px; min-height: 50px; }
.tier ul.perks { list-style: none; padding: 0; margin: 0 0 18px; }
.tier ul.perks li {
  padding: 8px 0; padding-left: 20px; position: relative;
  font-size: 13.5px; line-height: 1.7;
  border-bottom: 1px dashed var(--rule);
}
.tier ul.perks li::before {
  content: "+"; position: absolute; left: 0; top: 8px;
  font-family: var(--mono); color: var(--accent); font-weight: 700;
}
.tier ul.perks li.inh { color: var(--ink-muted); }
.tier ul.perks li.inh::before { content: "·"; color: var(--ink-muted); }
.tier .meta { display: flex; gap: 16px; flex-wrap: wrap; margin-top: auto; padding-top: 14px; border-top: 1px solid var(--rule); }
.tier .meta .m { font-family: var(--mono); font-size: 10px; letter-spacing: .12em; color: var(--ink-muted); }
.tier .meta .m b { color: var(--ink); font-weight: 700; }
.tier .ribbon {
  display: inline-block;
  font-family: var(--mono); font-size: 11px; letter-spacing: .22em;
  background: var(--accent); color: #fff;
  padding: 5px 12px; margin-bottom: 12px;
}

/* channel toggle */
.channel-toggle {
  margin-top: 56px; padding: 32px; border: 1.5px solid var(--ink); background: var(--paper-deep);
  box-shadow: 6px 6px 0 var(--accent-soft);
}
.channel-toggle h4 { font-family: var(--serif); font-weight: 900; font-size: 18px; margin-bottom: 8px; }
.channel-toggle p { font-size: 13.5px; color: var(--ink-soft); margin-bottom: 18px; }
.channel-table { width: 100%; border-collapse: collapse; font-size: 13.5px; background: var(--surface); table-layout: fixed; }
.channel-table col.col-label { width: 110px; }
.channel-table col.col-cf, .channel-table col.col-if { width: auto; }
.channel-table th, .channel-table td { padding: 12px 16px; border: 1px solid var(--rule); text-align: left; vertical-align: top; }
.channel-table thead th { background: var(--ink); color: var(--paper); font-family: var(--mono); letter-spacing: .14em; font-size: 11px; font-weight: 400; }
.channel-table tbody th { background: var(--paper-deep); font-family: var(--serif); font-weight: 700; width: 120px; }
.channel-table .both { background: #fef4e8; text-align: center; font-weight: 700; }

/* ------------------------------ TRUST (07) ------------------- */
.partner-bar {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border: 1px solid var(--rule); background: var(--surface);
}
.partner {
  padding: 28px; border-right: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 10px;
}
.partner:last-child { border-right: none; }
.partner .logo { height: 36px; display: flex; align-items: center; gap: 12px; }
.partner .logo img { max-height: 32px; width: auto; }
.partner .role { font-family: var(--mono); font-size: 10px; letter-spacing: .2em; color: var(--accent); }
.partner h5 { font-family: var(--serif); font-weight: 700; font-size: 16px; }
.partner p { font-size: 12.5px; line-height: 1.75; color: var(--ink-muted); }

.process-flow {
  margin-top: 48px;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px;
}
.process-step {
  background: var(--surface); border: 1px solid var(--rule);
  padding: 20px 22px; position: relative;
}
.process-step::after {
  content: "→"; position: absolute; right: -14px; top: 50%;
  transform: translateY(-50%); color: var(--accent); font-weight: 700;
  z-index: 2; background: var(--paper); padding: 0 4px;
}
.process-step:last-child::after { display: none; }
.process-step .n {
  font-family: var(--mono); font-size: 10px; letter-spacing: .2em;
  color: var(--accent); margin-bottom: 6px;
}
.process-step h5 { font-family: var(--serif); font-weight: 700; font-size: 15px; margin-bottom: 6px; }
.process-step p { font-size: 12px; line-height: 1.7; color: var(--ink-muted); }

.track-record { margin-top: 48px; }
.track-record h4 { font-family: var(--serif); font-weight: 900; font-size: 18px; margin-bottom: 16px; }
.track-list {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-top: 1.5px solid var(--ink); border-bottom: 1.5px solid var(--ink);
}
.track-item { padding: 18px 22px; border-right: 1px solid var(--rule); }
.track-item:last-child { border-right: none; }
.track-item .nm { font-family: var(--serif); font-weight: 700; font-size: 15px; margin-bottom: 4px; }
.track-item .stat { font-family: var(--mono); font-size: 11px; color: var(--ink-muted); letter-spacing: .08em; }
.track-item .stat b { color: var(--accent); font-weight: 700; font-family: var(--serif); font-size: 16px; }

/* ------------------------------ USAGE (08) ------------------ */
section.lp.usage-bg { background: #e8edf3 !important; }
.usage-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
  margin-bottom: 48px;
}
.usage-bar {
  background: var(--paper-deep); height: 56px; display: flex;
  border: 1.5px solid var(--ink);
  box-shadow: 6px 6px 0 var(--accent-soft);
}
.usage-seg {
  display: flex; align-items: center; justify-content: center;
  font-family: var(--mono); font-size: 11px; letter-spacing: .14em;
  color: var(--paper);
  border-right: 1px solid rgba(245,239,228,0.15);
}
.usage-seg:last-child { border-right: none; }
.usage-legend { display: flex; flex-direction: column; gap: 12px; }
.usage-legend .row { display: grid; grid-template-columns: 16px 1fr auto; gap: 12px; align-items: center; }
.usage-legend .swatch { width: 16px; height: 16px; }
.usage-legend .nm { font-family: var(--serif); font-weight: 700; font-size: 14px; }
.usage-legend .pct { font-family: var(--mono); font-size: 13px; color: var(--ink-muted); }

/* ------- Usage flow (08) ------------ */
.usage-flow { display: flex; flex-direction: column; gap: 0; max-width: 880px; margin: 0 auto; }
.usage-card {
  display: grid; grid-template-columns: 84px 1fr; gap: 24px; align-items: stretch;
  padding: 28px 32px; background: var(--surface); border: 1.5px solid var(--ink);
  position: relative; transition: transform .2s, box-shadow .2s;
}
.usage-card:hover { transform: translateX(4px); box-shadow: -6px 6px 0 var(--accent); }
.usage-card + .usage-card { margin-top: 28px; }
.usage-card-num {
  font-family: var(--serif); font-weight: 900; font-size: 56px;
  line-height: 1; color: var(--accent); letter-spacing: -.02em;
  border-right: 1.5px solid var(--rule); padding-right: 24px;
  display: flex; align-items: center; justify-content: center;
}
.usage-card-body h4 { font-family: var(--serif); font-weight: 900; font-size: 19px; margin-bottom: 8px; }
.usage-card-body p { font-size: 14px; line-height: 1.85; color: var(--ink-soft); }
.usage-card-arrow {
  position: absolute; bottom: -22px; left: 42px; font-size: 18px; color: var(--ink-muted); z-index: 2;
  background: var(--paper); width: 24px; height: 24px; display: flex; align-items: center; justify-content: center;
}
.usage-note {
  margin-top: 48px; display: grid; grid-template-columns: 80px 1fr; gap: 24px;
  padding: 28px 32px; background: var(--paper-deep); border-left: 4px solid var(--ink);
}
.usage-note .un-icon {
  font-family: var(--serif); font-weight: 900; font-size: 48px;
  color: var(--ink); display: flex; align-items: center; justify-content: center;
}
.usage-note h5 { font-family: var(--serif); font-weight: 800; font-size: 17px; margin-bottom: 6px; }
.usage-note p { font-size: 13.5px; line-height: 1.85; color: var(--ink-soft); }
@media (max-width: 768px) {
  .usage-card { grid-template-columns: 60px 1fr; padding: 22px; gap: 16px; }
  .usage-card-num { font-size: 40px; padding-right: 14px; }
  .usage-note { grid-template-columns: 1fr; padding: 22px; }
}

.roadmap { border-left: 2px solid var(--ink); padding-left: 0; }
.roadmap-phase { padding: 16px 0 16px 28px; position: relative; }
.roadmap-phase::before {
  content: ""; width: 12px; height: 12px; background: var(--accent);
  position: absolute; left: -7px; top: 22px; border: 2px solid var(--paper);
}
.roadmap-phase .time {
  font-family: var(--mono); font-size: 10px; letter-spacing: .18em;
  color: var(--accent); margin-bottom: 4px;
}
.roadmap-phase h5 { font-family: var(--serif); font-weight: 700; font-size: 17px; margin-bottom: 4px; }
.roadmap-phase p { font-size: 13.5px; color: var(--ink-soft); }

/* ------------------------------ FAQ (09) -------------------- */
.faq { max-width: 880px; margin: 0 auto; }
.faq-item {
  border-bottom: 1px solid var(--rule);
}
.faq-item summary {
  list-style: none; cursor: pointer;
  padding: 22px 0; display: flex; gap: 18px; align-items: baseline;
  font-family: var(--serif); font-weight: 700; font-size: 17px;
  line-height: 1.5;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::before {
  content: "Q"; flex-shrink: 0;
  font-family: var(--mono); color: var(--accent); font-size: 14px;
  letter-spacing: .1em;
}
.faq-item .a {
  padding: 0 0 22px 30px; font-size: 14px; line-height: 1.9;
  color: var(--ink-soft);
}
.faq-item[open] summary { color: var(--accent); }

/* ------------------------------ SPONSOR & GOODS (09b) -------- */
.sg-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.sg-card {
  padding: 28px 24px; border: 1.5px solid var(--rule); border-radius: 10px;
  background: #fff; display: flex; flex-direction: column; gap: 10px;
}
.sg-icon { font-size: 28px; color: var(--accent); }
.sg-card h3 { font-family: var(--serif); font-size: 17px; font-weight: 800; }
.sg-card p { font-size: 13px; color: var(--ink-soft); line-height: 1.65; flex: 1; }
.sg-btn {
  display: inline-flex; align-self: flex-start;
  font-family: var(--sans); font-size: 12px; font-weight: 700; letter-spacing: .03em;
  color: var(--ink); border: 1px solid var(--ink); padding: 10px 20px; border-radius: 4px;
  text-decoration: none; transition: background .15s, color .15s; margin-top: 4px;
}
.sg-btn:hover { background: var(--ink); color: var(--paper); }
.sg-btn-group { display: flex; flex-direction: column; gap: 8px; margin-top: 4px; }
.sg-btn-primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.sg-btn-primary:hover { background: var(--accent-deep); border-color: var(--accent-deep); color: #fff; }
.sg-grid { align-items: stretch; }
.sg-card { display: flex; flex-direction: column; }
.sg-card p { flex: 1; }
.sg-banner-link { display: block; border-radius: 8px; overflow: hidden; margin-bottom: 10px; }
.sg-banner-img { width: 100%; height: auto; display: block; transition: transform .2s; }
.sg-banner-link:hover .sg-banner-img { transform: scale(1.02); }
.sg-card-goods .sg-icon { color: var(--inofine); }
@media (max-width: 600px) { .sg-grid { grid-template-columns: 1fr; } }

/* ------------------------------ FINAL CTA (10) -------------- */
.final-cta {
  padding: 96px 0;
  background: var(--paper-deep);
  color: var(--ink);
  text-align: center;
  border-top: 1.5px solid var(--ink);
  position: relative;
}
.final-cta::before {
  content: "FINAL CALL"; position: absolute; top: 28px; left: 50%; transform: translateX(-50%);
  font-family: var(--mono); font-size: 11px; letter-spacing: .36em; color: var(--accent);
}
.final-cta h2 {
  font-family: var(--serif); font-weight: 900;
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.4; margin: 0 0 24px;
}
.final-cta h2 .accent { color: var(--accent); }
.final-cta p {
  font-size: 16px; line-height: 1.9; color: var(--ink-soft);
  margin-bottom: 40px;
}
.final-cta-appeal {
  font-size: 15px; line-height: 1.9; color: var(--ink-soft);
  margin-top: -24px; margin-bottom: 12px; opacity: .85;
}
.final-cta-highlight {
  font-family: var(--serif); font-weight: 900;
  font-size: clamp(20px, 3vw, 28px); line-height: 1.5;
  color: var(--ink); margin-bottom: 48px;
  background-image: linear-gradient(transparent 60%, var(--accent-soft) 60%);
  background-size: 100% 100%; display: inline-block;
  padding: 0 .1em;
}
.final-cta .cta-row { justify-content: center; }

/* ------------------------------ Footer ---------------------- */
/* ============ GH HEADER (あばちょ準拠・INO Fine) ============ */
.gh{position:fixed;top:0;left:0;right:0;z-index:80;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--rule)}
.gh-in{max-width:1280px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;gap:24px}
.gh-logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.gh-logo img{height:30px;width:auto;display:block}
.gh-tag{font-size:11px;color:var(--ink-muted);letter-spacing:.06em;border-left:1px solid var(--rule);padding-left:14px;line-height:1.4}
.gh-tag b{color:var(--ink);font-weight:700;display:block;font-size:11px}
.gh-vol{color:var(--ink);font-family:var(--mono);font-weight:600;font-size:12px;letter-spacing:.04em}
.gh-nav{display:flex;align-items:center;gap:20px;margin-left:auto}
.gh-nav a{font-size:13px;color:var(--ink-soft);font-weight:500;text-decoration:none;transition:color .15s}
.gh-nav a:hover{color:var(--inofine)}
.gh-burger{display:block;border:none;background:none;font-size:1.6rem;cursor:pointer;color:#000;z-index:10001}
@media(max-width:980px){.gh-nav{display:none}.gh-burger{margin-left:auto}}

/* ============ MOBILE MENU OVERLAY (あばちょLP準拠) ============ */
.mobile-menu-overlay{position:fixed;top:clamp(56px,10vw,62px);left:0;width:100%;height:calc(100vh - clamp(56px,10vw,62px));background:rgba(255,255,255,.98);z-index:10000;display:none;flex-direction:column;padding:20px;border-top:1px solid var(--rule);overflow-y:auto;backdrop-filter:blur(10px)}
.mobile-menu-overlay.open{display:flex}
.mobile-menu-overlay ul{list-style:none;margin:0;padding:0;text-align:center}
.mobile-menu-overlay li{margin:14px 0;border-bottom:1px solid #eee;padding-bottom:10px}
.mobile-menu-overlay a{font-size:1.1rem;font-weight:900;color:#000;text-decoration:none}
.mobile-menu-overlay a:hover{color:var(--inofine)}
.mobile-menu-overlay .cta-link{color:var(--inofine)}
.mobile-menu-overlay .mobile-menu-divider{margin-top:20px;border-top:2px solid #e0e0e0;padding-top:20px}

/* sub-nav (scroll appears) */
.sub-nav{position:fixed;top:62px;left:0;right:0;z-index:79;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-bottom:1px solid var(--rule);transform:translateY(-100%);transition:transform .28s cubic-bezier(.2,.7,.2,1);pointer-events:none}
.sub-nav.show{transform:translateY(0);pointer-events:auto}
.sub-nav-in{max-width:1280px;margin:0 auto;padding:10px 28px;display:flex;align-items:center;gap:22px;overflow-x:auto;scrollbar-width:none}
.sub-nav-in::-webkit-scrollbar{display:none}
.sub-nav-in a{font-size:12px;color:var(--ink-muted);font-weight:600;letter-spacing:.04em;white-space:nowrap;padding:6px 0;border-bottom:2px solid transparent;text-decoration:none;transition:color .15s,border-color .15s}
.sub-nav-in a:hover{color:var(--ink);border-bottom-color:var(--ink)}
.sub-nav-in a.sub-nav-cta{color:var(--accent);font-weight:800}
.sub-nav-in a.sub-nav-cta:hover{color:var(--accent-deep);border-bottom-color:var(--accent)}
.ph-header{height:62px}

/* ============ INO FINE FOOTER ============ */
footer.inofine{background:var(--paper-dark);color:rgba(255,255,255,.7);padding:72px 0 36px;border-top:none;font-family:var(--sans)}
footer.inofine .ftgrid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:36px;margin-bottom:48px}
footer.inofine h5{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--accent);margin-bottom:14px;font-weight:700}
footer.inofine .ft-brand{font-family:"Inter",system-ui,sans-serif;font-weight:800;font-size:20px;color:#fff;margin-bottom:12px;letter-spacing:.04em}
footer.inofine p{font-size:13px;line-height:1.85;color:rgba(255,255,255,.6);margin-bottom:18px}
footer.inofine ul{list-style:none;padding:0;margin:0}
footer.inofine li{margin-bottom:9px}
footer.inofine a{font-size:13px;color:rgba(255,255,255,.7);text-decoration:none;transition:color .15s}
footer.inofine a:hover{color:var(--accent)}
footer.inofine .ft-sns{display:flex;gap:10px;margin-top:6px}
footer.inofine .ft-sns a{display:grid;place-items:center;width:34px;height:34px;border:1px solid rgba(255,255,255,.18);border-radius:50%;color:rgba(255,255,255,.7);font-size:13px;transition:all .15s}
footer.inofine .ft-sns a:hover{background:var(--inofine);border-color:var(--inofine);color:#fff;transform:translateY(-1px)}
footer.inofine .copy{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:rgba(255,255,255,.4)}
@media(max-width:780px){footer.inofine .ftgrid{grid-template-columns:1fr 1fr;gap:28px}}
footer.legal .row { display: flex; justify-content: space-between; align-items: flex-start; gap: 40px; flex-wrap: wrap; }
footer.legal .links { display: flex; gap: 24px; flex-wrap: wrap; }
footer.legal a { color: var(--ink-soft); text-decoration: none; }
footer.legal a:hover { color: var(--accent); }
footer.legal .brand-label { color: var(--ink); }

/* ------------------------------ Responsive ------------------ */
@media (max-width: 920px) {
  .hero[data-pattern="A"] .hero-inner,
  .hero[data-pattern="B"] .hero-inner,
  .hero[data-pattern="C"] .hero-inner { grid-template-columns: 1fr; gap: 36px; }
  .pitch-grid, .char-grid, .manga-viewer, .partner-bar, .process-flow, .usage-grid, .track-list { grid-template-columns: 1fr; }
  .tier-grid { grid-template-columns: 1fr; }
  .tier.hero-tier { grid-column: span 1; }
  .compare { grid-template-columns: 1fr; }
  .creator { grid-template-columns: 1fr; }
  .creator-aside { position: static; }
  .topbar nav { display: none; }
}


/* ============================================================
   v2 ADDITIONS — 赤グラデ除去、CTA色分け、マーキー、モーダル、
   トラックレコード、SNSアイコン、scroll-reveal、魅せるアニメーション
   ============================================================ */

/* CTA 色分け —— CAMPFIRE=赤 / INO Fine=青 */
.btn-campfire, .btn-inofine {
  position: relative;
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  padding: 14px 36px 14px 18px;
  font-family: var(--serif);
  font-weight: 900;
  font-size: 16px;
  letter-spacing: .04em;
  text-decoration: none;
  border-radius: 4px;
  border: 1.5px solid transparent;
  transition: transform .18s ease, box-shadow .18s ease, background .18s;
  cursor: pointer;
  overflow: hidden;
}
.btn-campfire {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 4px 0 var(--accent-deep), 0 12px 32px rgba(200,64,31,0.28);
}
.btn-campfire:hover { transform: translateY(-2px); box-shadow: 0 6px 0 var(--accent-deep), 0 16px 40px rgba(200,64,31,0.36); }
.btn-inofine {
  background: var(--inofine);
  color: #fff;
  box-shadow: 0 4px 0 var(--inofine-d), 0 12px 32px rgba(26,68,128,0.28);
}
.btn-inofine:hover { transform: translateY(-2px); box-shadow: 0 6px 0 var(--inofine-d), 0 16px 40px rgba(26,68,128,0.36); }
.btn-campfire .btn-main, .btn-inofine .btn-main { display: block; font-size: 14px; line-height: 1.2; white-space: nowrap; }
.btn-campfire .btn-sub, .btn-inofine .btn-sub {
  display: block; font-family: var(--sans); font-weight: 500; font-size: 11px;
  letter-spacing: .08em; opacity: .85;
}
.btn-campfire .arrow, .btn-inofine .arrow {
  position: absolute; right: 22px; top: 50%; transform: translateY(-50%);
  font-family: var(--serif); font-size: 22px; font-weight: 400;
  transition: transform .18s;
}
.btn-campfire:hover .arrow, .btn-inofine:hover .arrow { transform: translate(4px, -50%); }

.cta-row { display: flex; gap: 16px; flex-wrap: nowrap; }
.cta-row .btn-campfire, .cta-row .btn-inofine { min-width: 0; }
.hero[data-pattern="B"] .btn-campfire, .hero[data-pattern="B"] .btn-inofine {
  border: 1.5px solid rgba(245,239,228,.2);
}

/* FundingStrip v3 —— カード型、グラデーションバー */
.funding-strip { display: flex; flex-direction: column; align-items: stretch; gap: 12px; width: 100%; }
.fs-cards-mode { background: #fff; border: 1.5px solid var(--rule); border-radius: 10px; padding: 18px 20px; width: 100%; }
.fs-badge-row { display: flex; align-items: center; justify-content: center; gap: 10px; margin-bottom: 4px; }
.fs-badge {
  flex-shrink: 0;
  background: var(--ink-muted); color: #fff;
  padding: 3px 10px; border-radius: 3px;
  font-family: var(--mono); font-weight: 600; font-size: 10px; letter-spacing: .1em;
}
.fs-badge-live { background: linear-gradient(90deg, #FC8A44, #FF5046); }
.fs-badge-ended { background: #6b7280; }
.fs-badge-text { font-size: 11px; color: var(--ink-muted); line-height: 1.5; }
/* info cards (before phase) */
.fs-info-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 8px; }
.fs-info-card {
  background: var(--paper-deep); border-radius: 8px; padding: 14px 16px;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  text-align: center;
}
.fs-ic-label { font-family: var(--sans); font-size: 10px; font-weight: 700; letter-spacing: .12em; color: var(--ink-muted); }
.fs-ic-value { font-family: var(--serif); font-weight: 900; font-size: 24px; line-height: 1.2; }
.fs-ic-value-sm { font-size: 16px; }
/* progress card (live / ended) */
.fs-progress-card { margin-top: 8px; }
.fs-pc-row { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 8px; }
.fs-pc-amount { font-family: var(--serif); font-weight: 900; font-size: 26px; line-height: 1.2; }
.fs-pc-small { font-family: var(--sans); font-weight: 500; font-size: 12px; color: var(--ink-muted); margin-left: 6px; }
.fs-pc-pct { font-family: var(--mono); font-weight: 700; font-size: 20px; background: linear-gradient(90deg, #FC8A44, #FF5046); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.fs-progress-bar { height: 8px; background: var(--rule); border-radius: 4px; overflow: hidden; }
.fs-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, #FC8A44, #FF5046);
  border-radius: 4px;
  transition: width 1.2s cubic-bezier(.2,.7,.2,1);
}
.fs-pc-meta { display: flex; gap: 20px; margin-top: 8px; font-size: 12px; color: var(--ink-soft); }
.fs-pc-meta b { font-weight: 700; color: var(--ink); }
/* dark hero overrides */
.hero[data-pattern="B"] .fs-cards-mode { background: rgba(30,30,30,0.7); border-color: rgba(245,239,228,0.15); color: #f5efe4; }
.hero[data-pattern="B"] .fs-badge-text { color: rgba(245,239,228,0.6); }
.hero[data-pattern="B"] .fs-info-card { background: rgba(245,239,228,0.08); }
.hero[data-pattern="B"] .fs-ic-label { color: rgba(245,239,228,0.5); }
.hero[data-pattern="B"] .fs-pc-small { color: rgba(245,239,228,0.5); }
.hero[data-pattern="B"] .fs-pc-meta { color: rgba(245,239,228,0.6); }
.hero[data-pattern="B"] .fs-pc-meta b { color: #f5efe4; }
.hero[data-pattern="B"] .fs-progress-bar { background: rgba(245,239,228,0.18); }

/* Read セクション —— 横スクロールマーキー */
.read-marquee {
  margin: 56px 0 40px;
  padding: 32px 0;
  background: var(--ink);
  overflow: hidden;
  position: relative;
  mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
}
.rm-track {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  scroll-behavior: auto;
  touch-action: pan-x;
}
.rm-track::-webkit-scrollbar { display: none; }
.rm-track.is-dragging { user-select: none; }
.rm-koma {
  flex: 0 0 auto;
  width: 280px;
  height: 380px;
  background: #f1efe8;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 12px 32px rgba(0,0,0,0.4);
  overflow: hidden;
}
.rm-koma img { width: 100%; height: 100%; object-fit: cover; object-position: center; filter: contrast(1.05); }

.read-cta-row {
  display: flex; flex-direction: column; align-items: center;
  gap: 14px;
  padding: 20px 0 0;
}
.btn-read-open {
  position: relative;
  display: inline-flex; flex-direction: column; align-items: flex-start; gap: 4px;
  padding: 22px 72px 22px 32px;
  background: var(--ink); color: #fff;
  border: none; border-radius: 4px;
  font-family: var(--serif); font-weight: 900; font-size: 19px; letter-spacing: .04em;
  cursor: pointer;
  box-shadow: 0 4px 0 #000;
  transition: transform .18s ease, box-shadow .18s ease;
}
.btn-read-open:hover { transform: translateY(-2px); box-shadow: 0 6px 0 #000; }
.btn-read-open .btn-sub { font-family: var(--sans); font-weight: 500; font-size: 11px; letter-spacing: .1em; opacity: .7; }
.btn-read-open .arrow { position: absolute; right: 24px; top: 50%; transform: translateY(-50%); font-size: 24px; }
.read-note { font-size: 11px; color: var(--ink-muted); }

/* 試し読みモーダル */
.read-modal {
  position: fixed; inset: 0;
  background: rgba(14,14,16,0.92);
  z-index: 9000;
  display: flex; flex-direction: column;
  animation: rm-fadein .25s ease;
}
@keyframes rm-fadein { from { opacity: 0; } to { opacity: 1; } }
.read-modal-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 28px;
  background: var(--ink); color: #f5efe4;
  border-bottom: 1px solid rgba(245,239,228,0.1);
  flex-shrink: 0;
}
.rmb-l { display: flex; align-items: center; gap: 14px; }
.rmb-tag { background: var(--accent); color: #fff; padding: 4px 10px; font-family: var(--mono); font-size: 10px; letter-spacing: .14em; }
.rmb-title { font-family: var(--serif); font-weight: 900; font-size: 16px; letter-spacing: .04em; }
.rmb-r { display: flex; align-items: center; gap: 18px; }
.rmb-note { font-size: 11px; color: rgba(245,239,228,0.55); }
.rmb-close {
  width: 36px; height: 36px; border-radius: 50%;
  background: transparent; border: 1px solid rgba(245,239,228,0.3); color: #f5efe4;
  font-size: 22px; line-height: 1; cursor: pointer;
  transition: background .15s;
}
.rmb-close:hover { background: rgba(245,239,228,0.1); }
.read-modal-scroll { flex: 1; overflow-y: auto; scroll-behavior: smooth; }
.read-modal-inner {
  max-width: 720px; margin: 0 auto;
  padding: 24px 16px 80px;
  display: flex; flex-direction: column; gap: 16px;
}
.read-modal-inner img {
  width: 100%; height: auto; display: block;
  background: #fff;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
.read-modal-end {
  margin-top: 32px; padding: 40px 24px;
  background: var(--paper);
  text-align: center;
}
.read-modal-end p { font-family: var(--serif); font-weight: 700; font-size: 18px; margin-bottom: 24px; }
.btn-modal-cta { display: inline-flex !important; }

/* —— モーダルバー：戻るボタン —— */
.rmb-back {
  background: transparent; color: #f5efe4;
  border: 1px solid rgba(245,239,228,0.3);
  padding: 6px 12px; border-radius: 4px;
  font-family: var(--mono); font-size: 11px; letter-spacing: .14em;
  cursor: pointer; margin-right: 4px;
  transition: background .15s, border-color .15s;
}
.rmb-back:hover { background: rgba(245,239,228,0.1); border-color: var(--accent); }

/* —— 試し読み カード選択画面 —— */
.read-cards-inner {
  max-width: 1080px; margin: 0 auto;
  padding: 48px 24px 80px;
}
.read-cards-head {
  text-align: center;
  margin-bottom: 40px;
  color: #f5efe4;
}
.read-cards-head h3 {
  font-family: var(--serif); font-weight: 900;
  font-size: 26px; letter-spacing: .02em;
  margin-bottom: 10px;
}
.read-cards-head p {
  font-size: 13px;
  color: rgba(245,239,228,0.6);
  letter-spacing: .04em;
}
.read-cards {
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 20px;
}
.read-card {
  display: flex; flex-direction: column;
  background: rgba(245,239,228,0.04);
  border: 1px solid rgba(245,239,228,0.14);
  padding: 16px;
  cursor: pointer;
  text-align: left;
  color: #f5efe4;
  font: inherit;
  transition: transform .22s ease, background .22s, border-color .22s, box-shadow .22s;
  position: relative;
}
/* 連載版/新作 タグラベル */
.rc-tag-label {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: .1em; padding: 3px 8px; border-radius: 3px;
  display: inline-block; margin-bottom: 8px; width: fit-content;
}
.rc-old .rc-tag-label { background: rgba(245,239,228,0.12); color: rgba(245,239,228,0.7); }
.rc-new .rc-tag-label { background: var(--accent); color: #fff; }
.read-card:hover {
  transform: translateY(-4px);
  background: rgba(245,239,228,0.08);
  border-color: var(--accent);
  box-shadow: 0 12px 32px rgba(0,0,0,0.4);
}
.rc-thumb {
  overflow: hidden;
  background: #fff;
  margin-bottom: 16px;
  position: relative;
}
.rc-thumb img {
  width: 100%; height: auto; display: block;
}
.rc-meta {
  display: flex; flex-direction: column; gap: 10px;
  margin-bottom: 18px;
}
.rc-no {
  font-family: var(--serif); font-weight: 900;
  font-size: 18px; letter-spacing: .02em;
  color: var(--accent);
  line-height: 1.2;
}
.rc-label {
  font-family: var(--mono); font-size: 10px; letter-spacing: .22em;
  color: rgba(245,239,228,0.55);
  text-transform: uppercase;
}
.rc-cta {
  display: block;
  font-family: var(--sans); font-size: 13px; font-weight: 700;
  letter-spacing: .08em;
  color: #fff;
  background: var(--accent);
  border: none; border-radius: 6px;
  padding: 10px 0;
  margin-top: 12px;
  text-align: center;
  transition: background 0.2s;
}
.read-card:hover .rc-cta { background: var(--accent-deep); }

/* —— 試し読み 閲覧モード —— */
.read-ep-inner {
  max-width: 720px; margin: 0 auto;
  padding: 24px 16px 60px;
  animation: ep-flash .22s ease-out;
}
@keyframes ep-flash {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.read-ep-head-mini {
  display: flex; align-items: center; gap: 14px;
  padding: 0 2px 14px;
  color: #f5efe4;
}
.read-ep-head-mini .re-no-mini {
  font-family: var(--serif); font-weight: 900;
  font-size: 28px; letter-spacing: .02em;
  color: var(--accent);
  line-height: 1;
}
.read-ep-head-mini .re-rule-mini {
  flex: 1; height: 1px;
  background: rgba(245,239,228,0.22);
}
.read-ep-art img {
  width: 100%; height: auto; display: block;
  background: #fff;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
.read-ep-aori {
  font-family: var(--serif); font-weight: 700;
  font-size: 15px; line-height: 1.7;
  color: rgba(245,239,228,0.92);
  text-align: right;
  letter-spacing: .04em;
  padding: 14px 8px 0;
  margin: 0;
}
.read-ep-nav {
  display: flex; justify-content: space-between;
  gap: 12px;
  margin-top: 48px;
}
.rep-nav-spacer { flex: 1; }
.rep-nav-btn {
  flex: 1;
  display: flex; flex-direction: column; gap: 4px;
  background: rgba(245,239,228,0.05);
  border: 1px solid rgba(245,239,228,0.18);
  color: #f5efe4;
  padding: 14px 18px;
  font: inherit;
  cursor: pointer;
  transition: background .18s, border-color .18s;
}
.rep-nav-btn:hover { background: rgba(245,239,228,0.1); border-color: var(--accent); }
.rep-nav-btn .rnb-dir {
  font-family: var(--mono); font-size: 11px; letter-spacing: .18em;
  color: rgba(245,239,228,0.65);
}
.rep-nav-btn .rnb-no {
  font-family: var(--serif); font-weight: 900;
  font-size: 18px; letter-spacing: .02em;
  color: var(--accent);
}
.rep-prev { text-align: left; }
.rep-next { text-align: right; align-items: flex-end; }
.rep-cta { flex: 1; justify-content: center; }
.read-back-row { margin-top: 28px; text-align: center; }
.read-back-btn {
  background: transparent; border: none;
  color: rgba(245,239,228,0.7);
  font-family: var(--mono); font-size: 11px; letter-spacing: .18em;
  cursor: pointer; padding: 8px 12px;
  transition: color .15s;
}
.read-back-btn:hover { color: var(--accent); }

@media (max-width: 1080px) {
  .read-cards { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .read-cards { grid-template-columns: 1fr; gap: 16px; }
  .read-cards-inner { padding: 32px 16px 60px; }
  .read-cards-head h3 { font-size: 22px; }
  .rc-thumb { margin-bottom: 12px; }
  .read-ep-nav { flex-direction: column; }
  .read-ep-head-mini .re-no-mini { font-size: 24px; }
  .read-ep-aori { font-size: 14px; }
}

/* Trust —— about-grid (INO Fine → 実業之日本社) */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; margin-top: 40px; }
.about-card {
  background: var(--surface);
  border: 1px solid var(--rule);
  padding: 36px 32px;
  position: relative;
  transition: transform .25s ease, box-shadow .25s ease;
}
.about-card:hover { transform: translate(-2px, -2px); box-shadow: 8px 8px 0 var(--accent-soft); }
.about-card .ab-logo {
  height: 56px; display: flex; align-items: center; margin-bottom: 20px;
}
.about-card .ab-logo img { max-height: 56px; width: auto; }
.about-card .role {
  display: inline-block;
  font-family: var(--mono); font-size: 10px; letter-spacing: .18em;
  color: var(--ink-muted);
  padding: 3px 8px; border: 1px solid var(--rule);
  margin-bottom: 12px;
}
.about-card h3 { font-family: var(--serif); font-weight: 900; font-size: 22px; letter-spacing: .02em; margin-bottom: 6px; }
.about-card .ab-co { font-size: 12px; color: var(--ink-muted); margin-bottom: 18px; padding-bottom: 18px; border-bottom: 1px solid var(--rule-soft); }
.about-card p { font-size: 14px; line-height: 1.9; color: var(--ink-soft); margin-bottom: 20px; }
.about-card p b { color: var(--ink); font-weight: 700; }
.about-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--sans); font-weight: 700; font-size: 13px;
  color: var(--accent); text-decoration: none;
  border-bottom: 1px solid var(--accent);
  padding-bottom: 2px;
  transition: gap .15s;
}
.about-link:hover { gap: 12px; }
.about-link .arrow { transition: transform .15s; }
.about-link:hover .arrow { transform: translateX(3px); }

/* Track Record —— あばちょLP準拠スタイル */
.tr-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.tr-card {
  text-decoration: none; color: inherit;
  background: var(--surface);
  border: 1px solid var(--rule);
  transition: transform .25s ease, box-shadow .25s ease;
  display: flex; flex-direction: column;
}
.tr-card:hover { transform: translate(-2px, -2px); box-shadow: 8px 8px 0 var(--accent-soft); }
.tr-thumb {
  aspect-ratio: 4/3;
  background: var(--paper-deep);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  border-bottom: 1px solid var(--rule);
}
.tr-thumb img { width: 100%; height: 100%; object-fit: cover; }
.tr-thumb-self {
  background: var(--ink);
  color: var(--accent);
  font-family: var(--serif); font-weight: 900;
  letter-spacing: .08em;
  background-image:
    repeating-linear-gradient(45deg, rgba(200,64,31,0.06) 0 2px, transparent 2px 12px);
}
.tr-self-cap { font-size: 22px; padding: 24px; text-align: center; line-height: 1.4; }
.tr-body { padding: 18px 18px 20px; display: flex; flex-direction: column; gap: 4px; }
.tr-vol { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; color: var(--ink-muted); }
.tr-name { font-family: var(--serif); font-weight: 900; font-size: 16px; letter-spacing: .02em; line-height: 1.4; }
.tr-author { font-size: 12px; color: var(--ink-soft); margin-bottom: 8px; }
.tr-badge {
  align-self: flex-start;
  font-family: var(--mono); font-size: 10px; letter-spacing: .12em;
  padding: 3px 8px; border-radius: 2px;
}
.tr-b-published { background: rgba(107,142,78,0.12); color: var(--leaf); border: 1px solid rgba(107,142,78,0.3); }
.tr-b-live { background: rgba(200,64,31,0.1); color: var(--accent); border: 1px solid rgba(200,64,31,0.3); }
.tr-b-soon { background: rgba(14,14,16,0.06); color: var(--ink); border: 1px solid var(--ink); font-weight: 700; }
.tr-card.tr-self { border: 1.5px solid var(--ink); position: relative; }
.tr-card.tr-self::before {
  content: "ここ";
  position: absolute; top: -10px; right: 16px;
  background: var(--ink); color: var(--accent);
  font-family: var(--serif); font-weight: 900; font-size: 11px;
  padding: 4px 10px; letter-spacing: .12em;
}
/* ----- TrackRecord Carousel ----- */
.tr-carousel {
  display: flex; gap: 16px; overflow-x: auto; scroll-behavior: smooth;
  padding: 8px calc((100% - var(--maxw)) / 2 + 28px) 16px; cursor: grab; -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.tr-carousel::-webkit-scrollbar { display: none; }
.tr-carousel.is-dragging { cursor: grabbing; scroll-behavior: auto; }
.tr-card-sm {
  flex: 0 0 180px; text-decoration: none; color: inherit;
  background: var(--surface); border: 1px solid var(--rule); border-radius: 8px;
  overflow: hidden; transition: transform .2s, box-shadow .2s;
  user-select: none;
}
.tr-card-sm:hover { transform: translateY(-2px); box-shadow: 4px 4px 0 var(--accent-soft); }
.tr-thumb-sm {
  aspect-ratio: 4/3; background: var(--paper-deep); overflow: hidden;
  border-bottom: 1px solid var(--rule);
}
.tr-thumb-sm img { width: 100%; height: 100%; object-fit: contain; pointer-events: none; }
.tr-body-sm { padding: 10px 12px 12px; display: flex; flex-direction: column; gap: 2px; }
.tr-vol-sm { font-family: var(--mono); font-size: 9px; letter-spacing: .16em; color: var(--ink-muted); }
.tr-name-sm { font-family: var(--serif); font-weight: 800; font-size: 13px; line-height: 1.35; }
.tr-author-sm { font-size: 11px; color: var(--ink-soft); margin-bottom: 4px; }
.tr-badge-sm {
  align-self: flex-start;
  font-family: var(--mono); font-size: 9px; letter-spacing: .1em;
  padding: 2px 6px; border-radius: 2px;
}
.tr-foot { margin-top: 36px; text-align: center; }
.btn-ghost {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 28px;
  background: transparent;
  border: 1px solid var(--ink);
  font-family: var(--sans); font-weight: 700; font-size: 13px;
  letter-spacing: .04em;
  color: var(--ink); text-decoration: none;
  transition: background .15s, color .15s;
}
.btn-ghost:hover { background: var(--ink); color: var(--paper); }
.btn-ghost .arrow { font-family: var(--serif); transition: transform .15s; }
.btn-ghost:hover .arrow { transform: translateX(3px); }

/* SNS アイコン —— Font Awesome ブランドカラー */
.sns-icons { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 4px; }
.sns-icons a {
  width: 40px; height: 40px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,0.85);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 16px;
  color: #fff;
  text-decoration: none;
  transition: transform .18s, box-shadow .18s;
}
.sns-icons a:hover { transform: translateY(-2px); box-shadow: 0 6px 16px rgba(0,0,0,0.3); }
.sns-tiktok-mono { background: #000 !important; }
.sns-x       { background: #000; }
.sns-line    { background: #06C755; }
.sns-discord { background: #5865F2; }
.sns-mail    { background: #c8401f; }
.sns-tiktok  { background: linear-gradient(135deg, #25F4EE 0%, #000 50%, #FE2C55 100%); }
.sns-youtube { background: #FF0000; }

/* scroll-reveal */
[data-anim] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);
  will-change: opacity, transform;
}
[data-anim].is-in { opacity: 1; transform: translateY(0); }
[data-anim="left"] { transform: translateX(-32px); }
[data-anim="left"].is-in { transform: translateX(0); }
[data-anim="right"] { transform: translateX(32px); }
[data-anim="right"].is-in { transform: translateX(0); }
[data-anim="zoom"] { transform: scale(.94); }
[data-anim="zoom"].is-in { transform: scale(1); }
[data-stagger] > [data-anim]:nth-child(1) { transition-delay: 0ms; }
[data-stagger] > [data-anim]:nth-child(2) { transition-delay: 80ms; }
[data-stagger] > [data-anim]:nth-child(3) { transition-delay: 160ms; }
[data-stagger] > [data-anim]:nth-child(4) { transition-delay: 240ms; }
[data-stagger] > [data-anim]:nth-child(5) { transition-delay: 320ms; }
[data-stagger] > [data-anim]:nth-child(6) { transition-delay: 400ms; }
@media (prefers-reduced-motion: reduce) {
  [data-anim] { opacity: 1; transform: none; transition: none; }
}

/* sec-title 補助アニメ—— 見出しの下線スイープイン */
.sec-head { position: relative; }
.sec-head .sec-title {
  background-image: linear-gradient(to right, var(--accent) 0, var(--accent) 100%);
  background-size: 0 3px;
  background-repeat: no-repeat;
  background-position: 0 100%;
  padding-bottom: 4px;
  transition: background-size 1.1s cubic-bezier(.2,.7,.2,1) .15s;
}
.sec-head[data-anim].is-in .sec-title { background-size: 64px 3px; }

/* mobile */
@media (max-width: 880px) {
  .fs-info-cards { grid-template-columns: 1fr; }
  .fs-ic-value { font-size: 20px; }
  .fs-pc-amount { font-size: 22px; }
  .cta-row { flex-direction: column; }
  .cta-row .btn-campfire, .cta-row .btn-inofine { width: 100%; min-width: 0; }
  .read-marquee { margin: 36px 0 28px; padding: 24px 0; }
  .rm-koma { width: 200px; height: 280px; }
  .about-grid { grid-template-columns: 1fr; gap: 20px; }
  .tr-grid { grid-template-columns: 1fr; }
  .sns-icons a { width: 36px; height: 36px; font-size: 14px; }
}


/* ============================================================
   v3 ADDITIONS — CFプラットフォーム（CAMPFIRE/Readyfor/Makuake/GREEN FUNDING）パターン
   sticky支援バー ・ セクションナビ ・ 活動報告 ・ リスク
   ============================================================ */

/* sticky-bar —— 画面下部に固定表示される支援バー (CAMPFIRE準拠) */
.sticky-bar {
  position: fixed; left: 0; right: 0; bottom: 0;
  z-index: 8000;
  background: #fff;
  border-top: 1px solid var(--rule);
  box-shadow: 0 -8px 32px rgba(14,14,16,0.08);
  transform: translateY(110%);
  transition: transform .35s cubic-bezier(.2,.7,.2,1);
  padding-bottom: env(safe-area-inset-bottom);
}
.sticky-bar.is-show { transform: translateY(0); }
.sb-inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 14px 28px;
  display: flex; align-items: center; gap: 24px; justify-content: space-between;
}
.sb-meta { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 6px; }
.sb-title { display: flex; align-items: center; gap: 10px; }
.sb-vol {
  font-family: var(--mono); font-size: 10px; letter-spacing: .14em;
  color: var(--accent); border: 1px solid var(--accent);
  padding: 2px 6px; border-radius: 2px;
}
.sb-name { font-family: var(--serif); font-weight: 900; font-size: 15px; letter-spacing: .02em; }
.sb-stats { display: flex; align-items: center; gap: 16px; }
.sb-stat { display: flex; align-items: baseline; gap: 6px; }
.sb-stat b { font-family: var(--serif); font-weight: 900; font-size: 22px; line-height: 1; color: var(--ink); }
.sb-stat small { font-family: var(--sans); font-weight: 600; font-size: 11px; margin-left: 2px; }
.sb-stat i { font-style: normal; font-family: var(--sans); font-weight: 700; font-size: 11px; color: var(--ink-muted); letter-spacing: .04em; }
.sb-stat-days b { color: var(--accent); }
.sb-sep { width: 1px; height: 22px; background: var(--rule); }
.sb-cta { display: flex; gap: 10px; flex-shrink: 0; }
.sb-btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 12px 20px;
  border: none; border-radius: 4px;
  font-family: var(--sans); font-weight: 700; font-size: 13px; letter-spacing: .03em;
  text-decoration: none; cursor: pointer;
  transition: transform .15s, box-shadow .15s;
  white-space: nowrap;
}
.sb-btn:hover { transform: translateY(-1px); }
.sb-btn .btn-main { font-size: 13px; }
.sb-btn-cf { background: var(--accent); color: #fff; box-shadow: 0 3px 0 var(--accent-deep); }
.sb-btn-cf:hover { box-shadow: 0 4px 0 var(--accent-deep); }
.sb-btn-if { background: var(--inofine); color: #fff; box-shadow: 0 3px 0 var(--inofine-d); }
.sb-btn-if:hover { box-shadow: 0 4px 0 var(--inofine-d); }
.sb-btn-goods { background: var(--ink); color: #fff; box-shadow: 0 3px 0 #000; }
.sb-btn-goods:hover { box-shadow: 0 4px 0 #000; }
body { padding-bottom: 0; }
.sticky-bar.is-show ~ * { /* room for sticky bar handled per-section bottom padding if needed */ }
@media (max-width: 880px) {
  .sb-inner { flex-direction: column; align-items: stretch; gap: 10px; padding: 12px 16px; }
  .sb-meta { gap: 4px; }
  .sb-stats { justify-content: space-between; gap: 8px; }
  .sb-stat b { font-size: 17px; }
  .sb-cta { width: 100%; }
  .sb-cta .sb-btn { flex: 1; padding: 10px 12px; min-width: 0; font-size: 12px; }
  .sb-cta .sb-btn .btn-main { font-size: 12px; }
  .sb-name { font-size: 13px; }
  .sb-stat i { font-size: 10px; }
}

/* sec-nav —— stickyなセクションタブ (CAMPFIRE/Readyfor準拠) */
.sec-nav {
  position: sticky; top: 0;
  z-index: 100;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--rule);
}
.sec-nav-inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 0 28px;
  display: flex; gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.sec-nav-inner::-webkit-scrollbar { display: none; }
.sn-tab {
  flex-shrink: 0;
  padding: 18px 16px 16px;
  font-family: var(--sans); font-weight: 700; font-size: 13px;
  letter-spacing: .04em;
  color: var(--ink-muted);
  text-decoration: none;
  position: relative;
  transition: color .15s;
  white-space: nowrap;
}
.sn-tab:hover { color: var(--ink); }
.sn-tab.is-active { color: var(--ink); }
.sn-tab.is-active::after {
  content: ""; position: absolute; left: 16px; right: 16px; bottom: 0;
  height: 3px; background: var(--accent);
  border-radius: 1.5px 1.5px 0 0;
}
@media (max-width: 880px) {
  .sn-tab { padding: 14px 12px 12px; font-size: 12px; }
  .sec-nav-inner { padding: 0 16px; }
}

/* Updates —— 活動報告タイムライン */
.updates-list { list-style: none; display: flex; flex-direction: column; gap: 0; max-width: 760px; margin: 0 auto; padding: 0; }
.upd {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 32px;
  padding: 28px 0;
  border-bottom: 1px solid var(--rule);
  position: relative;
}
.upd:first-child { padding-top: 0; }
.upd-date {
  display: flex; flex-direction: column; gap: 8px;
  align-items: flex-start;
}
.upd-date time {
  font-family: var(--mono); font-weight: 600; font-size: 13px;
  letter-spacing: .04em; color: var(--ink);
}
.upd-tag {
  font-family: var(--sans); font-weight: 700; font-size: 10px;
  letter-spacing: .12em;
  padding: 3px 8px;
  background: var(--accent-soft); color: var(--accent-deep);
  border-radius: 2px;
}
.upd-body h4 { font-family: var(--serif); font-weight: 900; font-size: 18px; letter-spacing: .02em; margin-bottom: 8px; }
.upd-body p { font-size: 14px; line-height: 1.9; color: var(--ink-soft); }
@media (max-width: 720px) {
  .upd { grid-template-columns: 1fr; gap: 10px; padding: 20px 0; }
  .upd-date { flex-direction: row; align-items: center; }
}

/* Risk —— リスクとチャレンジ */
.risk-list { list-style: none; display: flex; flex-direction: column; gap: 16px; max-width: 860px; margin: 0 auto; padding: 0; }
.risk-item {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 20px;
  padding: 24px 28px;
  background: var(--surface);
  border: 1px solid var(--rule);
  border-left: 3px solid var(--accent);
}
.risk-no {
  font-family: var(--serif); font-weight: 900; font-size: 28px;
  color: var(--accent); line-height: 1;
}
.risk-body h4 { font-family: var(--serif); font-weight: 900; font-size: 16px; letter-spacing: .02em; margin-bottom: 8px; }
.risk-body p { font-size: 13px; line-height: 1.9; color: var(--ink-soft); }
@media (max-width: 720px) {
  .risk-item { grid-template-columns: 1fr; gap: 8px; padding: 18px 20px; }
}

/* GhHeader スティッキー調整——sec-navと重ならないよう上位に */
.gh-header { z-index: 150; }

/* Hero pattern C —— キャッチ全幅 + 下部2カラム */
.hero[data-pattern="C"] { background: var(--paper); }

/* ① キャッチコピー — 全幅中央揃え1行 */
.hero-catch-line {
  text-align: center;
  font-family: var(--serif);
  font-weight: 900;
  font-size: clamp(24px, 3.2vw, 42px);
  line-height: 1.3;
  letter-spacing: .02em;
  color: var(--ink);
  margin: 0 0 32px;
  padding: 0 0 28px;
  border-bottom: 1px solid var(--rule);
}
.hero-catch-line .sp-only { display: none; }
.hero-catch-line .underline {
  border-bottom: none;
  background-image: linear-gradient(transparent 60%, var(--accent-soft) 60%);
  padding: 0 .15em;
  font-size: 1.5em;
  font-weight: 900;
  letter-spacing: .06em;
  display: inline-block;
  margin-top: 6px;
}
@keyframes honni-in {
  0% { opacity: 0; clip-path: inset(0 100% 0 0); }
  100% { opacity: 1; clip-path: inset(0 0 0 0); }
}
@media (max-width: 880px) {
  .hero-catch-line .underline {
    font-size: 2.25em;
    color: var(--ink);
    animation: honni-in 1s cubic-bezier(.25,.1,.25,1) .4s both;
  }
}

/* ② hero-body — PC2カラム / mobile1カラム */
.hero-body {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  align-items: start;
}

@media (min-width: 881px) {
  .hero[data-pattern="C"] .hero-inner {
    padding: 24px 0 56px;
  }
  .hero-body {
    grid-template-columns: 1.3fr .8fr;
    gap: 40px;
  }
  /* 右ギャラリー — hero-panel風デザイン */
  .hero[data-pattern="C"] .hero-slider {
    aspect-ratio: 3/4; max-height: 480px;
    border-radius: 0;
    background: #f2e8d0;
    border: 2px solid var(--ink);
    box-shadow: 10px 10px 0 var(--accent-soft), 10px 10px 0 1.5px var(--accent);
  }
  .hero[data-pattern="C"] .hero-slide img { object-fit: contain; }
  .hero[data-pattern="C"] .hero-thumb { width: 56px; height: 56px; }
  .hero[data-pattern="C"] .hero-thumbs { gap: 4px; padding: 28px 0 0; }
}
.hero-gallery-col { display: contents; }
@media (max-width: 880px) { .hero-gallery-col { display: block; } }
.hero[data-pattern="C"] .hero-title-msg {
  display: flex; flex-direction: column; justify-content: center;
  padding: 0;
}
/* FundingStrip + CTA 縦積み（進捗カード下にCTA横並び） */
.hero-funding-col {
  display: flex; flex-direction: column; gap: 14px;
}
.hero-funding-col .cta-row {
  flex-direction: row; gap: 10px;
}
/* 支援総額ラベル */
.fs-pc-label {
  font-family: var(--mono); font-size: 10px; letter-spacing: .2em;
  color: var(--ink-muted); margin-bottom: 4px;
}
/* 準備中テキスト */
.fs-pc-preparing {
  font-family: var(--sans); font-weight: 500; font-size: 14px;
  color: var(--ink-muted); letter-spacing: .04em;
}
/* underline highlight — .hero-catch-line版は上部で定義済み、旧.hero-title版は互換用 */
.hero[data-pattern="C"] .hero-title .underline {
  border-bottom: none;
  background-image: linear-gradient(transparent 68%, var(--accent-soft) 68%);
  padding: 0 .1em;
}
.hero[data-pattern="C"] .copy-author {
  font-family: var(--serif); font-weight: 500;
  font-size: 17px; line-height: 1.9; color: var(--ink-soft);
  margin-bottom: 10px;
  padding-left: 14px; border-left: 2px solid var(--rule);
}
.hero[data-pattern="C"] .copy-meta {
  font-family: var(--mono); font-size: 11px; letter-spacing: .18em;
  color: var(--ink-muted); margin-top: 8px;
}

/* CF風 リターンカード —— サイドバー補足　バッジ/残り枚数を誤解なく */
.tier .limit {
  font-family: var(--sans); font-weight: 700; font-size: 11px;
  letter-spacing: .04em;
  background: var(--accent); color: #fff;
  padding: 4px 10px;
  border-radius: 2px;
  margin-bottom: 10px;
  display: inline-flex; align-items: center; gap: 6px;
}
.tier .limit::before { content: "●"; font-size: 8px; }

/* page bottom 余白——sticky barとコンテンツ重なり防止 */
body { padding-bottom: 100px; }
@media (max-width: 880px) {
  body { padding-bottom: 200px; }
}

/* GhHeaderとsec-navの重なり調整——GhHeaderが表示されたらsec-navをその下に */
.gh-header.is-show ~ .sec-nav { top: 56px; }

/* ============================================================
   v4 BRUSHUP — モダンCF映えデザイン / セクション切替演出 /
   プラットフォーム区分 / Usage v2 / Footer(Goods Store準拠)
   ============================================================ */

/* ---------- セクション背景バリエーション（喫茶店 暖色統一） ---------- */
#pitch { background: var(--surface); }
#read { background: var(--paper-deep); }
#creator { background: var(--surface); }
#chars { background: var(--paper-deep); }
.offer-campfire { background: var(--surface); }
.offer-campfire::before { background: none; }
.offer-inofine { background: var(--inofine-l); }
.offer-inofine::before { background: none; }
.offer-compare { background: var(--paper-deep); }
.offer-compare::before { background: none; }
#trust { background: var(--paper-deep); }
#track { background: var(--surface); }
#usage { background: var(--grad-warm); }
#usage::before { background: none; }
#schedule { background: var(--paper-deep); }
#faq { background: var(--surface); }

/* ---------- セクション区切りデコレーション ---------- */
section.lp + section.lp { margin-top: 0; }

/* ---------- Hero — 暖色クラフト基調 ---------- */
.hero {
  background: var(--paper);
  padding: 64px 0 80px;
  position: relative;
  overflow: hidden;
}
/* Pattern B のみダーク（base CSSの指定を活かす） */
.hero[data-pattern="B"] .hero-panel {
  border-color: rgba(245,239,228,0.2);
  box-shadow: 10px 10px 0 rgba(230,59,26,0.25);
}

/* ---------- Visual Banner (作品イメージ) ---------- */
.visual-banner {
  padding: 0;
  background: var(--ink);
  overflow: hidden;
}
.vb-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  max-width: 100%;
}
.vb-item {
  aspect-ratio: 4/3;
  overflow: hidden;
  position: relative;
}
.vb-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .6s ease;
}
.vb-item:hover img { transform: scale(1.05); }
@media (max-width: 560px) {
  .vb-grid { grid-template-columns: 1fr; }
  .vb-item { aspect-ratio: 16/9; }
}

/* ---------- Pitch Visual Gallery ---------- */
.pitch-visual-gallery {
  display: flex; gap: 12px;
  overflow-x: auto; scroll-behavior: smooth;
  padding-bottom: 8px; margin-bottom: 48px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin; scrollbar-color: var(--rule) transparent;
}
.pitch-visual-gallery::-webkit-scrollbar { height: 6px; }
.pitch-visual-gallery::-webkit-scrollbar-thumb { background: var(--rule); border-radius: 3px; }
.pvg-item {
  flex: 0 0 auto; width: 240px;
  border: 1.5px solid var(--rule);
  border-radius: 6px;
  overflow: hidden;
  background: var(--paper-deep);
}
.pvg-item img {
  width: 100%; height: auto;
  display: block;
  transition: transform .6s ease;
}
.pvg-item:hover img { transform: scale(1.04); }

/* ---------- Work Split — 画像＋テキスト横並び ---------- */
.work-split {
  display: grid;
  grid-template-columns: .35fr .65fr;
  gap: 48px;
  align-items: start;
  margin-bottom: 48px;
}
.work-split-img {
  position: relative;
  border-radius: 0;
  overflow: visible;
  background: #f2e8d0;
  border: 2px solid var(--ink);
  box-shadow: 8px 8px 0 var(--accent-soft), 8px 8px 0 1.5px var(--accent);
  align-self: center;
}
.work-split-img img { width: 100%; height: auto; display: block; }
.work-split-text {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 15px;
  line-height: 2;
  color: var(--ink-soft);
}
.work-split-text p + p { margin-top: 14px; }
@media (max-width: 880px) {
  .work-split { grid-template-columns: 1fr; gap: 24px; }
  .work-split-img { max-width: 280px; margin: 0 auto; box-shadow: 6px 6px 0 var(--accent-soft), 6px 6px 0 1.5px var(--accent); }
  .work-split-text { font-size: 14.5px; line-height: 1.9; }
}

/* pitch narrative */
.pitch-narrative {
  margin-bottom: 48px;
  font-family: var(--serif);
  font-size: 16px; line-height: 2.0;
  color: var(--ink-soft);
  max-width: 780px;
}
.pitch-narrative p + p { margin-top: 16px; }

/* project banner */
.project-banner { margin-bottom: 40px; max-width: 960px; margin-left: auto; margin-right: auto; border-radius: 8px; overflow: hidden; transition: box-shadow .2s; }
.project-banner:hover { box-shadow: 0 4px 20px rgba(0,0,0,.12); }
.project-banner a { display: block; position: relative; }
.project-banner a::after { content: "NFT漫画プロジェクト 詳細はこちら →"; position: absolute; bottom: 0; left: 0; right: 0; padding: 10px 16px; background: linear-gradient(transparent, rgba(0,0,0,.65)); color: #fff; font-family: var(--sans); font-size: 12px; font-weight: 600; letter-spacing: .06em; text-align: right; }
.project-banner img { width: 100%; height: auto; display: block; }

/* pitch highlights */
.pitch-highlights {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 48px;
}
.ph-card {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: 8px;
  padding: 28px 24px;
}
.ph-card-num {
  font-family: var(--mono);
  font-size: 10px; letter-spacing: .2em;
  color: var(--accent);
  margin-bottom: 12px;
}
.ph-card h4 {
  font-family: var(--serif);
  font-weight: 700;
  font-size: 17px;
  line-height: 1.5;
  margin-bottom: 10px;
}
.ph-card p {
  font-size: 13px;
  line-height: 1.85;
  color: var(--ink-soft);
}
@media (max-width: 720px) {
  .pitch-highlights { grid-template-columns: 1fr; }
}

/* ---------- プラットフォーム区分セクション ---------- */
.platform-section { margin-bottom: 0; }
.ps-header {
  display: flex; align-items: center; gap: 20px;
  padding: 24px 32px;
  color: #fff;
  margin-bottom: 32px;
}
.ps-header.campfire-bg {
  background: var(--surface);
  border: 1.5px solid var(--accent);
  color: var(--ink);
}
.ps-header.campfire-bg .ps-icon {
  background: var(--accent-soft);
  color: var(--accent);
}
.ps-header.inofine-bg {
  background: var(--surface);
  border: 1.5px solid var(--inofine);
  color: var(--ink);
}
.ps-header.inofine-bg .ps-icon {
  background: var(--inofine-l);
  color: var(--inofine);
}
.ps-icon {
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  font-size: 20px;
  flex-shrink: 0;
  overflow: hidden;
}
.ps-icon img {
  width: 100%; height: 100%; object-fit: contain;
}
.ps-text { flex: 1; min-width: 0; }
.ps-header h3 {
  font-family: var(--serif); font-weight: 900; font-size: 22px;
  letter-spacing: .04em; margin: 0;
}
.ps-header p {
  font-size: 13px; color: var(--ink-muted); margin: 4px 0 0; line-height: 1.6;
}
.ps-btn {
  flex-shrink: 0;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 24px;
  font-family: var(--serif); font-weight: 700; font-size: 14px;
  letter-spacing: .04em;
  text-decoration: none;
  border: 1.5px solid var(--ink);
  color: var(--ink);
  background: transparent;
  transition: background .15s, color .15s;
  white-space: nowrap;
}
.ps-btn:hover { background: var(--ink); color: var(--paper); }
.ps-btn-cf { border-color: var(--accent); color: var(--accent); }
.ps-btn-cf:hover { background: var(--accent); color: #fff; }
.ps-btn-if { border-color: var(--inofine); color: var(--inofine); }
.ps-btn-if:hover { background: var(--inofine); color: #fff; }
@media (max-width: 560px) {
  .ps-header { flex-direction: column; text-align: center; gap: 12px; padding: 20px; }
  .ps-btn { width: 100%; justify-content: center; }
}

/* ---------- Usage v2 グリッドレイアウト ---------- */
.usage-grid-v2 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 1000px;
  margin: 0 auto;
}
.usage-card-v2 {
  background: var(--surface);
  border: 1.5px solid var(--ink);
  padding: 28px 24px;
  position: relative;
  box-shadow: 6px 6px 0 var(--accent-soft);
  transition: transform .2s ease, box-shadow .2s ease;
}
.usage-card-v2:hover {
  transform: translate(-2px, -2px);
  box-shadow: 8px 8px 0 var(--accent-soft);
}
.usage-card-v2-num {
  font-family: var(--serif); font-weight: 900; font-size: 36px;
  color: var(--inofine); opacity: .18;
  position: absolute; top: 12px; right: 16px;
  line-height: 1;
}
.usage-card-v2 h4 {
  font-family: var(--serif); font-weight: 900; font-size: 17px;
  margin-bottom: 10px; line-height: 1.4;
}
.usage-card-v2 p {
  font-size: 13px; line-height: 1.8; color: var(--ink-soft);
}
@media (max-width: 880px) {
  .usage-grid-v2 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .usage-grid-v2 { grid-template-columns: 1fr; }
}

/* ---------- Final CTA — 暖色基調 ---------- */
.final-cta {
  background: var(--paper-deep) !important;
  color: var(--ink);
  border-top: 1.5px solid var(--rule);
  position: relative;
  overflow: hidden;
}
.final-cta::before {
  content: "FINAL CALL"; position: absolute; top: 32px; left: 50%; transform: translateX(-50%);
  font-family: var(--mono); font-size: 12px; letter-spacing: .4em; color: var(--accent);
}
.final-cta h2 { color: var(--ink); }
.final-cta h2 .accent { color: var(--accent); }
.final-cta p { color: var(--ink-soft); }

/* ---------- Footer — INO Fine Goods Store 準拠 ---------- */
.ftr-gs {
  background: var(--grad-dark);
  color: rgba(255,255,255,.7);
  padding: 0;
  margin-top: 0;
}
.ftr-gs-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 72px 32px 32px;
}
.ftr-gs-top {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 48px;
}
.ftr-gs-brand { display: flex; flex-direction: column; gap: 14px; }
.ftr-gs-logo { display: block; }
.ftr-gs-logo img {
  display: block;
  width: auto;
  height: auto;
  max-width: 220px;
  max-height: 56px;
}
.ftr-gs-tagline {
  font-size: 13px;
  line-height: 1.7;
  color: rgba(255,255,255,.55);
  margin: 0;
}
.ftr-gs-sns {
  display: flex; gap: 10px; margin-top: 6px;
}
.ftr-gs-sns a {
  width: 40px; height: 40px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 16px;
  color: #fff;
  text-decoration: none;
  box-shadow: 0 4px 10px rgba(0,0,0,.25);
  transition: transform .18s, box-shadow .18s;
}
.ftr-gs-sns a:hover { transform: translateY(-2px) scale(1.05); box-shadow: 0 8px 20px rgba(0,0,0,.35); }
.ftr-gs-sns .sns-x       { background: #000; border: 1.5px solid rgba(255,255,255,.35); }
.ftr-gs-sns .sns-line    { background: #06c755; }
.ftr-gs-sns .sns-discord { background: #5865F2; }
.ftr-gs-sns .sns-mail    { background: var(--magenta); }
.ftr-gs-sns .sns-tiktok  { background: #000; border: 1.5px solid rgba(255,255,255,.35); }
.ftr-gs-sns .sns-youtube { background: #FF0000; }

.ftr-gs-col h5 {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--magenta);
  margin-bottom: 14px;
  font-weight: 700;
}
.ftr-gs-col ul { list-style: none; padding: 0; margin: 0; }
.ftr-gs-col li { margin-bottom: 10px; }
.ftr-gs-col a {
  font-size: 13px;
  color: rgba(255,255,255,.7);
  text-decoration: none;
  transition: color .15s;
}
.ftr-gs-col a:hover { color: var(--magenta); }

.ftr-gs-bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: 24px;
  padding-bottom: 48px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .16em;
  color: rgba(255,255,255,.35);
}

@media (max-width: 768px) {
  .ftr-gs-top { grid-template-columns: 1fr 1fr; gap: 28px; }
  .ftr-gs-brand { grid-column: 1 / -1; }
}
@media (max-width: 480px) {
  .ftr-gs-top { grid-template-columns: 1fr; }
}

/* ---------- 高度なスクロールアニメーション ---------- */
[data-anim="up"] {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1);
}
[data-anim="up"].is-in { opacity: 1; transform: translateY(0); }

[data-anim="scale"] {
  opacity: 0;
  transform: scale(.9);
  transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);
}
[data-anim="scale"].is-in { opacity: 1; transform: scale(1); }

/* stagger遅延を増やして波のような効果 */
[data-stagger] > [data-anim]:nth-child(1) { transition-delay: 0ms; }
[data-stagger] > [data-anim]:nth-child(2) { transition-delay: 100ms; }
[data-stagger] > [data-anim]:nth-child(3) { transition-delay: 200ms; }
[data-stagger] > [data-anim]:nth-child(4) { transition-delay: 300ms; }
[data-stagger] > [data-anim]:nth-child(5) { transition-delay: 400ms; }
[data-stagger] > [data-anim]:nth-child(6) { transition-delay: 500ms; }
[data-stagger] > [data-anim]:nth-child(7) { transition-delay: 600ms; }

/* sec-head — 見出し下線をより目立たせる */
.sec-head .sec-title {
  background-size: 0 4px;
}
.sec-head[data-anim].is-in .sec-title { background-size: 80px 4px; }

/* セクション見出しにグラデーションアクセント */
.sec-head .sec-num::after {
  content: "";
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--accent) 0%, transparent 100%);
  max-width: 120px;
}

/* ---------- Hero panel — フロートなし、静的表示 ---------- */

/* ---------- CTA ボタン — 光沢なし、シンプルホバー ---------- */

/* ---------- tier card ホバー ---------- */
.tier-grid-v2 .tier {
  transition: transform .2s ease, box-shadow .2s ease;
}
.tier-grid-v2 .tier:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--accent-soft);
}

/* ---------- about-card — フラットシャドウ統一 ---------- */
.about-card {
  border: 1.5px solid var(--ink);
  background: var(--surface);
  box-shadow: 6px 6px 0 var(--accent-soft);
}

/* ---------- roadmap phase ドット ---------- */
.roadmap-phase::before {
  background: var(--accent);
  border-radius: 50%;
}

/* ---------- FAQ アコーディオン hover ---------- */
.faq-item summary:hover { color: var(--accent); }
.faq-item {
  transition: background .15s;
}
.faq-item:hover { background: rgba(230,59,26,0.02); }

/* ---------- mobile CTA column on small screens ---------- */
@media (max-width: 560px) {
  .cta-row { flex-direction: column; }
  .cta-row .btn-campfire, .cta-row .btn-inofine { width: 100%; }
  .platform-label { flex-direction: column; text-align: center; gap: 12px; }
}

/* ---------- inofine-tier 区分 ---------- */
.inofine-tier {
  border-color: var(--inofine);
  background: var(--inofine-l);
}

/* ---------- track record カード hover ---------- */
.tr-card {
  overflow: hidden;
}

/* ---------- channel-toggle ---------- */
.channel-toggle {
  border-color: var(--ink);
}

/* ---------- Creator — 制作風景写真 + アコーディオン ---------- */
.creator-workspace {
  margin: 28px 0;
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.creator-workspace-3 { grid-template-columns: 1fr 1fr 1fr; }
@media (max-width: 880px) {
  .creator-workspace-3 {
    display: flex !important; overflow-x: auto; scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch; scrollbar-width: none;
    gap: 10px; grid-template-columns: none;
    mask-image: linear-gradient(to right, #000 0%, #000 80%, transparent 100%);
    -webkit-mask-image: linear-gradient(to right, #000 0%, #000 80%, transparent 100%);
  }
  .creator-workspace-3::-webkit-scrollbar { display: none; }
  .creator-workspace-3 figure {
    flex: 0 0 80%; scroll-snap-align: center;
  }
}
.creator-workspace figure {
  margin: 0; border: 1.5px solid var(--ink);
  box-shadow: 4px 4px 0 var(--accent-soft);
  overflow: hidden;
}
.creator-workspace img {
  width: 100%; height: auto; display: block;
}

/* 外観イラスト */
.work-atmosphere {
  margin-top: 48px;
  text-align: center;
}
.work-atmosphere img {
  max-width: 420px; width: 100%; height: auto; display: inline-block;
  border: 1.5px solid var(--rule); border-radius: 6px;
}
.work-atmosphere-cap {
  margin-top: 10px;
  font-family: var(--mono); font-size: 11px; letter-spacing: .1em;
  color: var(--ink-muted);
}
.workspace-cap {
  padding: 10px 16px;
  background: var(--paper-deep);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .1em;
  color: var(--ink-muted);
  border-top: 1px solid var(--rule);
}
.creator-expand {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 18px 22px;
  background: transparent;
  border: 1.5px solid var(--ink);
  font-family: var(--serif);
  font-weight: 700;
  font-size: 15px;
  color: var(--ink);
  cursor: pointer;
  transition: background .15s, color .15s;
  box-shadow: 4px 4px 0 var(--accent-soft);
}
.creator-expand:hover {
  background: var(--ink);
  color: var(--paper);
}
.creator-expand .arrow {
  font-family: var(--mono);
  font-size: 16px;
  transition: transform .2s;
}
.creator-expand:hover .arrow {
  transform: translateY(3px);
}
.creator-more {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .5s ease;
}
.creator-more > div { overflow: hidden; }
.creator-more.open {
  grid-template-rows: 1fr;
}

/* ---------- NFT カードプレビュー（コンパクト） ---------- */
.nft-card-preview {
  margin: 12px 0;
}
.nft-frame-sm {
  width: 140px; height: 196px;
  border: 2px dashed var(--inofine);
  background: rgba(67,97,238,0.04);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 4px;
}
.nft-frame-label {
  font-family: var(--serif); font-weight: 700; font-size: 12px;
  color: var(--inofine);
}
.nft-frame-sub {
  font-family: var(--mono); font-size: 10px; letter-spacing: .1em;
  color: var(--ink-muted);
}

/* ---------- Pitch 説明テキスト ---------- */
.pitch-desc {
  font-size: 13px; line-height: 1.85;
  color: var(--ink-soft);
  margin-top: 8px;
}
.pitch-cell-img {
  margin-top: 12px; border-radius: 6px; overflow: hidden;
  border: 1px solid var(--rule);
}
.pitch-cell-img img { width: 100%; height: auto; display: block; }

/* pitch-purpose — 上段フル幅（左テキスト＋右画像） */
.pitch-purpose {
  display: flex; align-items: center; gap: 32px;
  padding: 28px 32px;
  border: 1px solid var(--rule); border-radius: 3px;
  background: var(--surface);
  box-shadow: 6px 6px 0 var(--accent-soft);
  margin-bottom: 20px;
}
.pp-text { flex: 1; }
.pp-text .k { font-family: var(--mono); font-size: 10px; letter-spacing: .24em; color: var(--accent); margin-bottom: 10px; }
.pp-text .v { font-family: var(--serif); font-weight: 700; font-size: 20px; line-height: 1.5; color: var(--ink); }
.pp-img { width: 280px; flex-shrink: 0; border-radius: 6px; overflow: hidden; border: 1px solid var(--rule); }
.pp-img img { width: 100%; height: auto; display: block; }
.pitch-grid-3 { grid-template-columns: repeat(3, 1fr); }
.pitch-grid-3 .pitch-cell { border-bottom: none; }
.pitch-grid-3 .pitch-cell:last-child { border-right: none; }
@media (max-width: 720px) {
  .pitch-purpose { flex-direction: column; gap: 20px; }
  .pp-img { width: 100%; }
  .pitch-grid-3 { grid-template-columns: 1fr; }
  .pitch-grid-3 .pitch-cell { border-right: none; border-bottom: 1px solid var(--rule); }
  .pitch-grid-3 .pitch-cell:last-child { border-bottom: none; }
}

/* ---------- tier-grid-v2 レスポンシブ補助 ---------- */
@media (max-width: 960px) {
  .tier-grid-v2 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .tier-grid-v2 { grid-template-columns: 1fr; }
  .tier-grid-v2 .tier.hero-tier { grid-column: 1; }
  .platform-label { margin-bottom: 20px; }
}

/* ===== FundingStrip 中央寄せ（最終上書き） ===== */
.fs-badge-row { justify-content: center !important; }
.fs-info-card { align-items: center !important; text-align: center !important; }

/* ============================================================
   ▼▼▼ RESPONSIVE LAYER v2 (5/14) — モバイル再構築 ▼▼▼
   方針:
     - ブレイクポイント3段に統一: 880 / 640 / 400
     - 既存後発desktop指定の優先順位を「!important」で上書き
     - 余計な3D影・rotate・分厚いborderはmobileで除去
     - section.lp の縦余白を100→48pxまで段階的に圧縮
     - 文字スケールを「読みやすい」値で再定義
   ============================================================ */

/* ---------------------------------------------------------------
   880px 以下 — タブレット縦・スマホ横全般
   --------------------------------------------------------------- */
@media (max-width: 880px) {
  /* グローバル */
  .wrap { padding: 0 18px; }
  section.lp { padding: 64px 0; }
  .sec-head { margin-bottom: 32px; max-width: 100%; }
  .sec-head .sec-title { padding-bottom: 4px; }
  .sec-num { font-size: 11px; letter-spacing: .22em; margin-bottom: 12px; }
  .sec-num::before { width: 28px; height: 2px; }

  /* ヘッダー */
  /* gh-burger: 常時表示（あばちょLP準拠） */
  .gh-in { padding: 12px 18px; }
  .gh-logo img { height: 22px; }
  .ph-header { height: 56px; }
  .sub-nav { top: 56px; }
  .sub-nav-in { padding: 8px 18px; gap: 18px; mask-image: linear-gradient(90deg, #000 0, #000 90%, transparent 100%); -webkit-mask-image: linear-gradient(90deg, #000 0, #000 90%, transparent 100%); }
  .sub-nav-in a { font-size: 12px; }

  /* ====================================================
     ★ HERO — 全パターン1カラム強制（v3後発ルールを打消）
     ==================================================== */
  .hero { padding: 110px 0 56px !important; overflow: visible; }
  .hero[data-pattern="A"] .hero-inner,
  .hero[data-pattern="B"] .hero-inner,
  .hero[data-pattern="C"] .hero-inner {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
    padding: 0 !important;
    min-height: 0 !important;
  }
  .hero-inner { display: flex !important; flex-direction: column !important; }
  /* ヒーローパネル(漫画コマ)はテキスト下に配置 */
  .hero-panel { order: 2; aspect-ratio: 3/4 !important; transform: none !important; box-shadow: 6px 6px 0 var(--accent-soft), 6px 6px 0 1.5px var(--accent) !important; max-width: 100%; }
  /* pattern B/C: 画像/ギャラリーをテキスト下に配置 */
  .hero[data-pattern="B"] .hero-inner > div:not(.hero-title-mega) { order: 2; }
  .hero[data-pattern="C"] .hero-gallery { order: 2; }
  /* hero-body — mobile 1カラム、要素をフラット化して順序制御 */
  .hero-body { display: flex !important; flex-direction: column !important; gap: 20px !important; padding: 0 16px !important; }
  .hero-body .hero-gallery-col { order: 1; margin: 0 -16px; /* ギャラリーだけ全幅 */ }
  .hero-body .hero-title-msg {
    order: 2; display: flex !important; flex-direction: column !important; gap: 16px;
    align-items: stretch; text-align: center;
  }
  .hero-body .hero-title-msg .hero-work-name { order: 1; width: 100%; }
  .hero-body .hero-title-msg .hero-creator { order: 2; }
  .hero-body .hero-title-msg .copy-sub { order: 3; text-align: left; }
  .hero-body .hero-title-msg .hero-funding-col { order: 4; width: 100%; }
  .hero-catch-line .sp-only { display: block; }
  .hero-catch-line {
    font-size: clamp(18px, 5vw, 28px) !important; margin-bottom: 20px !important;
    text-align: center !important; display: block !important;
    color: var(--ink) !important; width: 100%;
  }
  /* hero-gallery — PC用非表示 / Mobile用表示 */
  .hero-gallery-pc { display: none !important; }
  .hero-gallery-mobile { display: block !important; }
  .hero-panel .stamp { font-size: 9px; padding: 3px 8px; top: 10px; left: 10px; letter-spacing: .18em; }
  .hero-side, .hero-title-mega, .hero-title-msg { order: 1; padding: 0 !important; }
  /* 作品名「THE 喫茶店」ボックス */
  .hero-work-name { padding: 16px 22px 18px; box-shadow: inset 0 0 0 3px #1a1410, inset 0 0 0 4.5px #5c4a38; }
  .hero-work-name::before, .hero-work-name::after { width: 48px; }
  .hwn-the { font-size: 26px; }
  .hwn-title { font-size: clamp(38px, 9vw, 48px); letter-spacing: .04em; }
  /* パターンC タイトル */
  .hero[data-pattern="C"] .hero-title { font-size: clamp(28px, 7vw, 42px) !important; line-height: 1.3 !important; margin-bottom: 20px !important; }
  .hero[data-pattern="C"] .hero-title br:not(:last-of-type) { display: none; }
  /* パターンC スライダー — モバイルではhero-panel風エフェクト解除 */
  .hero[data-pattern="C"] .hero-slider { border-radius: 6px; background: var(--ink); border: none; box-shadow: none; transform: none; }
  /* 作者名 */
  .hero-creator { margin-top: 16px; font-size: 18px; gap: 10px; }
  .hero-creator .hc-label { font-size: 9.5px; padding: 3px 7px; }
  .meta-eyebrow { font-size: 10px; letter-spacing: .18em; margin-bottom: 14px; }
  /* コピー本文 */
  .copy-author { font-size: 16px; line-height: 1.6; margin-top: 14px; }
  .copy-sub { font-size: 13px; line-height: 1.85; margin-top: 12px; }
  .copy-sub br, .copy-author br { display: none; } /* 強制改行を解除 */

  /* CTA & FundingStrip */
  /* mobileでもボタンは横並び・矢印省略でコンパクトに（Hero / Final CTA 共通） */
  .cta-row,
  .final-cta .cta-row { flex-direction: row !important; gap: 8px; flex-wrap: nowrap; }
  .cta-row .btn-campfire, .cta-row .btn-inofine,
  .final-cta .cta-row .btn-campfire, .final-cta .cta-row .btn-inofine {
    flex: 1 1 0 !important; width: auto !important; min-width: 0 !important;
    padding: 12px 10px !important; font-size: 13px !important;
    justify-content: center; text-align: center;
  }
  .btn-campfire .btn-main, .btn-inofine .btn-main { font-size: 12.5px !important; }
  .cta-row .btn-campfire .arrow, .cta-row .btn-inofine .arrow,
  .final-cta .cta-row .arrow { display: none !important; }
  .fs-cards-mode { padding: 16px 18px; }
  .fs-info-cards { grid-template-columns: 1fr; gap: 10px; }
  .fs-ic-value { font-size: 20px; }
  .fs-ic-value-sm { font-size: 14px; }
  .fs-pc-amount { font-size: 22px; }
  .fs-pc-pct { font-size: 19px; }
  .fs-pc-meta { gap: 14px; font-size: 11.5px; }

  /* ── 02 Work ── */
  .pitch-narrative { font-size: 14.5px; line-height: 1.9; margin-bottom: 32px; }
  /* 画像ギャラリー — 横スクロール可能性を視覚化（右端フェード + カード幅を大きく） */
  .pitch-visual-gallery {
    -webkit-mask-image: linear-gradient(90deg, #000 0, #000 calc(100% - 32px), transparent 100%);
    mask-image: linear-gradient(90deg, #000 0, #000 calc(100% - 32px), transparent 100%);
    padding-right: 24px;
  }
  .pvg-item { width: 72vw; max-width: 260px; min-width: 220px; }

  /* ── Project highlights ── */
  .pitch-highlights { grid-template-columns: 1fr; gap: 14px; margin-bottom: 36px; }
  .ph-card { padding: 22px 20px; }
  .pitch-purpose { flex-direction: column; padding: 22px 20px; gap: 18px; box-shadow: 4px 4px 0 var(--accent-soft); }
  .pp-img { width: 100%; }
  .pp-text .v { font-size: 18px; line-height: 1.5; }
  .pitch-grid-3 { grid-template-columns: 1fr; }
  .pitch-grid-3 .pitch-cell { border-right: none; border-bottom: 1px solid var(--rule); padding: 22px 20px; }
  .pitch-grid-3 .pitch-cell:last-child { border-bottom: none; }

  /* ── 03 Read マーキー＋モーダル ── */
  .read-marquee { margin: 36px 0 24px; padding: 22px 0; }
  .rm-koma { width: 180px; height: 250px; }
  .rm-track { gap: 14px; }
  .read-cta-row { padding: 8px 0 0; }
  .btn-read-open { padding: 18px 56px 18px 24px; font-size: 17px; }
  .btn-read-open .btn-sub { font-size: 10.5px; }
  .btn-read-open .arrow { right: 20px; font-size: 20px; }
  /* 試し読みモーダル */
  .read-modal-bar { padding: 12px 16px; flex-wrap: wrap; gap: 10px; }
  .rmb-l { gap: 8px; flex-wrap: wrap; min-width: 0; flex: 1; }
  .rmb-tag { font-size: 9.5px; padding: 3px 7px; letter-spacing: .1em; }
  .rmb-title { font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; min-width: 0; }
  .rmb-back { padding: 5px 10px; font-size: 10.5px; }
  .rmb-close { width: 32px; height: 32px; font-size: 18px; }
  .read-cards { grid-template-columns: 1fr; gap: 14px; }
  .read-cards-inner { padding: 28px 18px 60px; }
  .read-cards-head { margin-bottom: 24px; }
  .read-cards-head h3 { font-size: 20px; margin-bottom: 6px; }
  .read-cards-head p { font-size: 12.5px; }
  .read-card { padding: 14px; }
  .rc-thumb { margin-bottom: 10px; }
  .read-ep-inner { padding: 20px 14px 50px; }
  .read-ep-aori { font-size: 13.5px; padding: 12px 4px 0; }
  .read-ep-nav { flex-direction: column; gap: 10px; margin-top: 32px; }
  .rep-nav-btn { padding: 12px 18px; }
  .rep-nav-btn .rnb-no { font-size: 16px; }
  .rep-nav-btn .rnb-dir { font-size: 10.5px; }

  /* ── 04 Characters ── 横スクロール式（自動スクロール＋手動スワイプ・フェードヒント） */
  .char-grid {
    display: flex !important;
    grid-template-columns: none !important;
    gap: 12px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-right: 24px;
    touch-action: pan-x;
    -webkit-mask-image: linear-gradient(90deg, #000 0, #000 calc(100% - 32px), transparent 100%);
    mask-image: linear-gradient(90deg, #000 0, #000 calc(100% - 32px), transparent 100%);
    scrollbar-width: none;
  }
  .char-grid::-webkit-scrollbar { display: none; }
  .char-grid.is-dragging { user-select: none; }
  .char-card {
    flex: 0 0 auto;
    width: 72vw; max-width: 260px;
    padding: 18px 18px 20px;
  }
  .char-card .pic { margin-bottom: 12px; }
  .char-card .role { font-size: 9.5px; margin-bottom: 4px; }
  .char-card h4 { font-size: 17px; }
  .char-card .romaji { font-size: 10px; margin-bottom: 10px; }
  .char-card p { font-size: 12.5px; line-height: 1.75; }

  /* ── 05 Creator ── */
  .creator { grid-template-columns: 1fr; gap: 32px; }
  .creator-aside { position: static; text-align: center; max-width: 320px; margin-left: auto; margin-right: auto; }
  .creator-portrait { max-width: 240px; aspect-ratio: 4/5; margin: 0 auto 16px; }
  .creator-tags { justify-content: center; }
  .creator-name { font-size: 22px; }
  .creator-tags .tag { font-size: 9.5px; padding: 3px 8px; }
  .creator-body p { line-height: 1.85; font-size: 14px; }
  .creator-body h4 { font-size: 20px; line-height: 1.4; }
  .creator-body .ch { margin-bottom: 28px; padding-bottom: 28px; }
  .creator-body .ch-num { font-size: 10px; letter-spacing: .2em; }
  .pull-quote { font-size: 16.5px; line-height: 1.65; margin: 20px 0; padding: 18px 0; }
  .creator-workspace { grid-template-columns: 1fr 1fr; gap: 10px; }
  .workspace-cap { font-size: 10.5px; padding: 8px 14px; }

  /* ── 07 Trust ── */
  .about-grid { grid-template-columns: 1fr; gap: 16px; }
  .about-card { padding: 24px 20px; box-shadow: 4px 4px 0 var(--accent-soft); }
  .about-card h3 { font-size: 19px; line-height: 1.4; }
  .about-card .ab-logo { height: 44px; margin-bottom: 14px; }
  .about-card .ab-logo img { max-height: 44px; }
  .about-card p { font-size: 13.5px; line-height: 1.85; }
  .about-card .ab-co { font-size: 12px; margin-bottom: 14px; padding-bottom: 14px; }

  /* ── 07b Track Record ── */
  .tr-carousel { padding: 6px 18px 14px; gap: 12px; }
  .tr-card-sm { flex: 0 0 160px; }
  .tr-name-sm { font-size: 12.5px; }
  .tr-author-sm { font-size: 10.5px; }
  .tr-vol-sm { font-size: 8.5px; }
  .tr-foot { margin-top: 28px; }

  /* ── 08 Usage v2 ── */
  .usage-grid-v2 { grid-template-columns: 1fr; gap: 14px; }
  .usage-card-v2 { padding: 22px 20px; box-shadow: 4px 4px 0 var(--accent-soft); }
  .usage-card-v2 h4 { font-size: 16px; }
  .usage-card-v2 p { font-size: 13px; }
  .usage-note { grid-template-columns: 1fr; padding: 22px 20px; gap: 12px; }
  .usage-note .un-icon { font-size: 36px; }

  /* ── 06 Offer ── */
  .offer-duo { grid-template-columns: 1fr; gap: 14px; margin-bottom: 32px; }
  .offer-card-h { flex-direction: column !important; }
  .offer-card-h .oc-thumb { width: 100%; padding: 18px; }
  .offer-card-h .oc-body { padding: 20px; }
  .offer-card h3 { font-size: 18px; }
  .offer-card-price { font-size: 15px; }
  .offer-card-desc { font-size: 13px; }
  /* Offer Modal */
  .offer-modal-overlay { padding: 16px 8px; }
  .offer-modal-bar { padding: 14px 18px; }
  .offer-modal-title { font-size: 15px; }
  .offer-modal-close { width: 32px; height: 32px; font-size: 18px; }
  .offer-modal-body { padding: 18px 16px; }
  .offer-modal-intro { font-size: 13px; margin-bottom: 16px; }
  /* CAMPFIREプラン表 — mobileではテーブルをカード型に変換（横スクロール廃止） */
  .tier-scroll-hint { display: none; }
  .tier-table-wrap {
    -webkit-mask-image: none;
    mask-image: none;
    padding-right: 0;
    overflow-x: visible;
  }
  .tier-table-wrap::after { display: none; }
  .tier-table { display: block; min-width: 0; width: 100%; font-size: 13px; }
  .tier-table colgroup, .tier-table thead { display: none; }
  .tier-table tbody { display: block; }
  .tier-table tbody tr {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas:
      "img"
      "plan"
      "desc"
      "perks"
      "meta";
    gap: 10px 0;
    padding: 0;
    margin-bottom: 12px;
    background: var(--surface);
    border: 1.5px solid var(--rule);
    border-radius: 8px;
    overflow: hidden;
  }
  .tier-table tbody tr:last-child { margin-bottom: 0; }
  .tier-table tbody td {
    display: block;
    padding: 0 !important;
    border: none !important;
    width: auto !important;
    min-width: 0 !important;
    vertical-align: top;
  }
  .tier-table .tt-img { grid-area: img; padding: 0 !important; }
  .tier-table .tt-img img {
    width: 100% !important; min-width: 0 !important; height: auto !important;
    aspect-ratio: auto; object-fit: contain; border-radius: 0;
    border: none !important;
  }
  .tier-table .tt-plan { grid-area: plan; display: flex; flex-direction: column; gap: 3px; padding: 12px 16px 0 !important; }
  .tier-table .tt-code { font-size: 9.5px; }
  .tier-table .tt-label { font-size: 13px; margin-bottom: 2px; }
  .tier-table .tt-price { font-size: 15px; }
  .tier-table .tt-limit { align-self: flex-start; margin-top: 2px; font-size: 9.5px; }
  .tier-table .tt-desc {
    grid-area: desc;
    padding: 10px 16px 0 !important;
    border-top: 1px dashed var(--rule) !important;
  }
  .tier-table .tt-title { font-size: 14px; margin-bottom: 4px; }
  .tier-table .tt-tagline { font-size: 12px; line-height: 1.65; }
  .tier-table .tt-perks {
    grid-area: perks;
    padding: 10px 16px 0 !important;
    border-top: 1px dashed var(--rule) !important;
  }
  .tier-table .tt-perks ul { padding-left: 0; list-style: none; margin: 0; }
  .tier-table .tt-perks li { margin-bottom: 8px; font-size: 12.5px; line-height: 1.7; }
  .tier-table .tt-perks li:last-child { margin-bottom: 0; }
  .tier-table .tt-perks b { display: block; font-weight: 700; }
  .tier-table .tt-note { display: block; font-size: 11px; color: var(--ink-muted); margin-top: 2px; line-height: 1.6; }
  .tier-table .tt-meta {
    grid-area: meta;
    padding: 10px 16px 16px !important;
    border-top: 1px dashed var(--rule) !important;
    font-size: 11.5px;
    color: var(--ink-muted);
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
  }
  .tier-table .tt-deliver { color: var(--ink-muted); margin-top: 0; }
  /* IF plan */
  .if-plan-header { padding: 22px 20px 16px; }
  .if-plan-title { font-size: 19px; line-height: 1.4; }
  .if-plan-price { font-size: 28px; }
  .if-plan-unit { font-size: 12px; }
  .if-plan-lead { font-size: 13px; line-height: 1.8; }
  .if-plan-features { padding: 18px 20px; }
  .if-feat { gap: 14px; padding: 18px 0; }
  .if-feat-icon { width: 38px; height: 38px; font-size: 17px; }
  .if-feat-body h5 { font-size: 15px; }
  .if-feat-formula { font-size: 10.5px; letter-spacing: .04em; }
  .if-plan-note { margin: 0 20px 18px; padding: 12px 14px; font-size: 11.5px; }
  .if-plan-notes-list { margin: 14px 20px 20px; padding: 14px 16px; font-size: 11.5px; line-height: 1.75; }
  .if-plan-badge { font-size: 9.5px; padding: 4px 12px; letter-spacing: .18em; }

  /* ── 支援方法比較表（channel-table）→ 横並び2カラムカード型に変換 ── */
  .channel-toggle { padding: 22px 18px; box-shadow: 4px 4px 0 var(--accent-soft); margin-top: 36px; }
  .channel-toggle h4 { font-size: 16px; margin-bottom: 6px; }
  .channel-toggle > p { font-size: 12.5px; margin-bottom: 16px; }
  .channel-table { display: block; width: 100%; table-layout: auto; font-size: 12.5px; }
  .channel-table colgroup { display: none; }
  .channel-table thead { display: none; }
  .channel-table tbody { display: block; }
  .channel-table tbody tr {
    display: grid;
    grid-template-columns: 1fr 1fr;
    margin-bottom: 14px;
    border: 1px solid var(--rule);
    background: var(--surface);
    overflow: hidden;
  }
  .channel-table tbody tr:last-child { margin-bottom: 0; }
  .channel-table tbody th {
    grid-column: 1 / -1;
    width: auto;
    background: var(--ink); color: var(--paper);
    font-family: var(--mono); font-size: 11px; letter-spacing: .14em; font-weight: 400;
    padding: 8px 14px;
    border: none;
    text-align: left;
  }
  .channel-table tbody td {
    display: block;
    width: auto;
    padding: 10px 12px 12px;
    font-size: 11.5px; line-height: 1.7;
    border: none;
    vertical-align: top;
  }
  .channel-table tbody td:first-of-type { border-right: 1px dashed var(--rule); }
  .channel-table tbody td::before {
    display: block; margin-bottom: 6px;
    font-family: var(--mono); font-size: 9.5px; letter-spacing: .12em; font-weight: 700;
  }
  .channel-table tbody td:first-of-type::before { content: "CAMPFIRE"; color: var(--accent); }
  .channel-table tbody td:nth-of-type(2)::before { content: "INO Fine"; color: var(--inofine); }
  /* 両方共通行（colSpan=3）は1カラム表示 */
  .channel-table tr.both td {
    grid-column: 1 / -1;
    padding: 12px 14px;
    text-align: center;
    background: #fef4e8;
    border-right: none;
  }
  .channel-table tr.both td::before { display: none; }

  /* ── 08b Schedule ── */
  .roadmap-phase { padding: 14px 0 14px 24px; }
  .roadmap-phase h5 { font-size: 16px; }
  .roadmap-phase p { font-size: 13px; }

  /* ── 09 FAQ ── */
  .faq-item summary { padding: 18px 0; gap: 14px; font-size: 15px; line-height: 1.55; }
  .faq-item summary::before { font-size: 12px; }
  .faq-item .a { padding: 0 0 18px 26px; font-size: 13.5px; line-height: 1.85; }

  /* ── 09b Sponsor & Goods ── */
  .sg-grid { grid-template-columns: 1fr; gap: 14px; }
  .sg-card { padding: 22px 20px; gap: 10px; }
  .sg-card h3 { font-size: 17px; }
  .sg-card p { font-size: 13px; }
  .sg-btn { font-size: 12px; padding: 10px 18px; }

  /* ── 10 Final CTA ── */
  .final-cta { padding: 56px 0 64px; }
  .final-cta::before { top: 22px; font-size: 10px; letter-spacing: .32em; }
  .final-cta h2 { font-size: clamp(24px, 6.5vw, 34px); margin: 22px 0 16px; line-height: 1.45; }
  .final-cta p { font-size: 14px; line-height: 1.85; margin-bottom: 28px; }

  /* ── Footer ── */
  .ftr-gs-inner { padding: 48px 18px 24px; }
  .ftr-gs-top { grid-template-columns: 1fr 1fr; gap: 28px; margin-bottom: 32px; }
  .ftr-gs-brand { grid-column: 1 / -1; }
  .ftr-gs-logo img { max-width: 200px; max-height: 50px; }
  .ftr-gs-tagline { font-size: 12.5px; }
  .ftr-gs-tagline br { display: none; }
  .ftr-gs-col h5 { font-size: 11.5px; margin-bottom: 10px; }
  .ftr-gs-col a { font-size: 12.5px; }
  .ftr-gs-col li { margin-bottom: 8px; }
  .ftr-gs-sns a { width: 36px; height: 36px; font-size: 14px; }
  .ftr-gs-bottom { padding-top: 20px; padding-bottom: 28px; font-size: 10px; gap: 8px; flex-direction: column; align-items: flex-start; }

  /* ── Sticky bar ── */
  .sticky-bar { padding-bottom: env(safe-area-inset-bottom); }
  .sb-inner { flex-direction: column; align-items: stretch; padding: 10px 14px; gap: 8px; }
  .sb-meta { gap: 4px; }
  .sb-title { gap: 8px; }
  .sb-name { font-size: 12.5px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .sb-vol { font-size: 9.5px; padding: 1px 6px; }
  .sb-stats { gap: 8px; justify-content: space-between; }
  .sb-stat b { font-size: 16px; }
  .sb-stat small { font-size: 9.5px; }
  .sb-stat i { font-size: 9.5px; }
  .sb-sep { height: 16px; }
  .sb-cta { width: 100%; gap: 8px; }
  .sb-cta .sb-btn { flex: 1; padding: 10px 6px; font-size: 11.5px; gap: 4px; }
  .sb-cta .sb-btn .btn-main { font-size: 11.5px; }
  .sb-cta .sb-btn i { font-size: 11px; margin-right: 4px !important; }
  body { padding-bottom: 168px; }
}

/* ---------------------------------------------------------------
   640px 以下 — スマートフォン
   --------------------------------------------------------------- */
@media (max-width: 640px) {
  .wrap { padding: 0 16px; }
  section.lp { padding: 52px 0; }
  .sec-head { margin-bottom: 26px; }
  .sec-title { font-size: clamp(22px, 7vw, 30px) !important; line-height: 1.32; margin-bottom: 12px; }
  .sec-sub { font-size: 13.5px; line-height: 1.8; }

  /* Hero — さらに圧縮 */
  .hero { padding: 100px 0 40px !important; }
  .hero-inner { gap: 24px !important; }
  .hero-work-name { padding: 14px 18px 16px; box-shadow: inset 0 0 0 3px #1a1410, inset 0 0 0 4.5px #5c4a38; }
  .hero-work-name::before, .hero-work-name::after { width: 44px; }
  .hwn-the { font-size: 23px; }
  .hwn-title { font-size: clamp(34px, 9vw, 42px); }
  .hero[data-pattern="C"] .hero-title { font-size: clamp(24px, 7vw, 36px) !important; line-height: 1.32 !important; margin-bottom: 18px !important; }
  .hero-catch-line { font-size: clamp(16px, 4.5vw, 24px); margin-bottom: 16px; }
  .hero-creator { font-size: 16.5px; margin-top: 14px; }
  .hero-creator .hc-label { font-size: 9px; }
  .meta-eyebrow { margin-bottom: 12px; font-size: 9.5px; }
  .copy-author { font-size: 15px; }
  .copy-sub { font-size: 12.5px; }
  .hero-panel .stamp { font-size: 8.5px; padding: 3px 7px; }

  /* CTA — 横並び維持 / 880pxの設定をベースに微調整 */
  .cta-row .btn-campfire, .cta-row .btn-inofine { padding: 11px 8px; font-size: 12.5px; }
  .btn-campfire .btn-main, .btn-inofine .btn-main { font-size: 12px; }

  /* Funding Strip */
  .fs-cards-mode { padding: 14px 16px; }
  .fs-pc-amount { font-size: 20px; }
  .fs-ic-value { font-size: 19px; }

  /* Read */
  .rm-koma { width: 152px; height: 210px; }
  .btn-read-open { padding: 16px 50px 16px 22px; font-size: 15.5px; }
  .btn-read-open .arrow { right: 16px; font-size: 19px; }

  /* Creator */
  .creator-portrait { max-width: 220px; }
  .creator-name { font-size: 21px; }
  .creator-body p { font-size: 13.5px; }
  .creator-body h4 { font-size: 18.5px; }
  .pull-quote { font-size: 15.5px; }

  /* Project */
  .ph-card { padding: 20px 18px; }
  .ph-card h4 { font-size: 15px; }
  .ph-card p { font-size: 12.5px; }
  .pp-text .v { font-size: 17px; }

  /* About / Track */
  .about-card { padding: 22px 18px; }
  .about-card h3 { font-size: 18px; }

  /* IF plan */
  .if-plan-features { padding: 16px 18px; }
  .if-plan-note { margin: 0 18px 16px; padding: 12px 14px; }
  .if-plan-notes-list { margin: 12px 18px 18px; padding: 14px 16px; }

  /* Sticky bar */
  .sb-name { font-size: 12px; }
  .sb-stat b { font-size: 14.5px; }
  .sb-cta .sb-btn { padding: 9px 5px; font-size: 11px; }
  .sb-cta .sb-btn .btn-main { font-size: 11px; }
  body { padding-bottom: 162px; }

  /* Final CTA */
  .final-cta { padding: 48px 0 56px; }
  .final-cta h2 { font-size: clamp(22px, 6.5vw, 30px); margin: 18px 0 14px; }
  .final-cta p { font-size: 13.5px; margin-bottom: 24px; }
}

/* ---------------------------------------------------------------
   400px 以下 — 超小型スマホ
   --------------------------------------------------------------- */
@media (max-width: 400px) {
  .wrap { padding: 0 14px; }
  .sub-nav-in { gap: 14px; padding: 6px 14px; }
  .sub-nav-in a { font-size: 11.5px; }
  /* Hero */
  .hero-work-name { padding: 12px 16px 14px; }
  .hwn-the { font-size: 21px; }
  .hwn-title { font-size: 32px; }
  .hero-creator { font-size: 15.5px; }
  .hero[data-pattern="C"] .hero-title { font-size: clamp(22px, 7vw, 30px) !important; }
  .hero-catch-line { font-size: clamp(15px, 4.2vw, 22px); margin-bottom: 14px; }
  /* CTA */
  .btn-campfire .btn-main, .btn-inofine .btn-main { font-size: 12.5px; }
  /* Sticky bar — 文字優先・アイコン非表示 */
  .sb-cta .sb-btn { padding: 9px 4px; font-size: 10.5px; }
  .sb-cta .sb-btn .btn-main { font-size: 10.5px; }
  .sb-cta .sb-btn i { display: none !important; }
  .sb-stat b { font-size: 13.5px; }
  /* モーダル戻るボタン省略 */
  .rmb-back { display: none; }
  .rmb-title { font-size: 12px; }
}

/* ▲▲▲ RESPONSIVE LAYER v2 END ▲▲▲ */
