
* { box-sizing: border-box; }
body {
  margin: 0; font-family: 'Noto Sans JP', -apple-system, sans-serif;
  background: #f5efe6; color: #2a2018;
}
.wrap { max-width: 1100px; margin: 0 auto; padding: 18px 14px 60px; }
header {
  background: linear-gradient(135deg, #2a3a55, #44607f);
  color: #fff; border-radius: 12px;
  padding: 18px 22px; margin-bottom: 14px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.15);
}
header h1 { margin: 0; font-size: 22px; }
header .updated { font-size: 12px; opacity: 0.8; margin-top: 4px; }
.card {
  background: #fff; border-radius: 12px;
  padding: 18px 20px; margin-bottom: 14px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.06);
}
.card h2 { margin: 0 0 12px; font-size: 16px; color: #2a3a55; }
.card.warn { background: #fff7e6; border-left: 4px solid #d97a1a; }
.kpi-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
}
.kpi-cell { padding: 8px 4px; }
.kpi-cell .label { font-size: 11px; color: #6b5b48; }
.kpi-cell .big { font-size: 26px; font-weight: 800; margin-top: 2px; }
.kpi-cell .num { font-size: 17px; font-weight: 700; margin-top: 2px; }
.pos { color: #1f8a5b; }
.neg { color: #c8423b; }
.pj-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
}
.pj-card {
  background: #faf6ee; border-radius: 8px; padding: 12px 14px;
  border: 1px solid #e8dfca;
}
.pj-card h3 { margin: 0 0 6px; font-size: 14px; color: #2a3a55; }
.pj-pnl { font-size: 22px; font-weight: 800; }
.pj-roi { font-size: 13px; font-weight: 700; }
.pj-meta { font-size: 11px; color: #6b5b48; margin-top: 6px; line-height: 1.5; }
.dim { color: #8a7a64; }
table { width: 100%; border-collapse: collapse; font-size: 13px; }
th, td { padding: 8px 6px; border-bottom: 1px solid #ece4d2; vertical-align: middle; }
th { text-align: left; background: #f7f3ed; font-size: 12px; color: #6b5b48; }
td.num { text-align: right; font-variant-numeric: tabular-nums; }
td.chart { width: 320px; }
.pj-tag {
  display: inline-block; background: #2a3a55; color: #fff;
  padding: 2px 7px; border-radius: 99px; font-size: 11px; font-weight: 700;
}
.hint { font-size: 11px; color: #8a7a64; margin: 8px 0 0; }
.reports { margin: 0; padding: 0 0 0 18px; }
.reports li { margin-bottom: 6px; font-size: 14px; }
.reports a { color: #2a3a55; text-decoration: none; font-weight: 600; }
.reports a:hover { text-decoration: underline; }
footer { text-align: center; font-size: 11px; color: #8a7a64; margin-top: 24px; }
.card.forward {
  border-left: 4px solid #2a3a55;
  background: linear-gradient(180deg, #fff 0%, #f3f6fb 100%);
}
.card.forward h2 { color: #2a3a55; }
.card.forward h3.sub {
  font-size: 13px; color: #44607f; margin: 18px 0 6px;
  padding-bottom: 4px; border-bottom: 1px dashed #c8d1e0;
}
.card.forward .kpi-grid { margin-bottom: 8px; }
tr.unsettled td { background: #fff8d6; }
.badge {
  display: inline-block; background: #d97a1a; color: #fff;
  padding: 1px 7px; border-radius: 99px; font-size: 11px; font-weight: 700;
}
@media (max-width: 700px) {
  td.chart { display: none; }
}
