/* CTF OLC BO — Black Angel inspired theme
 * Base: deep black-navy with electric cyan accents and subtle glow.
 */
:root {
  /* 背景 */
  --bg: #000814;             /* 漆黒ベース */
  --bg-gradient-end: #001a2e;
  --bg-card: #0A1929;         /* カード */
  --bg-card-hi: #0F2440;      /* カード hover or highlight */

  /* アクセント */
  --cyan: #00D4FF;            /* 電気的シアン（主） */
  --cyan-bright: #5DE8FF;     /* ハイライト */
  --cyan-glow: rgba(0, 212, 255, 0.55);
  --cyan-glow-soft: rgba(0, 212, 255, 0.18);

  /* 補助色 */
  --accent-magenta: #FF2D7B;  /* 強調用 警告系（赤字など）*/
  --accent-gold: #FFD66B;     /* 保険的な金縁 */

  /* テキスト */
  --text: #E6F4FF;
  --text-sub: #6E8AAA;
  --text-dim: #3B556F;

  /* 罫線 */
  --line: rgba(0, 212, 255, 0.14);
  --line-strong: rgba(0, 212, 255, 0.35);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background:
    radial-gradient(ellipse at top, var(--bg-gradient-end) 0%, var(--bg) 60%),
    var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif;
  font-feature-settings: 'tnum' 1;  /* 等幅数字 */
  min-height: 100vh;
}

/* ===== Top bar ===== */
.topbar {
  background: linear-gradient(90deg, rgba(0, 8, 20, 0.95), rgba(10, 25, 41, 0.85));
  padding: 1rem 2rem;
  border-bottom: 1px solid var(--line-strong);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  position: sticky;
  top: 0;
  z-index: 10;
}

.brand {
  margin: 0;
  font-size: 1.15rem;
  letter-spacing: 0.08em;
  font-weight: 600;
  color: var(--cyan);
  text-shadow: 0 0 12px var(--cyan-glow), 0 0 24px var(--cyan-glow-soft);
}

/* ===== Container ===== */
.container {
  padding: 2.5rem 2rem;
  max-width: 1280px;
  margin: 0 auto;
}

.month-title {
  color: var(--cyan-bright);
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  margin-bottom: 2rem;
  text-shadow: 0 0 14px var(--cyan-glow);
}

/* ===== KPI grid ===== */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 1.1rem;
}

.kpi-card {
  background:
    linear-gradient(135deg, var(--bg-card) 0%, var(--bg-card-hi) 100%);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 1.3rem 1.4rem;
  position: relative;
  overflow: hidden;
  transition: border-color 0.2s ease, transform 0.15s ease;
}

.kpi-card::before {
  /* 左上から伸びるシアンの細線（geometricアクセント） */
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 28px;
  height: 1px;
  background: linear-gradient(90deg, var(--cyan), transparent);
}

.kpi-card::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 1px;
  height: 28px;
  background: linear-gradient(180deg, var(--cyan), transparent);
}

.kpi-card:hover {
  border-color: var(--line-strong);
  transform: translateY(-1px);
}

.kpi-card.highlight {
  border-color: var(--cyan);
  box-shadow:
    0 0 0 1px var(--cyan-glow-soft) inset,
    0 0 18px var(--cyan-glow),
    0 0 36px var(--cyan-glow-soft);
}

.kpi-card.highlight::before,
.kpi-card.highlight::after {
  background: var(--cyan);
}

.kpi-label {
  color: var(--text-sub);
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.kpi-value {
  color: var(--cyan-bright);
  font-size: 1.8rem;
  font-weight: 600;
  margin-top: 0.4rem;
  letter-spacing: -0.01em;
  text-shadow: 0 0 8px var(--cyan-glow);
}

.kpi-card.highlight .kpi-value {
  font-size: 2rem;
  text-shadow: 0 0 14px var(--cyan-glow), 0 0 28px var(--cyan-glow-soft);
}

.kpi-sub {
  color: var(--text-sub);
  font-size: 0.78rem;
  margin-top: 0.35rem;
}

/* 赤字（粗利マイナス）時はマゼンタへ */
.kpi-card.highlight.negative {
  border-color: var(--accent-magenta);
  box-shadow:
    0 0 0 1px rgba(255, 45, 123, 0.25) inset,
    0 0 18px rgba(255, 45, 123, 0.55),
    0 0 36px rgba(255, 45, 123, 0.18);
}

.kpi-card.highlight.negative .kpi-value {
  color: var(--accent-magenta);
  text-shadow: 0 0 14px rgba(255, 45, 123, 0.55);
}

/* ===== 月切替ナビ ===== */
.month-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.8rem;
  gap: 1rem;
}
.month-nav .month-title { margin: 0; }
.nav-btn {
  color: var(--text-sub);
  text-decoration: none;
  padding: 0.55rem 1rem;
  border: 1px solid var(--line);
  border-radius: 6px;
  font-size: 0.85rem;
  letter-spacing: 0.04em;
  transition: all 0.15s ease;
  white-space: nowrap;
}
.nav-btn:hover {
  border-color: var(--cyan);
  color: var(--cyan);
  text-shadow: 0 0 8px var(--cyan-glow);
}

/* ===== Panel grid（2カラム） ===== */
.panel-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.1rem;
  margin-top: 1.5rem;
}
@media (max-width: 900px) {
  .panel-grid { grid-template-columns: 1fr; }
}
.panel {
  background: linear-gradient(135deg, var(--bg-card) 0%, var(--bg-card-hi) 100%);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 1.3rem 1.4rem;
  margin-top: 1.5rem;
  position: relative;
  overflow: hidden;
}
.panel-grid > .panel { margin-top: 0; }
.panel::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 28px; height: 1px;
  background: linear-gradient(90deg, var(--cyan), transparent);
}
.panel::after {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 1px; height: 28px;
  background: linear-gradient(180deg, var(--cyan), transparent);
}
.panel-title {
  margin: 0 0 1rem;
  color: var(--cyan);
  font-size: 0.92rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-shadow: 0 0 8px var(--cyan-glow);
}

