/* いまいくら？ — v4 poster design (mock/v4-poster.html から外出し・全ページ共有) */
:root{
  --paper:#f2efe7;
  --ink:#111111;
  --sub:#56524a;
  --faint:#a39e92;
  --rule:#d9d4c8;
  --orange:#ff4d00;
  --blue:#0a36c4;
  --green:#0c7a3e;
  --anton:'Anton', sans-serif;
  --goth:'Zen Kaku Gothic New', sans-serif;
  --mono:'IBM Plex Mono', monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
::selection{background:var(--orange);color:#fff}
body{
  background:var(--paper);color:var(--ink);
  font-family:var(--goth);font-weight:500;font-size:14px;line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}

/* ============ top bar ============ */
.bar{background:var(--ink);color:var(--paper)}
.bar-in{display:flex;justify-content:space-between;align-items:center;height:48px;font-size:12px;gap:14px}
.brand{display:flex;align-items:baseline;gap:10px}
.brand a{color:inherit;text-decoration:none}
.brand .nm{font-weight:900;font-size:16px;letter-spacing:.04em}
.brand .nm em{font-style:normal;color:var(--orange)}
.brand .en{font-family:var(--mono);font-size:10px;color:#8d897f;letter-spacing:.15em}
.bar nav{display:flex;gap:14px;font-weight:700;margin-left:auto}
.bar nav a{color:#b6b1a4;text-decoration:none}
.bar nav a:hover{color:var(--orange)}
.bar .upd{font-family:var(--mono);color:#b6b1a4;white-space:nowrap}
.bar .upd b{color:var(--orange);font-weight:700}
@media(max-width:680px){.brand .en{display:none}.bar .upd{display:none}.bar-in{flex-wrap:wrap;height:auto;padding:7px 0;row-gap:6px}.brand{width:100%}.bar nav{margin-left:0;width:100%;gap:18px;font-size:13px}}

/* ============ ticker ============ */
.ticker{
  background:var(--orange);color:var(--ink);overflow:hidden;white-space:nowrap;
  border-bottom:3px solid var(--ink);
}
.ticker-track{
  display:inline-block;padding:7px 0;
  font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.02em;
  animation:tick 38s linear infinite;
}
.ticker-track span{margin:0 26px}
.ticker-track .dn{color:#fff;background:var(--ink);padding:1px 7px}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker:hover .ticker-track{animation-play-state:paused}

/* ============ breadcrumbs ============ */
.crumbs{font-family:var(--mono);font-size:12px;color:var(--sub);padding:20px 0 0;display:flex;gap:10px;flex-wrap:wrap;list-style:none}
.crumbs a{color:var(--sub);text-decoration:none;border-bottom:1px solid var(--rule)}
.crumbs a:hover{color:var(--orange);border-color:var(--orange)}
.crumbs li+li::before{content:"/";margin-right:10px;color:var(--faint)}

/* 個別ページ ヘッダー画像（出典: Steam。460x215 をアスペクト維持） */
.ghead{display:block;width:100%;max-width:460px;height:auto;aspect-ratio:460/215;margin:18px 0 2px;border:2px solid var(--ink);background:var(--rule)}

/* 固定ページ（プライバシー/運営者/問い合わせ） */
.doc h2{font-family:var(--goth);font-weight:900;font-size:18px;margin:28px 0 8px;padding-top:14px;border-top:1px solid var(--rule)}
.doc p{margin:0 0 12px}
.doc a{color:var(--blue);border-bottom:1px solid var(--rule)}
.doc a:hover{color:var(--orange);border-color:var(--orange)}
.doc code{font-family:var(--mono);font-size:.92em;background:var(--rule);padding:1px 5px;border-radius:3px}
.docmeta{font-family:var(--mono);font-size:12px;color:var(--faint);margin-top:28px}

/* 広告スロット（AD_HTML 未設定なら出力されない） */
.ad-slot{margin:26px 0;padding:14px;border:1px dashed var(--rule);text-align:center;overflow:hidden}
.ad-label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--faint);margin-bottom:8px;text-transform:uppercase}
.ad-slot a{display:inline-block;line-height:0}
.ad-slot img{max-width:100%;height:auto}

/* 個別ページ「このゲームを遊ぶには」導線（/start/ へ） */
.playbox{margin:22px 0;padding:16px 18px;background:#fff;border:2px solid var(--ink)}
.playbox h3{margin:0 0 6px;font-family:var(--goth);font-weight:900;font-size:16px}
.playbox p{margin:0;font-size:13.5px}
.playbox a{color:var(--blue);border-bottom:1px solid var(--rule)}
.playbox a:hover{color:var(--orange);border-color:var(--orange)}

/* 候補検索バー（全ページ・トップバー直下） */
.searchbar{background:var(--ink);padding:6px 0 16px}
.searchbar .wrap{position:relative}
#q{width:100%;padding:14px 16px 14px 48px;font-family:var(--goth);font-weight:700;font-size:16px;color:var(--ink);background:var(--paper) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23111111' stroke-width='2.5' stroke-linecap='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cline x1='21' y1='21' x2='16.5' y2='16.5'/%3E%3C/svg%3E") no-repeat 16px center;background-size:20px;border:2px solid var(--orange)}
#q::placeholder{color:var(--sub);font-weight:500}
#q:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,77,0,.3)}
.suggest{position:absolute;left:0;right:0;top:100%;margin:0;padding:0;list-style:none;background:#fff;border:2px solid var(--ink);border-top:none;z-index:60;max-height:60vh;overflow:auto;box-shadow:0 8px 24px rgba(0,0,0,.25)}
.suggest li a{display:block;padding:13px 16px;color:var(--ink);text-decoration:none;font-weight:700;font-size:15px;border-bottom:1px solid var(--rule)}
.suggest li.on a,.suggest li a:hover{background:var(--orange);color:#fff}
@media(max-width:680px){.searchbar{padding:8px 0 18px}#q{padding-top:15px;padding-bottom:15px}}

/* 記事末尾の回遊CTA */
.cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.cta .storebtn{margin:0}
.doc ul{margin:0 0 14px;padding-left:1.3em}
.doc li{margin:3px 0}
.doc h3{font-family:var(--goth);font-weight:900;font-size:15px;margin:18px 0 6px;color:var(--sub)}
.contactmail{font-family:var(--mono);font-size:20px;font-weight:700;color:var(--orange);margin:6px 0}

/* ============ hero ============ */
.hero{padding:54px 0 0;position:relative}
.hero .date{font-family:var(--mono);font-size:13px;color:var(--sub);margin-bottom:14px;display:flex;gap:14px;align-items:center}
.hero .date::before{content:"";width:46px;height:3px;background:var(--ink);display:inline-block}
h1{
  font-weight:900;letter-spacing:.01em;
  font-size:clamp(38px,7.4vw,86px);line-height:1.06;
  text-transform:uppercase;
}
h1 .q{color:var(--orange)}
h1 .latin{font-family:var(--anton);font-weight:400;letter-spacing:.02em}
.hero .stand{margin-top:20px;max-width:640px;font-size:15px;color:var(--sub);line-height:2}
.hero .stand b{color:var(--ink);background:linear-gradient(transparent 62%, rgba(255,77,0,.34) 62%)}

/* big stat band */
.band{
  margin-top:42px;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);
  display:grid;grid-template-columns:repeat(4,1fr);
}
.band .b{
  padding:20px 18px 16px;border-right:1px solid var(--ink);position:relative;
}
.band .b:last-child{border-right:none}
.band .v{font-family:var(--anton);font-size:clamp(38px,5.5vw,64px);line-height:.95;letter-spacing:.01em}
.band .v sup{font-size:.38em;vertical-align:super;letter-spacing:0}
.band .b:nth-child(2) .v,.band .b:nth-child(3) .v{color:var(--orange)}
.band .b:nth-child(4) .v{color:var(--blue)}
.band .k{font-size:11.5px;font-weight:700;letter-spacing:.18em;color:var(--sub);margin-top:8px}
@media(max-width:680px){
  .band{grid-template-columns:1fr 1fr}
  .band .b:nth-child(2){border-right:none}
  .band .b:nth-child(-n+2){border-bottom:1px solid var(--ink)}
}

/* ============ controls ============ */
.controls{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin:36px 0 0;padding-bottom:14px}
.fbtn{
  font-family:var(--goth);font-weight:900;font-size:13px;letter-spacing:.04em;
  background:transparent;color:var(--ink);border:2px solid var(--ink);
  padding:8px 18px;cursor:pointer;border-radius:99px;transition:.13s;
}
.fbtn:hover{background:var(--ink);color:var(--paper)}
.fbtn.on{background:var(--orange);border-color:var(--orange);color:#fff}
.ctrl-spacer{flex:1}
.sortwrap{display:flex;align-items:center;gap:9px;font-size:12px;font-weight:700;color:var(--sub)}
select{
  font-family:var(--goth);font-weight:900;font-size:13px;color:var(--paper);
  background:var(--ink);border:2px solid var(--ink);padding:9px 14px;cursor:pointer;border-radius:99px;
}

/* ============ table ============ */
.tablewrap{overflow-x:auto;border-top:3px solid var(--ink)}
table{width:100%;border-collapse:collapse;min-width:860px}
thead th{
  text-align:left;font-size:11px;font-weight:900;letter-spacing:.16em;
  color:var(--sub);padding:12px 12px;border-bottom:2px solid var(--ink);
  white-space:nowrap;user-select:none;cursor:pointer;
}
thead th:hover{color:var(--ink)}
thead th.nosort{cursor:default}
thead th .arr{color:var(--orange);margin-left:4px;font-size:10px}
th.num, td.num{text-align:right}
tbody td{padding:13px 12px;border-bottom:1px solid var(--rule);vertical-align:middle;transition:.1s}
tbody tr{cursor:default}
tbody tr:hover td{background:var(--ink);color:var(--paper);border-bottom-color:var(--ink)}
tbody tr:hover .gen{color:#9a958a}
tbody tr:hover .orig{color:#8d897f}
tbody tr:hover .appid{color:#8d897f}
tbody tr:hover .rank{color:var(--orange)}
tbody tr:hover .pbar i{background:var(--orange)}

td.rank{font-family:var(--anton);font-size:22px;color:var(--faint);width:54px;letter-spacing:.02em}
td.title{min-width:260px}
td.title a{color:inherit;text-decoration:none;display:flex;align-items:center;gap:11px}
td.title .thumb{width:100px;height:38px;object-fit:cover;border:1px solid var(--rule);flex:0 0 auto}
td.title .tx{min-width:0}
@media(max-width:520px){td.title{min-width:200px}td.title .thumb{width:78px;height:30px}td.title a{gap:8px}td.title .nm{font-size:13.5px}}
td.title .nm{font-weight:900;font-size:15.5px;letter-spacing:.01em}
td.title a:hover .nm{color:var(--orange)}
td.title .gen{display:block;font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--faint);margin-top:1px}

.orig{font-family:var(--mono);color:var(--faint);text-decoration:line-through;font-size:12px;margin-right:9px}
.now{font-family:var(--mono);font-weight:700;font-size:16px}
.now.sale{color:var(--orange)}
tbody tr:hover .now.sale{color:var(--orange)}
.f2p{font-weight:900;font-size:12.5px;color:var(--green);border:2px solid currentColor;border-radius:99px;padding:1px 10px;display:inline-block}
tbody tr:hover .f2p{color:#5ee08a}

td.disc-cell{width:110px}
.disc{font-family:var(--anton);font-size:26px;color:var(--orange);letter-spacing:.01em}
.disc.none{font-family:var(--mono);font-size:13px;color:var(--faint)}

td.players{width:210px}
.pwrap{display:flex;align-items:center;gap:10px;justify-content:flex-end}
.pbar{width:80px;height:10px;flex-shrink:0;position:relative;background:transparent}
.pbar i{position:absolute;right:0;top:0;height:100%;background:var(--blue);display:block;transition:.1s}
.pnum{font-family:var(--mono);font-weight:700;font-size:14px;min-width:88px;text-align:right}

td.appid{font-family:var(--mono);font-size:11px;color:var(--faint);text-align:right;width:84px}

.tfoot{font-size:11.5px;color:var(--faint);padding:12px 2px 0;line-height:1.9;font-weight:700}

/* ============ article ============ */
.article{max-width:780px;margin:76px 0 0;position:relative}
.article .secno{
  font-family:var(--anton);font-size:clamp(60px,9vw,110px);line-height:.9;
  color:transparent;-webkit-text-stroke:2px var(--ink);
  position:absolute;right:0;top:-26px;opacity:.25;pointer-events:none;
}
.article h2{font-weight:900;font-size:clamp(21px,3.4vw,30px);line-height:1.5;margin-bottom:20px;letter-spacing:.02em}
.article h2 mark{background:linear-gradient(transparent 60%, rgba(255,77,0,.4) 60%);color:inherit}
.article h3{font-weight:900;font-size:16px;margin:32px 0 8px;display:flex;align-items:center;gap:10px}
.article h3::before{content:"";width:14px;height:14px;background:var(--orange);display:inline-block;flex-shrink:0}
.article p{color:var(--sub);margin-bottom:14px;font-size:14.5px;line-height:2}
.article p b{color:var(--ink)}
.article code{font-family:var(--mono);font-size:.9em;background:#e7e3d6;padding:1px 6px;color:var(--ink)}

.faq{margin-top:20px;border-top:3px solid var(--ink)}
.faq details{border-bottom:1px solid var(--rule)}
.faq summary{
  cursor:pointer;font-weight:900;font-size:14.5px;padding:16px 4px;list-style:none;
  display:flex;align-items:center;gap:14px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .qn{font-family:var(--anton);font-size:19px;color:var(--orange);min-width:30px}
.faq summary::after{content:"＋";margin-left:auto;font-weight:500;color:var(--faint);font-size:18px;transition:.15s}
.faq details[open] summary::after{transform:rotate(45deg);color:var(--orange)}
.faq details p{padding:0 4px 18px 44px;margin:0}

/* ============ app page: 30日履歴 ============ */
.hist{margin-top:18px;border-top:3px solid var(--ink)}
.hist .row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:14px 4px;border-bottom:1px solid var(--rule);font-size:14px;font-weight:700}
.hist .row b{font-family:var(--mono);font-size:16px;color:var(--ink)}
.hist .row b .sale{color:var(--orange)}
.storebtn{
  display:inline-block;margin-top:30px;font-weight:900;font-size:14px;letter-spacing:.04em;
  border:2px solid var(--ink);padding:12px 26px;border-radius:99px;
  color:var(--ink);text-decoration:none;transition:.13s;
}
.storebtn:hover{background:var(--ink);color:var(--paper)}

/* ============ footer ============ */
footer{margin-top:80px;background:var(--ink);color:#b6b1a4;padding:36px 0 60px;font-size:12px;line-height:2}
footer .fbrand{font-weight:900;font-size:20px;color:var(--paper);margin-bottom:10px}
footer .fbrand em{font-style:normal;color:var(--orange)}
footer b{color:var(--orange)}
footer .mono{font-family:var(--mono);font-size:11px}
footer nav{display:flex;gap:18px;flex-wrap:wrap;margin:8px 0 14px;font-weight:700}
footer nav a{color:#b6b1a4;text-decoration:none}
footer nav a:hover{color:var(--orange)}

/* entry animation — once, subtle, fast */
.hero, .band, .controls, .tablewrap{opacity:0;transform:translateY(10px);animation:up .5s cubic-bezier(.2,.7,.3,1) forwards}
.band{animation-delay:.08s}.controls{animation-delay:.14s}.tablewrap{animation-delay:.2s}
@keyframes up{to{opacity:1;transform:none}}
