/* File: assets/css/talents.css
   Regulus Project – Talents page (grouped: Real / VTuber)
   - 既存 style.css のトークン/設計を尊重
   - ツールバーをガラス感で軽量化、Grid/List 切替はセグメント風
   - 上：実写配信（#gridReal）、下：VTuber（#gridVtuber）
*/

/* =========================
   Toolbar（検索/並び替え/ビュー切替）
   ========================= */
#talentsToolbar{
  background: color-mix(in oklab, var(--bg) 88%, #0b1222 12% / 18%);
  border: 1px solid color-mix(in oklab, var(--line) 80%, transparent);
  backdrop-filter: blur(8px);
  border-radius: 16px;
  padding: 14px 16px 12px;
  margin-bottom: 1.2rem;
}
.talents-toolbar{
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 10px 12px;
  align-items: center;
}
@media (max-width: 880px){
  .talents-toolbar{ grid-template-columns: 1fr 1fr; }
}

/* 検索ボックス */
.talents-toolbar .input.search{
  display:flex; align-items:center; gap:.45rem;
  padding:.55rem .75rem;
  border-radius: 10px;
  border:1px solid color-mix(in oklab, var(--line) 85%, transparent);
  background: color-mix(in oklab, var(--bg) 92%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
  flex: 1 1 260px;
}
.talents-toolbar .input.search svg{ opacity:.7 }
.talents-toolbar .input.search input{
  border:0; outline:0; background:transparent; width:100%;
  font-size: .98rem; color: var(--text);
}
body.dark .talents-toolbar .input.search{ background: rgba(255,255,255,.06); }

/* Select（並び替え） */
.talents-toolbar .select{ position:relative; display:flex; align-items:center; gap:.5rem; }
.talents-toolbar .select .kicker{ font-size:.8rem; color:var(--muted); }
.talents-toolbar .select select{
  appearance: none; -webkit-appearance: none;
  font-size: .95rem;
  padding: .5rem 2.1rem .5rem .6rem;
  border-radius: 10px;
  border:1px solid color-mix(in oklab, var(--line) 85%, transparent);
  background:
    linear-gradient( to bottom, currentColor 0 0) center right 10px/1px 12px no-repeat,
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") right 6px center / 18px 18px no-repeat,
    color-mix(in oklab, var(--bg) 94%, transparent);
  color: var(--text); cursor: pointer;
}
body:not(.dark) .talents-toolbar .select select{
  background:
    linear-gradient( to bottom, currentColor 0 0) center right 10px/1px 12px no-repeat,
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") right 6px center / 18px 18px no-repeat,
    color-mix(in oklab, var(--bg) 96%, transparent);
}
.talents-toolbar .select select:focus-visible{
  outline: none; box-shadow: 0 0 0 4px var(--ring);
}

/* View toggle（セグメントコントロール） */
.view-toggle{
  justify-self: end;
  display:inline-flex; gap:0;
  padding:4px; border-radius:999px;
  background: color-mix(in oklab, var(--bg) 85%, transparent);
  border:1px solid color-mix(in oklab, var(--line) 85%, transparent);
}
.view-toggle .vt-btn{
  border:0; background:transparent; color:var(--text);
  padding:.42rem .9rem; border-radius:999px; font-weight:700; font-size:.86rem;
  letter-spacing:.01em; cursor:pointer;
}
.view-toggle .vt-btn.is-active{
  background: color-mix(in oklab, var(--accent) 24%, transparent);
  color:#fff;
  box-shadow: inset 0 -1px 0 rgba(0,0,0,.12), 0 1px 2px rgba(0,0,0,.12);
}
body.dark .view-toggle{ background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.08); }
body.dark .view-toggle .vt-btn.is-active{
  background: color-mix(in oklab, var(--accent) 70%, #000);
}

/* クイックタグ（チップ） */
.quick-tags{
  display:flex; flex-wrap:wrap; gap:8px; margin-top:6px;
}
.quick-tags .tag{
  appearance:none; cursor:pointer;
  border:1px solid color-mix(in oklab, var(--line) 85%, transparent);
  background: color-mix(in oklab, var(--bg) 92%, transparent);
  color: var(--text);
  padding:.28rem .6rem; border-radius:999px;
  font-size:.83rem; font-weight:600;
  transition: background .18s var(--ease), border-color .18s var(--ease), transform .18s var(--ease);
}
.quick-tags .tag:hover{
  background: color-mix(in oklab, var(--accent) 12%, transparent);
  border-color: color-mix(in oklab, var(--accent) 40%, var(--line));
  transform: translateY(-1px);
}
body.dark .quick-tags .tag{ background: rgba(255,255,255,.06); }

/* =========================
   Subhead（実写 / VTuber の見出し）
   ========================= */
.subhead{
  margin: 1.1rem 0 .6rem;
  font-size: 1.05rem;
  letter-spacing: .02em;
  color: var(--muted);
  position: relative;
}
.subhead::after{
  content:"";
  display:block; height:2px; width:100%;
  margin-top:.35rem;
  background: linear-gradient(90deg, color-mix(in oklab, var(--accent) 60%, transparent), transparent);
}

/* =========================
   Grids（上：実写 / 下：VTuber）
   ========================= */
#gridReal, #gridVtuber{
  display:grid; gap:16px;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  justify-content:center;
}

