/* Auction Assistant — dark, mobile-first, big tap targets */
:root{
  --bg:#0d1117; --panel:#161b22; --panel2:#1c2430; --line:#2a3341;
  --txt:#e6edf3; --muted:#8b98a5; --star:#f5c451; --mid:#58a6ff; --low:#7d8896;
  --green:#2ea043; --green2:#3fb950; --amber:#d29922; --red:#e5534b; --blue:#388bfd;
  --mine:#a371f7;
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--txt);font:16px/1.4 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;-webkit-tap-highlight-color:transparent;padding-bottom:40px}
b{font-weight:700}
.muted{color:var(--muted)}
.hidden{display:none!important}
code{background:var(--panel2);padding:1px 6px;border-radius:6px;font-size:.85em}

/* top bar */
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--panel);border-bottom:1px solid var(--line)}
.brand{font-weight:800;font-size:1.05rem}
.tabs{display:flex;gap:6px;margin-left:auto}
.tabs a{color:var(--muted);text-decoration:none;padding:8px 14px;border-radius:10px;font-weight:600}
.tabs a.on{background:var(--panel2);color:var(--txt)}
.logout{color:var(--muted);text-decoration:none;font-size:1.2rem;padding:6px 10px}

.wrap{max-width:820px;margin:0 auto;padding:12px}

