/* VerifyUGC mobile app (m.verifyugc.dev / /m). A dedicated, app-like dark UI —
   single column, large tap targets, sticky search, fixed bottom tab bar. Built on
   the shared design tokens (/assets/tokens.css); this file owns only the mobile
   shell + view components. No desktop chrome is loaded. */

/* The font-family tokens live in v7/chrome.css (desktop chrome), which this app
   intentionally does NOT load — only the @font-face sheet (fonts.css) + tokens.css.
   Define them here so the brand faces actually apply. Mirrors chrome.css. */
:root{
  --sans:"Inter",system-ui,sans-serif;
  --display:"Space Grotesk","Inter",sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
.m-body{
  margin:0;
  min-height:100dvh;
  background:
    radial-gradient(1100px 520px at 50% -8%, rgba(168,85,247,.16), transparent 60%),
    radial-gradient(900px 480px at 100% 0%, rgba(59,130,246,.12), transparent 55%),
    var(--bg);
  background-attachment:fixed;
  color:var(--text);
  font-family:var(--sans, "Inter", system-ui, sans-serif);
  -webkit-font-smoothing:antialiased;
  /* room for the fixed top bar + bottom tab bar */
  padding:0 0 calc(72px + env(safe-area-inset-bottom));
  overscroll-behavior-y:none;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

/* ===== top bar ===== */
.m-topbar{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  height:calc(54px + env(safe-area-inset-top));
  padding:env(safe-area-inset-top) 16px 0;
  background:color-mix(in srgb, var(--bg) 78%, transparent);
  -webkit-backdrop-filter:saturate(140%) blur(14px);backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--border);
}
.m-brand{display:flex;align-items:center;gap:8px;font-family:var(--display);font-weight:700;font-size:1.02rem;letter-spacing:-.01em}
.m-brand__mark{display:grid;place-items:center;width:30px;height:30px;
  filter:drop-shadow(0 4px 14px rgba(168,85,247,.4))}
.m-brand__mark svg{width:30px;height:30px;display:block}
.m-brand__word b{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.m-topbar__right{display:flex;align-items:center;gap:8px;min-height:36px}

/* ===== view container ===== */
.m-view{display:block;padding:18px 16px 24px;max-width:560px;margin:0 auto;animation:m-fade .26s var(--ease,ease)}
@keyframes m-fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.m-view{animation:none}}
.m-h1{font-family:var(--display);font-size:1.6rem;line-height:1.15;font-weight:700;letter-spacing:-.02em;margin:6px 0 6px}
.m-h1 .grad{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.m-sub{color:var(--dim);font-size:.95rem;line-height:1.5;margin:0 0 18px}
.m-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--a1);margin-bottom:6px}
.m-eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--a1);box-shadow:0 0 10px var(--a1)}
.m-section-title{font-family:var(--display);font-size:.82rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--faint);margin:22px 2px 10px}

/* ===== search ===== */
.m-searchbar{position:sticky;top:calc(54px + env(safe-area-inset-top));z-index:30;
  margin:0 -16px 4px;padding:10px 16px;background:linear-gradient(var(--bg),color-mix(in srgb,var(--bg) 30%,transparent))}
.m-search{position:relative;display:flex;align-items:center}
.m-search__icon{position:absolute;left:15px;width:20px;height:20px;color:var(--faint);pointer-events:none}
.m-search input{
  width:100%;height:54px;padding:0 48px 0 46px;
  background:var(--surface);border:1.5px solid var(--border2);border-radius:var(--r-lg,16px);
  color:var(--text);font-size:16px;font-weight:500;outline:none;
  transition:border-color .18s, box-shadow .18s;
}
.m-search input::placeholder{color:var(--faint)}
.m-search input:focus{border-color:var(--a1);box-shadow:0 0 0 4px color-mix(in srgb,var(--a1) 18%,transparent)}
.m-search__clear{position:absolute;right:9px;width:34px;height:34px;display:none;place-items:center;
  border:0;background:transparent;color:var(--faint);border-radius:50%;cursor:pointer}
.m-search__clear.show{display:grid}
.m-search__clear:hover{color:var(--text)}
.m-search__clear svg{width:18px;height:18px}
.m-search-hint{color:var(--faint);font-size:.82rem;margin:9px 4px 2px}

