@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=DM+Mono:wght@400;500&display=swap');
:root{
  --white:#fff;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-700:#334155;--gray-900:#0f172a;
  --blue-50:#eff6ff;--blue-100:#dbeafe;--blue-500:#3b82f6;--blue-600:#2563eb;--blue-700:#1d4ed8;
  --green-50:#f0fdf4;--green-100:#dcfce7;--green-600:#16a34a;--green-700:#15803d;
  --red-50:#fef2f2;--red-100:#fee2e2;--red-600:#dc2626;
  --amber-50:#fffbeb;--amber-600:#d97706;
  --indigo-600:#4f46e5;
  --wb-bg:#1e3a8a;--lb-bg:#881337;--ko-bg:#4c1d95;
  --r:8px;--r-lg:12px;--r-xl:16px;
  --sh-sm:0 1px 2px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.1);
  --sh:0 4px 6px -1px rgba(0,0,0,.07),0 2px 4px -1px rgba(0,0,0,.06);
  --sh-md:0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -2px rgba(0,0,0,.04);
  --sh-lg:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
#bb-root{font-family:'Inter',system-ui,sans-serif;font-size:14px;line-height:1.5;background:var(--gray-50);color:var(--gray-900);border-radius:0!important;min-height:100vh;}

/* TOPBAR */
.bb-topbar{background:var(--white);border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding:.7rem 1.25rem;position:sticky;top:0;z-index:50;box-shadow:var(--sh-sm);}
.bb-brand{display:flex;align-items:center;gap:.75rem;}
.bb-logo{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--blue-600),var(--indigo-600));display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.bb-club-logo{width:40px;height:40px;border-radius:10px;object-fit:cover;flex-shrink:0;border:1px solid var(--gray-200);}
.bb-club-logo-sm{width:22px;height:22px;border-radius:5px;object-fit:cover;vertical-align:middle;margin-right:.25rem;}
.bb-t-name{font-size:.95rem;font-weight:700;color:var(--gray-900);line-height:1.2;}
.bb-t-meta{font-size:.72rem;color:var(--gray-400);margin-top:1px;}
.bb-map-link{color:var(--blue-600);text-decoration:none;font-weight:500;}
.bb-map-link:hover{text-decoration:underline;}
.bb-nav{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap;}
.bb-tab{background:transparent;border:none;color:var(--gray-500);padding:.4rem .85rem;border-radius:var(--r);cursor:pointer;font-family:inherit;font-size:.82rem;font-weight:500;transition:all .15s;white-space:nowrap;}
.bb-tab:hover{background:var(--gray-100);color:var(--gray-900);}
.bb-tab.on{background:var(--blue-600);color:#fff;font-weight:600;box-shadow:var(--sh-sm);}
.bb-tab-outline{border:1px solid var(--gray-200);}
.bb-sup{display:inline-flex;align-items:center;justify-content:center;background:var(--red-600);color:#fff;font-size:.6rem;font-weight:700;width:15px;height:15px;border-radius:50%;vertical-align:top;margin-left:2px;}

/* LAYOUT */
#bb-view{padding:1.25rem;max-width:none;}
.bb-scroll{display:flex;flex-direction:column;gap:1rem;}
.bb-join-bar{display:flex;align-items:center;gap:.75rem;background:var(--blue-50);border:1px solid var(--blue-100);border-radius:var(--r-lg);padding:.6rem 1rem;margin-bottom:1rem;font-size:.85rem;color:var(--blue-700);font-weight:500;}
.bb-join-bar a{color:var(--blue-600);font-weight:600;}

/* BRACKET */
.bb-section{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-sm);}
.bb-s-head{display:flex;align-items:center;gap:.5rem;padding:.55rem 1rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;}
.bb-wb .bb-s-head{background:var(--wb-bg);color:rgba(255,255,255,.95);}
.bb-lb .bb-s-head{background:var(--lb-bg);color:rgba(255,255,255,.95);}
.bb-ko .bb-s-head{background:var(--ko-bg);color:rgba(255,255,255,.95);}
.bb-rounds{display:flex;gap:.75rem;overflow-x:auto;padding:.85rem 1rem;}
.bb-rounds::-webkit-scrollbar{height:4px;}.bb-rounds::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:2px;}
.bb-round{min-width:172px;flex-shrink:0;}
.bb-r-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-400);font-weight:600;margin-bottom:.5rem;font-family:'DM Mono',monospace;}

