/* PokerBit — faithful replica of the Figma design */
:root{
  --sidebar:#232e51; --sidebar-2:#1d2645; --side-active:#2f3a60; --side-line:#33406a;
  --side-text:#9099b8; --side-textActive:#ffffff;
  --bg:#f4f7fc; --card:#ffffff; --ink:#20283f; --ink2:#3a4358; --muted:#8b93a6; --dim:#aab1c2;
  --line:#edf0f5; --line2:#e4e8f0;
  --primary:#385890; --primary-dk:#2d496f; --primary-soft:#eaf0f9;
  --link:#3a5a9a; --green:#23a06b; --red:#e2564a; --logo:#e0142b; --gold:#caa53d;
  --radius:12px; --shadow:0 1px 3px rgba(20,30,60,.06),0 1px 2px rgba(20,30,60,.04);
  --shadow-md:0 6px 22px rgba(20,30,60,.10);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--ink);
  font:14px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
a{color:inherit;text-decoration:none}
.app{display:flex;min-height:100vh}

/* ---- Sidebar ---- */
.sidebar{width:240px;flex:0 0 240px;background:var(--sidebar);position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;padding:0 0 16px}
.brand{display:flex;align-items:center;gap:10px;padding:22px 22px 24px;text-decoration:none;cursor:pointer}
.brand .logo{width:34px;height:34px;border-radius:8px;background:var(--logo);display:grid;place-items:center;
  color:#fff;font-weight:800;font-size:17px;box-shadow:0 2px 8px rgba(224,20,43,.4)}
.brand .bn{color:#fff;font-weight:800;font-size:18px;letter-spacing:.2px}
.brand .bn small{display:block;color:#8b93b8;font-size:9px;font-weight:500;letter-spacing:.3px}
.nav{display:flex;flex-direction:column;gap:2px;padding:0 12px}
.nav a{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:9px;color:var(--side-text);
  font-weight:500;font-size:14px;cursor:pointer}
.nav a svg{width:19px;height:19px;flex:0 0 19px;stroke:currentColor;fill:none;stroke-width:1.7}
.nav a:hover{background:#ffffff10;color:#cfd5e8}
.nav a.active{background:var(--side-active);color:#fff;font-weight:600}

/* ---- Content / Topbar ---- */
.content{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{height:64px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;
  gap:18px;padding:0 26px;position:sticky;top:0;z-index:20}
.search{flex:0 1 380px;display:flex;align-items:center;gap:9px;background:#f3f6fb;border:1px solid #eef1f6;
  border-radius:9px;padding:9px 13px;color:var(--muted)}
.search svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8}
.search input{border:none;background:none;outline:none;font:inherit;color:var(--ink);width:100%}
.topbar .sp{flex:1}
.topbar .ic{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;color:var(--ink2);cursor:pointer}
.topbar .ic:hover{background:#f3f6fb}
.topbar .ic svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:1.7}
.topbar .user{display:flex;align-items:center;gap:10px;cursor:pointer;padding-left:8px;border-left:1px solid var(--line);position:relative}
.user-dd{position:absolute;top:calc(100% + 10px);right:0;min-width:190px;background:#fff;border:1px solid var(--line);
  border-radius:11px;box-shadow:var(--shadow-md);padding:6px;display:none;z-index:50}
.user.open .user-dd{display:block}
.user-dd a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:var(--ink2);font-weight:600;font-size:13.5px}
.user-dd a svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.8}
.user-dd a:hover{background:var(--chip)}
.user-dd a.signout{color:var(--red)}
.user-dd a.signout:hover{background:#fdecea}
.topbar .user .av{width:38px;height:38px;border-radius:50%}
.topbar .user .nm{font-weight:700;font-size:13px;line-height:1.2}
.topbar .user .nm small{display:block;color:var(--muted);font-weight:500;font-size:11px}

/* ---- Page ---- */
.page{padding:26px 30px 60px;max-width:1320px;width:100%}
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.page-head h1{margin:0;font-size:22px;font-weight:700;letter-spacing:-.2px}
.crumb{color:var(--muted);font-size:13px;display:flex;gap:8px;align-items:center}
.crumb .cur{color:var(--link);font-weight:600}

/* toolbar above tables */
.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px;flex-wrap:wrap}
.toolbar .left{display:flex;gap:10px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:9px;padding:10px 16px;font:inherit;
  font-weight:600;font-size:13px;cursor:pointer;border:1px solid transparent;white-space:nowrap}
.btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.9}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dk)}
.btn-outline{background:#fff;border-color:var(--line2);color:var(--ink2)}
.btn-outline:hover{background:#f7f9fc}
.btn-ghost{background:none;color:var(--link);padding:8px 4px}
.btn-edit{background:#fff;border-color:var(--line2);color:var(--primary)}
.btn-edit:hover{background:var(--primary-soft)}
/* player detail: toolbar + edit inputs */
.pe-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:4px 0 14px;flex-wrap:wrap}
.pe-input{font:inherit;border:1px solid var(--line2);border-radius:8px;padding:7px 10px;width:100%;background:#fff;color:var(--ink);box-sizing:border-box}
.pe-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}
.pe-name{font-size:18px;font-weight:700;max-width:260px}
.dh .fields .field input.pe-input{margin-top:2px}
/* headline stat tiles */
.stat-tiles{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin:16px 0}
.stat-tile{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px}
.stat-tile .st-v{font-size:26px;font-weight:800;color:var(--ink)}
.stat-tile .st-l{font-size:12.5px;color:var(--ink2);margin-top:4px}
.stat-tile.st-pts{background:var(--primary);border-color:var(--primary)}
.stat-tile.st-pts .st-v{color:#fff}
.stat-tile.st-pts .st-l{color:rgba(255,255,255,.85)}
@media(max-width:1100px){.stat-tiles{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.stat-tiles{grid-template-columns:repeat(2,1fr)}}
/* finishing positions table */
.fp-table th,.fp-table td{text-align:center;white-space:nowrap}
.fp-table .fp-name{text-align:left;font-weight:600}
.fp-table td.fp-win{font-weight:700;color:var(--primary)}
.fp-table .fp-z{color:var(--line2)}
.fp-table .fp-sep{border-left:1px solid var(--line)}
.fp-table tbody tr:last-child{background:var(--primary-soft);font-weight:600;border-top:2px solid var(--line)}
.fp-table tbody tr:last-child .fp-name{color:var(--primary)}

/* ---- Cards ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:22px}
/* dashboard tiles: even rows (3 per row desktop, 2 tablet, 1 mobile) */
#tileGrid{grid-template-columns:repeat(3,1fr)}
@media(max-width:1024px){#tileGrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){#tileGrid{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.card .k{color:var(--muted);font-size:12px;font-weight:600}
.card .v{font-size:26px;font-weight:800;margin-top:8px;letter-spacing:-.5px}
.card .v.blue{color:var(--primary)}
.blocks{display:flex;flex-direction:column;gap:0}
.block{position:relative}
.block-handle{position:absolute;top:-2px;right:0;cursor:grab;color:var(--dim);font-size:15px;padding:6px 8px;user-select:none;opacity:0;transition:.15s;z-index:4}
.block:hover .block-handle{opacity:.55}
.block-handle:hover{opacity:1 !important;color:var(--primary)}
.block-handle:active{cursor:grabbing}
.block.dragging{opacity:.5;outline:2px dashed var(--primary);outline-offset:6px;border-radius:10px}
.card.tile{cursor:grab}
.card.tile:active{cursor:grabbing}
.card.tile.dragging{opacity:.4;outline:2px dashed var(--primary);outline-offset:-2px}
.card .sub{color:var(--dim);font-size:12px;margin-top:3px}

/* ---- Table ---- */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.panel .psearch{display:flex;align-items:center;gap:9px;margin:16px;padding:10px 13px;border:1px solid var(--line2);
  border-radius:9px;color:var(--muted)}
.panel .psearch svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8}
.panel .psearch input{border:none;outline:none;background:none;font:inherit;width:100%;color:var(--ink)}
table{width:100%;border-collapse:collapse}
thead th{text-align:center;padding:13px 16px;font-size:12px;font-weight:600;color:var(--muted);
  border-bottom:1px solid var(--line);white-space:nowrap}
.lb-filters{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:12px}
.lb-filters label{font-size:12px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:6px;margin:0}
.lb-filters select,.lb-filters input{padding:8px 11px;border:1px solid var(--line2);border-radius:8px;font:inherit;font-size:13px;font-weight:600;color:var(--ink);background:#fff}
.lb-filters select:focus,.lb-filters input:focus{outline:none;border-color:var(--primary)}
.lb-scroll{max-height:460px;overflow:auto}
.trow th{padding:6px 8px;background:var(--card2);border-bottom:1px solid var(--line);vertical-align:top}
.trow .colf{display:flex;flex-direction:column;gap:4px}
.trow input,.trow select{width:100%;padding:6px 8px;border:1px solid var(--line2);border-radius:6px;font:inherit;font-size:12px;font-weight:600;color:var(--ink);background:#fff}
.trow input:focus,.trow select:focus{outline:none;border-color:var(--primary)}
.lb-scroll thead th{position:sticky;top:0;z-index:1}
th.th-sort{cursor:pointer;user-select:none}
th.th-sort:hover{color:var(--ink)}
th .sa{color:var(--primary);font-size:10px}
tbody td{padding:13px 16px;border-bottom:1px solid var(--line);font-size:13.5px;color:var(--ink2);white-space:nowrap;text-align:center}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:#fafbfe}
.num{text-align:center;font-variant-numeric:tabular-nums}
.cell-user{display:flex;align-items:center;gap:11px;justify-content:flex-start;text-align:left}
.av-sm{width:32px;height:32px;border-radius:50%;background:var(--primary-soft);color:var(--primary);
  display:grid;place-items:center;font-weight:700;font-size:12px;flex:0 0 32px;object-fit:cover}
.cap{font-weight:600;color:var(--ink)}
.role{font-weight:600}
.role.admin{color:var(--primary)}
.tag{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.tag.holdem{color:#2f6fdb;background:#e8f0ff}
.tag.omaha{color:#c2701c;background:#fdeede}
.tag.mixed{color:#7c4fd0;background:#f1eafc}
.tag.backgammon{color:#1f8a59;background:#e4f6ef}
.tag.toc{color:#7a5e10;background:#fbefc6}
.tag.regular{color:#5a6478;background:#eef1f6}
.tag.bounty{color:#c2410c;background:#fde8dd}
.tag.active{color:#fff;background:var(--green)}
.tag.done{color:var(--muted);background:var(--chip)}
.act{display:flex;gap:8px}
.act .i{width:30px;height:30px;border-radius:7px;display:grid;place-items:center;cursor:pointer;border:1px solid var(--line2)}
.act .i svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.8}
.act .edit{color:var(--green)}.act .edit:hover{background:#e9f7f0}
.act .del{color:var(--red)}.act .del:hover{background:#fdecea}
.act .view{color:var(--primary)}.act .view:hover{background:var(--primary-soft)}
.act .save{color:#fff;background:var(--green);border-color:var(--green)}.act .save:hover{filter:brightness(1.05)}
.tbl-scroll{overflow-x:auto}
.tbl-scroll.infinite{max-height:calc(100vh - 260px);overflow-y:auto}
.tbl-scroll.infinite thead th{position:sticky;top:0;background:var(--card2,#f7f9fc);z-index:2}
.ou-row td{border-top:2px solid var(--line);background:var(--bg)}
.col-draggable{cursor:grab}
.col-draggable:active{cursor:grabbing}
th.col-dragging{opacity:.5}
th.col-over{box-shadow:inset 3px 0 0 var(--primary)}
td.fp-name{text-align:left}
tfoot td{border-top:2px solid var(--line);background:var(--bg);font-weight:700;padding:12px 14px}
.pl-rm{background:none;border:none;color:var(--red);cursor:pointer;padding:4px;border-radius:6px;display:grid;place-items:center;opacity:.55}
.pl-rm:hover{opacity:1;background:#fdecea}
.pl-rm svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.9}
.pl-txt{background:none;border:none;color:var(--primary);cursor:pointer;padding:4px;border-radius:6px;display:grid;place-items:center;opacity:.7}
.pl-txt:hover{opacity:1;background:var(--primary-soft)}
.pl-txt svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.9}
.act-cell{display:flex;gap:2px;justify-content:center;align-items:center}
.pl-chk,.sh input[type=checkbox]{width:16px;height:16px;cursor:pointer;align-self:center}
.pl-row{align-items:center}
/* ---- Table Seating ---- */
.seat-bar{display:flex;align-items:center;gap:10px;margin:4px 0 14px;flex-wrap:wrap}
.seat-unseated{background:#fff7e6;border:1px solid #f0deb0;border-radius:10px;padding:10px 14px;margin-bottom:14px;font-size:13px;color:#7a5b00}
.seat-grid{display:grid;grid-template-columns:1fr;gap:20px}
.seat-card{background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.seat-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#232e51;color:#fff;font-weight:800}
.seat-del{background:rgba(255,255,255,.15);color:#fff;border:none;border-radius:6px;width:24px;height:24px;cursor:pointer}
.seat-del:hover{background:var(--red)}
.seat-body{display:grid;grid-template-columns:300px 1fr;gap:22px;padding:18px;align-items:center}
@media(max-width:760px){.seat-body{grid-template-columns:1fr}}
.seat-head-r{display:flex;align-items:center;gap:8px}
.seat-add{background:#fff;color:var(--primary);border:1px solid #fff;border-radius:8px;font:inherit;font-size:12px;font-weight:700;padding:5px 10px;cursor:pointer;display:inline-flex;align-items:center;gap:4px}
.seat-add:hover{background:var(--primary-soft)}
.seat-add svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.4}
.seat-list{display:flex;flex-direction:column;gap:6px}
.seat-row{display:grid;grid-template-columns:26px 1fr 24px;align-items:center;gap:8px}
.seat-row.seat-hd{font-size:11px;font-weight:700;color:var(--ink2);text-transform:uppercase;letter-spacing:.4px;padding:0 2px 2px}
.seat-row.seat-drag{cursor:grab}
.seat-row.seat-drag:active{cursor:grabbing}
.seat-card.drop-hot{outline:2px dashed var(--primary);outline-offset:3px}
.seat-no{width:22px;height:22px;border-radius:50%;background:var(--primary-soft);color:var(--primary);font-size:12px;font-weight:700;display:grid;place-items:center}
.seat-sel{font:inherit;font-size:13px;border:1px solid var(--line2);border-radius:7px;padding:6px 8px;background:#fff;color:var(--ink);min-width:0}
.seat-rm{background:none;border:none;color:var(--red);font-size:13px;cursor:pointer;padding:2px;opacity:.6}
.seat-rm:hover{opacity:1}
.seat-empty{padding:30px 10px;text-align:center;color:var(--ink2);font-weight:700}
.seat-empty span{font-weight:400;font-size:12px;color:var(--dim)}
.seat-viz{display:grid;place-items:center;background:#eaf1fb;border-radius:12px;padding:30px 26px}
/* poker table (matches Figma): black rail + gray felt + seats around + dealer */
.ptable{position:relative;width:100%;max-width:600px;margin:0 auto;aspect-ratio:1.6/1}
.ptable-rail{position:absolute;inset:0;border-radius:48%/72%;background:radial-gradient(ellipse at 50% 35%,#34343a,#0b0b0d 75%);box-shadow:0 10px 26px rgba(0,0,0,.35),inset 0 3px 10px rgba(255,255,255,.06)}
.ptable-felt{position:absolute;inset:13% 9%;border-radius:48%/64%;background:radial-gradient(ellipse at 50% 42%,#7d7f86,#46474d 78%);box-shadow:inset 0 0 26px rgba(0,0,0,.55)}
.pseat{position:absolute;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0;cursor:pointer;border:2px solid #cfd8ea;background:#fff;z-index:2}
.pseat.filled{border:none;background:none}
.pseat .pseat-c{width:46px;height:46px;border-radius:50%;overflow:hidden;border:3px solid #e0c200;background:var(--primary);display:grid;place-items:center;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.pseat .pseat-c img{width:100%;height:100%;object-fit:cover}
.pseat-ini{color:#fff;font-weight:800;font-size:14px}
.pseat-num{position:absolute;bottom:-15px;left:50%;transform:translateX(-50%);font-size:10px;font-weight:800;color:#fff;background:#232e51;border-radius:8px;padding:1px 6px}
.pseat.empty .pseat-plus{color:var(--primary);font-size:22px;font-weight:400;line-height:1}
.pseat.empty .pseat-add{position:absolute;bottom:-16px;left:50%;transform:translateX(-50%);font-size:10px;font-weight:700;color:#fff;background:#3a3a40;border-radius:8px;padding:1px 7px}
.pseat.hot{outline:3px solid var(--primary);outline-offset:2px}
.ptable-dealer{position:absolute;left:50%;top:90%;transform:translate(-50%,-50%);text-align:center;z-index:3;pointer-events:none}
.ptable-dealer .dealer-ic{width:46px;height:46px;border-radius:50%;background:#cfe0ff;display:grid;place-items:center;margin:0 auto}
.ptable-dealer .dealer-ic svg{width:26px;height:26px;stroke:#385890;fill:none;stroke-width:1.8}
.ptable-dealer .dealer-lbl{font-size:10px;font-weight:800;color:#fff;background:#3a3a40;border-radius:8px;padding:1px 8px;margin-top:3px;letter-spacing:.5px}
/* add-player popup */
.modal-ov{position:fixed;inset:0;background:rgba(12,16,30,.5);display:grid;place-items:center;z-index:9999;backdrop-filter:blur(2px)}
.modal{background:var(--card);border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.3);padding:22px;width:min(420px,92vw)}
.modal-h{font-size:18px;font-weight:800;margin-bottom:14px}
.modal-h span{font-weight:500;color:var(--ink2)}
.modal-f{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}
.oval-svg{width:100%;max-width:320px;height:auto}
.oval-felt{fill:#161618;stroke:#3a3a3e;stroke-width:9}
.oval-seat{fill:#41434c;stroke:#6c6e78;stroke-width:2}
.oval-seat.taken{fill:var(--primary);stroke:#cdd8ee}
.oval-seat.ring{fill:none;stroke:#e0c200;stroke-width:2.5}
.oval-txt{font-size:11px;font-weight:700;fill:#cfd2da;text-anchor:middle}
.oval-txt.on{fill:#fff}
.oval-num{font-size:10px;font-weight:800;fill:var(--ink2);text-anchor:middle}
.oval-dealer{fill:#e0142b;stroke:#fff;stroke-width:2}
.oval-dealer-txt{font-size:9.5px;font-weight:800;fill:#fff;text-anchor:middle;letter-spacing:.5px}
@media(max-width:520px){.seat-body{grid-template-columns:1fr}}
/* ---- Designs (Figma reference) ---- */
.design-bar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.design-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.design-card{background:var(--card);border:1px solid var(--line);border-radius:13px;box-shadow:var(--shadow);overflow:hidden}
.design-card.is-built{opacity:.62}
.design-thumb{height:190px;background:#eef2f8;display:grid;place-items:center;overflow:hidden;cursor:zoom-in}
.design-thumb img{width:100%;height:100%;object-fit:cover;object-position:top}
.design-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:11px 13px}
.design-title{font-weight:600;font-size:13.5px}
.design-toggle{font:inherit;font-size:12px;font-weight:600;border:1px solid var(--line2);background:#fff;color:var(--ink2);border-radius:8px;padding:6px 10px;cursor:pointer}
.design-toggle.on{background:#e9f7f0;border-color:#9fe0c0;color:#0a8f54}
/* ---- Leagues page ---- */
.lg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.lg-col{background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.lg-head{padding:13px 16px;font-weight:800;font-size:15px;display:flex;align-items:center;justify-content:space-between}
.lg-head.gp-poker{background:var(--primary-soft);color:var(--primary)}
.lg-head.gp-bg{background:#fff1e6;color:#c2570a}
.lg-head.gp-both{background:#e9f7f0;color:#0a8f54}
.lg-count{background:rgba(0,0,0,.08);border-radius:20px;padding:1px 10px;font-size:13px}
.lg-list{max-height:560px;overflow-y:auto}
.lg-row{display:flex;align-items:center;gap:10px;padding:9px 14px;border-top:1px solid var(--line);cursor:pointer}
.lg-row:hover{background:var(--bg)}
.lg-row .cap{font-weight:600}
.lg-empty{padding:18px;color:var(--dim);text-align:center;font-size:13px}
@media(max-width:820px){.lg-grid{grid-template-columns:1fr}}
th.th-left{text-align:left}
/* ---- championship photo ---- */
.champ-cellwrap{display:inline-flex;align-items:center;gap:9px}
.champ-click{cursor:zoom-in;transition:transform .1s}
.champ-click:hover{transform:scale(1.08)}
.lightbox{position:fixed;inset:0;background:rgba(12,16,30,.82);display:grid;place-items:center;z-index:9999;cursor:zoom-out;backdrop-filter:blur(3px)}
.lb-inner{display:flex;flex-direction:column;align-items:center;max-width:92vw}
.lb-inner img{max-width:90vw;max-height:84vh;border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.5);border:4px solid #e0c200}
.lb-cap{color:#fff;margin-top:14px;font-weight:700;font-size:16px;text-shadow:0 1px 3px rgba(0,0,0,.5)}
.champ-card{display:flex;align-items:center;gap:18px;background:linear-gradient(100deg,#fff8e6,#fffdf7);border:1px solid #f0deb0;border-radius:14px;padding:14px 18px;margin-bottom:16px;box-shadow:var(--shadow)}
.champ-img{width:96px;height:96px;border-radius:12px;object-fit:cover;border:3px solid #e0c200;flex:none}
.champ-tag{font-size:11px;font-weight:800;letter-spacing:1.5px;color:#b8860b}
.champ-name{font-size:22px;font-weight:800;color:var(--ink);margin-top:2px}
.champ-sub{font-size:13px;color:var(--ink2);margin-top:3px}
.champ-cell{width:42px;padding-left:8px!important}
.champ-thumb{width:30px;height:30px;border-radius:6px;object-fit:cover;border:2px solid #e0c200;display:block}
/* ---- avatars w/ uploaded image ---- */
.av-img{object-fit:cover}
.av-edit{position:relative;display:inline-block;cursor:pointer}
.av-edit .av-cam{position:absolute;right:-2px;bottom:-2px;width:24px;height:24px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:12px;border:2px solid var(--card)}
/* ---- league group tags ---- */
.grouptag{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11.5px;font-weight:700}
.gp-poker{background:var(--primary-soft);color:var(--primary)}
.gp-bg{background:#fff1e6;color:#c2570a}
.gp-both{background:#e9f7f0;color:#0a8f54}
.grp-filter{font:inherit;border:1px solid var(--line2);border-radius:9px;padding:9px 12px;background:#fff;color:var(--ink);margin-left:10px}
/* ---- dashboard live tournament ---- */
.live-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.live-card{background:linear-gradient(135deg,#15924f,#0c6e3a);color:#fff;border-radius:14px;padding:18px;cursor:pointer;box-shadow:0 6px 18px rgba(12,80,45,.25);transition:.15s}
.live-card:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(12,80,45,.32)}
.live-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.live-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:1px;background:rgba(255,255,255,.18);padding:4px 9px;border-radius:20px}
.live-dot{width:8px;height:8px;border-radius:50%;background:#fff;box-shadow:0 0 0 0 rgba(255,255,255,.7);animation:livepulse 1.6s infinite}
@keyframes livepulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.6)}70%{box-shadow:0 0 0 8px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.live-when{font-size:12px;opacity:.85}
.live-title{font-size:20px;font-weight:800}
.live-meta{font-size:12.5px;opacity:.9;margin-top:4px}
.live-cta{margin-top:14px;font-weight:700;font-size:13.5px}
.live-empty{background:var(--card);border:1px dashed var(--line2);border-radius:13px;padding:22px;color:var(--ink2);text-align:center}
.live-empty a{color:var(--primary);font-weight:700;cursor:pointer}
/* ---- tournaments # range filter ---- */
.numf{display:flex;align-items:center;gap:5px}
.numf input{width:54px;font:inherit;border:1px solid var(--line2);border-radius:7px;padding:6px 7px;text-align:center;background:#fff;color:var(--ink)}
.numf span{color:var(--dim)}
.tag.wsoep{background:#efe7ff;color:#6b3fd1}
/* ---- player results: wins by game ---- */
.pr-gw-title{padding:16px 24px 0;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--ink2)}
.pr-gw{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;padding:10px 24px 18px}
.pr-gwc{background:var(--bg);border-radius:11px;padding:14px;text-align:center}
.pr-gwv{font-size:24px;font-weight:800;color:var(--primary)}
.pr-gwl{font-size:12px;font-weight:600;color:var(--ink);margin-top:3px}
.pr-gwsub{font-size:10.5px;color:var(--ink2);margin-top:2px}
/* ---- Player Points / Player of the Year ---- */
.poy-sub{color:var(--ink2);margin:0 0 14px}
.poy-hall{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:26px}
.poy-chip{background:var(--card);border:1px solid var(--line);border-radius:13px;box-shadow:var(--shadow);padding:14px;text-align:center}
.poy-chip.live{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-soft)}
.pc-yr{font-weight:800;color:var(--ink);font-size:15px;margin-bottom:8px}
.pc-live{font-size:9px;background:var(--red);color:#fff;padding:2px 6px;border-radius:6px;vertical-align:middle;letter-spacing:.5px}
.pc-av{width:46px;height:46px;border-radius:50%;background:var(--primary-soft);color:var(--primary);display:grid;place-items:center;font-weight:800;margin:0 auto 8px}
.pc-nm{font-weight:600;font-size:13.5px;color:var(--ink)}
.pc-pts{font-size:12px;color:var(--primary);font-weight:700;margin-top:3px}
.poy-year{margin-bottom:26px}
.poy-banner{display:flex;align-items:center;gap:18px;padding:18px 22px;border-radius:14px 14px 0 0;
  background:linear-gradient(100deg,#b8860b,#e0c200 55%,#f6d860);color:#3a2e00;box-shadow:var(--shadow)}
.poy-banner.live{background:linear-gradient(100deg,#232e51,#385890)}
.poy-banner.live .pb-title,.poy-banner.live .pb-yr,.poy-banner.live .pb-name,.poy-banner.live .pp-v,.poy-banner.live .pp-l{color:#fff}
.pb-trophy{font-size:38px;line-height:1}
.pb-info{flex:1}
.pb-yr{font-size:12px;font-weight:700;opacity:.8;letter-spacing:.5px}
.pb-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;opacity:.85}
.pb-name{font-size:24px;font-weight:800;margin-top:2px}
.pb-pts{text-align:right}
.pp-v{font-size:30px;font-weight:800;line-height:1}
.pp-l{font-size:12px;opacity:.85;margin-top:2px}
.poy-year .panel{border-radius:0 0 14px 14px;border-top:none}
tr.poy-top{background:#fffbe9}
/* ---- Player Results (shareable card) ---- */
.pr-pick{display:flex;align-items:center;gap:12px;margin:4px 0 18px;flex-wrap:wrap}
.pr-pick label{font-weight:600;color:var(--ink2)}
.pr-pick select{font:inherit;border:1px solid var(--line2);border-radius:9px;padding:9px 12px;min-width:260px;background:#fff;color:var(--ink)}
.pr-pick .pr-hint{color:var(--dim);font-size:13px}
.pr-card{max-width:640px;background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:0 10px 30px rgba(20,30,60,.10);overflow:hidden}
.pr-head{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;background:#232e51;color:#fff}
.pr-brand{display:flex;align-items:center;gap:11px}
.pr-logo{width:40px;height:40px;border-radius:10px;background:#e0142b;color:#fff;display:grid;place-items:center;font-size:20px}
.pr-bt{font-size:20px;font-weight:800;line-height:1}
.pr-bt small{display:block;font-size:9px;letter-spacing:2px;font-weight:600;opacity:.8;margin-top:3px}
.pr-season{font-size:13px;opacity:.85}
.pr-who{display:flex;align-items:center;gap:16px;padding:22px 24px 6px}
.pr-av{width:64px;height:64px;border-radius:50%;background:var(--primary-soft);color:var(--primary);display:grid;place-items:center;font-weight:800;font-size:22px}
.pr-name{font-size:24px;font-weight:800;color:var(--ink)}
.pr-role{color:var(--ink2);font-size:13px;margin-top:2px}
.pr-bigs{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:18px 24px}
.pr-big{border-radius:13px;padding:16px;text-align:center;background:var(--bg)}
.pr-big.blue{background:var(--primary);color:#fff}
.pr-big.pos{background:#e9f7f0}
.pr-big.neg{background:#fdecea}
.pr-bv{font-size:26px;font-weight:800;color:var(--ink)}
.pr-big.blue .pr-bv{color:#fff}
.pr-big.pos .pr-bv{color:#0a8f54}
.pr-big.neg .pr-bv{color:var(--red)}
.pr-bl{font-size:12px;margin-top:5px;color:var(--ink2)}
.pr-big.blue .pr-bl{color:rgba(255,255,255,.85)}
.pr-big.pos .pr-bl{color:#0a8f54}.pr-big.neg .pr-bl{color:var(--red)}
.pr-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.pr-stat{background:var(--card);padding:14px 10px;text-align:center}
.pr-sv{font-size:18px;font-weight:700;color:var(--ink)}
.pr-sl{font-size:11px;color:var(--ink2);margin-top:3px}
.pr-foot{padding:13px 24px;text-align:center;font-size:11.5px;color:var(--dim)}
@media(max-width:640px){.pr-stats{grid-template-columns:repeat(2,1fr)}}
.cell-link{cursor:pointer}
.cell-link:hover .cap{color:var(--primary);text-decoration:underline}
.row-editing{background:var(--primary-soft)}
.ue-input{font:inherit;border:1px solid var(--line2);border-radius:6px;padding:5px 7px;width:100%;min-width:80px;background:#fff;color:var(--ink);box-sizing:border-box}
.ue-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-soft)}
.cell-user .ue-input{min-width:90px}
.pos{font-weight:700;color:var(--primary)}
.ed-inp{width:100%;max-width:110px;padding:6px 8px;border:1px solid var(--primary);border-radius:7px;font:inherit;font-size:13px;text-align:center;background:var(--primary-soft)}
.ed-inp:focus{outline:none;border-color:var(--primary-dk)}
.desc-cell{white-space:normal;max-width:340px;color:var(--muted);font-size:12px;text-align:left}
.money{font-variant-numeric:tabular-nums;font-weight:600}
.money.neg{color:var(--red)}.money.pos{color:var(--green)}

/* pagination */
.pager{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-top:1px solid var(--line)}
.pager .rpp{color:var(--muted);font-size:13px;display:flex;align-items:center;gap:8px}
.pager .pages{display:flex;gap:6px}
.pager .pages button{min-width:32px;height:32px;border:1px solid var(--line2);background:#fff;border-radius:7px;
  font:inherit;font-weight:600;font-size:13px;color:var(--ink2);cursor:pointer}
.pager .pages button.on{background:var(--primary);color:#fff;border-color:var(--primary)}
.pager .pages button:disabled{color:var(--dim);cursor:default}

/* ---- Player details ---- */
.dh{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:20px 22px;display:flex;align-items:center;gap:22px;flex-wrap:wrap;margin-bottom:18px}
.dh .av-lg{width:66px;height:66px;border-radius:50%;background:var(--primary-soft);color:var(--primary);
  display:grid;place-items:center;font-weight:800;font-size:24px;flex:0 0 66px}
.dh .who .nm{font-size:18px;font-weight:700}
.dh .field{font-size:12px}
.dh .field .l{color:var(--muted);font-size:11px;font-weight:600;margin-bottom:3px}
.dh .field .v{font-weight:600;color:var(--ink2)}
.dh .fields{display:flex;gap:34px;flex-wrap:wrap;margin-left:auto}
.summ-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:18px}
@media(max-width:900px){.summ-grid{grid-template-columns:1fr}}
.summ{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px}
.summ h3{margin:0 0 12px;font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px}
.summ .row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--line);font-size:13px}
.summ .row:last-child{border:none}
.summ .row .l{color:var(--muted)}.summ .row .v{font-weight:700}
.section-title{font-size:14px;font-weight:700;margin:22px 0 12px}

/* ---- Forms (New Tournament) ---- */
.formcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px 22px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px 22px}
@media(max-width:760px){.grid2,.grid3{grid-template-columns:1fr}}
.field-l{display:block;font-size:13px;font-weight:600;color:var(--ink2);margin:0 0 7px}
.inp{width:100%;border:1px solid var(--line2);border-radius:9px;padding:11px 13px;font:inherit;font-size:13px;
  color:var(--ink);background:#fff}
.inp::placeholder{color:var(--dim)}
.inp:focus{outline:none;border-color:var(--primary)}
select.inp{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238b93a6' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:34px}
.subtable{border:1px solid var(--line);border-radius:10px;overflow:hidden;margin-top:6px}
.subtable .sh{display:grid;background:#f7f9fc;padding:11px 14px;font-size:12px;font-weight:600;color:var(--muted)}
.subtable .sr{display:grid;padding:10px 14px;border-top:1px solid var(--line);gap:10px;align-items:center}
.subtable .tot{display:flex;justify-content:flex-end;gap:30px;padding:12px 14px;border-top:1px solid var(--line);font-weight:700}
.form-foot{display:flex;justify-content:flex-end;gap:12px;margin-top:22px}

/* ---- hamburger + mobile ---- */
.ham{display:none;width:38px;height:38px;border-radius:9px;place-items:center;color:var(--ink2);cursor:pointer}
.ham svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2}
.ham:hover{background:#f3f6fb}
.backdrop{display:none;position:fixed;inset:0;background:rgba(15,22,40,.45);z-index:30}
.backdrop.show{display:block}
@media(max-width:900px){
  .sidebar{position:fixed;left:0;top:0;z-index:40;transform:translateX(-100%);transition:transform .22s ease;box-shadow:0 0 40px rgba(0,0,0,.3)}
  .sidebar.open{transform:translateX(0)}
  .ham{display:grid}
  .search{flex:1}
  .topbar{padding:0 16px;gap:12px}
  .topbar .user .nm{display:none}
  .page{padding:18px 16px 60px}
  .page-head{flex-direction:column;align-items:flex-start;gap:6px}
  .panel{overflow-x:auto}
  .toolbar{flex-direction:column;align-items:stretch}
  .toolbar .btn{width:100%;justify-content:center}
  .dh{gap:14px}.dh .fields{margin-left:0;gap:18px}
}
@media(max-width:560px){
  .topbar .search{display:none}
  .cards{grid-template-columns:1fr 1fr}
  .summ-grid{grid-template-columns:1fr}
}

.placeholder{display:grid;place-items:center;min-height:50vh;text-align:center;color:var(--muted)}
.placeholder .big{font-size:46px;margin-bottom:10px}
.placeholder h2{margin:0 0 6px;color:var(--ink)}
.empty{color:var(--dim);padding:30px;text-align:center}
.back{color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;margin-bottom:14px;display:inline-block}
.back:hover{color:var(--primary)}
.loading{display:grid;place-items:center;height:100vh;color:var(--muted)}
.admin-only{}  /* in this admin replica everything is admin-side */