/* buttons */
.btn{border:none;border-radius:12px;padding:12px 16px;font-size:1rem;font-weight:700;color:#fff;cursor:pointer;min-height:48px}
.btn.sm{min-height:38px;padding:8px 12px;font-size:.9rem}
.btn.big{font-size:1.1rem;padding:14px 20px}
.btn:disabled{opacity:.4}
.btn-green{background:var(--green)} .btn-green:hover{background:var(--green2)}
.btn-amber{background:var(--amber)} .btn-red{background:var(--red)} .btn-blue{background:var(--blue)}
.btn-ghost{background:var(--panel2);color:var(--txt);border:1px solid var(--line)}

/* team strip (live) */
.team-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}
.ts-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:10px;text-align:center}
.ts-card.mine{border-color:var(--mine);box-shadow:0 0 0 1px var(--mine) inset}
.ts-card.locked{opacity:.6}
.ts-name{font-weight:700;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ts-purse{font-size:1.4rem;font-weight:800;color:var(--green2)}
.ts-sub{font-size:.72rem;color:var(--muted)}

.toolbar{display:flex;align-items:center;gap:10px;margin:8px 0}
.toolbar.end{justify-content:flex-end;margin-top:20px}
.talent{display:flex;gap:6px;flex-wrap:wrap}
.tools{margin-left:auto;display:flex;gap:8px}
.chip{background:var(--panel2);border:1px solid var(--line);border-radius:20px;padding:5px 10px;font-size:.8rem;font-weight:600}
.chip.star{color:var(--star)} .chip.mid{color:var(--mid)} .chip.low{color:var(--low)}

/* player list — clean tap-through card grid (details live in the detail view) */
.player-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:560px){.player-list{grid-template-columns:repeat(3,1fr)}}
@media(min-width:860px){.player-list{grid-template-columns:repeat(4,1fr)}}
.pcard{display:flex;flex-direction:column;gap:8px;background:var(--panel);border:1px solid var(--line);border-top:4px solid var(--line);border-radius:var(--radius);padding:12px;cursor:pointer;min-height:118px;transition:transform .08s ease,border-color .2s,box-shadow .2s}
.pcard:active{transform:scale(.97)}
.pcard:hover{box-shadow:0 4px 18px rgba(0,0,0,.35)}
.pcard.m-target{border-top-color:var(--green2)}
.pcard.m-must{border-top-color:var(--mine)}
.pcard.m-drive{border-top-color:var(--amber)}
.pcard.m-pass{border-top-color:var(--low);opacity:.72}
.pc-head{display:flex;align-items:center;justify-content:space-between;gap:6px}
.pc-pills{display:flex;align-items:center;gap:5px}
.val-badge{font-size:.85rem;line-height:1}
.pc-rating{font-weight:800;border-radius:9px;padding:3px 11px;font-size:1.05rem;background:var(--panel2)}
.pc-rating.rstar{color:#1a1200;background:var(--star)}
.pc-rating.rmid{color:#04203f;background:var(--mid)}
.pc-rating.rlow{color:#fff;background:var(--low)}
.pc-mode-pill{font-size:.58rem;font-weight:800;letter-spacing:.05em;padding:3px 8px;border-radius:20px;background:var(--panel2);color:var(--muted);white-space:nowrap}
.m-target .pc-mode-pill{color:var(--green2);background:#12261a}
.m-must .pc-mode-pill{color:#c9a7ff;background:#20163a}
.m-drive .pc-mode-pill{color:var(--amber);background:#2a2410}
.m-pass .pc-mode-pill{color:var(--low)}
.pc-name{font-weight:700;font-size:1.08rem;line-height:1.2}
.pc-flags{display:flex;gap:4px;flex-wrap:wrap}
.flag{background:#3a2a12;color:var(--star);border-radius:6px;padding:1px 6px;font-size:.66rem;font-weight:700;letter-spacing:.02em}
.pc-tap{margin-top:auto;font-size:.66rem;color:var(--muted)}
.all-sold{text-align:center;padding:30px;font-size:1.2rem}

/* modal */
.modal{position:fixed;inset:0;z-index:50;background:rgba(0,0,0,.6);display:flex;align-items:flex-end;justify-content:center;padding:0}
.modal-card{background:var(--panel);width:100%;max-width:560px;border-radius:18px 18px 0 0;border:1px solid var(--line);max-height:94vh;overflow:auto}
@media(min-width:600px){.modal{align-items:center;padding:16px}.modal-card{border-radius:18px}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--panel)}
.modal-head h2{margin:0;font-size:1.15rem}
.x{background:none;border:none;color:var(--muted);font-size:1.3rem;cursor:pointer}
.modal-body{padding:16px}
.modal-body label{display:block;font-size:.8rem;color:var(--muted);margin:12px 0 6px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.modal-foot{display:flex;gap:10px;padding:14px 16px;border-top:1px solid var(--line);position:sticky;bottom:0;background:var(--panel)}
.modal-foot .btn{flex:1}

.team-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.team-btn{display:flex;flex-direction:column;gap:2px;background:var(--panel2);border:2px solid var(--line);border-radius:12px;padding:12px 8px;color:var(--txt);cursor:pointer;min-height:64px}
.team-btn small{color:var(--muted);font-size:.68rem}
.team-btn.mine{border-color:var(--mine)}
.team-btn.sel{border-color:var(--green2);background:#12261a}
.team-btn.disabled{opacity:.35;cursor:not-allowed}
.price-input,.pin-input{width:100%;background:var(--panel2);border:2px solid var(--line);border-radius:12px;color:var(--txt);font-size:1.6rem;font-weight:800;padding:12px;text-align:center}
.hint{color:var(--muted);font-size:.8rem;margin-top:10px;line-height:1.4}
.err{color:#fff;background:var(--red);border-radius:10px;padding:8px 12px;margin-top:10px;font-size:.9rem}

/* NOW BIDDING */
.bid-card{max-width:560px}
.bid-name{font-size:1.5rem;font-weight:800;display:flex;align-items:center;gap:10px}
.bid-rate{font-size:1rem;border-radius:8px;padding:2px 10px}
.bid-rate.rstar{color:#1a1200;background:var(--star)}.bid-rate.rmid{color:#04203f;background:var(--mid)}.bid-rate.rlow{background:var(--low)}
.bid-flags{display:flex;gap:6px;margin:8px 0}
.bid-current{display:flex;align-items:baseline;justify-content:space-between;margin:16px 0 8px;padding:12px 16px;background:var(--panel2);border-radius:12px}
.bid-current .lbl{color:var(--muted);font-size:.8rem;text-transform:uppercase}
.bid-level{font-size:2.6rem;font-weight:900}
.incs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.incs .btn{min-height:52px;font-size:1.05rem}
.bid-advice{margin:16px 0;border-radius:14px;padding:16px;font-weight:700}
.bid-advice .adv-line{font-size:1.15rem}
.bid-advice .adv-sub{font-size:.78rem;font-weight:500;margin-top:8px;opacity:.9}
.adv-green{background:#0f2a17;border:1px solid var(--green);color:#7ee2a0}
.adv-amber{background:#2a2410;border:1px solid var(--amber);color:#f0c869}
.adv-red{background:#2c1414;border:1px solid var(--red);color:#ff9a92}
.bid-ceiling{text-align:center;font-size:1.05rem;margin:6px 0}
.bid-ceiling b{font-size:1.4rem;color:var(--green2)}
.ceil-extra{font-size:.85rem;color:var(--star);margin-top:4px}
.ceil-extra b{font-size:1rem;color:var(--star)}
.bid-rivals{margin-top:12px;display:flex;flex-direction:column;gap:6px}
.rival-line{display:flex;justify-content:space-between;gap:8px;background:var(--panel2);border-radius:10px;padding:8px 12px;font-size:.85rem}
.rival-line .pot{color:var(--star)}

/* dashboard */
.section-h{margin:22px 0 10px;font-size:1rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.section-h.danger{color:var(--red)}
.team-cards{display:grid;gap:12px;grid-template-columns:1fr}
@media(min-width:720px){.team-cards{grid-template-columns:repeat(3,1fr)}}
.tcard{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px}
.tcard.mine{border-color:var(--mine)}
.tcard.locked{opacity:.7}
.tc-head{display:flex;justify-content:space-between;align-items:center}
.tc-head h3{margin:0;font-size:1.1rem}
.tc-rating{color:var(--star);font-weight:800}
.tc-nums{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:12px 0}
.tc-nums div{display:flex;justify-content:space-between;background:var(--panel2);border-radius:8px;padding:6px 10px;font-size:.85rem}
.tc-nums span{color:var(--muted)}
.topup-btn{width:100%;margin-bottom:10px}
.tc-roster{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
.tc-roster li{display:flex;align-items:center;gap:8px;background:var(--panel2);border-radius:8px;padding:6px 10px;font-size:.9rem}
.tc-roster .r{font-weight:800;border-radius:6px;padding:0 7px;font-size:.8rem}
.tc-roster li b{margin-left:auto;color:var(--green2)}
.r.rstar{color:#1a1200;background:var(--star)}.r.rmid{color:#04203f;background:var(--mid)}.r.rlow{color:#fff;background:var(--low)}

.talent-big{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.tbig{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px;text-align:center}
.tbig b{display:block;font-size:2rem;font-weight:900}
.tbig span{color:var(--muted);font-size:.78rem}
.tbig.star b{color:var(--star)}.tbig.mid b{color:var(--mid)}.tbig.low b{color:var(--low)}

.log{display:flex;flex-direction:column;gap:5px}
.log-row{display:grid;grid-template-columns:64px 1fr auto;gap:8px;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:8px 10px;font-size:.82rem}
.log-row .lt{font-weight:800;font-size:.68rem;color:var(--muted)}
.log-row.sale{border-left:3px solid var(--green2)}
.log-row.topup{border-left:3px solid var(--blue)}
.log-row.undo{border-left:3px solid var(--amber);opacity:.85}
.log-row.rev{opacity:.5;text-decoration:line-through}
.log-row .la{font-weight:700;text-align:right}
.log-row .lw{grid-column:2 / span 2;color:var(--muted);font-size:.68rem}

/* setup */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px;margin-bottom:12px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-grid label{display:flex;flex-direction:column;gap:4px;font-size:.78rem;color:var(--muted);font-weight:600}
.form-grid input{background:var(--panel2);border:1px solid var(--line);border-radius:10px;color:var(--txt);padding:10px;font-size:1rem}
.form-grid .btn{grid-column:1 / -1}
.table-wrap{overflow-x:auto;padding:6px}
.ptable{width:100%;border-collapse:collapse;font-size:.85rem}
.ptable th{color:var(--muted);text-align:left;font-size:.7rem;text-transform:uppercase;padding:6px}
.ptable td{padding:4px 6px;border-top:1px solid var(--line)}
.ptable input{background:var(--panel2);border:1px solid var(--line);border-radius:8px;color:var(--txt);padding:7px;width:100%}

/* login */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:28px;width:320px;max-width:90vw;text-align:center;display:flex;flex-direction:column;gap:12px}
.login-card h1{margin:0;font-size:1.3rem}

/* toast */
.toast{position:fixed;left:50%;bottom:20px;transform:translateX(-50%) translateY(20px);background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:12px;padding:12px 18px;font-weight:600;opacity:0;pointer-events:none;transition:.25s;z-index:100;max-width:90vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{border-color:var(--green2)} .toast.err{border-color:var(--red)} .toast.warn{border-color:var(--amber)}
.dash-grid{margin-top:6px}
.setup-status{height:20px}