/* MATCH CARD */
.bb-match{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-lg);margin-bottom:.45rem;overflow:hidden;transition:border-color .15s,box-shadow .15s;position:relative;}
.bb-match.done{border-color:var(--gray-200);}
.bb-match.bye{opacity:.4;pointer-events:none;}
.bb-match.pickable:hover{border-color:var(--blue-500);box-shadow:0 0 0 3px rgba(59,130,246,.12);}
.bb-match.pickable:hover .bb-pick-hint{opacity:1;}
.bb-match-inner{flex:1;}
.bb-slot{padding:.44rem .7rem;font-size:.82rem;font-weight:500;min-height:35px;display:flex;align-items:center;gap:.3rem;transition:background .12s;user-select:none;}
.bb-slot.empty{color:var(--gray-400);font-style:italic;font-weight:400;}
.bb-slot.win{background:var(--green-50);color:var(--green-700);font-weight:700;}
.bb-slot.loss{background:var(--red-50);color:var(--gray-400);text-decoration:line-through;font-weight:400;}
.bb-slot.pick{cursor:pointer;}.bb-slot.pick:hover{background:var(--blue-50);color:var(--blue-700);}
.bb-slot.fill-slot{cursor:pointer;color:var(--blue-600);font-style:normal;font-size:.75rem;font-weight:600;}.bb-slot.fill-slot:hover{background:var(--blue-50);}
.bb-rank{font-size:.7rem;color:var(--gray-400);font-family:'DM Mono',monospace;min-width:28px;}
.bb-tbd{color:var(--gray-300);font-style:italic;font-size:.78rem;}
.bb-crown{margin-left:auto;font-size:.8rem;}
.bb-vs{height:1px;background:var(--gray-100);}
.bb-pick-hint{text-align:center;font-size:.63rem;color:var(--blue-600);padding:.14rem 0;opacity:0;transition:opacity .2s;font-weight:500;background:var(--blue-50);}
.bb-edit-btn{position:absolute;top:3px;right:3px;background:none;border:none;cursor:pointer;font-size:.72rem;opacity:0;transition:opacity .15s;padding:2px 4px;border-radius:4px;color:var(--gray-400);line-height:1;}
.bb-match:hover .bb-edit-btn{opacity:1;}.bb-edit-btn:hover{background:var(--gray-100);color:var(--gray-700);}
.bb-table-tag{background:var(--amber-50);color:var(--amber-600);font-size:.68rem;font-weight:600;padding:.15rem .5rem;border-top:1px solid #fde68a;display:flex;align-items:center;gap:.25rem;}
.bb-match.highlight{border-color:var(--blue-500)!important;box-shadow:0 0 0 3px rgba(59,130,246,.2)!important;animation:bb-pulse 1.5s ease-in-out 3;}
@keyframes bb-pulse{0%,100%{box-shadow:0 0 0 3px rgba(59,130,246,.2);}50%{box-shadow:0 0 0 6px rgba(59,130,246,.35);}}

/* MY-MATCH: highlight matches the logged-in player is in */
.bb-match.my-match{
  border-color:#f59e0b;
  box-shadow:0 0 0 2px rgba(245,158,11,.18),0 2px 8px rgba(245,158,11,.10);
  background:linear-gradient(135deg,#fffbeb 0%,#fff 60%);
}
.bb-match.my-match::before{
  content:'★';
  position:absolute;top:3px;left:5px;
  font-size:.65rem;color:#f59e0b;
  line-height:1;pointer-events:none;
  z-index:1;
}
.bb-match.my-match .bb-slot:not(.loss):not(.empty){font-weight:700;}
.bb-slot.mine{background:linear-gradient(90deg,rgba(251,191,36,.13) 0%,transparent 100%);}
.bb-slot.mine.win{background:linear-gradient(90deg,rgba(251,191,36,.18) 0%,var(--green-50) 100%);}
.bb-match.my-match.done{border-color:#d1d5db;box-shadow:none;background:var(--white);}
.bb-match.my-match:not(.done){animation:my-match-glow 2.8s ease-in-out infinite;}
@keyframes my-match-glow{
  0%,100%{box-shadow:0 0 0 2px rgba(245,158,11,.18),0 2px 8px rgba(245,158,11,.08);}
  50%{box-shadow:0 0 0 4px rgba(245,158,11,.30),0 4px 14px rgba(245,158,11,.16);}
}

/* SEARCH */
.bb-search-bar{position:relative;margin-bottom:.85rem;}
.bb-search-wrap{display:flex;align-items:center;background:var(--white);border:1px solid var(--gray-300);border-radius:var(--r-lg);padding:.42rem .75rem;gap:.45rem;transition:border-color .15s,box-shadow .15s;}
.bb-search-wrap:focus-within{border-color:var(--blue-500);box-shadow:0 0 0 3px rgba(59,130,246,.1);}
.bb-search-input{flex:1;border:none;outline:none;font-family:inherit;font-size:.875rem;color:var(--gray-900);background:transparent;}
.bb-search-input::placeholder{color:var(--gray-400);}
.bb-search-clear{background:none;border:none;cursor:pointer;color:var(--gray-400);font-size:.85rem;padding:.1rem .2rem;border-radius:4px;line-height:1;}
.bb-search-results{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:200;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-lg);box-shadow:var(--sh-md);max-height:260px;overflow-y:auto;}
.bb-sr-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .85rem;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--gray-100);}
.bb-sr-item:last-child{border-bottom:none;}.bb-sr-item:hover{background:var(--gray-50);}
.bb-sr-name{font-weight:600;font-size:.85rem;flex:1;}.bb-sr-loc{font-size:.75rem;color:var(--gray-400);}
.bb-sr-empty{padding:.75rem 1rem;color:var(--gray-400);font-size:.85rem;}

