/* ============================================================
   WhoIsPlaying — design system v2
   Phone-first · app-like · light & high-contrast
   ============================================================ */
:root{
  --bg:#eef0f7; --surface:#ffffff; --surface2:#f3f4fa;
  --ink:#13151d; --ink2:#454b5c; --mut:#697086;
  --line:#e5e7f0; --line2:#d3d7e4;
  --accent:#6c4cff; --accent-ink:#ffffff; --accent-soft:#efeaff; --accent-press:#5a3ce6;
  --ok:#16a34a;
  --shadow:0 6px 22px -10px rgba(28,30,60,.28);
  --shadow-lg:0 16px 40px -16px rgba(28,30,60,.4);
  --app:480px;
  --nav-h:64px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;overflow-x:hidden}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);color:var(--ink);
  font-family:'Inter',system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:#fff}

/* app shell — phone-width column, centered everywhere */
.app{position:relative;max-width:var(--app);margin:0 auto;min-height:100vh;background:var(--bg);
  padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom) + 14px);
  box-shadow:0 0 60px -20px rgba(0,0,0,.25)}
.pad{padding:0 18px}

.display{font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:-.01em}
.eyebrow{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.mut{color:var(--mut)}

/* top bar */
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;background:rgba(238,240,247,.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.logo{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.05rem;color:var(--ink)}
.logo b{color:var(--accent)} .logo .net{color:var(--mut);font-weight:500}
.topbar .mini{font-size:.8rem;color:var(--mut);font-weight:600}

/* buttons */
.btn{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;min-height:54px;
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.02rem;border:0;border-radius:15px;cursor:pointer;
  transition:transform .12s, box-shadow .15s, background .15s;text-align:center}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 10px 22px -10px var(--accent)}
.btn-primary:active{background:var(--accent-press)}
.btn-ghost{background:var(--surface);color:var(--ink);border:1.5px solid var(--line2)}
.btn-inline{display:inline-flex;width:auto;padding:0 22px;min-height:48px}
.btn-sm{min-height:44px;font-size:.92rem;padding:0 18px;border-radius:12px;width:auto;display:inline-flex}

/* cards/panels */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow)}
.section{padding:26px 18px 6px}
.section h2{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.4rem;letter-spacing:-.01em}
.section .sub{color:var(--mut);margin-top:4px;font-size:.96rem}

/* form bits */
.field{margin-bottom:18px}
label.lbl{display:block;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.82rem;color:var(--ink2);margin-bottom:9px}
input[type=text],input[type=search]{width:100%;min-height:54px;background:var(--surface);border:1.5px solid var(--line2);border-radius:14px;
  color:var(--ink);padding:0 16px;font-family:inherit;font-size:16px;transition:border-color .15s, box-shadow .15s}
input::placeholder{color:#9aa0b2}
input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.hint{color:var(--mut);font-size:.84rem;margin-top:8px}
.count{float:right;color:var(--mut);font-size:.8rem;font-weight:500}

.chips{display:flex;flex-wrap:wrap;gap:9px}
.opt{font-weight:600;font-size:.92rem;border:1.5px solid var(--line2);background:var(--surface);color:var(--ink2);
  padding:11px 16px;border-radius:12px;cursor:pointer;transition:.14s;user-select:none;display:inline-flex;align-items:center;min-height:46px}
.opt:active{transform:scale(.97)}
.opt.on{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 8px 18px -8px var(--accent)}

/* ============ FULL CARD (showpiece: profile + create preview) ============ */
.card{position:relative;border-radius:20px;overflow:hidden;background:var(--surface);
  border:1px solid var(--line);box-shadow:var(--shadow-lg)}
.card .band{background:var(--acc,#6c4cff);padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.card .tier{display:inline-flex;align-items:center;gap:8px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:#fff}
.card .tier .dot{width:9px;height:9px;border-radius:50%;background:#fff;opacity:.9}
.card .plats{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.card .plat{font-weight:700;font-size:.66rem;letter-spacing:.02em;border-radius:6px;padding:4px 8px;color:#fff;background:rgba(255,255,255,.22)}
.card .body{padding:18px}
.card .gt{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(1.7rem,8vw,2.3rem);line-height:1.02;letter-spacing:-.02em;color:var(--ink);word-break:break-word}
.card .handle{font-size:.82rem;color:var(--acc,#6c4cff);font-weight:600;margin-top:6px;word-break:break-all}
.card .c-games{display:flex;flex-wrap:wrap;gap:7px;margin-top:15px}
.card .c-game{font-weight:600;font-size:.82rem;background:var(--surface2);border:1px solid var(--line);border-radius:9px;padding:7px 11px;color:var(--ink2)}
.card .c-meta{margin-top:13px}
.card .pill{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line2);border-radius:10px;padding:9px 13px;font-size:.84rem;font-weight:600;background:var(--surface);color:var(--ink2)}
.card .pill .ic{color:var(--acc,#6c4cff)}
.card .c-line{margin-top:13px;color:var(--ink2);font-size:.92rem}
.card .c-foot{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.card .c-foot .wm{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:.82rem;color:var(--ink)}
.card .c-foot .wm b{color:var(--acc,#6c4cff)}
.card .c-foot .url{font-size:.74rem;color:var(--mut);font-weight:500}

/* ============ PLAYER ROW (browse / home feed) ============ */
.prow{display:flex;align-items:stretch;gap:0;background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:12px;transition:transform .12s}
.prow:active{transform:scale(.99)}
.prow .bar{width:7px;background:var(--acc,#6c4cff);flex:none}
.prow .in{flex:1;padding:14px 14px 14px 13px;min-width:0}
.prow .r1{display:flex;align-items:center;justify-content:space-between;gap:10px}
.prow .name{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.12rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.prow .vibe-tag{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#fff;background:var(--acc,#6c4cff);padding:4px 9px;border-radius:999px;flex:none}
.prow .games{color:var(--ink2);font-size:.9rem;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.prow .r3{display:flex;align-items:center;gap:8px;margin-top:9px;flex-wrap:wrap}
.prow .tag{font-size:.72rem;font-weight:600;color:var(--mut);background:var(--surface2);border:1px solid var(--line);border-radius:7px;padding:3px 8px}
.prow .go{margin-left:auto;color:var(--acc,#6c4cff);font-weight:700;font-size:.82rem;white-space:nowrap}

/* bottom tab nav */
.tabbar{position:fixed;left:50%;transform:translateX(-50%);bottom:0;width:100%;max-width:var(--app);z-index:30;
  display:flex;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom)}
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;height:var(--nav-h);
  color:var(--mut);font-size:.7rem;font-weight:600;letter-spacing:.01em}
.tabbar a svg{width:23px;height:23px;stroke:var(--mut);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.tabbar a.on{color:var(--accent)} .tabbar a.on svg{stroke:var(--accent)}
.tabbar a.create{color:var(--accent)} .tabbar a.create svg{stroke:var(--accent)}

/* misc */
.foot-note{text-align:center;color:var(--mut);font-size:.82rem;padding:26px 18px 8px}
.foot-note a{color:var(--accent);font-weight:600}
.center{text-align:center}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
