:root{
  --ink:#0e0f12; --ink2:#16181c; --surface:#1b1f25; --surface2:#232932;
  --line:rgba(255,255,255,.08); --line2:rgba(255,255,255,.16);
  --silver:#c6cfdb; --brass:#e0a642; --teal:#4fb99a; --coral:#d9714e;
  --txt:#eef1f5; --muted:#99a1ac; --faint:#6b727c;
  --r:14px; --r-lg:18px;
  --shell:460px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--ink);
  color:var(--txt);
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  font-size:15px; line-height:1.5;
  -webkit-font-smoothing:antialiased;
  padding-bottom:84px;
}
.shell{max-width:var(--shell);margin:0 auto;min-height:100vh;position:relative}
.num{font-family:'Space Grotesk',sans-serif;font-variant-numeric:tabular-nums;letter-spacing:-.01em}
button,input,select,textarea{font:inherit;color:inherit}
a{color:var(--silver)}

/* top bar */
.topbar{
  position:sticky;top:0;z-index:20;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px 12px;
  background:linear-gradient(180deg,var(--ink) 70%,rgba(14,15,18,0));
}
.brand{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:20px;letter-spacing:.4px}
.brand .dot{color:var(--brass)}
.pts{
  display:flex;align-items:center;gap:6px;
  background:var(--surface);border:1px solid var(--line);
  padding:5px 11px;border-radius:20px;font-size:13px;font-weight:600;
}
.pts svg,.pts i{color:var(--brass)}

.view{padding:4px 18px 24px;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* search + chips */
.search{
  display:flex;align-items:center;gap:9px;
  background:var(--surface);border:1px solid var(--line);
  border-radius:12px;padding:10px 13px;margin-bottom:13px;color:var(--muted);
}
.search input{background:none;border:none;outline:none;width:100%;color:var(--txt)}
.search input::placeholder{color:var(--faint)}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.chip{
  font-size:13px;color:var(--muted);background:none;
  border:1px solid var(--line2);padding:5px 13px;border-radius:20px;cursor:pointer;
}
.chip.on{background:var(--silver);color:#15171b;border-color:var(--silver);font-weight:600}

/* list card */
.card{
  position:relative;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r);
  padding:12px 13px;margin-bottom:9px;
  display:flex;align-items:center;gap:12px;cursor:pointer;
  transition:border-color .15s,transform .05s;
}
.card::before{
  content:"";position:absolute;inset:0 0 auto 0;height:1px;
  border-radius:var(--r) var(--r) 0 0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);
}
.card:active{transform:scale(.992)}
.card.new{border-color:rgba(224,166,66,.3)}
.thumb{
  width:42px;height:42px;border-radius:10px;flex:none;
  background:var(--surface2);display:flex;align-items:center;justify-content:center;
  color:var(--faint);font-size:21px;overflow:hidden;
}
.thumb img{width:100%;height:100%;object-fit:cover}
.cbody{flex:1;min-width:0}
.cname{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.csub{font-size:12px;color:var(--muted);margin-top:1px}
.score{text-align:center;min-width:42px}
.score .v{font-size:23px;font-weight:600;color:var(--brass);line-height:1}
.score .l{font-size:10px;color:var(--faint);margin-top:1px}
.badge-new{
  font-size:10px;font-weight:700;color:#15171b;background:var(--silver);
  padding:3px 9px;border-radius:20px;letter-spacing:.4px;
}

/* generic blocks */
.section-label{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--faint);margin:18px 0 8px}
.box{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:14px}
.quote{font-size:13px;color:#cdd3db;background:var(--surface);padding:9px 12px;border-radius:0 8px 8px 0;margin-bottom:7px}
.quote.me{border-left:2px solid var(--brass)}
.quote.you{border-left:2px solid var(--silver)}

.btn{
  display:flex;align-items:center;justify-content:center;gap:8px;width:100%;
  background:linear-gradient(180deg,#ecb957,var(--brass));color:#1b1407;
  border:none;border-radius:12px;padding:14px;font-weight:600;font-size:15px;
  cursor:pointer;transition:filter .15s,transform .05s;
}
.btn:active{transform:scale(.99)}
.btn:disabled{filter:grayscale(.6) brightness(.7);cursor:not-allowed}
.btn.ghost{background:none;border:1px solid var(--line2);color:var(--txt)}
.btn.danger{background:none;border:1px solid rgba(217,113,78,.5);color:var(--coral)}

.field{margin-bottom:14px}
.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}
.input,select.input,textarea.input{
  width:100%;background:var(--surface);border:1px solid var(--line2);
  border-radius:11px;padding:12px;outline:none;
}
.input:focus{border-color:var(--brass)}
textarea.input{resize:vertical;min-height:60px}
.photo-drop{
  border:1px dashed var(--line2);border-radius:12px;padding:22px;text-align:center;
  color:var(--faint);cursor:pointer;
}
.photo-drop.has{padding:0;border-style:solid;overflow:hidden}
.photo-drop img{width:100%;max-height:200px;object-fit:cover;display:block}

/* rating sliders */
.cat{margin-bottom:15px}
.cat-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.cat-top .lbl{font-size:14px}
.cat-top .val{font-family:'Space Grotesk',sans-serif;font-size:16px;font-weight:600;color:var(--brass)}
input[type=range]{
  -webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:6px;
  background:var(--surface2);outline:none;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:20px;height:20px;border-radius:50%;
  background:linear-gradient(180deg,#f0f3f7,var(--silver));border:1px solid #fff3;cursor:pointer;
}
input[type=range]::-moz-range-thumb{
  width:20px;height:20px;border:none;border-radius:50%;
  background:var(--silver);cursor:pointer;
}

/* reveal */
.duel{display:flex;gap:11px;margin-bottom:13px}
.duel .seat{
  flex:1;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:15px 10px;text-align:center;
}
.duel .seat.mine{border-color:rgba(224,166,66,.4)}
.duel .seat .who{font-size:12px;color:var(--muted)}
.duel .seat .big{font-family:'Space Grotesk',sans-serif;font-size:38px;font-weight:600;line-height:1.1}
.duel .seat.mine .big{color:var(--brass)}
.duel .seat .big{color:var(--silver)}
.stat2{display:flex;gap:11px;margin-bottom:14px}
.stat2 .s{flex:1;background:var(--surface);border-radius:11px;padding:11px;text-align:center}
.stat2 .s .k{font-size:11px;color:var(--muted)}
.stat2 .s .v{font-family:'Space Grotesk',sans-serif;font-size:19px;font-weight:600;margin-top:2px}
.v-coral{color:var(--coral)} .v-teal{color:var(--teal)} .v-brass{color:var(--brass)}
.win{
  display:flex;align-items:center;gap:11px;background:var(--surface);
  border:1px solid rgba(224,166,66,.35);border-radius:var(--r);padding:13px;margin-bottom:14px;
}
.win i{font-size:22px;color:var(--brass)}
.reveal-in{animation:pop .4s cubic-bezier(.2,.7,.3,1.4)}
@keyframes pop{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:none}}

.meter{height:6px;background:var(--surface2);border-radius:4px;overflow:hidden;margin-top:6px}
.meter > span{display:block;height:100%;border-radius:4px}

/* bottom nav */
.nav{
  position:fixed;left:0;right:0;bottom:0;z-index:30;
  max-width:var(--shell);margin:0 auto;
  display:flex;justify-content:space-around;align-items:center;
  background:rgba(22,24,28,.92);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);padding:9px 0 calc(9px + env(safe-area-inset-bottom));
}
.nav button{background:none;border:none;color:var(--faint);font-size:23px;cursor:pointer;padding:6px 14px}
.nav button.on{color:var(--silver)}
.nav .add{
  width:46px;height:46px;border-radius:50%;margin-top:-16px;
  background:linear-gradient(180deg,#ecb957,var(--brass));color:#1b1407;
  display:flex;align-items:center;justify-content:center;font-size:24px;
  box-shadow:0 6px 18px rgba(224,166,66,.3);
}

/* login / setup */
.center-wrap{padding:48px 22px;display:flex;flex-direction:column;min-height:100vh}
.hero-mark{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:30px;letter-spacing:.5px;margin-bottom:4px}
.hero-mark .dot{color:var(--brass)}
.hero-sub{color:var(--muted);margin-bottom:34px}
.userpick{display:flex;flex-direction:column;gap:9px;margin-bottom:20px}
.userpick .u{
  display:flex;align-items:center;gap:12px;background:var(--surface);
  border:1px solid var(--line2);border-radius:12px;padding:13px;cursor:pointer;
}
.userpick .u.on{border-color:var(--brass)}
.userpick .av{
  width:36px;height:36px;border-radius:50%;background:var(--surface2);
  display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--silver);
}
.pin{letter-spacing:6px;text-align:center;font-size:20px}