/* List 表示（JSで .is-list を付与） */
#gridReal.is-list, #gridVtuber.is-list{ display:block; }
#gridReal.is-list .talent-card, #gridVtuber.is-list .talent-card{
  display:grid;
  grid-template-columns: 120px 1fr;
  align-items:center;
  gap:16px;
  padding:16px;
}
#gridReal.is-list .talent-card img, #gridVtuber.is-list .talent-card img{ width:120px; height:120px; }
@media (max-width:560px){
  #gridReal.is-list .talent-card, #gridVtuber.is-list .talent-card{
    grid-template-columns: 84px 1fr; gap:12px; padding:12px;
  }
  #gridReal.is-list .talent-card img, #gridVtuber.is-list .talent-card img{ width:84px; height:84px; }
}

/* =========================
   Talent Card
   ========================= */
.talent-card{
  display:flex; align-items:center; gap:14px;
  padding:16px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  box-shadow:0 4px 12px rgba(0,0,0,.06);
  transition: transform .2s var(--ease), box-shadow .2s var(--ease);
}
.talent-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0,0,0,.1);
}
body.dark .talent-card{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 6px 22px rgba(0,0,0,.35);
}

/* アバター */
.talent-card img{
  width:96px; height:96px; border-radius:50%;
  object-fit:cover; border:2px solid var(--line);
}
@media (min-width:980px){
  .talent-card img{ width:104px; height:104px; }
}

/* タイトル/補足/タグ/リンク */
.talent-card .name{ margin:0 0 .1rem; line-height:1.25; }
.talent-card .name a{
  font-size:1.15rem; font-weight:700;
  color: var(--accent);
  text-decoration:none;
}
.talent-card .name a:hover{ text-decoration:underline; }
body.dark .talent-card .name a{ color: var(--accent-2); }

.talent-card .kicker{ font-size:.9rem; color:var(--muted); margin-bottom:.25rem; }

.talent-card .tags{ display:flex; flex-wrap:wrap; gap:6px; margin:.25rem 0 .35rem; }
.talent-card .tags .tag{
  background: color-mix(in oklab, var(--bg) 95%, var(--accent) 5%);
  border:1px solid var(--line);
  border-radius:999px; padding:.2rem .55rem; font-size:.75rem;
}
body.dark .talent-card .tags .tag{ background: rgba(255,255,255,.08); }

.talent-card .links{ display:flex; gap:10px; flex-wrap:wrap; }
.talent-card .links a{
  color:var(--muted); text-decoration:none; font-weight:600;
}
.talent-card .links a:hover{ color:var(--text); }