/* chips for quick examples */
.m-chips{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 4px}
.m-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:var(--r-pill);
  background:var(--surface);border:1px solid var(--border);color:var(--dim);font-size:.84rem;font-weight:600;cursor:pointer;
  transition:border-color .15s,color .15s,background .15s}
.m-chip:hover,.m-chip:active{border-color:var(--a1);color:var(--text)}

/* ===== generic card ===== */
.m-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg,16px);
  padding:16px;box-shadow:0 12px 34px rgba(0,0,0,.34);overflow:hidden}
.m-card+.m-card{margin-top:12px}
.m-card__rail{position:absolute;inset:0 auto 0 0;width:4px}

/* ===== result card (the hero payoff) ===== */
.m-result{padding:0}
.m-result__head{display:flex;align-items:center;gap:14px;padding:18px 16px}
.m-verdict-emblem{flex:0 0 auto;width:54px;height:54px;border-radius:15px;display:grid;place-items:center}
.m-verdict-emblem svg{width:28px;height:28px}
.m-result__head h2{margin:0;font-family:var(--display);font-size:1.18rem;font-weight:700;letter-spacing:-.01em}
.m-result__head p{margin:3px 0 0;font-size:.86rem;color:var(--dim)}
.m-result__q{font-weight:700;color:var(--text);word-break:break-word}
.m-result__body{border-top:1px solid var(--border);padding:6px 16px 16px}

/* verdict theming */
.v-clear .m-verdict-emblem{background:color-mix(in srgb,var(--success) 16%,transparent);color:var(--success)}
.v-clear .m-card__rail{background:var(--success)}
.v-banned .m-verdict-emblem{background:color-mix(in srgb,var(--danger) 18%,transparent);color:var(--danger)}
.v-banned .m-card__rail{background:var(--danger)}
.v-watch .m-verdict-emblem{background:color-mix(in srgb,var(--warning) 18%,transparent);color:var(--warning)}
.v-watch .m-card__rail{background:var(--warning)}
.v-unknown .m-verdict-emblem{background:var(--surface2);color:var(--dim)}
.v-unknown .m-card__rail{background:var(--border2)}

/* per-platform hit rows */
.m-hit{display:flex;align-items:flex-start;gap:12px;padding:13px 0;border-top:1px solid var(--border)}
.m-hit:first-child{border-top:0}
.m-hit__plat{flex:0 0 auto;width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
  background:var(--surface2);border:1px solid var(--border);font-size:.7rem;font-weight:800;text-transform:uppercase;color:var(--dim)}
.m-hit__main{flex:1;min-width:0}
.m-hit__name{font-weight:700;font-size:.95rem;word-break:break-word}
.m-hit__meta{font-size:.82rem;color:var(--dim);margin-top:2px}
.m-hit__tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:7px}

/* status pills */
.m-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--r-pill);
  font-size:.72rem;font-weight:800;letter-spacing:.02em;text-transform:uppercase;line-height:1;white-space:nowrap}
.m-pill svg{width:12px;height:12px}
.p-danger{background:color-mix(in srgb,var(--danger) 16%,transparent);color:var(--danger)}
.p-warn{background:color-mix(in srgb,var(--warning) 16%,transparent);color:var(--warning)}
.p-ok{background:color-mix(in srgb,var(--success) 16%,transparent);color:var(--success)}
.p-info{background:color-mix(in srgb,var(--info) 16%,transparent);color:var(--info)}
.p-mute{background:var(--surface2);color:var(--dim)}

/* suggestions */
.m-suggest{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.m-suggest button{padding:8px 12px;border-radius:var(--r-pill);background:var(--surface2);
  border:1px solid var(--border);color:var(--a1);font-weight:700;font-size:.84rem;cursor:pointer}

/* ===== trust meter ===== */
.m-meter{margin-top:12px}
.m-meter__track{height:10px;border-radius:var(--r-pill);background:var(--surface2);overflow:hidden;border:1px solid var(--border)}
.m-meter__fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--a1),var(--a2));transition:width .5s var(--ease,ease)}
.m-meter__row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.m-meter__score{font-family:var(--display);font-weight:800;font-size:1.5rem}
.m-meter__score small{font-size:.8rem;color:var(--faint);font-weight:600}

