:root {
  --brand: #1CC2BB;
  --brand-600: #17a8a2;
  --brand-700: #0f8c86;

  --bg: #f5f6fa;
  --bg-elev: #ffffff;
  --bg-sunken: #eceef4;
  --surface-glass: rgba(255, 255, 255, 0.72);
  --border: #e4e7ef;
  --border-strong: #d4d9e6;

  --text: #11131a;
  --text-soft: #4a5066;
  --text-mut: #8b91a6;

  --ok: #10b981;
  --warn: #f59e0b;
  --danger: #ef4444;
  --info: #3b82f6;
  --neutral: #6b7280;

  --st-suspect: #6b7280;
  --st-arrested: #f59e0b;
  --st-on_trial: #3b82f6;
  --st-convicted: #ef4444;
  --st-released: #10b981;
  --st-active: #8b5cf6;

  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 22px;
  --r-xl: 28px;
  --r-pill: 999px;

  --sh-1: 0 1px 2px rgba(17, 19, 26, 0.04), 0 1px 3px rgba(17, 19, 26, 0.06);
  --sh-2: 0 4px 12px rgba(17, 19, 26, 0.06), 0 2px 6px rgba(17, 19, 26, 0.05);
  --sh-3: 0 12px 32px rgba(17, 19, 26, 0.10), 0 4px 10px rgba(17, 19, 26, 0.06);
  --sh-fab: 0 8px 24px rgba(28, 194, 187, 0.40);

  --maxw: 1200px;
  --gutter: 16px;
  --header-h: 56px;
  --bottomnav-h: 64px;
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in: cubic-bezier(0.55, 0, 1, 0.45);
  --dur-1: 140ms;
  --dur-2: 240ms;
  --dur-3: 380ms;

  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue",
    Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
  --font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
}

@media (prefers-color-scheme: dark) {
  :root {
    --bg: #0b0d12;
    --bg-elev: #151821;
    --bg-sunken: #0f121a;
    --surface-glass: rgba(21, 24, 33, 0.72);
    --border: #232838;
    --border-strong: #313850;
    --text: #f3f5fb;
    --text-soft: #b8bed2;
    --text-mut: #7e859c;
    --sh-1: 0 1px 2px rgba(0, 0, 0, 0.4);
    --sh-2: 0 4px 14px rgba(0, 0, 0, 0.45);
    --sh-3: 0 16px 40px rgba(0, 0, 0, 0.55);
  }
}

[data-theme="light"] {
  --bg: #f5f6fa; --bg-elev: #fff; --bg-sunken: #eceef4;
  --surface-glass: rgba(255,255,255,0.72);
  --border: #e4e7ef; --border-strong: #d4d9e6;
  --text: #11131a; --text-soft: #4a5066; --text-mut: #8b91a6;
}

[data-theme="dark"] {
  --bg: #0b0d12; --bg-elev: #151821; --bg-sunken: #0f121a;
  --surface-glass: rgba(21,24,33,0.72);
  --border: #232838; --border-strong: #313850;
  --text: #f3f5fb; --text-soft: #b8bed2; --text-mut: #7e859c;
}

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; -webkit-tap-highlight-color: transparent; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  line-height: 1.5;
  font-size: 15px;
  min-height: 100dvh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overscroll-behavior-y: none;
}

img, svg, video { display: block; max-width: 100%; }
button, input, select, textarea { font: inherit; color: inherit; }
button { cursor: pointer; background: none; border: none; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; padding: 0; }
:focus-visible { outline: 2px solid var(--brand); outline-offset: 2px; border-radius: 6px; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
}

.app {
  max-width: var(--maxw);
  margin: 0 auto;
  padding-top: calc(var(--header-h) + var(--safe-top));
  padding-bottom: calc(var(--bottomnav-h) + var(--safe-bottom) + 12px);
  min-height: 100dvh;
}

.appbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  height: calc(var(--header-h) + var(--safe-top));
  padding: var(--safe-top) var(--gutter) 0;
  display: flex; align-items: center; gap: 12px;
  background: var(--surface-glass);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  backdrop-filter: saturate(180%) blur(18px);
  border-bottom: 1px solid var(--border);
}

