/* ===================================================================
   邦題ガチャ — 文芸・活版印刷のための組版
   設計トークンは design_handoff に忠実。色・余白・モーションは仕様準拠。
   =================================================================== */

/* ───────────── tokens ───────────── */
:root{
  --r-1:2px; --r-2:6px; --r-3:10px; --r-pill:999px;
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(0,0,.2,1);
  --dur-fast:120ms; --dur-base:160ms; --dur-slow:240ms;

  --font-gothic:'Zen Kaku Gothic New','Noto Sans JP',system-ui,sans-serif;
  --font-en:'Newsreader',Georgia,serif;
  --font-mincho:'Shippori Mincho B1','Noto Serif JP',serif;
}
[data-mincho="noto"]{ --font-mincho:'Noto Serif JP','Shippori Mincho B1',serif; }

/* ── 案A : 文芸・活版（生成り紙＋墨＋朱）── default ── */
.stage{
  --paper:#f4efe3;
  --card:#fffbf3;
  --card-hall:#efe6d4;
  --ink:#1a1714;
  --ink-2:#4a453d;
  --ink-3:#6b6253;
  --rule:#d8cfba;
  --rule-soft:#e6decc;
  --shu:#c1432f;
  --shu-soft:rgba(193,67,47,.08);
  --kin:#b3902f;
  --card-shadow:0 1px 0 rgba(27,26,23,.04), 0 10px 30px -18px rgba(27,26,23,.30);
  --vignette:transparent;
  --grain-blend:multiply;
  --grain-opacity:.05;
}
/* ── 案B : 墨一色＋白い紙のミニマル ── */
.stage[data-tone="B"]{
  --paper:#faf8f2;
  --card:#fffefb;
  --card-hall:#f3efe5;
  --ink:#16140f;
  --ink-2:#54504a;
  --ink-3:#8b857a;
  --rule:#e7e1d4;
  --rule-soft:#efeae0;
  --shu:#16140f;            /* 墨一色：差し色も墨 */
  --shu-soft:rgba(22,20,15,.05);
  --kin:#54504a;
  --card-shadow:0 1px 0 rgba(27,26,23,.03), 0 8px 24px -18px rgba(27,26,23,.18);
  --vignette:transparent;
  --grain-blend:multiply;
  --grain-opacity:.03;
}
/* ── 案C : 夜の名画座（暗色＋朱と金）── */
.stage[data-tone="C"]{
  --paper:#14110c;
  --card:#211c14;
  --card-hall:#1a160f;
  --ink:#ece2cf;
  --ink-2:#b8ad97;
  --ink-3:#8a8170;
  --rule:#3a3226;
  --rule-soft:#2c261c;
  --shu:#d4543f;
  --shu-soft:rgba(212,84,63,.12);
  --kin:#c9a23f;
  --card-shadow:0 1px 0 rgba(0,0,0,.2), 0 18px 44px -22px rgba(0,0,0,.7);
  --vignette:radial-gradient(120% 90% at 50% 30%, transparent 38%, rgba(0,0,0,.45) 100%);
  --grain-blend:overlay;
  --grain-opacity:.06;
}

*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  background:#14110c;
  font-family:var(--font-gothic);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}

.stage{
  position:relative;
  min-height:100vh;
  background:var(--paper);
  color:var(--ink);
  padding:clamp(24px,6vw,56px) 18px 96px;
  transition:background var(--dur-slow) var(--ease), color var(--dur-slow) var(--ease);
  overflow:hidden;
}
.paper-vignette{
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background:var(--vignette);
  transition:background var(--dur-slow) var(--ease);
}
.stage > *{ position:relative; z-index:1; }

