/**
 * /quizzes/ 問題集一覧 — mockup 準拠スキン (issue #120)。
 *
 * mockup 準拠 / 進捗UI省略・サイドバー無し。
 *  ダッシュボード版モックの「中央カラム」のみを実装する。進捗リング/
 *  レベル/連続日数/今日の学習目標、ログイン出し分け、左サイドバー、
 *  会員ヘッダーは一切描かない (PHP 側でも撤去済)。
 *
 * 全クラスは `.wf-quizzes__*` 接頭辞。
 * 既存 .filter-tab / .filter-tab--active は流用 (再定義しない。anchor 化に
 * 伴う最小補正と active タブ形状の堅牢化フォールバックのみ付与)。
 * カテゴリ色のみインラインで注入 (帯背景/ラベル文字/アイコン円)。
 * それ以外は design-tokens.css のトークンを使う。zone palette は
 * ラッパ <div class="wf-quizzes" data-zone="free"> で適用。
 */

/* ---- 0. wrapper + container --------------------------------------- */
.wf-quizzes {
  background: var(--color-bg);
}
.wf-quizzes__container {
  max-width: 1080px;
  margin: 0 auto;
  padding: var(--space-8) var(--space-5) var(--space-10);
}

/* ---- 1. breadcrumb (mag-breadcrumb 同等の見た目を自前で) ----------- */
.wf-quizzes__breadcrumb {
  margin-bottom: var(--space-5);
  font-size: var(--text-caption);
}
.wf-quizzes__breadcrumb-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  list-style: none;
  margin: 0;
  padding: 0;
  color: var(--color-text-secondary);
}
.wf-quizzes__breadcrumb-item:not(:last-child)::after {
  content: "›";
  margin-left: var(--space-2);
  color: var(--color-text-muted);
}
.wf-quizzes__breadcrumb a {
  color: var(--color-accent);
  text-decoration: none;
}
.wf-quizzes__breadcrumb a:hover {
  text-decoration: underline;
}
.wf-quizzes__breadcrumb a:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* ---- 2. page header ----------------------------------------------- */
.wf-quizzes__header {
  margin-bottom: var(--space-6);
}
.wf-quizzes__title {
  font-size: var(--text-h1);
  font-weight: var(--weight-bold);
  line-height: 1.3;
  color: var(--color-text-primary);
  margin: 0 0 var(--space-2);
}
.wf-quizzes__lead {
  font-size: var(--text-body);
  line-height: 1.75;
  color: var(--color-text-secondary);
  margin: 0;
}

/* ---- 3. filter bar (tabs + sort) ---------------------------------- */
.wf-quizzes__filterbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}
.wf-quizzes__tabs {
  flex: 1 1 auto;
  min-width: 0;
}
/* .filter-tab / .filter-tab--active は anchor なので装飾を整える */
.wf-quizzes__tab {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  transition: border-color 0.15s, background 0.15s, color 0.15s;
}
a.wf-quizzes__tab.filter-tab:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}
/* 堅牢性: active タブのピル形状を base .filter-tab に依存せず補完しておく
   (.filter-tab--active は色/太字のみ定義のため・visual/tokens レンズ med)。 */
.wf-quizzes__tab.filter-tab--active {
  font-size: var(--text-small);
  padding: 6px 14px;
  border: 1px solid var(--color-accent);
  border-radius: var(--zone-radius-button, var(--radius-pill));
}

.wf-quizzes__sort {
  flex: none;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin: 0;
}
/* ラベルは a11y 用に残しつつ視覚的に隠す (モックは select 単体表示・visual レンズ low)。 */
.wf-quizzes__sort-label {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}
/* JS 無効時のみ <noscript> で現れる submit ボタン (php レンズ #3)。 */
.wf-quizzes__sort-submit {
  font-size: var(--text-caption);
  font-weight: var(--weight-semibold);
  color: var(--color-accent);
  background: var(--color-surface);
  border: 1px solid var(--color-accent);
  border-radius: var(--zone-radius-button, var(--radius-pill));
  padding: 6px 14px;
  cursor: pointer;
}
.wf-quizzes__select {
  font-family: var(--font-family-base);
  font-size: var(--text-caption);
  color: var(--color-text-primary);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 7px 30px 7px 12px;
  cursor: pointer;
  appearance: none;
  /* 矢印 stroke は data-URI 内のためトークン参照不可・ゾーン非追従。
     値は free ゾーンの --color-text-secondary (#475569) と同値。ダークゾーンへ
     展開する場合は mask + background-color 方式へ要変更 (tokens レンズ #2)。 */
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
}
.wf-quizzes__select:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 1px;
}

/* ---- 4. card grid ------------------------------------------------- */
.wf-quizzes__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}
.wf-quizzes__grid-item {
  display: flex;
}

.wf-quizzes__card {
  display: flex;
  flex-direction: column;
  width: 100%;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--zone-radius-card, var(--radius-xl));
  overflow: hidden;
  transition: box-shadow 0.18s ease, transform 0.18s ease, border-color 0.18s ease;
}
.wf-quizzes__card:hover {
  box-shadow: var(--shadow-card);
  transform: translateY(-3px);
  border-color: var(--color-accent-light);
}
.wf-quizzes__card:focus-within {
  box-shadow: var(--shadow-card);
  border-color: var(--color-accent);
}

/* カテゴリ色の淡色帯 (背景色はインライン) */
.wf-quizzes__card-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
}
.wf-quizzes__card-cat {
  font-size: var(--text-small);
  font-weight: var(--weight-semibold);
  line-height: 1.3;
}
.wf-quizzes__bookmark {
  display: inline-flex;
  flex: none;
  opacity: 0.85;
}
.wf-quizzes__bookmark .wf-quizzes__svg {
  width: 18px;
  height: 18px;
}
.wf-quizzes__bookmark:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.wf-quizzes__card-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4);
  flex: 1;
}

