html {
  touch-action: manipulation;
}

.bfhlvs-root {
  max-width: 960px;
  margin: 0 auto;
  padding: 8px;
  box-sizing: border-box;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 14px;
}

.bfhlvs-wrapper {
  border: 1px solid #ddd;
  border-radius: 6px;
  padding: 8px;
  background: #fafafa;
}

/* ヘッダー（タイトル〜リセットまで） */

.bfhlvs-header {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 6px;
  padding-bottom: 4px;
  background: #fafafa;
}

.bfhlvs-title {
  font-size: 18px;
  font-weight: bold;
  margin: 0 0 4px;
}

.bfhlvs-subtitle {
  font-size: 12px;
  color: #555;
}

.bfhlvs-header-right {
  text-align: right;
  font-size: 12px;
}

.bfhlvs-total-line,
.bfhlvs-max-line,
.bfhlvs-remaining-line {
  margin-bottom: 2px;
}

.bfhlvs-total-value,
.bfhlvs-max-value,
.bfhlvs-remaining-value {
  font-weight: bold;
}

.bfhlvs-max-input {
  width: 80px;
  padding: 2px 4px;
  font-size: 12px;
}

.bfhlvs-remaining-over {
  color: #d00;
}

.bfhlvs-reset-button {
  margin-top: 4px;
  padding: 4px 8px;
  font-size: 12px;
  border-radius: 4px;
  border: 1px solid #888;
  background: #fff;
  cursor: pointer;
}
.bfhlvs-reset-button:hover {
  background: #eee;
}

/* コンテンツ全体 */

.bfhlvs-content {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* 探索基地／修練場／ファクトリーごとのまとまり */

.bfhlvs-group-section {
  border-top: 1px solid #ddd;
  padding-top: 4px;
  margin-top: 4px;
}

.bfhlvs-group-title {
  font-size: 15px;
  font-weight: bold;
  margin: 0;      /* ← これで上下左右すべて 0になる */
  padding: 0;     /* 念のため padding も 0 にしたい場合 */
}

.bfhlvs-card-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 6px;
}

/* カード */

.bfhlvs-card {
  box-sizing: border-box;
  border: 2px solid #ccc;
  border-radius: 6px;
  background: #fff;
  padding: 6px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: box-shadow 0.1s ease, transform 0.05s ease, border-color 0.1s ease, opacity 0.1s ease;
}

.bfhlvs-card:hover {
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
  transform: translateY(-1px);
}

.bfhlvs-card-main {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.bfhlvs-card-title-block {
  display: flex;
  flex-direction: column;
}

.bfhlvs-card-category {
  font-size: 11px;
  color: #666;
}

.bfhlvs-card-name {
  font-size: 14px;
  font-weight: bold;
}

.bfhlvs-card-meta {
  text-align: right;
  font-size: 11px;
}

.bfhlvs-card-state {
  display: block;
}

.bfhlvs-card-volume {
  display: block;
}

.bfhlvs-card-nextcost {
  display: block;
}

.bfhlvs-card-desc {
  font-size: 11px;
  color: #333;
}

/* レベル操作ボタン部分 */

.bfhlvs-card-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 2px;
  font-size: 11px;
}

.bfhlvs-level-buttons {
  display: flex;
  gap: 6px;
}

.bfhlvs-level-button {
  padding: 4px 8px;
  font-size: 11px;
  border-radius: 3px;
  border: 1px solid #888;
  background: #fff;
  cursor: pointer;
}
.bfhlvs-level-button:hover:not(:disabled) {
  background: #eee;
}
.bfhlvs-level-button:disabled {
  opacity: 0.4;
  cursor: default;
}

.bfhlvs-card--off {
  border-color: #ccc;      /* Lv.0: グレー */
}

.bfhlvs-card--mid {
  border-color: #ff9800;   /* Lv.1〜最大-1: 橙 */
}

.bfhlvs-card--max {
  border-color: #d00;      /* 最大レベル: 赤#d00 */
}

.bfhlvs-card--locked {
  opacity: 0.5;
}

/* グループ見出しの余白を完全になくす（テーマ指定を上書き） */
.bfhlvs-root h3.bfhlvs-group-title {
  margin: 0 !important;
  padding: 0 !important;
}