/* ===== buttons ===== */
.m-btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;width:100%;
  min-height:52px;padding:0 18px;border-radius:var(--r-md,14px);border:0;cursor:pointer;
  font-weight:700;font-size:1rem;letter-spacing:.01em;transition:transform .12s, filter .15s, background .15s}
.m-btn:active{transform:scale(.985)}
.m-btn--primary{color:#fff;background:linear-gradient(135deg,var(--a1),var(--a2));box-shadow:0 10px 26px rgba(168,85,247,.34)}
.m-btn--primary:hover{filter:brightness(1.06)}
.m-btn--discord{color:#fff;background:#5865F2;box-shadow:0 10px 26px rgba(88,101,242,.34)}
.m-btn--ghost{background:var(--surface);border:1px solid var(--border2);color:var(--text)}
.m-btn svg{width:20px;height:20px}
.m-btn[disabled]{opacity:.55;pointer-events:none}

/* small inline action (top bar / mark all read) */
.m-act{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 13px;border-radius:var(--r-pill);
  background:var(--surface);border:1px solid var(--border2);color:var(--dim);font-weight:700;font-size:.82rem;cursor:pointer}
.m-act:hover{color:var(--text);border-color:var(--a1)}
.m-act svg{width:15px;height:15px}
.m-avatar-sm{width:32px;height:32px;border-radius:50%;object-fit:cover;border:1px solid var(--border2);background:var(--surface2)}

/* ===== list rows (alerts / reports) ===== */
.m-row{display:flex;gap:13px;padding:14px 15px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-md,14px);align-items:flex-start}
.m-row+.m-row{margin-top:10px}
.m-row--unread{border-color:color-mix(in srgb,var(--a1) 45%,var(--border));background:color-mix(in srgb,var(--a1) 6%,var(--surface))}
.m-row__dot{flex:0 0 auto;width:9px;height:9px;border-radius:50%;margin-top:6px;background:transparent}
.m-row--unread .m-row__dot{background:var(--a1);box-shadow:0 0 8px var(--a1)}
.m-row__icon{flex:0 0 auto;width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:var(--surface2);color:var(--a1)}
.m-row__icon svg{width:20px;height:20px}
.m-row__main{flex:1;min-width:0}
.m-row__title{font-weight:700;font-size:.95rem;line-height:1.3}
.m-row__body{font-size:.86rem;color:var(--dim);margin-top:3px;line-height:1.45}
.m-row__time{font-size:.74rem;color:var(--faint);margin-top:6px;font-variant-numeric:tabular-nums}
.m-row__meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px}

/* ===== profile ===== */
.m-prof{text-align:center;padding:24px 16px 18px}
.m-prof__avatar{width:84px;height:84px;border-radius:50%;margin:0 auto 12px;object-fit:cover;
  border:2px solid var(--border2);background:var(--surface2);display:grid;place-items:center;color:var(--faint);font-size:2rem;font-weight:800;font-family:var(--display)}
.m-prof__handle{font-family:var(--display);font-size:1.35rem;font-weight:700}
.m-prof__sub{color:var(--dim);font-size:.88rem;margin-top:3px}
.m-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:4px}
.m-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md,14px);padding:14px 8px;text-align:center}
.m-stat__num{font-family:var(--display);font-weight:800;font-size:1.32rem;line-height:1}
.m-stat__lbl{font-size:.7rem;color:var(--faint);text-transform:uppercase;letter-spacing:.06em;margin-top:6px;font-weight:700}

/* badge grid */
.m-badges{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:12px}
.m-badge{text-align:center}
.m-badge__ico{width:100%;aspect-ratio:1;border-radius:14px;display:grid;place-items:center;
  background:var(--surface);border:1px solid var(--border);font-size:1.5rem}
.m-badge--earned .m-badge__ico{border-color:color-mix(in srgb,var(--a1) 50%,transparent);
  background:color-mix(in srgb,var(--a1) 10%,var(--surface));box-shadow:0 0 16px rgba(168,85,247,.18)}