/* FORMS & BUTTONS */
.bb-input{width:100%;padding:.5rem .7rem;background:var(--white);border:1px solid var(--gray-300);border-radius:var(--r);color:var(--gray-900);font-family:inherit;font-size:.875rem;transition:border-color .15s,box-shadow .15s;outline:none;}
.bb-input:focus{border-color:var(--blue-500);box-shadow:0 0 0 3px rgba(59,130,246,.1);}
.bb-input::placeholder{color:var(--gray-400);}
.bb-btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.48rem 1rem;border-radius:var(--r);font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;border:1px solid transparent;line-height:1.2;}
.bb-btn:disabled{opacity:.45;cursor:not-allowed;}
.bb-btn-primary{background:var(--blue-600);color:#fff;border-color:var(--blue-600);}.bb-btn-primary:hover:not(:disabled){background:var(--blue-700);}
.bb-btn-success{background:var(--green-600);color:#fff;border-color:var(--green-600);}.bb-btn-success:hover:not(:disabled){background:var(--green-700);}
.bb-btn-ghost{background:var(--white);color:var(--gray-700);border-color:var(--gray-300);}.bb-btn-ghost:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-400);}
.bb-btn-danger{background:var(--red-50);color:var(--red-600);border-color:var(--red-100);}.bb-btn-danger:hover:not(:disabled){background:var(--red-100);}
.bb-btn-sm{padding:.28rem .65rem;font-size:.78rem;}.bb-btn-lg{padding:.62rem 1.5rem;font-size:.9rem;}.bb-btn-icon{width:30px;height:30px;padding:0;}.w100{width:100%;}
.bb-label{font-size:.72rem;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.04em;display:block;}

/* CARDS */
.bb-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-xl);padding:1.1rem;box-shadow:var(--sh-sm);}
.bb-card-h{font-size:.78rem;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;padding-bottom:.6rem;border-bottom:1px solid var(--gray-100);margin-bottom:.8rem;display:flex;align-items:center;gap:.4rem;}
.bb-kv{width:100%;border-collapse:collapse;font-size:.83rem;}.bb-kv tr+tr td{padding-top:.3rem;}
.bb-kv td:first-child{color:var(--gray-500);width:42%;padding-right:.5rem;}.bb-kv td:last-child{color:var(--gray-900);font-weight:500;}
.bb-divider{height:1px;background:var(--gray-100);margin:.5rem 0;}