.appbar__brand { display: flex; align-items: center; gap: 10px; font-weight: 800; letter-spacing: -0.02em; font-size: 17px; }
.appbar__logo { width: 28px; height: 28px; border-radius: 8px; object-fit: cover; box-shadow: var(--sh-1); }
.appbar__spacer { flex: 1; }
.iconbtn { width: 40px; height: 40px; border-radius: var(--r-pill); display: grid; place-items: center; color: var(--text-soft); transition: background var(--dur-1) var(--ease), transform var(--dur-1) var(--ease); }
.iconbtn:hover { background: var(--bg-sunken); }
.iconbtn:active { transform: scale(0.92); }
.icon { width: 22px; height: 22px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.icon--sm { width: 16px; height: 16px; }
.icon--lg { width: 26px; height: 26px; }

.section { padding: 18px var(--gutter) 4px; }
.section__head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 12px; }
.section__title { font-size: 18px; font-weight: 750; letter-spacing: -0.02em; }
.section__link { font-size: 13px; color: var(--brand-600); font-weight: 600; }
.page-title { font-size: 26px; font-weight: 820; letter-spacing: -0.03em; padding: 8px var(--gutter) 0; }
.page-sub { color: var(--text-mut); padding: 2px var(--gutter) 0; font-size: 14px; }