/* ───────────── masthead ───────────── */
.masthead{
  max-width:520px; margin:0 auto clamp(28px,5vw,44px);
  text-align:center;
}
.masthead-rule{
  height:1px; background:var(--rule);
  max-width:280px; margin:0 auto;
}
.masthead-rule:first-child{ box-shadow:0 3px 0 -2px var(--rule); }
.masthead-rule:last-child{ box-shadow:0 -3px 0 -2px var(--rule); }
.brand{
  margin:18px 0 10px;
  font-family:var(--font-mincho);
  font-weight:800;
  font-size:clamp(30px,8vw,42px);
  letter-spacing:.14em;
  line-height:1;
  color:var(--ink);
}
.tagline{
  margin:0 0 16px;
  font-family:var(--font-gothic);
  font-weight:400;
  font-size:clamp(12px,3.4vw,13.5px);
  letter-spacing:.18em;
  color:var(--ink-3);
}

/* ── 把握：開閉式オンボード ── */
.intro-toggle{
  margin-top:2px;
  background:none; border:none; cursor:pointer;
  font-family:var(--font-gothic); font-weight:500;
  font-size:11.5px; letter-spacing:.16em;
  color:var(--ink-3);
  padding:4px 8px;
  transition:color var(--dur-base) var(--ease);
}
.intro-toggle::before{ content:'— '; }
.intro-toggle::after{ content:' ›'; display:inline-block; transition:transform var(--dur-base) var(--ease); }
.intro-toggle.is-open::after{ transform:rotate(90deg); }
.intro-toggle:hover{ color:var(--shu); }
.stage[data-tone="B"] .intro-toggle:hover{ color:var(--ink); }

/* ── 把握：開閉式オンボード（端的・軽い一文） ── */
.intro{
  max-width:430px; margin:clamp(-34px,-5vw,-22px) auto clamp(20px,4vw,28px);
  padding:0 10px;
  text-align:center;
  font-family:var(--font-gothic); font-weight:400;
  font-size:12.5px; line-height:1.95; letter-spacing:.04em;
  color:var(--ink-2);
  text-wrap:pretty;
  animation:introIn var(--dur-base) var(--ease-out) both;
}
@keyframes introIn{ from{opacity:0;} to{opacity:1;} }