.empty{text-align:center;color:var(--muted);padding:50px 20px}
.empty i{font-size:40px;color:var(--faint);display:block;margin-bottom:12px}
.toast{
  position:fixed;left:50%;bottom:96px;transform:translateX(-50%);
  background:var(--surface2);border:1px solid var(--line2);color:var(--txt);
  padding:10px 16px;border-radius:10px;font-size:14px;z-index:50;
  max-width:90%;
}
.err{color:var(--coral);font-size:13px;margin-top:8px;min-height:18px}
.muted{color:var(--muted)}
.row-actions{display:flex;gap:10px;margin-top:18px}
@keyframes spin{to{transform:rotate(360deg)}}
.btn .ti-loader-2{display:inline-block;animation:spin .8s linear infinite}
.navbadge{position:absolute;top:0;right:8px;background:var(--brass);color:#1b1407;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.qa{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}
.qa button{flex:1;min-width:70px;background:var(--surface2);border:1px solid var(--line2);color:var(--txt);border-radius:11px;padding:10px 6px;font-size:12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px}
.qa button:active{transform:scale(.97)}
.qa button:disabled{opacity:.4;cursor:not-allowed}
.qa button i{font-size:18px}
.qa button.acc{border-color:rgba(224,166,66,.5);color:var(--brass)}
.stepper{display:inline-flex;align-items:center;border:1px solid var(--line2);border-radius:10px;overflow:hidden}
.stepper button{background:var(--surface2);border:none;color:var(--txt);width:34px;height:34px;font-size:18px;cursor:pointer}
.stepper button:active{background:var(--surface)}
.stepper span{min-width:32px;text-align:center;font-size:15px}