/* ===== テーブル（micro） ===== */
table.micro {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}
table.micro th {
  text-align: left;
  color: var(--text-sub);
  font-weight: 400;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: 0.7rem;
  padding: 0.5rem 0.5rem;
  border-bottom: 1px solid var(--line);
}
table.micro td {
  padding: 0.5rem 0.5rem;
  border-bottom: 1px solid rgba(0, 212, 255, 0.05);
  color: var(--text);
}
table.micro tr:last-child td { border-bottom: none; }
table.micro tr:hover td { background: rgba(0, 212, 255, 0.04); }
table.micro .num { text-align: right; font-feature-settings: 'tnum' 1; }
table.micro .dim { color: var(--text-sub); }
table.micro .ellip {
  max-width: 220px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
table.scroll {
  display: block;
  max-height: 360px;
  overflow-y: auto;
}
table.scroll thead { position: sticky; top: 0; background: var(--bg-card); z-index: 1; }

/* ===== タグ ===== */
.tag {
  display: inline-block;
  padding: 0.15rem 0.5rem;
  font-size: 0.68rem;
  letter-spacing: 0.04em;
  border-radius: 3px;
  border: 1px solid var(--line);
  color: var(--text-sub);
}
.tag-customer_transfer { color: #5DE8FF; border-color: rgba(93,232,255,0.3); }
.tag-provider_payout { color: #FFD66B; border-color: rgba(255,214,107,0.3); }
.tag-legacy_payout { color: #FF2D7B; border-color: rgba(255,45,123,0.3); }
.tag-fee { color: #94A3B8; border-color: rgba(148,163,184,0.3); }
.tag-interest { color: #6E8AAA; border-color: rgba(110,138,170,0.3); }
.tag-other { color: #6E8AAA; }

.tag-src-ecforce { color: #00D4FF; border-color: rgba(0,212,255,0.3); }
.tag-src-paysis { color: #FFD66B; border-color: rgba(255,214,107,0.3); }
.tag-src-atone-direct { color: #34D399; border-color: rgba(52,211,153,0.3); }
.tag-src-bank { color: #5DE8FF; border-color: rgba(93,232,255,0.3); }

.tag-line-drug { color: #5DE8FF; border-color: rgba(93,232,255,0.3); }
.tag-line-handling { color: #FFD66B; border-color: rgba(255,214,107,0.3); }
.tag-line-shipping { color: #94A3B8; }
.tag-line-exception { color: #FF2D7B; border-color: rgba(255,45,123,0.3); }
.tag-line-consumable { color: #6E8AAA; }

/* ===== 入出金行の色付け ===== */
tr.cls-legacy_payout { background: rgba(255, 45, 123, 0.04); }
tr.cls-provider_payout { background: rgba(255, 214, 107, 0.04); }
tr.cls-customer_transfer { background: rgba(93, 232, 255, 0.03); }

/* ===== ドット凡例 ===== */
.dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  margin-right: 0.5rem;
  vertical-align: baseline;
}
.dot-1 { background: #00D4FF; }
.dot-2 { background: #5DE8FF; }
.dot-3 { background: #FFD66B; }
.dot-4 { background: #FF2D7B; }
.dot-5 { background: #34D399; }

/* ===== 薬局請求書ブロック ===== */
.ph-inv {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  padding-bottom: 0.5rem;
}
.ph-row {
  display: flex;
  justify-content: space-between;
  font-size: 0.85rem;
}
.ph-row span { color: var(--text-sub); }
.ph-row strong { color: var(--text); font-weight: 500; }
.ph-row.hi strong {
  color: var(--cyan-bright);
  font-size: 1.1rem;
  text-shadow: 0 0 8px var(--cyan-glow);
}

.empty {
  color: var(--text-sub);
  font-style: italic;
  text-align: center;
  padding: 1rem 0;
}

/* ===== Sub nav & alert panels ===== */
.sub-nav {
  margin: 0 0 1.2rem;
}
.nav-btn.primary {
  border-color: var(--cyan);
  color: var(--cyan-bright);
  text-shadow: 0 0 8px var(--cyan-glow);
}
.nav-btn.primary:hover {
  background: rgba(0, 212, 255, 0.08);
}

.panel.alert {
  border-color: rgba(255, 45, 123, 0.4);
}
.panel.alert .panel-title.warn {
  color: var(--accent-magenta);
  text-shadow: 0 0 8px rgba(255, 45, 123, 0.55);
}
.panel.alert::before, .panel.alert::after {
  background: linear-gradient(90deg, var(--accent-magenta), transparent);
}

.panel.info {
  border-color: rgba(255, 214, 107, 0.3);
}
.panel.info .panel-title {
  color: var(--accent-gold);
  text-shadow: 0 0 8px rgba(255, 214, 107, 0.4);
}
.panel.info::before, .panel.info::after {
  background: linear-gradient(90deg, var(--accent-gold), transparent);
}

/* 差分セル */
.diff.plus { color: var(--accent-gold); }
.diff.minus { color: var(--accent-magenta); }

/* マッチ品質に応じた行強調 */
table.micro tr.ok td { opacity: 0.75; }
table.micro tr.warn td { background: rgba(255, 45, 123, 0.06); }

/* ===== Scrollbar ===== */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb {
  background: var(--line-strong);
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover { background: var(--cyan); }
