/* ════════════════════════════════════════════════════════════
   PEDIGREE — 5代血統表モーダル
   Horse Central / shared component (broodmares + sales)
   ════════════════════════════════════════════════════════════ */

:root{
  --ped-sire:#D6E9E5;     /* 父系：淡い青磁 */
  --ped-sire-line:#C2DCD7;
  --ped-dam:#F6DDE4;      /* 母系：淡い桜 */
  --ped-dam-line:#EFCBD6;
  --ped-empty:#F3F1EC;
  --ped-dash:#C9C4B8;
  --ped-head:#0C1A26;     /* タイトル帯：濃紺 */
  --ped-x:#BC2E2E;        /* クロス（該当先祖）：赤 */
}

/* ── カード下部の起動ボタン ───────────────────────── */
.ped-trigger{
  width:100%;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;gap:11px;
  padding:14px 16px;
  background:#fff;
  border:0;border-top:1px solid var(--rule);
  color:var(--gold);cursor:pointer;
  font-family:var(--serif-jp);font-size:12.5px;letter-spacing:.18em;font-weight:600;
  transition:background .28s ease,color .28s ease;
}
.hcard:hover .ped-trigger{background:#FBF8F2;}
.ped-trigger:hover{background:var(--green);color:#fff;}
.ped-trigger-en{
  font-family:var(--display);font-size:10px;letter-spacing:.34em;
  text-transform:uppercase;font-weight:700;opacity:.65;
}
.ped-trigger:hover .ped-trigger-en{opacity:.85;}
.ped-trigger-arrow{display:inline-block;transition:transform .28s ease;font-size:11px;}
.ped-trigger:hover .ped-trigger-arrow{transform:translateX(4px);}

.hcard{cursor:pointer;}

/* ── オーバーレイ + モーダル ───────────────────────── */
.ped-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(20,24,22,.58);
  backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);
  display:flex;align-items:flex-start;justify-content:center;
  padding:40px 24px;overflow:auto;
  opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;
}
.ped-overlay.is-open{opacity:1;visibility:visible;}

.ped-modal{
  position:relative;width:100%;max-width:980px;margin:auto;
  background:#fff;border-radius:5px;
  box-shadow:0 24px 70px rgba(12,20,18,.36);
  display:flex;flex-direction:column;
  transform:translateY(14px) scale(.985);
  transition:transform .34s cubic-bezier(.22,.61,.36,1);
}
.ped-overlay.is-open .ped-modal{transform:none;}