/* ───────────── reel / draw bar ───────────── */
.reel{ max-width:1160px; margin:0 auto; }
.draw-bar{
  display:flex; gap:12px; align-items:stretch; justify-content:center;
  max-width:460px; margin:0 auto clamp(24px,5vw,38px);
}
.draw-primary{
  flex:1 1 auto;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:3px;
  border:none; cursor:pointer;
  background:var(--shu); color:#f7efe2;
  border-radius:var(--r-2);
  padding:14px 18px; min-height:60px;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.06), 0 1px 0 rgba(0,0,0,.12);
  transition:filter var(--dur-base) var(--ease), transform var(--dur-fast) var(--ease);
}
.draw-primary-label{
  font-family:var(--font-mincho); font-weight:700;
  font-size:19px; letter-spacing:.22em; text-indent:.22em;
}
.stage[data-tone="B"] .draw-primary{ color:#faf8f2; }
.draw-primary:hover{ filter:brightness(.93); }
.draw-primary:active{ filter:brightness(.86); transform:translateY(1px); }
.draw-primary:disabled{ opacity:.5; cursor:default; }

/* ───────────── empty / pulling ───────────── */
.empty{ text-align:center; padding:48px 0 24px; }
.empty-mark{
  font-family:var(--font-mincho); font-weight:800;
  font-size:clamp(44px,13vw,64px); line-height:1.15; color:var(--ink);
  letter-spacing:.08em;
  opacity:.06; margin-bottom:8px; user-select:none;
}
.empty-text{
  font-family:var(--font-gothic); font-weight:400;
  font-size:14px; line-height:2; letter-spacing:.14em;
  color:var(--ink-3); margin:0;
}
.pulling{
  display:flex; gap:10px; justify-content:center; align-items:center;
  padding:80px 0;
}
.pulling-dot{
  width:6px; height:6px; border-radius:50%; background:var(--shu);
  opacity:.3; animation:pulse 1s var(--ease) infinite;
}
.pulling-dot:nth-child(2){ animation-delay:.16s; }
.pulling-dot:nth-child(3){ animation-delay:.32s; }
@keyframes pulse{ 0%,100%{opacity:.18; transform:translateY(0);} 50%{opacity:.7; transform:translateY(-4px);} }

/* ───────────── stack : glanceable grid ───────────── */
.stack{
  display:grid; gap:14px;
  grid-template-columns:repeat(2,1fr);
  perspective:1600px;
}
@media(min-width:560px){ .stack{ gap:16px; grid-template-columns:repeat(3,1fr); } }
@media(min-width:880px){ .stack{ gap:18px; grid-template-columns:repeat(5,1fr); } }
.stack--single{ grid-template-columns:minmax(0,360px); justify-content:center; }

/* ───────────── card ───────────── */
.kcard{
  position:relative;
  display:flex; flex-direction:column;
  background:var(--card);
  border:1px solid var(--rule);
  border-radius:var(--r-3);
  box-shadow:var(--card-shadow);
  overflow:hidden;
  transition:opacity var(--dur-slow) var(--ease), filter var(--dur-slow) var(--ease), transform var(--dur-base) var(--ease);
}
.kcard--hall{
  background:var(--card-hall);
  box-shadow:var(--card-shadow), inset 0 0 0 1px var(--rule-soft);
}
.kcard--hall .kcard-face{
  /* a second keyline frame — different 組版, not a badge */
  outline:1px solid var(--rule-soft);
  outline-offset:-8px;
}
.kcard-grain{
  position:absolute; inset:0; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:var(--grain-blend);
  opacity:var(--grain-opacity);
}
.stage[data-grain="off"] .kcard-grain{ display:none; }

.kcard-face{
  position:relative;
  flex:1 1 auto;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:24px 16px 22px;
  text-align:center;
}
.kcard-ja{
  margin:0;
  font-family:var(--font-mincho); font-weight:700;
  font-size:clamp(21px,5.2vw,30px);
  line-height:1.36;
  letter-spacing:.04em;
  color:var(--ink);
  text-wrap:balance;
}
.kcard-sep{
  width:30px; height:2px; background:var(--shu);
  margin:16px auto 14px; border-radius:2px;
}
.kcard-sep--hall{
  width:6px; height:6px; background:transparent;
  border:1px solid var(--ink-3); transform:rotate(45deg);
  border-radius:1px; margin:17px auto 15px;
}
.kcard-meta{
  display:flex; flex-direction:column; gap:4px; align-items:center;
  margin-bottom:16px;
}
.kcard-en{
  font-family:var(--font-en); font-style:italic; font-weight:400;
  font-size:14px; line-height:1.4; color:var(--ink-2);
}
.kcard-year{
  font-family:var(--font-gothic); font-weight:500;
  font-size:10.5px; letter-spacing:.24em; text-indent:.24em;
  color:var(--ink-3);
}
.kcard-kata{
  font-family:var(--font-gothic); font-weight:500;
  font-size:12px; letter-spacing:.04em; color:var(--ink-2);
  padding:6px 13px;
  border:1px solid var(--rule);
  background:var(--shu-soft);
  border-radius:var(--r-pill);
}

.kcard-actions{
  display:flex;
  border-top:1px solid var(--rule);
}
.kbtn{
  flex:1 1 0; min-height:46px; cursor:pointer;
  background:transparent; border:none;
  font-family:var(--font-gothic); font-weight:500;
  font-size:13.5px; letter-spacing:.14em;
  display:flex; align-items:center; justify-content:center; gap:7px;
  transition:background var(--dur-base) var(--ease), color var(--dur-base) var(--ease);
}
.kbtn + .kbtn{ border-left:1px solid var(--rule); }
.kbtn-like{ color:var(--shu); }
.kbtn-study{ color:var(--ink-2); }
.kbtn-share{ color:var(--ink-2); }
.stage[data-tone="B"] .kbtn-like{ color:var(--ink); }
.kbtn-heart{ font-size:15px; line-height:1; }
.kbtn:hover{ background:var(--shu-soft); }

.kcard.is-liked{ box-shadow:var(--card-shadow), inset 0 0 0 2px var(--shu); }
.kcard.is-liked .kbtn-like{ background:var(--shu-soft); font-weight:700; }

/* ── rise motion : 文庫の扉が起き上がる ── */
.kcard.is-rising{
  transform-origin:top center;
  animation:kRise 420ms var(--ease-out) both;
  animation-delay:var(--rise-delay);
}
@keyframes kRise{
  0%{ opacity:0; transform:rotateX(-82deg); filter:blur(3px); }
  55%{ filter:blur(.5px); }
  100%{ opacity:1; transform:rotateX(0deg); filter:blur(0); }
}
@media (prefers-reduced-motion:reduce){
  .kcard.is-rising{ animation:kFade 300ms var(--ease-out) both; }
  @keyframes kFade{ from{opacity:0;} to{opacity:1;} }
}

/* ───────────── shelf : a little bookshelf ───────────── */
.shelf{
  max-width:600px; margin:clamp(36px,7vw,56px) auto 0;
  border-top:1px solid var(--rule);
  padding-top:18px;
}
.shelf-head{
  display:flex; align-items:baseline; gap:10px;
  padding:0 2px 4px;
}
.shelf-title{
  font-family:var(--font-gothic); font-weight:700;
  font-size:13px; letter-spacing:.14em; color:var(--ink-2);
}
.shelf-count{
  font-family:var(--font-en); font-style:italic;
  font-size:15px; color:var(--shu);
}
.stage[data-tone="B"] .shelf-count{ color:var(--ink-2); }
.shelf-empty-text{
  font-family:var(--font-gothic); font-weight:400;
  font-size:12px; letter-spacing:.14em; color:var(--ink-3);
  margin:8px 2px 4px;
}
/* 横書きの短冊が、紙束のように少しずつ重なる。クリックで詳細へ。 */
.shelf-stack{
  position:relative;
  display:flex; flex-direction:column;
  padding:18px 2px 12px;
}
.slip{
  position:relative;
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center; column-gap:16px;
  width:100%; text-align:left; cursor:pointer;
  background:var(--card);
  border:1px solid var(--rule);
  border-radius:var(--r-2);
  box-shadow:var(--card-shadow);
  padding:13px 18px 13px 22px;
  margin-top:-11px;            /* 重なり：紙束のように */
  transition:transform var(--dur-base) var(--ease),
             box-shadow var(--dur-base) var(--ease),
             border-color var(--dur-base) var(--ease);
}
.slip:first-child{ margin-top:0; }
/* 小口（紙の束の側面）— ふだんは罫線、引き出すと朱が差す */
.slip::before{
  content:'';
  position:absolute; left:0; top:9px; bottom:9px; width:3px;
  border-radius:0 2px 2px 0;
  background:var(--rule);
  transition:background var(--dur-base) var(--ease);
}
.slip:hover, .slip:focus-visible{
  transform:translateX(10px);
  border-color:var(--ink-3);
  box-shadow:var(--card-shadow), 0 12px 28px -16px rgba(27,26,23,.5);
  z-index:5; outline:none;
}
.slip:hover::before, .slip:focus-visible::before{ background:var(--shu); }
.slip-no{
  align-self:start; padding-top:3px;
  font-family:var(--font-gothic); font-weight:500;
  font-size:11px; letter-spacing:.1em; color:var(--ink-3);
  font-variant-numeric:tabular-nums;
}
.slip-body{ display:flex; flex-direction:column; gap:3px; min-width:0; }
.slip-ja{
  font-family:var(--font-mincho); font-weight:700;
  font-size:16px; letter-spacing:.04em; line-height:1.32;
  color:var(--ink);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.slip-en{
  font-family:var(--font-en); font-style:italic; font-weight:400;
  font-size:11.5px; line-height:1.3; color:var(--ink-3);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.slip-year{
  align-self:start; padding-top:3px;
  flex:0 0 auto;
  font-family:var(--font-en); font-style:italic; font-weight:400;
  font-size:13px; color:var(--ink-3);
}

/* ───────────── detail : クリックした一枚の詳細 ───────────── */
.detail-backdrop{
  position:fixed; inset:0; z-index:80;
  display:flex; align-items:center; justify-content:center;
  padding:24px;
  background:rgba(20,17,12,.84);            /* 賑やかな一覧を確実に沈めてモーダルを立たせる（背後のにじみを断つ） */
  -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px);
  animation:dFade var(--dur-fast) var(--ease-out) both;
}
@keyframes dFade{ from{opacity:0;} to{opacity:1;} }
.detail{
  position:relative;
  width:100%; max-width:392px;
  background:var(--card);
  border:1px solid var(--rule);
  border-radius:var(--r-3);
  box-shadow:0 18px 48px -18px rgba(27,26,23,.55), 0 2px 6px rgba(27,26,23,.10);
  overflow:hidden;
  animation:dRise var(--dur-slow) var(--ease-out) both;
}
@keyframes dRise{ from{opacity:0; transform:translateY(10px);} to{opacity:1; transform:none;} }
/* 詳細では紙ノイズを止める — mix-blend が文字に重なって可読性を落とすため（シェアカードでは残す） */
.detail .kcard-grain{ display:none; }
.detail-face{
  position:relative;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:38px 26px 30px;
  text-align:center;
}
.detail-close{
  position:absolute; top:10px; right:12px;
  width:30px; height:30px; border:none; background:transparent; cursor:pointer;
  font-family:var(--font-gothic); font-size:18px; line-height:1;
  color:var(--ink-3); border-radius:var(--r-2);
  transition:background var(--dur-base) var(--ease), color var(--dur-base) var(--ease);
}
.detail-close:hover{ background:var(--shu-soft); color:var(--ink); }
.detail-actions{
  display:flex; border-top:1px solid var(--rule);
}
.detail-act{
  flex:1 1 0; min-height:52px; cursor:pointer;
  background:transparent; border:none;
  font-family:var(--font-gothic); font-weight:600;
  font-size:14px; letter-spacing:.1em;
  color:var(--ink);
  transition:background var(--dur-base) var(--ease), color var(--dur-base) var(--ease);
}
.detail-act + .detail-act{ border-left:1px solid var(--rule); }
.detail-act--remove{ color:var(--shu); }
.stage[data-tone="B"] .detail-act--remove{ color:var(--ink); }
.detail-act:hover{ background:var(--shu-soft); }

.detail-synopsis{
  margin:22px auto 2px;
  padding-top:18px;
  max-width:300px;
  border-top:1px solid var(--rule);
  font-family:var(--font-gothic); font-weight:400;
  font-size:14px; line-height:1.85; letter-spacing:.02em;
  color:var(--ink);
  text-wrap:pretty;
}

/* ── 詳細モーダルだけ可視性を底上げ（一覧の小カードには影響させない） ──
   「おしゃれ」を保ちつつ、本文・メタ・型・リンクの寸法とコントラストを上げる。 */
.detail-face .kcard-ja{
  font-size:clamp(24px,6vw,33px); line-height:1.32; font-weight:800;
}
.detail-face .kcard-en{
  font-size:16px; line-height:1.45; color:var(--ink);   /* 原題をはっきり読める濃さに */
}
.detail-face .kcard-year{
  font-size:12px; letter-spacing:.16em; text-indent:.16em; color:var(--ink-2);
}
.detail-face .kcard-meta{ gap:6px; margin-bottom:18px; }
.detail-face .kcard-kata{
  font-size:13.5px; color:var(--ink);                   /* 型を読める濃さ＋枠を明確に */
  padding:7px 15px; border-color:var(--shu);
}
.stage[data-tone="B"] .detail-face .kcard-kata{ border-color:var(--ink-3); }
.detail-face .detail-link{ font-size:13.5px; }

/* 「タイトルええな」→「どんな作品か」への静かな扉。バッジ感は出さず、組版の二行として。 */
.detail-links{
  position:relative;
  display:flex; flex-direction:column; align-items:center; gap:9px;
  margin-top:24px;
}
.detail-links::before{
  content:""; position:absolute; top:-13px; left:50%; transform:translateX(-50%);
  width:42px; height:1px; background:var(--rule);
}
.detail-synopsis + .detail-links{ margin-top:14px; }
.detail-synopsis + .detail-links::before{ display:none; }
.detail-link{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--font-gothic); font-weight:500;
  font-size:12.5px; letter-spacing:.06em;
  color:var(--shu); text-decoration:none;
}
.detail-link--shop{ color:var(--ink-2); }  /* 商業導線は控えめに（押し売り感を出さない） */
.detail-link:hover{ text-decoration:underline; text-underline-offset:4px; text-decoration-thickness:1px; }
.detail-link--shop:hover{ color:var(--shu); }
.detail-link-arrow{ font-size:11px; opacity:.75; }
.stage[data-tone="B"] .detail-link{ color:var(--ink); }

/* ───────────── share : 縦長のシェアカード（1枚絵として持ち帰る） ───────────── */
.share-overlay{
  position:fixed; inset:0; z-index:90;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:18px; padding:24px;
  background:rgba(20,17,12,.84);
  -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px);
  animation:dFade var(--dur-fast) var(--ease-out) both;
  overflow:auto;
}
.share-inner{
  display:flex; flex-direction:column; align-items:center; gap:18px;
  width:100%; max-width:340px;
  animation:dRise var(--dur-slow) var(--ease-out) both;
}
/* the rasterised node — a 4:5 vertical poster */
.share-card{
  position:relative;
  width:100%; aspect-ratio:4/5;
  display:flex; flex-direction:column;
  background:var(--card);
  border:1px solid var(--rule);
  border-radius:var(--r-3);
  box-shadow:0 22px 56px -22px rgba(0,0,0,.6);
  overflow:hidden;
  isolation:isolate;   /* グレインの mix-blend を内側に閉じ込め、背後の朱のにじみを断つ */
}
.share-card-rule{
  position:absolute; inset:14px;
  border:1px solid var(--rule-soft);
  border-radius:var(--r-2);
  pointer-events:none;
}
.share-card-body{
  position:relative; z-index:1;
  flex:1 1 auto;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center;
  padding:44px 34px 24px;
}
.share-card-kicker{
  font-family:var(--font-gothic); font-weight:500;
  font-size:11px; letter-spacing:.4em; text-indent:.4em;
  color:var(--ink-3);
  margin-bottom:18px;
}
.share-card-ja{
  margin:0;
  font-family:var(--font-mincho); font-weight:800;
  font-size:clamp(28px,9vw,38px);
  line-height:1.34; letter-spacing:.05em;
  color:var(--ink);
  text-wrap:balance;
}
.share-card-en{
  font-family:var(--font-en); font-style:italic; font-weight:400;
  font-size:15px; line-height:1.4; color:var(--ink-2);
  margin-top:2px;
}
.share-card-year{
  font-family:var(--font-gothic); font-weight:500;
  font-size:11px; letter-spacing:.26em; text-indent:.26em;
  color:var(--ink-3);
  margin-top:8px;
}
.share-card-kata{
  margin-top:18px;
  font-family:var(--font-gothic); font-weight:500;
  font-size:12px; letter-spacing:.06em; color:var(--ink-2);
  padding:7px 15px;
  border:1px solid var(--rule);
  background:var(--shu-soft);
  border-radius:var(--r-pill);
}
.share-card-foot{
  position:relative; z-index:1;
  display:flex; flex-direction:column; align-items:center; gap:5px;
  padding:0 28px 30px;
}
.share-card-foot::before{
  content:''; width:26px; height:2px; background:var(--shu);
  border-radius:2px; margin-bottom:12px;
}
.share-card-mark{
  font-family:var(--font-mincho); font-weight:800;
  font-size:15px; letter-spacing:.18em; text-indent:.18em;
  color:var(--ink);
}
.share-card-cta{
  font-family:var(--font-gothic); font-weight:500;
  font-size:10.5px; letter-spacing:.1em;
  color:var(--ink-2);
}
.share-card-url{
  font-family:var(--font-en); font-style:italic; font-weight:500;
  font-size:11px; letter-spacing:.04em;
  color:var(--shu);
  margin-top:2px;
}
.stage[data-tone="B"] .share-card-url{ color:var(--ink-2); }

