/* ============================================================
   BBT Manager v2 — Mobile-First Styles
   ============================================================ */
:root {
  --bbt-primary: #003f7f;
  --bbt-secondary: #c8a800;
  --bbt-accent: #e63329;
  --bbt-bg: #f4f6fa;
  --bbt-white: #fff;
  --bbt-border: #dde3ec;
  --bbt-text: #1a2433;
  --bbt-muted: #6b7a8d;
  --bbt-green: #16a34a;
  --bbt-orange: #ea580c;
  --bbt-radius: 10px;
  --bbt-shadow: 0 2px 12px rgba(0,63,127,.10);
}

/* Base */
.bbt-container { font-family:'Segoe UI',Arial,sans-serif; color:var(--bbt-text); max-width:1100px; margin:0 auto; }
.bbt-header { background:linear-gradient(135deg,var(--bbt-primary) 0%,#005bb5 100%); color:#fff; padding:18px 20px; border-radius:var(--bbt-radius) var(--bbt-radius) 0 0; }
.bbt-header h2 { margin:0; font-size:1.3rem; color:#fff; }

/* Tabs */
.bbt-tabs { display:flex; gap:2px; background:var(--bbt-primary); padding:0 12px; flex-wrap:wrap; overflow-x:auto; -webkit-overflow-scrolling:touch; }
.bbt-tab { background:transparent; color:rgba(255,255,255,.7); border:none; padding:11px 16px; cursor:pointer; font-size:.85rem; font-weight:600; border-bottom:3px solid transparent; transition:all .2s; white-space:nowrap; }
.bbt-tab:hover { color:#fff; background:rgba(255,255,255,.1); }
.bbt-tab.active { color:var(--bbt-secondary); border-bottom-color:var(--bbt-secondary); }
.bbt-extra-badge { background:var(--bbt-secondary); color:#000; font-size:.65rem; padding:1px 5px; border-radius:8px; margin-left:4px; }
.bbt-count-small { background:rgba(255,255,255,.3); color:#fff; font-size:.7rem; padding:1px 5px; border-radius:8px; margin-left:4px; }

/* Panels */
.bbt-cat-panel, .bbt-tour-panel { display:none; padding:16px; }
.bbt-cat-panel.active, .bbt-tour-panel.active { display:block; }
.bbt-cat-header { display:flex; align-items:center; gap:12px; margin-bottom:14px; flex-wrap:wrap; }
.bbt-cat-header h3 { margin:0; font-size:1rem; color:var(--bbt-primary); }
.bbt-count { background:var(--bbt-primary); color:#fff; font-size:.75rem; padding:2px 8px; border-radius:20px; font-weight:normal; }
.bbt-extra-note, .bbt-extra-note-public { background:#fef9c3; border:1px solid #fde68a; color:#92400e; padding:10px 16px; border-radius:8px; font-size:.85rem; margin:10px 0; }

/* Desktop/Mobile toggles */
@media (min-width:769px) { .bbt-mobile-only { display:none !important; } }
@media (max-width:768px)  { .bbt-desktop-only { display:none !important; } }

/* Table */
.bbt-table-wrap { overflow-x:auto; border-radius:var(--bbt-radius); box-shadow:var(--bbt-shadow); }
.bbt-table { width:100%; border-collapse:collapse; font-size:.84rem; background:#fff; }
.bbt-table thead { background:var(--bbt-primary); color:#fff; }
.bbt-table thead th { padding:9px 8px; text-align:center; font-weight:600; white-space:nowrap; font-size:.78rem; letter-spacing:.3px; }
.bbt-table th.bbt-col-name, .bbt-table td.bbt-col-name { text-align:left; min-width:140px; }
.bbt-table tbody tr { border-bottom:1px solid var(--bbt-border); transition:background .15s; }
.bbt-table tbody tr:hover { background:#f0f5ff; }
.bbt-table td { padding:8px 7px; text-align:center; }
.bbt-table td.bbt-col-pos { font-weight:700; font-size:1rem; }
.bbt-table td.bbt-col-net strong { color:var(--bbt-primary); font-size:.95rem; }

/* Scores */
.bbt-score-ok { background:#f0f7ff; }
.bbt-score-empty { color:#bbb; }
.bbt-score-exclu { background:#fff3cd; position:relative; }
.bbt-x { color:var(--bbt-accent); font-size:.75rem; margin-left:2px; }

/* Positions */
tr.bbt-pos-1 { background:linear-gradient(90deg,#fff8dc,#fffde7); }
tr.bbt-pos-2 { background:linear-gradient(90deg,#f8f8f8,#fafafa); }
tr.bbt-pos-3 { background:linear-gradient(90deg,#fdf3e7,#fdf8f2); }
tr.bbt-qualified { border-left:3px solid var(--bbt-green); }

/* Cards (mobile) */
.bbt-cards { display:flex; flex-direction:column; gap:10px; padding:4px 0; }
.bbt-card { background:#fff; border:1px solid var(--bbt-border); border-radius:var(--bbt-radius); padding:12px 14px; box-shadow:var(--bbt-shadow); }
.bbt-card-qualified { border-left:4px solid var(--bbt-green); }
.bbt-card-header { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.bbt-card-pos { font-size:1.2rem; font-weight:700; min-width:30px; }
.bbt-card-name { flex:1; font-weight:600; font-size:.9rem; }
.bbt-card-pts { font-size:1rem; color:var(--bbt-primary); white-space:nowrap; }
.bbt-card-body { display:flex; gap:12px; flex-wrap:wrap; font-size:.8rem; color:var(--bbt-muted); margin-bottom:8px; }
.bbt-card-scores { display:grid; grid-template-columns:repeat(6,1fr); gap:4px; }
.bbt-card-score { text-align:center; background:var(--bbt-bg); border-radius:6px; padding:4px 2px; }
.bbt-card-score.has-score { background:#e8f4ff; }
.bbt-card-score.exclu { background:#fff3cd; }
.bbt-card-score-label { font-size:.65rem; color:var(--bbt-muted); }
.bbt-card-score-val { font-size:.82rem; font-weight:600; }
.bbt-card-score-bonus { font-size:.6rem; color:var(--bbt-green); }

/* Vétéran badge */
.bbt-vet-badge { background:#7c3aed; color:#fff; font-size:.65rem; padding:1px 4px; border-radius:4px; margin-left:3px; vertical-align:middle; }

/* Cat badges */
.bbt-cat-badge { padding:2px 7px; border-radius:10px; font-size:.75rem; font-weight:600; }
.bbt-cat-195 { background:#dbeafe; color:#1e40af; }
.bbt-cat-194 { background:#dcfce7; color:#166534; }
.bbt-cat-dames { background:#fce7f3; color:#9d174d; }
.bbt-cat-veterans { background:#ede9fe; color:#5b21b6; }
.bbt-cat-onhold { background:#fef9c3; color:#854d0e; }

/* Filter bar */
.bbt-filter-bar { display:flex; gap:6px; margin-bottom:12px; flex-wrap:wrap; }
.bbt-filter { padding:5px 12px; border-radius:20px; border:1.5px solid var(--bbt-border); background:#fff; cursor:pointer; font-size:.8rem; font-weight:500; transition:all .15s; }
.bbt-filter:hover { border-color:var(--bbt-primary); color:var(--bbt-primary); }
.bbt-filter.active { background:var(--bbt-primary); color:#fff; border-color:var(--bbt-primary); }

/* Legend */
.bbt-legend { display:flex; gap:16px; padding:10px 0; font-size:.78rem; color:var(--bbt-muted); flex-wrap:wrap; }
.bbt-legend-dot { width:10px; height:10px; border-radius:50%; display:inline-block; margin-right:4px; vertical-align:middle; }
.bbt-legend-qualified { background:var(--bbt-green); }

/* Tournois grid */
.bbt-tournois-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:14px; padding:16px; }
.bbt-tournoi-card { background:#fff; border:1px solid var(--bbt-border); border-radius:var(--bbt-radius); padding:18px 16px; box-shadow:var(--bbt-shadow); position:relative; }
.bbt-tournoi-num { position:absolute; top:-10px; left:14px; background:var(--bbt-primary); color:#fff; width:26px; height:26px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.85rem; }
.bbt-tournoi-done { border-top:3px solid var(--bbt-green); }
.bbt-tournoi-live { border-top:3px solid var(--bbt-accent); }
.bbt-tournoi-upcoming { border-top:3px solid var(--bbt-muted); }
.bbt-tournoi-card h4 { margin:8px 0 6px; font-size:.95rem; color:var(--bbt-primary); }
.bbt-tournoi-card p { margin:3px 0; font-size:.82rem; color:var(--bbt-muted); }
.bbt-tournoi-status { font-size:.75rem; font-weight:600; margin-bottom:4px; }
.bbt-badge-done { display:inline-block; margin-top:8px; padding:3px 9px; border-radius:12px; background:#dcfce7; color:#166534; font-size:.78rem; font-weight:600; }
.bbt-badge-pending { display:inline-block; margin-top:8px; padding:3px 9px; border-radius:12px; background:#fef9c3; color:#854d0e; font-size:.78rem; }

/* Tops / Stats */
.bbt-tops-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:14px; margin-bottom:24px; }
.bbt-top-box { background:#fff; border:1px solid var(--bbt-border); border-radius:var(--bbt-radius); padding:14px; box-shadow:var(--bbt-shadow); }
.bbt-top-box h4 { margin:0 0 10px; font-size:.9rem; color:var(--bbt-primary); }
.bbt-top-row { display:flex; align-items:center; gap:8px; padding:5px 0; border-bottom:1px solid var(--bbt-border); font-size:.82rem; }
.bbt-top-row:last-child { border-bottom:none; }
.bbt-top-pos { font-weight:700; min-width:24px; }
.bbt-top-name { flex:1; }
.bbt-top-pts { font-weight:700; color:var(--bbt-primary); }

/* Recherche joueur */
.bbt-recherche .bbt-search-box { padding:16px; }
.bbt-search-input { width:100%; max-width:400px; padding:10px 14px; border:2px solid var(--bbt-border); border-radius:8px; font-size:.95rem; margin-right:8px; }
.bbt-search-btn { padding:10px 20px; background:var(--bbt-primary); color:#fff; border:none; border-radius:8px; cursor:pointer; font-weight:600; }
.bbt-joueur-card { background:#fff; border:1px solid var(--bbt-border); border-radius:var(--bbt-radius); padding:16px; box-shadow:var(--bbt-shadow); margin-bottom:10px; }
.bbt-joueur-card-header { display:flex; gap:12px; align-items:flex-start; margin-bottom:10px; }
.bbt-joueur-flag { font-size:1.8rem; }
.bbt-joueur-meta { display:flex; gap:10px; flex-wrap:wrap; font-size:.8rem; color:var(--bbt-muted); margin-top:3px; }
.bbt-joueur-section { padding:8px 0; border-top:1px solid var(--bbt-border); font-size:.85rem; }
.bbt-vet-section { background:#f5f3ff; border-radius:6px; padding:8px 10px; margin-top:4px; }

/* Misc */
.bbt-tour-info { margin-bottom:12px; }
.bbt-tour-info h3 { margin:0 0 4px; font-size:1rem; color:var(--bbt-primary); }
.bbt-tour-info p { margin:2px 0; font-size:.82rem; color:var(--bbt-muted); }
.bbt-empty { color:var(--bbt-muted); font-style:italic; padding:20px 0; text-align:center; }
.bbt-updated { text-align:right; font-size:.74rem; color:var(--bbt-muted); padding:8px 0 4px; margin:0; }

/* Responsive tweaks */
@media (max-width:480px) {
  .bbt-header h2 { font-size:1.1rem; }
  .bbt-tab { padding:9px 11px; font-size:.78rem; }
  .bbt-card-scores { grid-template-columns:repeat(3,1fr); }
  .bbt-tournois-grid { grid-template-columns:1fr; }
}

/* Sélecteur de saison */
.bbt-saison-selector { display:flex; gap:8px; flex-wrap:wrap; padding:12px 16px; background:#f4f6fa; border-bottom:1px solid var(--bbt-border); }
.bbt-saison-btn { padding:6px 14px; border-radius:20px; border:1.5px solid var(--bbt-border); background:#fff; text-decoration:none; color:var(--bbt-text); font-size:.85rem; font-weight:500; transition:all .15s; }
.bbt-saison-btn:hover { border-color:var(--bbt-primary); color:var(--bbt-primary); }
.bbt-saison-btn.active { background:var(--bbt-primary); color:#fff; border-color:var(--bbt-primary); }
