/* ============================================================
   COMPONENTS — buttons, cards, grid, forms, states, glass bars
   Flat everywhere; glass only on floating chrome.
   ============================================================ */

/* ---- Buttons ---- */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  height:42px; padding:0 20px; border-radius:var(--r);
  font-family:var(--font-body); font-size:14px; font-weight:600; letter-spacing:0.005em;
  border:1px solid transparent; transition:background var(--t-fast), color var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
  white-space:nowrap;
}
.btn .pf-icon { font-size:17px; }
.btn:active { transform:translateY(1px); }
.btn--primary { background:var(--spoke-orange); color:#fff; }
.btn--primary:hover { background:var(--spoke-orange-deep); }
.btn--ghost { background:transparent; color:var(--ink); border-color:var(--line); }
.btn--ghost:hover { border-color:var(--ink); }
.btn--quiet { background:transparent; color:var(--ink-soft); padding:0 12px; }
.btn--quiet:hover { background:rgba(38,38,38,0.06); }
.btn--sm { height:34px; padding:0 14px; font-size:13px; }
.btn--block { width:100%; }
.btn:disabled { opacity:0.45; cursor:not-allowed; transform:none; }

/* ---- Links / inline ---- */
.link-arrow { display:inline-flex; align-items:center; gap:6px; font-weight:600; font-size:14px; color:var(--ink); transition:gap var(--t-fast), color var(--t-fast); }
.link-arrow .pf-icon { font-size:16px; color:var(--spoke-orange); }
.link-arrow:hover { gap:10px; color:var(--spoke-orange); }

/* ---- Form fields ---- */
.field { display:block; margin-bottom:16px; }
.field > label { display:block; font-size:13px; font-weight:600; margin-bottom:7px; }
.field .hint { font-size:12px; color:var(--grey-med); margin-top:6px; }
.input, .select, .textarea {
  width:100%; min-height:44px; padding:11px 14px;
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  font-size:14.5px; transition:border-color var(--t-fast), box-shadow var(--t-fast);
}
.textarea { min-height:120px; resize:vertical; line-height:1.55; }
.input:focus, .select:focus, .textarea:focus { outline:none; border-color:var(--spoke-orange); box-shadow:0 0 0 3px rgba(244,121,32,0.12); }
.select { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23959595' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:38px; }

/* ---- Controls bar (search / filter / sort) ---- */
.controls { display:flex; flex-wrap:wrap; gap:12px; align-items:center; margin-bottom:24px; }
.controls .search-inline { position:relative; flex:1 1 260px; min-width:200px; }
.controls .search-inline .pf-icon { position:absolute; left:13px; top:50%; transform:translateY(-50%); font-size:18px; color:var(--grey-med); }
.controls .search-inline input { width:100%; height:42px; padding:0 14px 0 38px; border:1px solid var(--line); border-radius:var(--r); font-size:14px; }
.controls .search-inline input:focus { outline:none; border-color:var(--spoke-orange); }
.controls .select { width:auto; min-width:150px; flex:0 0 auto; height:42px; min-height:0; }
.controls__count { margin-left:auto; font-size:13px; color:var(--grey-med); }

/* ---- Type-tag filter row (flat segmented, orange underline; never pills) ---- */
.type-filter { display:flex; flex-wrap:wrap; gap:2px; margin:-4px 0 22px; border-bottom:1px solid var(--line); }
.type-filter button {
  position:relative; padding:9px 13px; font-family:var(--font-body); font-size:13.5px; font-weight:500;
  color:var(--grey-med); background:none; border:0; border-bottom:2px solid transparent; margin-bottom:-1px;
  transition:color var(--t-fast), border-color var(--t-fast);
}
.type-filter button:hover { color:var(--ink); }
.type-filter button[aria-pressed="true"] { color:var(--ink); font-weight:600; border-bottom-color:var(--spoke-orange); }
.type-filter .tf-count { font-size:12px; font-weight:500; color:var(--grey-med); margin-left:5px; }
.type-filter button[aria-pressed="true"] .tf-count { color:var(--ink); }

/* ---- Asset grid ---- */
.asset-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(230px, 1fr)); gap:18px; }
.asset-card {
  position:relative; display:flex; flex-direction:column;
  border:1px solid var(--line); border-radius:var(--r-lg); background:#fff; overflow:hidden;
  transition:border-color var(--t-fast), transform var(--t-fast);
}
.asset-card:hover { border-color:var(--line-strong); transform:translateY(-2px); }
.asset-card.selected { border-color:var(--spoke-orange); box-shadow:0 0 0 1px var(--spoke-orange); }
.asset-card__thumb {
  position:relative; aspect-ratio:4/3; background:var(--paper-2);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.asset-card__thumb img { width:100%; height:100%; object-fit:cover; }
.asset-card__thumb .ph-icon { font-size:42px; color:#d9d6d2; }
.asset-card__play {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background:rgba(38,38,38,0.18);
  opacity:0; transition:opacity var(--t-fast);
}
.asset-card:hover .asset-card__play { opacity:1; }
.asset-card__play span { width:48px; height:48px; border-radius:50%; background:rgba(255,255,255,0.9); display:flex; align-items:center; justify-content:center; }
.asset-card__play .pf-icon { font-size:22px; color:var(--ink); margin-left:2px; }
.asset-card__check {
  position:absolute; top:10px; left:10px; width:22px; height:22px; border-radius:6px;
  background:rgba(255,255,255,0.85); border:1px solid var(--line-strong); display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background var(--t-fast), border-color var(--t-fast);
}
.asset-card__check .pf-icon { font-size:15px; color:#fff; opacity:0; }
.asset-card.selected .asset-card__check { background:var(--spoke-orange); border-color:var(--spoke-orange); }
.asset-card.selected .asset-card__check .pf-icon { opacity:1; }
.asset-card__body { padding:14px 15px 16px; display:flex; flex-direction:column; flex:1; }
.asset-card__title { font-family:var(--font-display); font-weight:700; font-size:0.98rem; line-height:1.25; letter-spacing:-0.01em; }
.asset-card__meta { font-size:12px; color:var(--grey-med); margin-top:5px; }
.asset-card__lock { display:flex; align-items:center; gap:6px; font-size:12px; font-weight:500; color:var(--spoke-orange); margin-top:9px; }
.asset-card__lock .pf-icon { font-size:14px; }
.asset-card__lock.granted { color:#3a9d6e; }
.asset-card__tags { font-size:12px; color:var(--ink-soft); margin-top:9px; line-height:1.5; }
.asset-card__tags span { color:var(--grey-med); }
.asset-card__actions { display:flex; align-items:center; gap:8px; margin-top:14px; }
.asset-card__add {
  width:34px; height:34px; flex:0 0 auto; border:1px solid var(--line); border-radius:var(--r-sm);
  display:flex; align-items:center; justify-content:center; transition:border-color var(--t-fast), color var(--t-fast);
}
.asset-card__add .pf-icon { font-size:17px; }
.asset-card__add:hover { border-color:var(--spoke-orange); color:var(--spoke-orange); }
.asset-card__dl { flex:1; }

/* ---- Tiles (dashboard) ---- */
.tile-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(220px,1fr)); gap:16px; }
.tile {
  display:flex; flex-direction:column; gap:14px; padding:22px;
  border:1px solid var(--line); border-radius:var(--r-lg); background:#fff;
  transition:border-color var(--t-fast), transform var(--t-fast);
}
.tile:hover { border-color:var(--line-strong); transform:translateY(-2px); }
.tile__icon { width:40px; height:40px; border-radius:var(--r-sm); background:var(--paper-2); display:flex; align-items:center; justify-content:center; }
.tile__icon .pf-icon { font-size:24px; color:var(--spoke-orange); }
.tile__name { font-family:var(--font-display); font-weight:700; font-size:1.15rem; }
.tile__desc { font-size:13px; color:var(--grey-med); line-height:1.5; }
.tile__count { margin-top:auto; font-size:13px; font-weight:600; color:var(--ink); }
.tile__count b { color:var(--spoke-orange); }

/* ---- Section heading ---- */
.section-head { display:flex; align-items:baseline; justify-content:space-between; gap:16px; margin:0 0 18px; }
.section-head h2 { font-size:clamp(1.3rem,2.2vw,1.7rem); }
.section-head a { font-size:13px; color:var(--grey-med); }
.section-head a:hover { color:var(--spoke-orange); }
.section + .section { margin-top:52px; }

/* ---- Sticky glass action bar (multi-select) ---- */
.action-bar {
  position:fixed; left:50%; bottom:28px; transform:translate(-50%, 140%);
  z-index:180; display:flex; align-items:center; gap:16px;
  padding:12px 14px 12px 22px; border-radius:16px;
  background:var(--glass-bg); -webkit-backdrop-filter:var(--glass-blur); backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border); box-shadow:var(--glass-shadow);
  transition:transform var(--t-med);
}
.action-bar.show { transform:translate(-50%, 0); }
.action-bar__n { font-size:14px; font-weight:600; }
.action-bar__n b { color:var(--spoke-orange); }
.action-bar__clear { font-size:13px; color:var(--grey-med); }
.action-bar__clear:hover { color:var(--ink); }

/* ---- Skeleton / empty / error states ---- */
.skel-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(230px,1fr)); gap:18px; }
.skel-card { border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; }
.skel-thumb { aspect-ratio:4/3; }
.skel-line { height:12px; margin:14px 15px 0; border-radius:4px; }
.skel-line.short { width:55%; }
.shimmer { background:linear-gradient(100deg,#f2f1ef 30%,#f9f8f7 50%,#f2f1ef 70%); background-size:200% 100%; animation:shimmer 1.3s linear infinite; }
@keyframes shimmer { to { background-position:-200% 0; } }

.state {
  text-align:center; padding:72px 24px; border:1px dashed var(--line-strong); border-radius:var(--r-lg);
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.state .pf-icon { font-size:34px; color:var(--grey-med); margin-bottom:4px; }
.state h3 { font-size:1.2rem; }
.state p { color:var(--grey-med); font-size:14px; max-width:42ch; }
.state .btn { margin-top:12px; }
.state--error { border-color:rgba(226,83,79,0.4); }
.state--error .pf-icon { color:var(--spoke-red); }

/* ---- Toast ---- */
.toast-wrap { position:fixed; bottom:28px; right:28px; z-index:300; display:flex; flex-direction:column; gap:10px; align-items:flex-end; }
.toast {
  display:flex; align-items:center; gap:11px; padding:13px 17px; min-width:240px; max-width:380px;
  background:var(--glass-bg); -webkit-backdrop-filter:var(--glass-blur); backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border); border-radius:var(--r); box-shadow:var(--glass-shadow);
  font-size:14px; font-weight:500;
  animation:toast-in 0.35s var(--ease);
}
@keyframes toast-in { from { opacity:0; transform:translateY(12px); } }
.toast.out { opacity:0; transform:translateY(12px); transition:opacity var(--t-fast), transform var(--t-fast); }
.toast .pf-icon { font-size:19px; flex:0 0 auto; }
.toast--ok .pf-icon { color:var(--spoke-orange); }
.toast--err .pf-icon { color:var(--spoke-red); }

/* ---- Modal ---- */
.modal-backdrop { position:fixed; inset:0; z-index:250; background:rgba(38,38,38,0.32); display:flex; align-items:center; justify-content:center; padding:24px; opacity:0; pointer-events:none; transition:opacity var(--t-fast); }
.modal-backdrop.open { opacity:1; pointer-events:auto; }
.modal {
  width:100%; max-width:460px; background:var(--glass-bg); -webkit-backdrop-filter:var(--glass-blur); backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border); border-radius:var(--r-lg); box-shadow:var(--glass-shadow);
  padding:26px; transform:translateY(14px) scale(0.98); transition:transform var(--t-med);
}
.modal-backdrop.open .modal { transform:none; }
.modal h3 { margin-bottom:6px; }
.modal p.sub { color:var(--grey-med); font-size:14px; margin-bottom:18px; }
.modal__foot { display:flex; gap:10px; justify-content:flex-end; margin-top:22px; }
.modal__list { max-height:240px; overflow-y:auto; margin:4px 0 2px; }
.modal__list button { display:flex; width:100%; align-items:center; gap:10px; padding:11px 12px; border-radius:var(--r-sm); font-size:14px; text-align:left; transition:background var(--t-fast); }
.modal__list button:hover { background:rgba(38,38,38,0.05); }
.modal__list .pf-icon { font-size:18px; color:var(--spoke-orange); }

/* ---- What's new feed ---- */
.feed { display:flex; flex-direction:column; }
.feed__item { display:flex; align-items:center; gap:16px; padding:15px 0; border-bottom:1px solid var(--line); }
.feed__item:last-child { border-bottom:0; }
.feed__thumb { width:56px; height:56px; flex:0 0 auto; border-radius:var(--r-sm); background:var(--paper-2); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.feed__thumb img { width:100%; height:100%; object-fit:cover; }
.feed__thumb .pf-icon { font-size:22px; color:#d9d6d2; }
.feed__main { flex:1; min-width:0; }
.feed__main b { font-family:var(--font-display); font-size:0.98rem; font-weight:700; }
.feed__main span { display:block; font-size:12.5px; color:var(--grey-med); margin-top:2px; }
.feed__when { font-size:12px; color:var(--grey-med); flex:0 0 auto; }
.feed__cat { font-size:11px; font-weight:600; letter-spacing:0.04em; color:var(--spoke-orange); }

/* ---- Tables ---- */
.table-wrap { border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; }
table.data-table { width:100%; border-collapse:collapse; font-size:13.5px; }
.data-table th { text-align:left; font-family:var(--font-body); font-weight:600; font-size:12px; letter-spacing:0.03em; color:var(--grey-med); padding:13px 16px; background:var(--paper-2); border-bottom:1px solid var(--line); cursor:pointer; white-space:nowrap; }
.data-table th.no-sort { cursor:default; }
.data-table td { padding:13px 16px; border-bottom:1px solid var(--line); vertical-align:middle; }
.data-table tr:last-child td { border-bottom:0; }
.data-table tbody tr { transition:background var(--t-fast); }
.data-table tbody tr:hover { background:var(--paper-2); }
.data-table .num { text-align:right; font-variant-numeric:tabular-nums; }
.status-dot { display:inline-flex; align-items:center; gap:7px; font-weight:500; }
.status-dot::before { content:""; width:7px; height:7px; border-radius:50%; background:var(--grey-med); }
.status-dot.open::before { background:var(--spoke-orange); }
.status-dot.in_progress::before { background:var(--spoke-blue); }
.status-dot.done::before { background:#3a9d6e; }

/* ---- KPI strip ---- */
.kpi-strip { display:grid; grid-template-columns:repeat(auto-fit, minmax(160px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; }
.kpi { background:#fff; padding:20px 22px; }
.kpi__val { font-family:var(--font-display); font-weight:700; font-size:clamp(1.6rem,2.6vw,2.2rem); letter-spacing:-0.02em; line-height:1; }
.kpi__val.accent { color:var(--spoke-orange); }
.kpi__label { font-size:12.5px; color:var(--grey-med); margin-top:8px; }
.kpi__unit { font-size:0.7em; color:var(--grey-med); font-weight:500; margin-left:3px; }

/* ---- Segmented control (quiet chart-type switch) ---- */
.segmented { display:inline-flex; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
.segmented button { padding:7px 14px; font-size:13px; font-weight:500; color:var(--grey-med); display:flex; align-items:center; gap:6px; transition:background var(--t-fast), color var(--t-fast); }
.segmented button .pf-icon { font-size:16px; }
.segmented button + button { border-left:1px solid var(--line); }
.segmented button[aria-pressed="true"] { background:var(--ink); color:#fff; }

/* tag list plain */
.taglist { font-size:12.5px; color:var(--ink-soft); }
.taglist b { color:var(--grey-med); font-weight:500; }