/* TABLES UI */
.bb-tables-wrap{max-width:none;}
.bb-tables-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1.1rem;}
.bb-tables-title{font-size:1rem;font-weight:700;color:var(--gray-900);display:flex;align-items:center;gap:.4rem;}
.bb-table-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:.75rem;}
.bb-table-card{background:var(--white);border:2px solid var(--gray-200);border-radius:var(--r-xl);padding:.85rem;display:flex;flex-direction:column;gap:.5rem;box-shadow:var(--sh-sm);transition:all .2s;}
.bb-table-card.free{border-color:#d1fae5;}.bb-table-card.busy{border-color:#fecaca;}
.bb-table-card.free:hover{border-color:var(--green-600);box-shadow:var(--sh);}
.bb-table-card.busy:hover{border-color:var(--red-600);box-shadow:var(--sh);}
.bb-table-label{font-size:1rem;font-weight:800;color:var(--gray-900);padding-bottom:.45rem;border-bottom:1px solid var(--gray-100);}
.bb-table-body{flex:1;}.bb-table-dot-row{display:flex;align-items:center;gap:.4rem;margin-bottom:.3rem;}
.bb-table-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.bb-table-dot.free{background:var(--green-600);box-shadow:0 0 6px rgba(22,163,74,.4);}
.bb-table-dot.busy{background:var(--red-600);box-shadow:0 0 5px rgba(220,38,38,.4);animation:bb-blink 2s infinite;}
@keyframes bb-blink{0%,100%{opacity:1;}50%{opacity:.4;}}
.bb-table-status-txt{font-size:.78rem;font-weight:600;color:var(--gray-500);}
.bb-table-card.free .bb-table-status-txt{color:var(--green-600);}
.bb-table-card.busy .bb-table-status-txt{color:var(--red-600);}
.bb-table-players{font-size:.82rem;font-weight:600;color:var(--gray-900);line-height:1.3;}
.bb-vs-txt{color:var(--gray-400);font-weight:400;margin:0 .25rem;}
.bb-table-actions{margin-top:.35rem;}

/* ADMIN */
.bb-admin-top{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.85rem;margin-bottom:.85rem;}
.bb-table-wrap{overflow-x:auto;border-radius:var(--r-lg);border:1px solid var(--gray-200);}
.bb-tbl{width:100%;border-collapse:collapse;font-size:.82rem;}
.bb-tbl th{padding:.5rem .7rem;text-align:left;font-size:.7rem;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;background:var(--gray-50);border-bottom:1px solid var(--gray-200);white-space:nowrap;}
.bb-tbl td{padding:.5rem .7rem;border-bottom:1px solid var(--gray-100);vertical-align:middle;}
.bb-tbl tbody tr:last-child td{border-bottom:none;}.bb-tbl tbody tr:hover td{background:var(--gray-50);}
.bb-badge{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:999px;font-size:.7rem;font-weight:600;white-space:nowrap;}
.bb-badge-blue{background:var(--blue-50);color:var(--blue-700);}.bb-badge-green{background:var(--green-50);color:var(--green-700);}
.bb-badge-red{background:var(--red-50);color:var(--red-600);}.bb-badge-amber{background:var(--amber-50);color:var(--amber-600);}
.bb-badge-gray{background:var(--gray-100);color:var(--gray-500);}

/* AUTH / PROFILE */
.bb-auth{max-width:380px;margin:1rem auto;}
.bb-auth-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh);}
.bb-auth-tabs{display:flex;border-bottom:1px solid var(--gray-200);}
.bb-atab{flex:1;padding:.65rem;background:none;border:none;color:var(--gray-500);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;}
.bb-atab.on{color:var(--blue-600);border-bottom-color:var(--blue-600);font-weight:600;}
.bb-at-panel{padding:1.2rem;display:flex;flex-direction:column;gap:.45rem;}
.bb-profile{max-width:680px;}
.bb-profile-hdr{display:flex;align-items:center;gap:.85rem;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-xl);padding:1.1rem;margin-bottom:1rem;box-shadow:var(--sh-sm);}
.bb-avatar{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--blue-600),var(--indigo-600));color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;flex-shrink:0;}
.bb-profile-nm{font-size:.95rem;font-weight:700;}
.bb-stats-row{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem;}
.bb-stat{flex:1;min-width:85px;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-lg);padding:.8rem .7rem;text-align:center;}
.bb-stat-n{display:block;font-size:1.6rem;font-weight:700;line-height:1;}.bb-stat-l{display:block;font-size:.68rem;color:var(--gray-400);margin-top:.2rem;text-transform:uppercase;letter-spacing:.05em;}

/* MODAL */
.bb-modal{display:none;position:fixed;inset:0;z-index:9999;align-items:center;justify-content:center;background:rgba(15,23,42,.45);backdrop-filter:blur(4px);}
.bb-modal.on{display:flex;}
.bb-modal-box{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-xl);padding:1.6rem;min-width:300px;max-width:94vw;display:flex;flex-direction:column;gap:.55rem;box-shadow:var(--sh-lg);}
.bb-modal-title{font-size:1rem;font-weight:700;color:var(--gray-900);}
.bb-modal-sub{font-size:.82rem;color:var(--gray-500);}
.bb-winner-box{max-width:460px;}
.bb-winner-choices{display:flex;align-items:stretch;gap:.75rem;margin:.3rem 0;}
.bb-winner-btn{flex:1;padding:.9rem .75rem;background:var(--gray-50);border:2px solid var(--gray-200);border-radius:var(--r-lg);color:var(--gray-700);font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .18s;text-align:center;line-height:1.4;}
.bb-winner-btn:hover{background:var(--blue-50);border-color:var(--blue-500);color:var(--blue-700);}
.bb-winner-btn.selected{background:var(--green-50);border-color:var(--green-600);color:var(--green-700);}
.bb-winner-vs{display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--gray-400);flex-shrink:0;}