.m-badge--locked{opacity:.4;filter:grayscale(.6)}
.m-badge__name{font-size:.64rem;color:var(--faint);margin-top:5px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ===== empty + states ===== */
.m-empty{text-align:center;padding:46px 24px;color:var(--dim)}
.m-empty__ico{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;margin:0 auto 16px;
  background:var(--surface);border:1px solid var(--border);color:var(--faint)}
.m-empty__ico svg{width:30px;height:30px}
.m-empty h3{margin:0 0 6px;font-family:var(--display);font-size:1.1rem;color:var(--text);font-weight:700}
.m-empty p{margin:0 auto;max-width:300px;font-size:.9rem;line-height:1.5}
.m-error{border:1px solid color-mix(in srgb,var(--danger) 40%,transparent);background:color-mix(in srgb,var(--danger) 8%,var(--surface));
  border-radius:var(--r-md);padding:14px 16px;color:var(--text);font-size:.9rem;display:flex;gap:10px;align-items:flex-start}
.m-error svg{width:20px;height:20px;color:var(--danger);flex:0 0 auto}

/* ===== loading: skeleton + spinner ===== */
.m-skeleton{padding:8px 0}
.m-skel-line,.m-skel-card{background:linear-gradient(100deg,var(--surface) 30%,var(--surface2) 50%,var(--surface) 70%);
  background-size:200% 100%;animation:m-shimmer 1.3s linear infinite;border-radius:10px}
.m-skel-line{height:14px;margin:0 0 12px}
.m-skel-card{height:120px;margin-top:18px;border-radius:var(--r-lg)}
@keyframes m-shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
@media (prefers-reduced-motion:reduce){.m-skel-line,.m-skel-card{animation:none}}
.m-spin{width:20px;height:20px;border:2.5px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:m-rot .7s linear infinite}
@keyframes m-rot{to{transform:rotate(360deg)}}
.m-inline-loading{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--dim);padding:30px;font-size:.9rem}
.m-inline-loading .m-spin{border-color:rgba(255,255,255,.18);border-top-color:var(--a1)}

/* ===== bottom tab bar ===== */
.m-tabbar{
  position:fixed;left:0;right:0;bottom:0;z-index:50;
  display:grid;grid-template-columns:repeat(4,1fr);
  padding:6px 8px env(safe-area-inset-bottom);
  background:color-mix(in srgb, var(--bg2) 84%, transparent);
  -webkit-backdrop-filter:saturate(150%) blur(18px);backdrop-filter:saturate(150%) blur(18px);
  border-top:1px solid var(--border);
}
.m-tab{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  padding:8px 0 7px;color:var(--faint);border-radius:14px;-webkit-tap-highlight-color:transparent;transition:color .15s}
.m-tab__icon{display:grid;place-items:center}
.m-tab__icon svg{width:24px;height:24px;transition:transform .18s}
.m-tab__label{font-size:.66rem;font-weight:700;letter-spacing:.01em}
.m-tab[aria-current="page"]{color:var(--a1)}
.m-tab[aria-current="page"] .m-tab__icon svg{transform:translateY(-1px) scale(1.06)}
.m-tab[aria-current="page"]::before{content:"";position:absolute;top:2px;width:26px;height:3px;border-radius:3px;
  background:var(--a1);box-shadow:0 0 12px var(--a1)}
.m-tab:active .m-tab__icon svg{transform:scale(.9)}
.m-tab__badge{position:absolute;top:5px;left:calc(50% + 7px);min-width:8px;height:8px;border-radius:5px;
  background:var(--danger);box-shadow:0 0 0 2px var(--bg2)}
.m-tab__badge[data-count]{height:15px;min-width:15px;padding:0 4px;top:2px;font-size:.6rem;font-weight:800;
  color:#fff;display:grid;place-items:center;line-height:1}

/* ===== toast ===== */
.m-toast{position:fixed;left:50%;bottom:calc(80px + env(safe-area-inset-bottom));
  transform:translateX(-50%) translateY(20px);z-index:60;opacity:0;pointer-events:none;
  background:var(--surface2);border:1px solid var(--border2);color:var(--text);
  padding:12px 18px;border-radius:var(--r-pill);font-size:.88rem;font-weight:600;box-shadow:0 14px 40px rgba(0,0,0,.5);
  transition:opacity .22s, transform .22s}
.m-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* small helpers */
.m-muted{color:var(--dim)}
.m-mt{margin-top:16px}
.m-center{text-align:center}
.m-divider{height:1px;background:var(--border);margin:18px 0}
.m-verif{display:inline-flex;align-items:center;gap:5px;color:var(--info);font-weight:700;font-size:.8rem}
.m-verif svg{width:15px;height:15px}