.stat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; padding: 4px var(--gutter); }
.stat {
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 16px; box-shadow: var(--sh-1); position: relative; overflow: hidden;
  transition: transform var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease);
}
.stat:hover { transform: translateY(-2px); box-shadow: var(--sh-2); }
.stat__icon { width: 40px; height: 40px; border-radius: 12px; display: grid; place-items: center; margin-bottom: 10px; color: #fff; }
.stat__value { font-size: 26px; font-weight: 820; letter-spacing: -0.03em; font-variant-numeric: tabular-nums; }
.stat__label { color: var(--text-mut); font-size: 12.5px; font-weight: 600; margin-top: 2px; }
.stat__spark { position: absolute; right: -6px; bottom: -6px; width: 76px; height: 44px; opacity: 0.10; }

.cat-scroller { display: flex; gap: 10px; overflow-x: auto; padding: 4px var(--gutter) 12px; scroll-snap-type: x proximity; scrollbar-width: none; }
.cat-scroller::-webkit-scrollbar { display: none; }
.cat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; padding: 4px var(--gutter); }
.cat-card {
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 16px; box-shadow: var(--sh-1); display: flex; flex-direction: column; gap: 10px;
  transition: transform var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease);
  scroll-snap-align: start;
}
.cat-card:active { transform: scale(0.97); }
.cat-card__icon { width: 46px; height: 46px; border-radius: 14px; display: grid; place-items: center; color: #fff; }
.cat-card__name { font-weight: 700; letter-spacing: -0.01em; }
.cat-card__count { font-size: 13px; color: var(--text-mut); }
.cat-chip { flex: 0 0 auto; display: flex; align-items: center; gap: 8px; padding: 9px 14px; border-radius: var(--r-pill); background: var(--bg-elev); border: 1px solid var(--border); font-weight: 600; font-size: 13.5px; box-shadow: var(--sh-1); transition: transform var(--dur-1) var(--ease); }
.cat-chip:active { transform: scale(0.95); }
.cat-chip .dot { width: 9px; height: 9px; border-radius: 50%; }

.case-list { display: grid; grid-template-columns: 1fr; gap: 12px; padding: 6px var(--gutter); }
.case-rail { display: flex; gap: 12px; overflow-x: auto; padding: 6px var(--gutter) 14px; scroll-snap-type: x mandatory; scrollbar-width: none; }
.case-rail::-webkit-scrollbar { display: none; }
.case-rail .case-card { flex: 0 0 78%; max-width: 320px; scroll-snap-align: start; }

.case-card {
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--r-lg);
  box-shadow: var(--sh-1); overflow: hidden; display: flex; flex-direction: column;
  transition: transform var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease);
  text-align: left; width: 100%;
}
.case-card:hover { transform: translateY(-3px); box-shadow: var(--sh-3); }
.case-card:active { transform: scale(0.985); }
.case-card__media { position: relative; aspect-ratio: 16 / 9; display: grid; place-items: center; color: #fff; font-weight: 800; font-size: 30px; letter-spacing: -0.02em; }
.case-card__badge { position: absolute; top: 10px; left: 10px; }
.case-card__signal { position: absolute; top: 10px; right: 10px; }
.case-card__body { padding: 12px 14px 14px; display: flex; flex-direction: column; gap: 6px; }
.case-card__name { font-weight: 750; font-size: 16px; letter-spacing: -0.01em; }
.case-card__meta { display: flex; gap: 8px; align-items: center; font-size: 12.5px; color: var(--text-mut); flex-wrap: wrap; }
.case-card__desc { color: var(--text-soft); font-size: 13.5px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.case-card__foot { display: flex; align-items: center; justify-content: space-between; margin-top: 6px; }

.gradient-media { background: linear-gradient(135deg, var(--c1, var(--brand)), var(--c2, var(--brand-700))); }
.avatar { border-radius: 50%; display: grid; place-items: center; color: #fff; font-weight: 800; letter-spacing: -0.02em; flex: none; }

.badge { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: var(--r-pill); font-size: 11.5px; font-weight: 700; letter-spacing: 0.01em; background: var(--bg-sunken); color: var(--text-soft); border: 1px solid var(--border); white-space: nowrap; }
.badge .dot { width: 7px; height: 7px; border-radius: 50%; }
.badge--status { color: #fff; border: none; backdrop-filter: blur(4px); }
.badge--glass { background: rgba(0,0,0,0.42); color: #fff; border: none; -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); }
.status-suspect { background: var(--st-suspect); }
.status-arrested { background: var(--st-arrested); }
.status-on_trial { background: var(--st-on_trial); }
.status-convicted { background: var(--st-convicted); }
.status-released { background: var(--st-released); }
.status-active { background: var(--st-active); }

.signal { display: inline-grid; place-items: center; width: 38px; height: 38px; border-radius: 50%; font-size: 12px; font-weight: 800; color: #fff; font-variant-numeric: tabular-nums; background:
  conic-gradient(currentColor calc(var(--score) * 1%), rgba(255,255,255,0.25) 0); position: relative; }
.signal::after { content: ""; position: absolute; inset: 4px; border-radius: 50%; background: rgba(0,0,0,0.55); }
.signal span { position: relative; z-index: 1; }
.signal--chip { color: var(--brand-600); background: var(--bg-sunken); width: auto; height: auto; padding: 4px 9px; border-radius: var(--r-pill); }
.signal--chip::after { display: none; }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 11px 18px; border-radius: var(--r-pill); font-weight: 700; font-size: 14px; transition: transform var(--dur-1) var(--ease), box-shadow var(--dur-2) var(--ease), background var(--dur-1) var(--ease); }
.btn:active { transform: scale(0.96); }
.btn--primary { background: linear-gradient(135deg, var(--brand), var(--brand-700)); color: #fff; box-shadow: var(--sh-2); }
.btn--ghost { background: var(--bg-sunken); color: var(--text); }
.btn--block { width: 100%; }
.btn--sm { padding: 8px 14px; font-size: 13px; }
.quick-view { align-self: flex-start; }

.bottomnav {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 50;
  height: calc(var(--bottomnav-h) + var(--safe-bottom));
  padding-bottom: var(--safe-bottom);
  display: flex; align-items: stretch;
  background: var(--surface-glass);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  backdrop-filter: saturate(180%) blur(20px);
  border-top: 1px solid var(--border);
}

.bottomnav__item { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; color: var(--text-mut); font-size: 10.5px; font-weight: 600; position: relative; transition: color var(--dur-1) var(--ease); }
.bottomnav__item .icon { transition: transform var(--dur-2) var(--ease); }
.bottomnav__item.is-active { color: var(--brand-600); }
.bottomnav__item.is-active .icon { transform: translateY(-2px); }
.bottomnav__item.is-active::before { content: ""; position: absolute; top: 8px; width: 38px; height: 30px; border-radius: var(--r-pill); background: color-mix(in srgb, var(--brand) 14%, transparent); z-index: -1; }

.fab-wrap { position: fixed; right: 16px; bottom: calc(var(--bottomnav-h) + var(--safe-bottom) + 10px); z-index: 55; }
.fab { width: 58px; height: 58px; border-radius: 20px; background: linear-gradient(135deg, var(--brand), var(--brand-700)); color: #fff; display: grid; place-items: center; box-shadow: var(--sh-fab); transition: transform var(--dur-2) var(--ease); }
.fab .icon { width: 26px; height: 26px; transition: transform var(--dur-3) var(--ease); }
.fab[aria-expanded="true"] .icon { transform: rotate(135deg); }
.fab:active { transform: scale(0.92); }
.fab-actions { position: absolute; right: 0; bottom: calc(100% + 14px); display: flex; flex-direction: column; gap: 10px; align-items: flex-end; pointer-events: none; }
.fab-action { display: flex; align-items: center; gap: 10px; opacity: 0; transform: translateY(8px) scale(0.9); pointer-events: none; transition: opacity var(--dur-2) var(--ease), transform var(--dur-2) var(--ease); }
.fab-wrap.is-open .fab-action { opacity: 1; transform: translateY(0) scale(1); pointer-events: auto; }
.fab-wrap.is-open .fab-action:nth-child(1) { transition-delay: 40ms; }
.fab-wrap.is-open .fab-action:nth-child(2) { transition-delay: 80ms; }
.fab-wrap.is-open .fab-action:nth-child(3) { transition-delay: 120ms; }
.fab-action__label { background: var(--bg-elev); border: 1px solid var(--border); padding: 6px 12px; border-radius: var(--r-pill); font-size: 13px; font-weight: 600; box-shadow: var(--sh-1); }
.fab-action__btn { width: 46px; height: 46px; border-radius: 16px; background: var(--bg-elev); border: 1px solid var(--border); color: var(--brand-600); display: grid; place-items: center; box-shadow: var(--sh-2); }
.fab-scrim { position: fixed; inset: 0; z-index: 54; background: rgba(0,0,0,0.28); opacity: 0; pointer-events: none; transition: opacity var(--dur-2) var(--ease); }
.fab-scrim.is-open { opacity: 1; pointer-events: auto; }

.search-overlay { position: fixed; inset: 0; z-index: 70; background: var(--bg); display: flex; flex-direction: column; transform: translateY(8px); opacity: 0; pointer-events: none; transition: opacity var(--dur-2) var(--ease), transform var(--dur-2) var(--ease); padding-top: var(--safe-top); }
.search-overlay.is-open { opacity: 1; transform: none; pointer-events: auto; }
.search-bar { display: flex; align-items: center; gap: 10px; padding: 12px var(--gutter); border-bottom: 1px solid var(--border); }
.search-input { flex: 1; background: var(--bg-sunken); border: 1px solid var(--border); border-radius: var(--r-pill); padding: 12px 16px; font-size: 16px; }
.search-results { flex: 1; overflow-y: auto; padding: 8px var(--gutter) 24px; -webkit-overflow-scrolling: touch; }
.search-empty { text-align: center; color: var(--text-mut); padding: 48px 16px; }
.result-row { display: flex; gap: 12px; align-items: center; padding: 10px; border-radius: var(--r-md); transition: background var(--dur-1) var(--ease); }
.result-row:active { background: var(--bg-sunken); }
.result-row__name { font-weight: 650; }
.result-row__meta { font-size: 12.5px; color: var(--text-mut); }
.search-pills { display: flex; gap: 8px; flex-wrap: wrap; padding: 12px var(--gutter); }

.filter-bar { display: flex; gap: 8px; overflow-x: auto; padding: 8px var(--gutter); scrollbar-width: none; }
.filter-bar::-webkit-scrollbar { display: none; }
.filter-pill { flex: 0 0 auto; padding: 8px 14px; border-radius: var(--r-pill); border: 1px solid var(--border); background: var(--bg-elev); font-size: 13px; font-weight: 600; color: var(--text-soft); display: inline-flex; gap: 6px; align-items: center; transition: all var(--dur-1) var(--ease); }
.filter-pill.is-active { background: var(--brand); color: #fff; border-color: var(--brand); }
.filter-panel { background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--r-lg); margin: 8px var(--gutter); padding: 14px; display: grid; gap: 14px; box-shadow: var(--sh-1); }
.field { display: flex; flex-direction: column; gap: 6px; }
.field label { font-size: 12.5px; font-weight: 700; color: var(--text-soft); }
.field select, .field input[type="text"] { background: var(--bg-sunken); border: 1px solid var(--border); border-radius: var(--r-md); padding: 10px 12px; font-size: 14px; }
.range-row { display: flex; align-items: center; gap: 10px; }
input[type="range"] { width: 100%; accent-color: var(--brand); }

.hero { position: relative; aspect-ratio: 16 / 10; display: flex; flex-direction: column; justify-content: flex-end; color: #fff; padding: 16px var(--gutter) 18px; overflow: hidden; }
.hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,0.65) 100%); z-index: 0; }
.hero > * { position: relative; z-index: 1; }
.hero__row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 8px; }
.hero__title { font-size: 28px; font-weight: 820; letter-spacing: -0.03em; text-shadow: 0 2px 12px rgba(0,0,0,0.4); }
.hero__back { position: absolute; top: calc(var(--safe-top) + 12px); left: var(--gutter); z-index: 2; background: rgba(0,0,0,0.4); color: #fff; -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); }

.detail { padding: 0 var(--gutter); }
.panel { background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 16px; margin-top: 14px; box-shadow: var(--sh-1); }
.panel__title { font-size: 13px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-mut); font-weight: 700; margin-bottom: 12px; }
.kv { display: grid; grid-template-columns: 120px 1fr; gap: 8px 12px; font-size: 14px; }
.kv dt { color: var(--text-mut); }
.kv dd { font-weight: 600; }
.taglist { display: flex; flex-wrap: wrap; gap: 8px; }
.taglist .badge {max-width: 100%; white-space: normal; overflow-wrap: anywhere; word-break: break-word; text-align: left;}
.prose { color: var(--text-soft); font-size: 15px; line-height: 1.65; }

.timeline { position: relative; padding-left: 28px; }
.timeline::before { content: ""; position: absolute; left: 9px; top: 6px; bottom: 6px; width: 2px; background: var(--border-strong); }
.tl-item { position: relative; padding-bottom: 18px; }
.tl-item:last-child { padding-bottom: 0; }
.tl-item::before { content: ""; position: absolute; left: -23px; top: 3px; width: 14px; height: 14px; border-radius: 50%; background: var(--bg-elev); border: 3px solid var(--brand); }
.tl-item.is-done::before { background: var(--brand); }
.tl-item__date { font-size: 12px; color: var(--text-mut); font-weight: 600; }
.tl-item__title { font-weight: 700; margin-top: 1px; }
.tl-item__detail { color: var(--text-soft); font-size: 13.5px; margin-top: 2px; }

.gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.ev-card { border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; background: var(--bg-sunken); display: flex; flex-direction: column; transition: transform var(--dur-2) var(--ease); }
.ev-card:active { transform: scale(0.97); }
.ev-card__thumb { aspect-ratio: 4 / 3; display: grid; place-items: center; color: var(--text-mut); background: var(--bg-sunken); }
.ev-card__cap { padding: 8px 10px; font-size: 12.5px; font-weight: 600; display: flex; gap: 6px; align-items: center; }
.ev-type { font-size: 10px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--brand-600); }

.profile-head { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 20px var(--gutter); gap: 8px; }
.profile-head .avatar { width: 92px; height: 92px; font-size: 34px; box-shadow: var(--sh-2); }
.profile-name { font-size: 22px; font-weight: 800; letter-spacing: -0.02em; }
.profile-loc { color: var(--text-mut); font-size: 14px; }
.profile-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; padding: 6px var(--gutter); }
.pstat { background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--r-md); padding: 12px 8px; text-align: center; box-shadow: var(--sh-1); }
.pstat__v { font-size: 20px; font-weight: 800; font-variant-numeric: tabular-nums; }
.pstat__l { font-size: 10.5px; color: var(--text-mut); font-weight: 600; margin-top: 2px; }
.risk-ring { width: 84px; height: 84px; }

