﻿:root{--bg:#0b0c10;--card:#141622;--line:#242844;--text:#e9eefb;--muted:#a9b3cc;--danger:#ff7a7a;}
body{margin:0;font-family:system-ui,-apple-system,"Segoe UI","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;background:radial-gradient(1200px 800px at 20% 10%, #1a1f3a 0%, var(--bg) 55%);color:var(--text);}
.wrap{max-width:980px;margin:0 auto;padding:20px 16px 80px;}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:0 10px 28px rgba(0,0,0,.25);}
h1{margin:0;font-size:20px}
.sub{margin-top:6px;color:var(--muted);font-size:13px;line-height:1.6}
.grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:14px}
@media(min-width:860px){.grid{grid-template-columns:1.12fr .88fr}}
label{display:block;margin-top:14px;font-size:12px;color:var(--muted)}
input{width:100%;padding:12px;margin-top:6px;border-radius:12px;border:1px solid var(--line);background:#0e1020;color:var(--text);outline:none}
.warn{margin-top:6px;font-size:12px;color:var(--danger);display:none;line-height:1.5}
button{margin-top:16px;width:100%;padding:12px;border-radius:14px;border:1px solid var(--line);background:linear-gradient(180deg, rgba(122,162,255,.35), #0e1020);color:var(--text);font-weight:900;cursor:pointer}
.result{margin-top:18px;border-top:1px solid var(--line);padding-top:16px;display:none}
.kpi{display:grid;grid-template-columns:1fr;gap:10px;margin-top:10px}
@media(min-width:520px){.kpi{grid-template-columns:1fr 1fr}}
.box{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:14px;padding:12px}
.t{font-size:12px;color:var(--muted)}
.v{margin-top:4px;font-size:18px;font-weight:900}
.pills{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}
.pill{display:inline-flex;align-items:center;padding:7px 10px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.03);font-size:12px;color:var(--muted)}
hr{border:none;border-top:1px solid var(--line);margin:14px 0}
.reading{white-space:pre-wrap;line-height:1.75;font-size:14px}
.tabs{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.tabbtn{padding:8px 10px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--muted);cursor:pointer;font-size:12px}
.tabbtn.active{border-color:rgba(122,162,255,.6);color:var(--text);background:rgba(122,162,255,.08)}
.tab{display:none;margin-top:10px}
.tab.active{display:block}
.small{font-size:12px;color:var(--muted);line-height:1.6}
.nav{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.nav a{color:var(--text);text-decoration:none;border-bottom:1px solid rgba(233,238,251,.35);font-weight:900}
/* ボタン無効風（disabled属性は使わない） */
.btn-disabled{
  opacity:.45;
  cursor:not-allowed;
  pointer-events:none; /* ←クリック不可の本体 */
}
/* ===== Hub ===== */
.hub{display:grid;grid-template-columns:1fr;gap:12px;margin-top:14px}
@media(min-width:860px){.hub{grid-template-columns:1fr 1fr 1fr}}
.hubCard{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:16px;padding:14px}
.hubTitle{font-size:14px;font-weight:900}
.hubDesc{margin-top:6px;color:var(--muted);font-size:12px;line-height:1.6}
.hubBtn{display:inline-flex;align-items:center;gap:8px;margin-top:10px;padding:9px 11px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text);text-decoration:none;font-weight:900;font-size:12px}
.hubBtn:hover{background:rgba(122,162,255,.10)}
.hubMeta{margin-top:8px;font-size:11px;color:var(--muted)}
.anchor{display:block;height:0;visibility:hidden;scroll-margin-top:16px}
