/* ===== Layout ===== */
.container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 24px;
}
.site-header {
  padding: 20px 24px;
  background: var(--panel);
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  z-index: 10;
}
.site-header__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.brand {
  font-size: 1.15rem;
  font-weight: 700;
}
.muted { color: var(--muted); }
.layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 416px);
  gap: 24px;
  align-items: start;
}
.layout > * {
  min-width: 0;
}
#dashboard-content {
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
  max-width: 100%;
}
#dashboard-content .stack,
#dashboard-content .panel {
  min-width: 0;
  max-width: 100%;
}
#form-panel {
  grid-column: 2;
  grid-row: 1;
  min-width: 0;
  width: 100%;
  max-width: 416px;
  justify-self: stretch;
  align-self: start;
  /* v1.18.6: スクロール時に右側空白が出ないよう sticky で追従させる。
     dashboard-content が長くなっても form は画面内に残るので
     「取引を追加」までスクロールアップする手間も省ける */
  position: sticky;
  top: 84px;
  max-height: calc(100vh - 100px);
  overflow-y: auto;
}
/* v1.18.6: tablet 横置き (1366-769px) は form-panel を 340px に圧縮し、
   dashboard-content に十分な幅 (取引一覧 6 列) を確保する */
@media (max-width: 1366px) and (min-width: 769px) {
  .layout {
    grid-template-columns: minmax(0, 1fr) minmax(0, 340px);
    gap: 16px;
  }
  #form-panel {
    max-width: 340px;
  }
}

/* ===== Panel ===== */
.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.panel__body { padding: 20px; }

/* ===== Hero summary ===== */
.summary-hero {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 16px;
  margin-bottom: 18px;
}
/* ヒーロー上 + 3 カード下の縦積み (収支折返し問題対策) */
.summary-hero--stacked {
  grid-template-columns: 1fr;
  gap: 12px;
}
/* v1.18.6: tablet 横置き (≤1366px) では 1.4fr:1fr で右側カードが狭く、
   資産合計 ¥1,060,637 のような 7-8 桁の値がカードからはみ出す。
   縦積みにして各カードを全幅にする (.summary-hero--stacked と同等の挙動)。 */
@media (max-width: 1366px) {
  .summary-hero {
    grid-template-columns: 1fr;
  }
}
.hero-card {
  position: relative;
  padding: 22px 24px;
  border-radius: var(--radius);
  background: linear-gradient(135deg, var(--primary-soft), var(--panel) 80%);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  overflow: hidden;
}
.hero-card--compact {
  padding: 14px 20px;
}
.hero-card--compact .hero-card__value {
  font-size: var(--fs-hero);
  letter-spacing: -0.01em;
}
.hero-card--compact .hero-card__caption {
  margin-top: 6px;
}
.hero-card[data-tone="positive"] {
  background: linear-gradient(135deg, var(--success-soft), var(--panel) 80%);
}
.hero-card[data-tone="negative"] {
  background: linear-gradient(135deg, var(--danger-soft), var(--panel) 80%);
}
.hero-card__label {
  color: var(--muted-strong);
  font-size: var(--fs-small);
  font-weight: 600;
  margin-bottom: 6px;
}
.hero-card__value {
  font-size: var(--fs-display);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.1;
  font-variant-numeric: tabular-nums;
  overflow-wrap: anywhere;
}
.hero-card[data-tone="positive"] .hero-card__value { color: var(--success); }
.hero-card[data-tone="negative"] .hero-card__value { color: var(--danger); }
.hero-card__caption {
  margin-top: 10px;
  color: var(--muted-strong);
  font-size: var(--fs-small);
}
.hero-card__trend {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 8px;
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.04);
  font-size: var(--fs-meta);
  font-weight: 700;
}
.hero-card__trend[data-tone="positive"] {
  background: var(--success-soft);
  color: var(--success);
}
.hero-card__trend[data-tone="negative"] {
  background: var(--danger-soft);
  color: var(--danger);
}

/* ===== Cards (secondary metrics) ===== */
.cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}
.cards--3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 640px) {
  .cards--3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .cards--3 .card--net {
    grid-column: span 2;
  }
}
/* v1.18.6: tablet landscape (769-1366px) は form-panel と並ぶため content 領域が狭く、
   3 列だと cards 内の金額 (¥1,234,567 等) が折り返す。
   iPad Pro 12.9" landscape (1366px) もカバーするため上限を 1366px に。
   2 列 + 収支 (net) を span 2 で全幅に */
@media (min-width: 769px) and (max-width: 1366px) {
  .cards--3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .cards--3 .card--net {
    grid-column: span 2;
  }
}
/* セーフティネット: card__value は決して文字の途中で折り返さない。
   font-size は viewport ベースの clamp で自動縮小し、~1200px 以下では小さくなる */
.card__value {
  white-space: nowrap;
}
@media (max-width: 1366px) {
  .card__value {
    font-size: clamp(1.1rem, 2.4vw, 1.5rem);
  }
}
.card--net {
  border-color: var(--line-strong);
  background: var(--panel);
}

/* ===== Expense breakdown 2 列 grid (dashboard 統合パネル) ===== */
.expense-breakdown-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 8px;
}
.expense-breakdown-col {
  min-width: 0;
}
.section-subtitle {
  font-size: var(--fs-small);
  font-weight: 700;
  color: var(--muted-strong);
  letter-spacing: 0.02em;
  margin: 0 0 8px;
}
.empty--sm {
  padding: 12px;
  font-size: var(--fs-small);
}
@media (max-width: 720px) {
  .expense-breakdown-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}
.card {
  padding: 14px 16px;
  border-radius: var(--radius-sm);
  background: var(--panel-soft);
  border: 1px solid var(--line);
}
.card--income .card__value { color: var(--success); }
.card--expense .card__value { color: var(--danger); }
.card--net-positive .card__value { color: var(--success); }
.card--net-negative .card__value { color: var(--danger); }
.card__label {
  color: var(--muted-strong);
  font-size: var(--fs-meta);
  font-weight: 600;
  margin-bottom: 4px;
  letter-spacing: 0.02em;
  text-transform: none;
}
.card__value {
  font-size: var(--fs-hero);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  overflow-wrap: anywhere;
}