.skeleton { background: linear-gradient(100deg, var(--bg-sunken) 30%, color-mix(in srgb, var(--bg-sunken) 60%, var(--bg-elev)) 50%, var(--bg-sunken) 70%); background-size: 200% 100%; animation: shimmer 1.3s var(--ease) infinite; border-radius: var(--r-md); }
@keyframes shimmer { to { background-position: -200% 0; } }
.sk-card { height: 230px; border-radius: var(--r-lg); }
.sk-line { height: 12px; margin: 8px 0; }

.state { text-align: center; padding: 56px 24px; color: var(--text-mut); }
.state__icon { width: 54px; height: 54px; margin: 0 auto 12px; color: var(--text-mut); }
.state__title { font-weight: 750; color: var(--text); font-size: 17px; }

.toast { position: fixed; left: 50%; bottom: calc(var(--bottomnav-h) + var(--safe-bottom) + 84px); transform: translateX(-50%) translateY(20px); background: var(--text); color: var(--bg); padding: 11px 18px; border-radius: var(--r-pill); font-size: 13.5px; font-weight: 600; box-shadow: var(--sh-3); opacity: 0; pointer-events: none; transition: opacity var(--dur-2) var(--ease), transform var(--dur-2) var(--ease); z-index: 80; }
.toast.is-show { opacity: 1; transform: translateX(-50%) translateY(0); }