.share-bar{
  display:flex; gap:10px; align-items:stretch;
  width:100%; max-width:340px;
}
.share-btn{
  flex:1 1 0; min-height:48px; cursor:pointer;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.06);
  color:#f4efe3;
  border-radius:var(--r-2);
  font-family:var(--font-gothic); font-weight:500;
  font-size:13.5px; letter-spacing:.1em;
  transition:background var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease), filter var(--dur-base) var(--ease);
}
.share-btn:hover{ background:rgba(255,255,255,.13); }
.share-btn:disabled{ opacity:.55; cursor:default; }
.share-btn--primary{
  flex:1.4 1 0;
  background:var(--shu); border-color:transparent; color:#f7efe2;
}
.stage[data-tone="B"] .share-btn--primary{ background:#16140f; }
.share-btn--primary:hover{ filter:brightness(.93); background:var(--shu); }
.share-btn--ghost{ flex:0 0 auto; padding:0 18px; }

/* ───────────── 組版（トーン）選択 — 奥付のように頁の末尾に ───────────── */
.colophon{
  max-width:600px; margin:clamp(40px,8vw,64px) auto 0;
  padding-top:20px;
  border-top:1px solid var(--rule);
  display:flex; flex-wrap:wrap; align-items:center; gap:14px 18px;
}
.colophon-label{
  font-family:var(--font-gothic); font-weight:700;
  font-size:11px; letter-spacing:.18em; color:var(--ink-3);
}
.tone-set{ display:flex; gap:8px; flex-wrap:wrap; }
.tone-opt{
  cursor:pointer; background:transparent;
  border:1px solid var(--rule);
  border-radius:var(--r-pill);
  padding:7px 15px;
  font-family:var(--font-gothic); font-weight:500;
  font-size:11.5px; letter-spacing:.1em;
  color:var(--ink-2);
  transition:border-color var(--dur-base) var(--ease),
             background var(--dur-base) var(--ease),
             color var(--dur-base) var(--ease);
}
.tone-opt:hover{ border-color:var(--ink-3); }
.tone-opt.is-active{
  border-color:var(--shu);
  background:var(--shu-soft);
  color:var(--ink);
}
.stage[data-tone="B"] .tone-opt.is-active{ border-color:var(--ink); }
.tone-opt .tone-en{
  font-family:var(--font-en); font-style:italic;
  margin-left:6px; font-size:10.5px; color:var(--ink-3);
}
/* Amazon アソシエイト開示。法令・規約上の必須表示だが、組版の最下段に静かに置く。 */
.colophon-note{
  flex-basis:100%; margin:2px 0 0;
  font-family:var(--font-gothic); font-weight:400;
  font-size:10.5px; line-height:1.7; letter-spacing:.04em;
  color:var(--ink-3); opacity:.78;
}

@media(min-width:880px){
  .kcard-face{ padding:30px 20px 26px; }
}