.wf-quizzes__card-head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.wf-quizzes__card-icon {
  flex: none;
  width: 56px;
  height: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-circle);
}
.wf-quizzes__card-icon .wf-quizzes__svg {
  width: 26px;
  height: 26px;
}
.wf-quizzes__card-title {
  font-size: var(--text-h3);
  font-weight: var(--weight-bold);
  line-height: 1.4;
  color: var(--color-text-primary);
  margin: 0;
}
.wf-quizzes__card-title a {
  color: inherit;
  text-decoration: none;
}
.wf-quizzes__card-title a:hover {
  color: var(--color-accent);
}
.wf-quizzes__card-title a:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.wf-quizzes__card-desc {
  font-size: var(--text-caption);
  line-height: 1.6;
  color: var(--color-text-secondary);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.wf-quizzes__card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  margin-top: auto;
}
.wf-quizzes__meta-count {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-caption);
  color: var(--color-text-secondary);
}
.wf-quizzes__meta-count .wf-quizzes__svg {
  width: 15px;
  height: 15px;
  color: var(--color-text-muted);
}

/* 難易度バッジ */
.wf-quizzes__badge {
  flex: none;
  display: inline-flex;
  align-items: center;
  font-size: var(--text-tiny);
  font-weight: var(--weight-semibold);
  line-height: 1;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
}
.wf-quizzes__badge--easy {
  color: var(--color-accent);
  background: var(--color-accent-bg);
}
.wf-quizzes__badge--mid {
  /* warning トークンへ寄せてコントラスト確保 (tokens レンズ #3/#5)。
     ゾーンで色追従する。極小文字のため濃い text 値が望ましい。 */
  color: var(--color-warning-text);
  background: var(--color-warning-bg);
}

/* 全幅アウトラインボタン (アクセント枠 + アクセント文字 + 白背景) */
.wf-quizzes__card-btn {
  display: block;
  text-align: center;
  text-decoration: none;
  font-size: var(--text-caption);
  font-weight: var(--weight-semibold);
  color: var(--color-accent);
  background: var(--color-surface);
  border: 1px solid var(--color-accent);
  border-radius: var(--zone-radius-button, var(--radius-pill));
  padding: 9px var(--space-4);
  transition: background 0.15s, color 0.15s;
}
.wf-quizzes__card-btn:hover {
  background: var(--color-accent);
  color: var(--zone-accent-on-accent, #fff);
}
.wf-quizzes__card-btn:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

/* ---- 5. もっと見る (ページ送り) ----------------------------------- */
.wf-quizzes__more {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-8);
}
.wf-quizzes__more .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  padding: 8px 14px;
  font-size: var(--text-caption);
  color: var(--color-text-primary);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  text-decoration: none;
}
.wf-quizzes__more a.page-numbers:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}
.wf-quizzes__more .page-numbers.current {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--zone-accent-on-accent, #fff);
  font-weight: var(--weight-semibold);
}

.wf-quizzes__empty {
  text-align: center;
  font-size: var(--text-body);
  color: var(--color-text-secondary);
  padding: var(--space-10) var(--space-4);
}
.wf-quizzes__empty a {
  color: var(--color-accent);
}
.wf-quizzes__empty a:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* ---- 6. 苦手克服バナー -------------------------------------------- */
.wf-quizzes__weakness {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  margin-top: var(--space-10);
  padding: clamp(18px, 2.6vw, 26px);
  background: var(--color-accent-bg);
  border: 1px solid var(--color-accent-light);
  border-radius: var(--zone-radius-card, var(--radius-xl));
}
.wf-quizzes__weakness-icon {
  flex: none;
  width: 52px;
  height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-circle);
  background: var(--color-surface);
  color: var(--color-accent);
}
.wf-quizzes__weakness-icon .wf-quizzes__svg {
  width: 26px;
  height: 26px;
}
.wf-quizzes__weakness-body {
  flex: 1;
  min-width: 0;
}
.wf-quizzes__weakness-title {
  font-size: var(--text-h3);
  font-weight: var(--weight-bold);
  color: var(--color-text-primary);
  margin: 0 0 var(--space-1);
}
.wf-quizzes__weakness-sub {
  font-size: var(--text-caption);
  line-height: 1.6;
  color: var(--color-text-secondary);
  margin: 0;
}
.wf-quizzes__weakness-btn {
  flex: none;
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  white-space: nowrap;
  font-size: var(--text-caption);
  font-weight: var(--weight-semibold);
  color: var(--zone-accent-on-accent, #fff);
  background: var(--color-accent);
  border: 1px solid var(--color-accent);
  border-radius: var(--zone-radius-button, var(--radius-pill));
  padding: 10px var(--space-5);
  transition: filter 0.15s;
}
.wf-quizzes__weakness-btn:hover {
  filter: brightness(0.94);
}
.wf-quizzes__weakness-btn:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

/* ---- responsive --------------------------------------------------- */
@media (max-width: 1024px) {
  .wf-quizzes__grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .wf-quizzes__grid { grid-template-columns: repeat(2, 1fr); }
  .wf-quizzes__filterbar { align-items: stretch; }
  .wf-quizzes__sort { justify-content: flex-end; }
}
@media (max-width: 520px) {
  .wf-quizzes__grid { grid-template-columns: 1fr; }
  .wf-quizzes__weakness {
    flex-direction: column;
    text-align: center;
  }
  .wf-quizzes__weakness-btn { width: 100%; justify-content: center; }
}