.ped-actions{
  flex:0 0 auto;
  display:flex;align-items:center;justify-content:flex-end;gap:10px;
  padding:14px 16px;border-bottom:1px solid var(--rule);
  background:#fff;border-radius:5px 5px 0 0;
}
.ped-btn{
  font-family:var(--display);font-size:11px;letter-spacing:.22em;font-weight:700;
  text-transform:uppercase;cursor:pointer;border:1px solid var(--rule);
  background:#fff;color:var(--ink-2);
  padding:9px 16px;border-radius:3px;line-height:1;
  transition:background .2s ease,color .2s ease,border-color .2s ease;
}
.ped-btn:hover{background:var(--green);color:#fff;border-color:var(--green);}
.ped-print{display:inline-flex;align-items:center;gap:8px;}
.ped-close{
  width:38px;height:38px;padding:0;font-size:22px;letter-spacing:0;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink-2);font-family:var(--sans-jp);font-weight:400;
}
.ped-close:hover{background:var(--green);color:#fff;border-color:var(--green);}

.ped-scroll{flex:1 1 auto;overflow:auto;padding:30px;}

/* ── 印刷用シート ──────────────────────────────────── */
.ped-sheet{
  min-width:0;margin:0 auto;
  border:1px solid #E3E0D8;
  background:#fff;
}

/* 表だけ横スクロール（テキストは画面幅で折り返す） */
.ped-gridwrap{
  overflow-x:auto;-webkit-overflow-scrolling:touch;
}

.ped-title{
  background:var(--ped-head);color:#fff;
  font-family:var(--serif-jp);font-weight:600;
  font-size:26px;letter-spacing:.14em;text-align:center;
  padding:24px 24px;line-height:1.3;
}

/* ── 馬の紹介（キャッチ＋説明文） ─────────────────── */
.ped-intro{background:#fff;padding:18px 26px 6px;}
.ped-intro:empty{display:none;}
.ped-intro .ped-catch{
  font-family:var(--serif-jp);font-size:15px;font-weight:700;
  letter-spacing:.08em;color:var(--green);margin-bottom:8px;line-height:1.5;
}
.ped-intro .ped-desc{
  font-family:var(--sans-jp);font-size:12.5px;line-height:1.95;
  color:var(--ink-2);letter-spacing:.03em;margin:0;text-wrap:pretty;
}

/* ── 5代グリッド：32行 × 5列 ─────────────────────── */
.ped-grid{
  display:grid;
  grid-template-columns:1.02fr 1.12fr 1.16fr 1.04fr 1fr;
  grid-template-rows:repeat(32, minmax(22px, 1fr));
  gap:2px;background:#fff;padding:2px;
  min-width:680px;
}
.ped-cell{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:5px 7px;line-height:1.28;
  overflow:hidden;
  -webkit-print-color-adjust:exact;print-color-adjust:exact;
}
.ped-cell.sire{background:var(--ped-sire);}
.ped-cell.dam{background:var(--ped-dam);}
.ped-cell.ped-empty{background:var(--ped-empty);}
.ped-dash{color:var(--ped-dash);font-size:13px;letter-spacing:.1em;}

.ped-n{font-family:var(--sans-jp);color:var(--ink);font-weight:600;letter-spacing:.02em;text-wrap:balance;}
.ped-n2{font-family:var(--display);color:var(--ink-2);font-weight:600;letter-spacing:.04em;margin-top:2px;}
.ped-s{font-family:var(--sans-jp);color:var(--ink-2);font-weight:400;margin-top:3px;letter-spacing:.02em;}

/* 世代ごとの文字サイズ */
.ped-gen1 .ped-n{font-size:16px;}
.ped-gen1 .ped-n2{font-size:11px;}
.ped-gen1 .ped-s{font-size:11px;}
.ped-gen2 .ped-n{font-size:13.5px;}
.ped-gen2 .ped-s{font-size:10.5px;}
.ped-gen3 .ped-n{font-size:12px;}
.ped-gen3 .ped-s{font-size:10px;}
.ped-gen4 .ped-n{font-size:11px;}
.ped-gen4 .ped-s{font-size:9.5px;}
.ped-gen5 .ped-n{font-size:10.5px;font-weight:500;}

/* クロス該当セル：赤文字 */
.ped-cell.ped-x .ped-n{color:var(--ped-x);font-weight:700;}
.ped-cell.ped-x .ped-s{color:var(--ped-x);opacity:.8;}

.ped-foot{
  font-family:var(--sans-jp);font-size:10.5px;color:var(--ink-2);
  letter-spacing:.08em;text-align:right;padding:10px 14px;
  border-top:1px solid #EDEAE2;background:#fff;
}

/* ── 血統クロス（プレーンテキスト） ───────────────── */
.ped-cross{
  background:#fff;border-top:1px solid #EDEAE2;
  padding:18px 26px 22px;
}
.ped-cross-head{
  font-family:var(--serif-jp);font-size:14px;font-weight:700;
  letter-spacing:.12em;color:var(--ink);margin-bottom:10px;
}
.ped-cross-list{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:column;gap:5px;
}
.ped-cross-item{
  font-family:var(--sans-jp);font-size:12.5px;color:var(--ink);
  letter-spacing:.03em;line-height:1.7;
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;
}
.ped-cross-item .cx-name{font-weight:700;min-width:150px;color:var(--ped-x);}
.ped-cross-item .cx-pat{font-weight:400;letter-spacing:.04em;}
.ped-cross-item .cx-pct{color:var(--ink-2);font-weight:400;}
.ped-cross-none{
  font-family:var(--sans-jp);font-size:12.5px;color:var(--ink-2);
  letter-spacing:.04em;padding:2px 0;
}

/* ── ブラックタイプ ──────────────────────────────── */
.ped-bt-wrap{
  background:#fff;border-top:1px solid #EDEAE2;
  padding:18px 26px 24px;
}
.ped-bt-toggle{
  display:inline-flex;align-items:center;gap:11px;
  font-family:var(--serif-jp);font-size:13px;font-weight:700;letter-spacing:.12em;
  color:var(--green);background:#FBF8F2;border:1px solid var(--rule);border-radius:3px;
  padding:12px 22px;cursor:pointer;line-height:1;
  transition:background .2s ease,color .2s ease,border-color .2s ease;
}
.ped-bt-toggle:hover{background:var(--green);color:#fff;border-color:var(--green);}
.ped-bt-toggle .bt-en{
  font-family:var(--display);font-size:10px;letter-spacing:.3em;font-weight:700;
  text-transform:uppercase;opacity:.6;
}
.ped-bt-toggle .ar{display:inline-block;transition:transform .25s ease;font-size:11px;}
.ped-bt-toggle.open .ar{transform:rotate(180deg);}

.ped-bt{margin-top:20px;}
.ped-bt[hidden]{display:none;}
.bt-sec-head{
  font-family:var(--serif-jp);font-size:14px;font-weight:700;letter-spacing:.08em;
  color:var(--ink);padding-bottom:8px;border-bottom:2px solid var(--ped-head);
  margin:22px 0 14px;
}
.bt-sec-head:first-child{margin-top:0;}
.bt-subhead{
  font-family:var(--serif-jp);font-weight:700;color:var(--green);
  font-size:12.5px;letter-spacing:.06em;margin:12px 0 6px;
}
.bt-head{
  font-family:var(--sans-jp);font-size:12.5px;line-height:1.85;
  color:var(--ink);margin:11px 0 3px;letter-spacing:.02em;text-wrap:pretty;
}
.bt-item{
  display:flex;gap:9px;font-family:var(--sans-jp);line-height:1.8;
  color:var(--ink-2);letter-spacing:.02em;text-wrap:pretty;
}
.bt-item.lvl0{margin:5px 0;color:var(--ink);font-size:12.5px;}
.bt-item.lvl1{margin:2px 0 2px 20px;font-size:12px;}
.bt-mk{color:var(--gold);flex:0 0 auto;line-height:1.7;}
.bt-head strong,.bt-item strong{color:var(--ink);font-weight:700;}
.ped-recon{
  font-family:var(--sans-jp);font-size:10.5px;color:var(--ink-2);
  letter-spacing:.04em;margin-top:14px;line-height:1.6;opacity:.85;
}

/* ── レスポンシブ ─────────────────────────────────── */
@media (max-width:768px){
  .ped-overlay{padding:0;align-items:stretch;}
  .ped-modal{
    max-width:100%;width:100%;border-radius:0;margin:0;
    max-height:100vh;height:100vh;height:100dvh;
  }
  .ped-actions{padding:11px 12px;border-radius:0;}
  .ped-scroll{padding:14px;}
  .ped-sheet{border-left:none;border-right:none;}
  .ped-title{font-size:19px;padding:16px 14px;letter-spacing:.08em;}
  .ped-intro{padding:14px 14px 4px;}
  .ped-intro .ped-desc{font-size:12px;line-height:1.85;}
  .ped-gridwrap{
    margin:0 -14px;padding:8px 14px;
    border-top:1px solid #EDEAE2;border-bottom:1px solid #EDEAE2;
  }
  .ped-cross{padding:16px 14px 18px;}
  .ped-bt-wrap{padding:16px 14px 20px;}
  .ped-bt-toggle{width:100%;justify-content:center;}
  .ped-bt-toggle .bt-en{display:none;}
  .ped-foot{padding:10px 14px;}
  .bt-item.lvl1{margin-left:14px;}
}
@media (max-width:430px){
  .ped-grid{min-width:600px;}
  .ped-gen1 .ped-n{font-size:14px;}
  .ped-gen1 .ped-n2,.ped-gen1 .ped-s{font-size:10px;}
  .ped-title{font-size:17px;}
}

body.ped-open{overflow:hidden;}

/* ── 詳細ページボタン ─────────────────────────────── */
.hcard-detail-btn{
  display:flex;align-items:center;justify-content:center;gap:12px;
  background:var(--gold);color:#fff;
  padding:16px;flex:0 0 auto;
  font-family:var(--serif-jp);font-size:13px;font-weight:600;
  letter-spacing:.16em;line-height:1;
  text-decoration:none;
  transition:background .25s ease;
}
.hcard-detail-btn:hover{background:#8a6535;color:#fff;}
.hcard-detail-btn-en{
  font-family:var(--display);font-size:10px;letter-spacing:.34em;
  text-transform:uppercase;font-weight:700;opacity:.8;
}
.hcard-detail-btn-arrow{display:inline-block;transition:transform .28s ease;font-size:11px;}
.hcard-detail-btn:hover .hcard-detail-btn-arrow{transform:translateX(4px);}

/* ── 印刷 / PDF ────────────────────────────────────── */
@media print{
  body.ped-printing{background:#fff !important;}
  body.ped-printing > *:not(.ped-overlay){display:none !important;}
  body.ped-printing .ped-overlay{
    position:static;background:#fff;display:block;padding:0;overflow:visible;
    opacity:1;visibility:visible;backdrop-filter:none;-webkit-backdrop-filter:none;
  }
  body.ped-printing .ped-modal{
    box-shadow:none;max-width:none;width:auto;border-radius:0;margin:0;transform:none;
  }
  body.ped-printing .ped-actions{display:none !important;}
  body.ped-printing .ped-scroll{overflow:visible;padding:0;}
  body.ped-printing .ped-sheet{min-width:0;border:none;}
  @page{size:landscape;margin:10mm;}
}
