/* components.css — UIコンポーネント */

/* ボタン */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2) var(--space-5);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color 0.15s, color 0.15s, border-color 0.15s;
  text-decoration: none;
  background: var(--color-accent);
  color: var(--color-accent-fg);
}
.btn:hover {
  background: var(--color-accent-hover);
  text-decoration: none;
}
.btn--outline {
  background: transparent;
  border-color: var(--color-accent);
  color: var(--color-accent);
}
.btn--outline:hover {
  background: var(--color-accent);
  color: var(--color-accent-fg);
}
.btn--sm {
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
}

/* ステータスバッジ */
.status {
  display: inline-block;
  padding: 0.15rem 0.6rem;
  border-radius: 100px;
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  border: 1px solid currentColor;
}
.status--published  { color: var(--color-status-published);  background: var(--color-status-published-bg); }
.status--wip        { color: var(--color-status-wip);        background: var(--color-status-wip-bg); }
.status--private    { color: var(--color-status-private);    background: var(--color-status-private-bg); }
.status--other      { color: var(--color-muted);             background: transparent; }

/* バッジ */
.badge {
  display: inline-block;
  padding: 0.15rem 0.6rem;
  border-radius: 100px;
  font-size: var(--text-xs);
  font-weight: var(--font-weight-bold);
}
.badge--featured {
  background: var(--color-featured-bg);
  color: var(--color-featured-fg);
}

/* タグ */
.tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
}
.tag {
  display: inline-block;
  padding: 0.1rem 0.55rem;
  background: var(--color-tag-bg);
  color: var(--color-tag-fg);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-family: var(--font-mono);
}

/* リスト */
.list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.list li::before {
  content: '— ';
  color: var(--color-accent);
  font-weight: var(--font-weight-bold);
}
.list li {
  font-size: var(--text-base);
  color: var(--color-text);
}

/* インプット */
.input {
  display: block;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text);
  font-size: var(--text-sm);
  transition: border-color 0.15s;
  outline: none;
}
.input:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 2px var(--color-accent-ring);
}

/* フィルターボタン */
.filter-btn {
  padding: 0.2rem 0.8rem;
  border-radius: 100px;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
}
.filter-btn:hover,
.filter-btn--active {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-accent-fg);
}

/* プロジェクトカード */
.project-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  transition: box-shadow 0.15s, transform 0.15s;
}
.project-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.project-card--featured {
  border-color: var(--color-accent);
  border-width: 2px;
}
.project-card__header {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.project-card__meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.project-card__title {
  font-size: var(--text-lg);
  line-height: var(--leading-tight);
}
.project-card__title a {
  color: var(--color-heading);
  text-decoration: none;
}
.project-card__title a:hover {
  color: var(--color-accent);
}
.project-card__category {
  font-size: var(--text-xs);
  color: var(--color-muted);
}
.project-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1;
}
.project-card__summary {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
}
.project-card__footer {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

/* スキルカード */
.skill-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
}
.skill-card__title {
  font-size: var(--text-base);
  margin-bottom: var(--space-2);
  color: var(--color-accent);
}
.skill-card__desc {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
}

/* ユーティリティ */
.text-muted {
  color: var(--color-muted);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}
.filter-empty {
  color: var(--color-muted);
  font-size: var(--text-sm);
  padding: var(--space-6) 0;
}

/* hidden by JS filter */
.project-card[hidden] {
  display: none;
}
