:root{
  --bg:#f3f5fb; --paper:#ffffff; --ink:#16203a; --ink2:#33405e; --muted:#5f6b86; --soft:#8a95b2;
  --line:#e4e9f5; --line2:#d3dcf0; --accent:#1b2a78; --accent2:#2746c9; --warn:#b9760a; --red:#e11d48;
  --pill:#eef2fd; --card2:#f4f7fe;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:"Helvetica Neue",Helvetica,Arial,"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic UI",sans-serif;
  line-height:1.8;-webkit-font-smoothing:antialiased;font-feature-settings:"palt" 1}
a{color:var(--accent2)}
img{max-width:100%}
/* topbar */
.topbar{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.86);backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--line)}
.tinner{max-width:1040px;margin:0 auto;display:flex;align-items:center;gap:12px;padding:9px 18px}
.brand{display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--accent);font-weight:800;font-size:14px;letter-spacing:.01em;min-width:0}
.brand img{border-radius:6px;flex:0 0 auto}
.brand span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tback{margin-left:auto;font-size:13px;text-decoration:none;color:var(--muted);white-space:nowrap}
.tback:hover{color:var(--accent2)}
/* article shell */
.post{max-width:720px;margin:0 auto;padding:18px 20px 70px}
.crumb{font-size:12px;color:var(--soft);margin:6px 0 18px;display:flex;flex-wrap:wrap;align-items:center;gap:2px}
.crumb a{color:var(--muted);text-decoration:none}.crumb a:hover{color:var(--accent2)}
.crumb i{font-style:normal;margin:0 7px;color:var(--line2)}
.kicker{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:800;letter-spacing:.09em;text-transform:uppercase;color:var(--accent2);margin:0 0 10px}
.kicker .flag{height:15px}
.headline{font-size:33px;line-height:1.28;font-weight:900;letter-spacing:.01em;margin:0 0 14px;color:var(--ink)}
.headline em{font-style:normal;color:var(--soft);font-weight:700;font-size:.7em;margin:0 4px;vertical-align:.05em}
.headline .flag{height:24px;border-radius:3px;vertical-align:-3px;box-shadow:0 0 0 .5px rgba(0,0,0,.12)}
.headline .mpre{display:inline-block;color:var(--accent2);font-size:.62em;font-weight:800;letter-spacing:.04em;margin-right:6px}
.dek{font-size:18px;line-height:1.75;color:var(--ink2);margin:0 0 18px;font-weight:500}
.byline{display:flex;flex-wrap:wrap;gap:8px 14px;align-items:center;font-size:13px;color:var(--muted);padding:13px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:0 0 22px}
.byline .b{display:inline-flex;align-items:center;gap:5px}
.byline .lg{font-weight:800;color:var(--accent)}
/* body prose */
.post-body{font-size:16.5px;line-height:1.95}
.post-body p{margin:0 0 18px}
.post-body h2{font-size:21px;font-weight:900;letter-spacing:.01em;margin:34px 0 12px;padding-top:6px}
.post-body h2.lined{border-top:2px solid var(--ink);padding-top:14px}
.warn-strip{display:flex;gap:10px;align-items:flex-start;background:#fff8ec;border:1px solid #f0dcb4;border-left:3px solid var(--warn);border-radius:10px;padding:11px 13px;font-size:13.5px;color:#7a5410;margin:0 0 22px}
/* ===== 試合本文の埋め込みコンポーネント（index と共通の見た目） ===== */
.score{font-size:26px;font-weight:900;margin:6px 0 4px;letter-spacing:.02em}
.score .n{color:var(--accent)}
ul.facts{margin:10px 0 18px;padding-left:20px;font-size:15.5px;line-height:1.9}
ul.facts li{margin:5px 0}
.sources{display:grid;gap:14px;margin:14px 0}
.source{border:1px solid var(--line2);border-radius:14px;background:var(--paper);overflow:hidden;box-shadow:0 2px 10px rgba(20,30,90,.05)}
.source:first-child{box-shadow:0 8px 26px rgba(20,30,90,.12)}
.source-head{display:flex;align-items:center;gap:9px;padding:11px 14px;font-size:13px;flex-wrap:wrap}
.source-head .name{font-weight:800}
.source-head .geo{color:var(--muted)}
.tag{font-size:11px;font-weight:800;padding:3px 9px;border-radius:999px;white-space:nowrap;border:1px solid transparent}
.tag.embed,.tag.clean{background:rgba(37,99,235,.13);color:var(--accent);border-color:rgba(37,99,235,.34)}
.tag.link{background:rgba(59,130,246,.12);color:#1d4ed8;border-color:rgba(59,130,246,.34)}
.tag.blocked,.tag.spoiler{background:rgba(244,183,64,.14);color:var(--warn);border-color:rgba(244,183,64,.4)}
.dualnote{font-size:13px;color:var(--accent);margin:4px 0 10px;font-weight:700}
.embedwrap{position:relative;width:100%;aspect-ratio:16/9;background:#000;border-top:1px solid var(--line)}
.embedwrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
a.golink{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit;padding:14px;border-top:1px solid var(--line)}
a.golink:hover{background:var(--card2)}
a.golink .play{flex:0 0 auto;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:var(--red);color:#fff;font-size:15px}
a.golink .play.fifa{background:#326efd}a.golink .play.dazn{background:#f8f400;color:#111}
a.golink .lbl{font-size:14px}a.golink .lbl small{display:block;color:var(--muted);font-size:12px}
a.golink .go{margin-left:auto;color:var(--accent2);font-size:12.5px;white-space:nowrap}
.src{color:var(--muted);font-size:12.5px;margin-top:14px}.src a{color:var(--muted)}
.lineup{margin-top:14px;padding:12px 14px;background:var(--card2);border:1px solid var(--line);border-radius:12px;font-size:13.5px;line-height:2;color:var(--ink)}
.lineup .src2{color:var(--muted);font-size:11px;margin-left:6px}
/* fact card */
.factcard{background:var(--card2);border:1px solid var(--line2);border-radius:14px;padding:6px 18px;margin:24px 0}
.factcard table{width:100%;border-collapse:collapse;font-size:14.5px}
.factcard th{text-align:left;color:var(--muted);font-weight:700;white-space:nowrap;vertical-align:top;padding:10px 14px 10px 0;width:1%}
.factcard td{padding:10px 0;vertical-align:top}
.factcard tr+tr th,.factcard tr+tr td{border-top:1px solid var(--line)}
/* related cards */
.mcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:13px;margin:14px 0 6px}
.mcard{display:flex;flex-direction:column;text-decoration:none;color:inherit;background:var(--paper);border:1px solid var(--line2);border-radius:13px;overflow:hidden;box-shadow:0 2px 9px rgba(20,30,90,.06);transition:transform .09s,box-shadow .15s}
.mcard:hover{transform:translateY(-2px);box-shadow:0 9px 22px rgba(20,30,90,.15)}
.mthumb{position:relative;aspect-ratio:16/9;background:#0b1430;display:block}
.mthumb img{width:100%;height:100%;object-fit:cover;display:block}
.mplay{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:38px;height:38px;border-radius:50%;background:rgba(225,29,72,.92);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;box-shadow:0 3px 12px rgba(0,0,0,.34)}
.mttl{padding:10px 12px 4px;font-size:13px;font-weight:700;line-height:1.46}
.mttl .flag{height:13px;border-radius:2px;vertical-align:-2px}
.mttl em{font-style:normal;color:var(--soft);font-size:.85em;margin:0 2px}
.mttl .mpre{display:block;color:var(--accent2);font-size:11px;font-weight:800;margin-bottom:1px}
.msub{padding:0 12px 11px;font-size:11.5px;color:var(--muted)}
.chips{display:flex;flex-wrap:wrap;gap:7px;margin:10px 0 6px}
.chips a{font-size:13px;text-decoration:none;padding:6px 13px;border-radius:999px;border:1px solid var(--line2);background:var(--paper);color:var(--ink)}
.chips a:hover{border-color:var(--accent);color:var(--accent)}
.chips a .flag{height:12px;vertical-align:-1px;margin-right:4px}
/* entity hero */
.ehero{position:relative;border-radius:18px;overflow:hidden;margin:0 0 22px;color:#fff;background:linear-gradient(120deg,#0c1657,#1b2a78 58%,#26368f);box-shadow:0 10px 30px rgba(16,26,86,.24)}
.ehero .ei{display:flex;align-items:center;gap:18px;padding:26px 24px}
.ehero .crest{flex:0 0 auto;width:74px;height:74px;border-radius:16px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);display:flex;align-items:center;justify-content:center;font-size:34px;overflow:hidden}
.ehero .crest img{width:60px;height:auto;border-radius:5px;box-shadow:0 1px 6px rgba(0,0,0,.4)}
.ehero h1{font-size:30px;font-weight:900;letter-spacing:.01em;margin:0 0 4px;line-height:1.2}
.ehero .esub{color:#cdd6f6;font-size:13.5px;font-weight:600}
.post-foot{margin-top:40px;padding-top:20px;border-top:1px solid var(--line);color:var(--muted);font-size:13.5px}
.post-foot p{margin:7px 0}.post-foot a{color:var(--accent2);text-decoration:none}
.post-foot .cc{color:var(--soft);font-size:12.5px;margin-top:14px}
@media(max-width:560px){
  .headline{font-size:27px}.dek{font-size:16.5px}.post{padding:14px 16px 60px}
  .ehero h1{font-size:24px}.ehero .ei{padding:20px 18px;gap:14px}.ehero .crest{width:60px;height:60px}.ehero .crest img{width:48px}
}
/* ページ表示時のフェードイン（カルーセル等からの切替を滑らかに） */
@keyframes pageIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.post{animation:pageIn .42s cubic-bezier(.2,.7,.2,1) both}
@media(prefers-reduced-motion:reduce){.post{animation:none}}
/* 広告枠（レスポンシブ） */
.ad{margin:28px auto 6px;max-width:728px;text-align:center;min-height:100px}
.ad .adlabel{display:block;font-size:10px;letter-spacing:.08em;color:var(--muted);margin-bottom:4px}
.ad ins{display:block}