/* Match action bar */
.bb-match-action{padding:.35rem .5rem;border-top:1px solid var(--gray-100);}
.bb-btn-start{width:100%;background:var(--green-50);color:var(--green-700);border:1px solid var(--green-100);padding:.32rem .5rem;font-size:.78rem;font-weight:700;border-radius:var(--r);cursor:pointer;font-family:inherit;transition:all .15s;}
.bb-btn-start:hover{background:var(--green-100);border-color:var(--green-600);}
.bb-btn-pick{width:100%;background:var(--blue-50);color:var(--blue-700);border:1px solid var(--blue-100);padding:.32rem .5rem;font-size:.78rem;font-weight:700;border-radius:var(--r);cursor:pointer;font-family:inherit;transition:all .15s;}
.bb-btn-pick:hover{background:var(--blue-100);border-color:var(--blue-600);}
.bb-match.startable{border-color:#bbf7d0;}
.bb-match.pickable{border-color:var(--blue-100);}

/* Start modal players */
.bb-sm-players{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;}
.bb-sm-player{flex:1;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--r-lg);padding:.75rem .7rem;text-align:center;font-weight:700;font-size:.95rem;color:var(--gray-900);}
.bb-sm-vs{font-size:.8rem;font-weight:700;color:var(--gray-400);flex-shrink:0;}

/* Logo fix - ensure it shows in topbar */
.bb-logo-img{width:36px;height:36px;border-radius:10px;object-fit:cover;flex-shrink:0;border:1px solid var(--gray-200);box-shadow:var(--sh-sm);}

/* Scrollbar */
#bb-root ::-webkit-scrollbar{width:5px;height:5px;}
#bb-root ::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:99px;}
.bb-empty-icon{font-size:2.5rem;opacity:.3;margin-bottom:.75rem;}
.bb-empty-title{font-size:.95rem;font-weight:600;color:var(--gray-700);margin-bottom:.4rem;}
.bb-loader{text-align:center;padding:1.5rem;color:var(--gray-400);font-size:.85rem;}
.bb-dim{color:var(--gray-400);font-size:.83rem;}
.bb-green{color:var(--green-700);}.bb-red{color:var(--red-600);}
.bb-err-msg{color:var(--red-600);font-size:.8rem;min-height:1rem;}
.bb-toast{position:fixed;bottom:1.2rem;right:1.2rem;z-index:99999;padding:.6rem 1rem;border-radius:var(--r-lg);font-family:inherit;font-size:.85rem;font-weight:500;box-shadow:var(--sh-md);pointer-events:none;transition:opacity .4s;display:flex;align-items:center;gap:.4rem;}
.bb-toast-ok{background:var(--white);color:var(--green-700);border:1px solid var(--green-100);}
.bb-toast-err{background:var(--white);color:var(--red-600);border:1px solid var(--red-100);}
.bb-toast-warn{background:var(--white);color:var(--amber-600);border:1px solid var(--amber-50);}
.bb-logs-panel{margin-top:.85rem;}
#bb-root ::-webkit-scrollbar{width:5px;height:5px;}
#bb-root ::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:99px;}
@media(max-width:600px){
  .bb-topbar{flex-direction:column;align-items:flex-start;}
  .bb-nav{width:100%;overflow-x:auto;flex-wrap:nowrap;}
  .bb-round{min-width:148px;}.bb-slot{font-size:.76rem;padding:.36rem .5rem;}
  .bb-admin-top{grid-template-columns:1fr;}.bb-modal-box{padding:1.2rem;}.#bb-view{padding:.85rem;}
}

/* ════════ PLAYERS VIEW ════════ */
.bb-players-wrap{max-width:680px;}
.bb-players-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;}
.bb-players-title{font-size:1rem;font-weight:700;color:var(--gray-900);}
.bb-players-grid{display:flex;flex-direction:column;gap:.4rem;}