/* 配信中の強調 */
.talent-card.is-live{
  outline: 2px solid color-mix(in oklab, #d92534 55%, var(--accent));
}

/* =========================
   互換：旧 pager を使っていても崩れないよう軽く定義
   ========================= */
.pager{
  display:flex; gap:.8rem; align-items:center; justify-content:center;
  margin-top:12px;
}
.pager .pg{ min-width:72px; }
.pager .pg[disabled]{ opacity:.55; cursor:not-allowed; }
.pager .pg-info{ min-width:86px; text-align:center; }

/* =========================
   微調整
   ========================= */
.talents-toolbar input,
.talents-toolbar select,
.view-toggle .vt-btn{ font-variant-numeric: lining-nums; }
/* ========== Toolbar Minimal / Office-like ========== */
/* ベース：背景も影も箱もやめて、行内UI＋淡い下境界のみ */
#talentsToolbar.toolbar-quiet{
  background: transparent !important;
  border: 0 !important;
  backdrop-filter: none !important;
  border-radius: 0 !important;
  padding: 6px 0 10px !important;
  margin-bottom: .6rem !important;
  position: relative;
}
#talentsToolbar.toolbar-quiet::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0;
  height:1px;
  background: color-mix(in oklab, var(--line) 80%, transparent);
}

/* レイアウト：行内で軽く詰める。PCは右寄せ、狭幅は2段落ち */
#talentsToolbar.toolbar-quiet .talents-toolbar{
  display:flex; flex-wrap:wrap; align-items:center; gap:10px 12px;
  justify-content:flex-end;
}

/* 検索：縁取りや白ボックスをやめて“線＋透過” */
#talentsToolbar.toolbar-quiet .input.search{
  border: 0 !important;
  background: transparent !important;
  padding: 0 !important;
  gap: .5rem;
}
#talentsToolbar.toolbar-quiet .input.search svg{ opacity:.6; }
#talentsToolbar.toolbar-quiet .input.search input{
  border: 0; outline: 0; background: transparent;
  font-size: .96rem; color: var(--text);
  padding: .35rem .2rem;
  border-bottom: 1px solid color-mix(in oklab, var(--line) 90%, transparent);
}
#talentsToolbar.toolbar-quiet .input.search input:focus-visible{
  box-shadow: 0 2px 0 0 var(--accent) inset;
  border-bottom-color: transparent;
}

/* セレクト：カプセル化をやめ、淡い“チップ”に。ダークで浮かない濃度 */
#talentsToolbar.toolbar-quiet .select{
  display:flex; align-items:center; gap:.45rem;
}
#talentsToolbar.toolbar-quiet .select .kicker{
  font-size:.82rem; color:var(--muted);
}
#talentsToolbar.toolbar-quiet .select select{
  appearance:none; -webkit-appearance:none;
  font-size:.92rem; line-height:1;
  padding: .38rem .9rem .38rem .6rem;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--line) 85%, transparent);
  background: color-mix(in oklab, var(--bg) 92%, transparent);
  color: var(--text);
}
body.dark #talentsToolbar.toolbar-quiet .select select{
  background: rgba(255,255,255,.06);
}

/* Grid/List：セグメントの“台座”を消して、ボタン自体を小さく */
#talentsToolbar.toolbar-quiet .view-toggle{
  border:0; background:transparent; padding:0; gap:4px;
}
#talentsToolbar.toolbar-quiet .view-toggle .vt-btn{
  border:1px solid color-mix(in oklab, var(--line) 85%, transparent);
  background: transparent;
  color: var(--text);
  padding: .32rem .7rem;
  border-radius: 999px;
  font-size: .82rem; font-weight: 700;
}
#talentsToolbar.toolbar-quiet .view-toggle .vt-btn.is-active{
  background: color-mix(in oklab, var(--accent) 18%, transparent);
  color: #fff;
  border-color: transparent;
}

/* クイックタグ：小さめ・線だけ。ホバー時だけ色味を出す */
#talentsToolbar.toolbar-quiet .quick-tags{
  margin-top: 4px;
  justify-content: flex-end;
}
#talentsToolbar.toolbar-quiet .quick-tags .tag{
  padding:.22rem .55rem; font-size:.8rem; font-weight:600;
  border-radius:999px;
  border:1px solid color-mix(in oklab, var(--line) 85%, transparent);
  background: transparent; color: var(--text);
}
#talentsToolbar.toolbar-quiet .quick-tags .tag:hover{
  background: color-mix(in oklab, var(--accent) 10%, transparent);
  border-color: color-mix(in oklab, var(--accent) 40%, var(--line));
  transform: translateY(-1px);
}

/* スペースの前後に呼吸感（主役カードとの距離を稼ぐ） */
.section .section-head{ margin-bottom: .4rem; }
#gridReal, #gridVtuber{ margin-top: .2rem; }