.install-banner { position: fixed; left: var(--gutter); right: var(--gutter); bottom: calc(var(--bottomnav-h) + var(--safe-bottom) + 14px); z-index: 60; background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--sh-3); padding: 14px; display: none; align-items: center; gap: 12px; }
.install-banner.is-show { display: flex; animation: slideUp var(--dur-3) var(--ease); }
@keyframes slideUp { from { transform: translateY(30px); opacity: 0; } to { transform: none; opacity: 1; } }

.app { animation: pageIn var(--dur-3) var(--ease); }
@keyframes pageIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.reveal { opacity: 0; transform: translateY(14px); transition: opacity var(--dur-3) var(--ease), transform var(--dur-3) var(--ease); }
.reveal.is-in { opacity: 1; transform: none; }

#splash { position: fixed; inset: 0; z-index: 200; background: var(--bg); display: grid; place-items: center; transition: opacity var(--dur-3) var(--ease); }
#splash.is-hide { opacity: 0; pointer-events: none; }
.splash-logo { width: 84px; height: 84px; border-radius: 24px; overflow: hidden; box-shadow: var(--sh-fab); animation: pulse 1.4s var(--ease) infinite; }
.splash-logo img { width: 100%; height: 100%; display: block; }
@keyframes pulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.08); } }