.bb-player-card{
  display:flex;align-items:center;gap:.75rem;
  background:var(--white);border:1px solid var(--gray-200);
  border-radius:var(--r-lg);padding:.7rem 1rem;
  cursor:pointer;transition:all .15s;
}
.bb-player-card:hover{border-color:var(--blue-500);box-shadow:0 0 0 3px rgba(59,130,246,.08);background:var(--blue-50);}
.bb-pc-avatar{
  width:36px;height:36px;border-radius:9px;flex-shrink:0;
  background:linear-gradient(135deg,var(--blue-600),var(--indigo-600));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:.9rem;font-weight:700;
}
.bb-pc-info{flex:1;min-width:0;}
.bb-pc-name{font-weight:600;font-size:.88rem;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.bb-pc-stats{display:flex;align-items:center;gap:.2rem;font-size:.82rem;font-weight:600;}
.bb-pc-stat{display:flex;align-items:center;gap:.2rem;}
.bb-pc-stat-sep{color:var(--gray-300);font-size:.75rem;}
.bb-pc-wr{font-size:.78rem;font-weight:700;color:var(--gray-400);min-width:32px;text-align:right;}
.bb-pc-wr.good{color:var(--green-600);}
.bb-pc-arrow{color:var(--gray-300);font-size:1.2rem;font-weight:300;flex-shrink:0;}

/* Player profile */
.bb-player-profile{max-width:640px;}
.bb-pp-header{
  display:flex;align-items:center;gap:1rem;
  background:var(--white);border:1px solid var(--gray-200);
  border-radius:var(--r-xl);padding:1.25rem;box-shadow:var(--sh-sm);
}
.bb-pp-avatar{
  width:56px;height:56px;border-radius:14px;flex-shrink:0;
  background:linear-gradient(135deg,var(--blue-600),var(--indigo-600));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;font-weight:700;
}
.bb-pp-name{font-size:1.2rem;font-weight:700;color:var(--gray-900);}

/* ════════ PLAYER MODAL ════════ */
.bb-player-modal-box{
  width:min(440px,94vw);
  padding:0;overflow:hidden;
  border-radius:var(--r-xl);
}
.bb-pp-header{
  display:flex;align-items:center;gap:.9rem;
  padding:1.25rem 1.25rem 1rem;
  border-bottom:1px solid var(--gray-100);
  position:relative;
}
.bb-pp-avatar{
  width:52px;height:52px;border-radius:14px;flex-shrink:0;
  background:linear-gradient(135deg,var(--blue-600),var(--indigo-600));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;font-weight:700;
}
.bb-pp-info{flex:1;min-width:0;}
.bb-pp-name{font-size:1.05rem;font-weight:700;color:var(--gray-900);}
.bb-modal-close{
  position:absolute;top:.85rem;right:.85rem;
  background:var(--gray-100);border:none;cursor:pointer;
  width:28px;height:28px;border-radius:50%;
  font-size:.8rem;color:var(--gray-500);
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;flex-shrink:0;
}
.bb-modal-close:hover{background:var(--gray-200);color:var(--gray-900);}

.bb-pp-stats{
  display:flex;border-bottom:1px solid var(--gray-100);
}
.bb-pp-stat{
  flex:1;padding:.85rem .5rem;text-align:center;
  border-right:1px solid var(--gray-100);
}
.bb-pp-stat:last-child{border-right:none;}
.bb-pp-stat-n{display:block;font-size:1.4rem;font-weight:700;line-height:1;}
.bb-pp-stat-l{display:block;font-size:.67rem;color:var(--gray-400);margin-top:.2rem;text-transform:uppercase;letter-spacing:.04em;}

.bb-pp-matches{padding:.85rem 1.25rem;}
.bb-pp-sec-title{font-size:.75rem;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.6rem;}
.bb-pp-match-row{
  display:flex;align-items:center;gap:.6rem;
  padding:.5rem 0;border-bottom:1px solid var(--gray-100);
}
.bb-pp-match-row:last-child{border-bottom:none;}

/* ════════ AVATAR UPLOAD ════════ */
.bb-avatar-upload{display:flex;flex-direction:column;gap:.5rem;}
.bb-av-preview{
  width:100%;height:150px;background:var(--gray-50);border:2px dashed var(--gray-300);
  border-radius:var(--r-lg);display:flex;flex-direction:column;
  align-items:center;justify-content:center;overflow:hidden;
  transition:border-color .15s;
}
.bb-av-preview img{width:100%;height:100%;object-fit:cover;}
.bb-av-placeholder{font-size:2.5rem;opacity:.3;}
.bb-av-btns{display:flex;gap:.5rem;}

/* Auth form wider */
.bb-auth{max-width:460px;}

/* ════════ MEMBER REVIEW GRID ════════ */
.bb-members-review-grid{display:flex;flex-direction:column;gap:.75rem;}
.bb-member-review-card{
  display:flex;align-items:flex-start;gap:1rem;
  border:1px solid var(--gray-200);border-radius:var(--r-lg);
  padding:.85rem;background:var(--gray-50);
}
.bb-mrc-avatar{
  width:72px;height:72px;border-radius:var(--r-lg);overflow:hidden;
  border:2px solid var(--gray-200);flex-shrink:0;
  background:var(--gray-200);display:flex;align-items:center;justify-content:center;
}
.bb-mrc-avatar img{width:100%;height:100%;object-fit:cover;}
.bb-mrc-initials{font-size:1.5rem;font-weight:700;color:var(--gray-400);}
.bb-mrc-info{flex:1;min-width:0;}
.bb-mrc-name{font-weight:700;font-size:.95rem;color:var(--gray-900);margin-bottom:.25rem;}
.bb-mrc-meta{font-size:.78rem;color:var(--gray-500);margin-bottom:.15rem;}
.bb-mrc-rank{font-size:.82rem;color:var(--gray-700);margin-top:.3rem;}
.bb-mrc-actions{display:flex;flex-direction:column;gap:.35rem;flex-shrink:0;}

@media(max-width:540px){
  .bb-member-review-card{flex-direction:column;}
  .bb-mrc-actions{flex-direction:row;flex-wrap:wrap;}
  .bb-auth{max-width:100%;}
}

/* Player card with avatar */
.bb-pc-avatar-img{
  width:36px;height:36px;border-radius:9px;flex-shrink:0;
  object-fit:cover;border:1px solid var(--gray-200);
}

/* ════════ MATCH FOOTER ════════ */
.bb-match-footer{
  display:flex;align-items:center;justify-content:flex-end;
  gap:.2rem;padding:.2rem .4rem;
  border-top:1px solid var(--gray-100);min-height:22px;
}
.bb-detail-btn{
  background:none;border:none;cursor:pointer;
  font-size:.7rem;color:var(--gray-400);
  padding:1px 4px;border-radius:4px;line-height:1;
  transition:all .12s;
}
.bb-detail-btn:hover{background:var(--gray-100);color:var(--blue-600);}

/* Avatar tiny in slot */
.bb-slot-av{
  width:20px;height:20px;border-radius:4px;
  object-fit:cover;flex-shrink:0;margin-right:.25rem;
  border:1px solid var(--gray-200);
}

/* Match clickable cursor */
.bb-match[data-mid]{cursor:pointer;}
.bb-match[data-mid]:hover:not(.bye){box-shadow:0 0 0 2px rgba(59,130,246,.15);}

/* ════════ MATCH DETAIL MODAL ════════ */
.bb-mmd-matchup{
  display:flex;align-items:stretch;gap:.6rem;
  margin:.75rem 0;
}
.bb-mmd-player{
  flex:1;display:flex;flex-direction:column;align-items:center;
  gap:.4rem;padding:.85rem .6rem;
  background:var(--gray-50);border:2px solid var(--gray-200);
  border-radius:var(--r-lg);text-align:center;transition:all .15s;
}
.bb-mmd-player.win{background:var(--green-50);border-color:var(--green-600);}
.bb-mmd-player.loss{background:var(--red-50);border-color:var(--red-100);opacity:.7;}
.bb-mmd-player.empty{opacity:.5;}
.bb-mmd-av{
  width:52px;height:52px;border-radius:12px;
  object-fit:cover;border:2px solid var(--gray-200);
}
.bb-mmd-av-ph{
  width:52px;height:52px;border-radius:12px;
  background:linear-gradient(135deg,var(--blue-600),var(--indigo-600));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;font-weight:700;
}
.bb-mmd-pname{font-size:.88rem;font-weight:700;color:var(--gray-900);line-height:1.3;}
.bb-mmd-vs{
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;font-weight:700;color:var(--gray-400);
  flex-shrink:0;padding:0 .25rem;
}
.bb-mmd-table{
  text-align:center;font-size:.82rem;font-weight:600;
  color:var(--amber-600);background:var(--amber-50);
  border-radius:var(--r);padding:.4rem .75rem;
}

/* Connector lines between rounds (CSS only, no SVG needed) */
.bb-round:not(:last-child){
  position:relative;
}
.bb-round:not(:last-child)::after{
  content:'';
  position:absolute;
  top:0;bottom:0;right:-12px;
  width:12px;
  background:transparent;
  pointer-events:none;
}
/* Visual connector via border on match cards */
.bb-match{
  position:relative;
}
.bb-match::after{
  content:'';
  position:absolute;
  right:-13px;top:50%;
  width:13px;height:2px;
  background:var(--gray-200);
  z-index:1;
}
.bb-match.done::after{background:var(--green-600);opacity:.4;}
.bb-round:last-child .bb-match::after{display:none;}

/* ══════════════════════════════════════════════════════
   BILLIARDS BRACKET — Member Widget Shortcodes
   [bb_profile] và [bb_login]
══════════════════════════════════════════════════════ */
.bbw{
  --bb-bg:  #12161e;
  --bb-bg2: #1a1f2b;
  --bb-bd:  #272d3d;
  --bb-tx:  #e2e6f0;
  --bb-tx2: #9aa0b0;
  --bb-gold:#c9a84c;
  background:var(--bb-bg);
  border:1px solid var(--bb-bd);
  border-radius:12px;
  padding:16px;
  font-family:'DM Sans',sans-serif;
  color:var(--bb-tx);
  font-size:14px;
  max-width:100%;
  box-sizing:border-box;
}
.bbw *{box-sizing:border-box;}

/* ── Auth tabs ── */
.bbw-auth-tabs{display:flex;gap:4px;margin-bottom:12px;background:var(--bb-bg2);border-radius:8px;padding:3px;}
.bbw-atab{flex:1;background:transparent;border:none;color:var(--bb-tx2);padding:7px 0;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .18s;}
.bbw-atab.on{background:var(--bb-gold);color:#12161e;font-weight:700;}
.bbw-at-panel{display:flex;flex-direction:column;gap:8px;}

/* ── Inputs ── */
.bbw-input{width:100%;background:var(--bb-bg2);border:1px solid var(--bb-bd);border-radius:8px;color:var(--bb-tx);padding:9px 12px;font-size:13px;outline:none;transition:border .15s;}
.bbw-input:focus{border-color:var(--bb-gold);}
select.bbw-input{cursor:pointer;}

/* ── Buttons ── */
.bbw-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;padding:9px 16px;transition:all .18s;}
.bbw-btn-primary{background:var(--bb-gold);color:#12161e;}
.bbw-btn-primary:hover{filter:brightness(1.1);}
.bbw-btn-ghost{background:transparent;border:1px solid var(--bb-bd);color:var(--bb-tx2);}
.bbw-btn-ghost:hover{border-color:var(--bb-gold);color:var(--bb-gold);}
.bbw-btn-sm{padding:6px 12px;font-size:12px;}
.bbw-btn-xs{padding:4px 10px;font-size:11px;}
.bbw-btn:disabled{opacity:.5;cursor:not-allowed;}
.w100{width:100%;}

/* ── Badges ── */
.bbw-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.02em;}
.bbw-badge-green{background:rgba(34,197,94,.15);color:#22c55e;}
.bbw-badge-amber{background:rgba(245,158,11,.15);color:#f59e0b;}
.bbw-badge-red  {background:rgba(239,68,68,.12);color:#ef4444;}
.bbw-badge-blue {background:rgba(96,165,250,.13);color:#60a5fa;}

/* ── Profile card ── */
.bbw-profile-card{display:flex;align-items:center;gap:12px;padding:4px 0 12px;}
.bbw-av-wrap{width:52px;height:52px;border-radius:12px;overflow:hidden;background:var(--bb-bg2);border:2px solid var(--bb-bd);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:var(--bb-gold);}
.bbw-av-wrap img{width:100%;height:100%;object-fit:cover;}
.bbw-profile-info{flex:1;min-width:0;}
.bbw-profile-name{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.bbw-profile-stats{display:flex;align-items:center;gap:4px;margin-top:4px;font-size:12px;color:var(--bb-tx2);}
.bbw-stat-sep{color:var(--bb-bd);}
.bbw-green{color:#22c55e;}
.bbw-red{color:#ef4444;}

/* ── History ── */
.bbw-history{margin-top:4px;border-top:1px solid var(--bb-bd);padding-top:10px;}
.bbw-hist-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--bb-tx2);margin-bottom:6px;}
.bbw-hist-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid rgba(39,45,61,.7);font-size:13px;}
.bbw-hist-row:last-child{border-bottom:none;}
.bbw-hist-name{font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.bbw-dim{color:var(--bb-tx2);}
.bbw-loader{text-align:center;padding:10px;color:var(--bb-tx2);font-size:13px;}

/* ── Notes ── */
.bbw-note{font-size:.78rem;color:var(--bb-tx2);background:var(--bb-bg2);border-radius:8px;padding:8px 10px;line-height:1.5;margin:0 0 4px;}
.bbw-err{color:#ef4444;font-size:12px;min-height:16px;margin:2px 0 0;}

/* ── Avatar upload in widget ── */
.bbw-av-upload{background:var(--bb-bg2);border:1px dashed var(--bb-bd);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:6px;}
.bbw-av-preview-ph{text-align:center;color:var(--bb-tx2);font-size:13px;padding:8px;}
.bbw-av-btns{display:flex;gap:6px;}

/* ── Mini [bb_login] ── */
.bbw-mini{padding:14px;}
.bbw-mini-logged{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.bbw-mini-form{display:flex;flex-direction:column;gap:8px;}
