/* HOMES.mil ダッシュボード — カスタムスタイル (Pico CSS 上の最小限の拡張) */

/* タブナビゲーション */
.tabs ul {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0 0 1.5rem 0;
  border-bottom: 2px solid var(--pico-muted-border-color);
  gap: 0;
}

.tabs li {
  margin: 0;
  padding: 0;
}

.tabs li a {
  display: block;
  padding: 0.6rem 1.2rem;
  text-decoration: none;
  color: var(--pico-muted-color);
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  font-weight: 500;
}

.tabs li.active a {
  color: var(--pico-primary);
  border-bottom-color: var(--pico-primary);
}

.tabs li a:hover {
  color: var(--pico-primary);
}

/* サマリーカード */
.summary-cards article {
  text-align: center;
  padding: 1rem;
  margin-bottom: 0;
}

.summary-label {
  margin-bottom: 0.2rem;
  font-size: 0.85rem;
  color: var(--pico-muted-color);
}

.summary-value {
  margin-bottom: 0;
  font-size: 1.4rem;
  font-weight: 700;
}

/* フィルター */
.filters {
  margin-bottom: 1.5rem;
}

.filters .grid {
  margin-bottom: 0.5rem;
}

/* テーブル */
.table-wrap {
  overflow-x: auto;
}

.sortable {
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}

.sortable:hover {
  color: var(--pico-primary);
}

td.links {
  white-space: nowrap;
}

td.links a {
  margin-right: 0.5rem;
  font-size: 0.85rem;
}

.result-count {
  font-size: 0.85rem;
  color: var(--pico-muted-color);
  margin-top: 0.5rem;
}

/* バッジ */
.badge {
  display: inline-block;
  padding: 0.15rem 0.5rem;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
}

.badge-house      { background: #dbeafe; color: #1d4ed8; }
.badge-apartment  { background: #fef3c7; color: #92400e; }
.badge-condo      { background: #d1fae5; color: #065f46; }
.badge-townhouse  { background: #ede9fe; color: #5b21b6; }
.badge-unknown    { background: #f3f4f6; color: #6b7280; }
.badge-vacant     { background: #d1fae5; color: #065f46; }
.badge-occupied   { background: #fee2e2; color: #991b1b; }

/* ボタンサイズ */
.btn-sm {
  padding: 0.4rem 0.8rem;
  font-size: 0.85rem;
}

/* 変更履歴カード */
.diff-card {
  margin-bottom: 1rem;
}

.diff-card header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.diff-added   { color: #16a34a; }
.diff-removed { color: #dc2626; }
.diff-change  { color: #d97706; }

.no-change {
  color: var(--pico-muted-color);
  font-style: italic;
}

/* サブタイトル */
.subtitle {
  color: var(--pico-muted-color);
  margin-top: -0.5rem;
}

/* エラー */
.error {
  color: #dc2626;
  font-weight: 600;
}

/* カラム表示設定 */
.column-config {
  margin-bottom: 1rem;
  padding: 0.8rem;
  border: 1px solid var(--pico-muted-border-color);
  border-radius: 8px;
  background: var(--pico-card-background-color);
}

.column-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.chip {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.25rem 0.6rem;
  border-radius: 16px;
  font-size: 0.8rem;
  cursor: pointer;
  border: 1px solid var(--pico-muted-border-color);
  background: var(--pico-card-background-color);
  transition: all 0.15s;
  margin: 0;
  user-select: none;
}

.chip input[type="checkbox"] {
  display: none;
}

.chip-on {
  background: var(--pico-primary-background);
  color: var(--pico-primary-inverse);
  border-color: var(--pico-primary);
}

/* 詳細パネル */
.detail-toggle {
  text-decoration: none;
  font-weight: 600;
}

.detail-panel {
  margin-top: 1rem;
  margin-bottom: 1.5rem;
}

.detail-panel header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.close-btn {
  font-size: 1.5rem;
  text-decoration: none;
  line-height: 1;
}

.detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
}

.detail-dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.2rem 0.8rem;
  font-size: 0.85rem;
  margin: 0;
}

.detail-dl dt {
  font-weight: 600;
  color: var(--pico-muted-color);
  white-space: nowrap;
}

.detail-dl dd {
  margin: 0;
}

.badge-duplex { background: #fce7f3; color: #9d174d; }

/* x-cloak: Alpine.js初期化前の非表示 */
[x-cloak] {
  display: none !important;
}

/* フッター */
footer {
  margin-top: 3rem;
  padding-top: 1rem;
  border-top: 1px solid var(--pico-muted-border-color);
  text-align: center;
  font-size: 0.85rem;
  color: var(--pico-muted-color);
}