.row { display: flex; align-items: center; gap: 8px; }
.wrap { flex-wrap: wrap; }
.mut { color: var(--text-mut); }
.hide { display: none !important; }
.center { text-align: center; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.tabnum { font-variant-numeric: tabular-nums; }

@media (min-width: 820px) {
  :root { --gutter: 28px; --header-h: 64px; }
  body { font-size: 16px; }
  .bottomnav { display: none; }
  .fab-wrap { display: none; }
  .app { padding-bottom: 48px; padding-left: 240px; }
  .appbar { padding-left: 28px; }
  .appbar__nav { display: flex; gap: 4px; margin-left: 18px; }
  .appbar__nav a { padding: 8px 14px; border-radius: var(--r-pill); font-weight: 600; font-size: 14px; color: var(--text-soft); transition: background var(--dur-1) var(--ease); }
  .appbar__nav a:hover { background: var(--bg-sunken); }
  .appbar__nav a.is-active { color: var(--brand-600); background: color-mix(in srgb, var(--brand) 12%, transparent); }

  .sidebar { position: fixed; top: calc(var(--header-h) + var(--safe-top)); left: max(0px, calc(50% - var(--maxw) / 2)); width: 240px; bottom: 0; padding: 18px 14px; border-right: 1px solid var(--border); overflow-y: auto; display: flex; flex-direction: column; }
  .sidebar__item { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border-radius: var(--r-md); color: var(--text-soft); font-weight: 600; transition: background var(--dur-1) var(--ease); }
  .sidebar__item:hover { background: var(--bg-sunken); }
  .sidebar__item.is-active { background: color-mix(in srgb, var(--brand) 12%, transparent); color: var(--brand-600); }
  .sidebar__footer { margin-top: auto; display: flex; align-items: center; gap: 10px; padding: 14px 12px 6px; border-top: 1px solid var(--border); }
  .sidebar__poweredlogo { width: 30px; height: 30px; flex: none; border-radius: 8px; }
  .sidebar__poweredtext { font-size: 12.5px; font-weight: 700; color: var(--text-soft); letter-spacing: -0.01em; }

  .stat-grid { grid-template-columns: repeat(5, 1fr); }
  .cat-grid { grid-template-columns: repeat(3, 1fr); }
  .case-list { grid-template-columns: repeat(3, 1fr); }
  .case-rail .case-card { flex-basis: 300px; }
  .gallery { grid-template-columns: repeat(4, 1fr); }
  .hero { aspect-ratio: 21 / 9; border-radius: var(--r-xl); margin: 16px 0; }
  .detail { display: grid; grid-template-columns: 1.6fr 1fr; gap: 16px; align-items: start; }
  .detail .panel { margin-top: 16px; }
  .detail__main, .detail__side { display: contents; }
  .profile-stats { grid-template-columns: repeat(4, 1fr); max-width: 520px; margin: 0 auto; }
  .search-overlay .search-bar, .search-overlay .search-results { max-width: 760px; margin-left: auto; margin-right: auto; width: 100%; }
}
@media (max-width: 819px) { .sidebar, .appbar__nav { display: none; } }

@media (min-width: 1100px) {
  .case-list { grid-template-columns: repeat(4, 1fr); }
}

.qv-overlay { position: fixed; inset: 0; z-index: 75; display: flex; align-items: flex-end; justify-content: center; background: rgba(0,0,0,0.5); -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px); opacity: 0; pointer-events: none; transition: opacity var(--dur-2) var(--ease); }
.qv-overlay.is-open { opacity: 1; pointer-events: auto; }
.qv-card { position: relative; background: var(--bg-elev); width: 100%; max-width: 520px; max-height: 88dvh; overflow-y: auto; border-radius: var(--r-xl) var(--r-xl) 0 0; box-shadow: var(--sh-3); transform: translateY(28px); transition: transform var(--dur-2) var(--ease); -webkit-overflow-scrolling: touch; }
.qv-overlay.is-open .qv-card { transform: none; }
.qv-close { position: absolute; top: 12px; right: 12px; z-index: 2; background: rgba(0,0,0,0.42); color: #fff; -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); }
.qv-media { position: relative; aspect-ratio: 16 / 9; display: grid; place-items: center; color: #fff; font-weight: 800; font-size: 34px; letter-spacing: -0.02em; overflow: hidden; border-radius: var(--r-xl) var(--r-xl) 0 0; }
.qv-media img { width: 100%; height: 100%; object-fit: cover; }
.qv-body { padding: 16px var(--gutter) calc(var(--safe-bottom) + 18px); display: flex; flex-direction: column; gap: 12px; }
.qv-name { font-size: 21px; font-weight: 800; letter-spacing: -0.02em; }
.qv-info { display: grid; grid-template-columns: 116px 1fr; gap: 8px 12px; font-size: 14px; margin: 0; }
.qv-info dt { color: var(--text-mut); }
.qv-info dd { font-weight: 600; margin: 0; }
.qv-desc { color: var(--text-soft); font-size: 14px; line-height: 1.6; }
.qv-actions { display: flex; flex-direction: column; gap: 10px; margin-top: 4px; }
.btn--block { width: 100%; justify-content: center; }
@media (min-width: 820px) { .qv-overlay { align-items: center; } .qv-card { border-radius: var(--r-xl); } }

@media (max-width: 819px) {
  #cat-chips > .cat-chip:nth-child(n+4) { display: none; }
}
@media (min-width: 820px) {
  #cat-chips { flex-wrap: wrap; overflow: visible; }
}