    /* Franchise mode (Indian Championship League) */
    .fl-team-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin-bottom: 16px; }
    @media (max-width: 1100px) { .fl-team-grid { grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); } }
    /* justify-content/items: start beat the UA button rules that center grid
       content - without them short names float to the middle while long ones
       hug the left edge. */
    .fl-team-card { position: relative; overflow: hidden; display: grid; gap: 4px; align-content: start; justify-content: start; justify-items: start; padding: 14px 14px 12px; text-align: left; background: var(--panel) !important; color: var(--text) !important; border: 1px solid var(--line) !important; border-left: 4px solid var(--fl-color, var(--accent)) !important; border-radius: var(--r-lg); cursor: pointer; transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease; animation: flCardIn .4s ease both; }
    @keyframes flCardIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
    .fl-team-card::before { content: ''; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(130% 100% at 100% 0%, color-mix(in srgb, var(--fl-color, var(--accent)) 16%, transparent), transparent 55%); }
    .fl-team-card:hover { transform: translateY(-4px); border-color: color-mix(in srgb, var(--fl-color, var(--accent)) 70%, transparent) !important; box-shadow: 0 14px 34px color-mix(in srgb, var(--fl-color, var(--accent)) 22%, transparent); }
    .fl-team-card.chosen { border-color: var(--fl-color, var(--accent)) !important; box-shadow: 0 0 0 1px var(--fl-color, var(--accent)), 0 14px 34px color-mix(in srgb, var(--fl-color, var(--accent)) 28%, transparent); }
    .fl-card-mono { position: absolute; right: -6px; bottom: -22px; font-size: 80px; font-weight: 900; letter-spacing: -5px; line-height: 1; color: var(--fl-color, var(--accent)); opacity: 0.07; pointer-events: none; user-select: none; }
    .fl-card-top { display: flex; align-items: center; min-width: 0; padding-right: 46px; }
    .fl-team-abbrev { font-size: 20px; letter-spacing: 0.1em; font-weight: 800; color: var(--fl-color, var(--accent)); text-shadow: 0 0 18px color-mix(in srgb, var(--fl-color, var(--accent)) 45%, transparent); }
    .fl-card-ovr { position: absolute; top: 12px; right: 12px; display: inline-grid; place-items: center; min-width: 34px; height: 26px; padding: 0 7px; border-radius: 8px; font-weight: 800; font-size: 14px; background: rgba(255,255,255,0.04); border: 1px solid var(--line-strong); }
    .fl-team-name { font-weight: 800; font-size: 15px; position: relative; min-width: 0; max-width: 100%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .fl-team-place { color: var(--muted); position: relative; font-size: 12px; min-width: 0; max-width: 100%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .fl-team-card.chosen .fl-card-ovr { border-color: var(--fl-color, var(--accent)); background: color-mix(in srgb, var(--fl-color, var(--accent)) 18%, transparent); }
    .fl-mode-panel { margin-top: 4px; border-left: 4px solid var(--fl-color, var(--accent)) !important; animation: flCardIn .3s ease both; }
    .fl-mode-panel h2 { margin-top: 0; }
    .fl-mode-options { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 12px; margin-top: 12px; }
    .fl-mode-option { position: relative; overflow: hidden; min-width: 0; display: grid; grid-template-columns: minmax(0, 1fr); gap: 6px; justify-content: start; justify-items: start; white-space: normal; text-align: left; padding: 18px 18px 16px; background: var(--panel-2) !important; color: var(--text) !important; border: 1px solid var(--line-strong) !important; border-radius: var(--r-md); cursor: pointer; transition: transform .14s ease, border-color .14s ease, box-shadow .14s ease; }
    .fl-mode-option::before { content: ''; position: absolute; inset: 0; pointer-events: none; opacity: 0; transition: opacity .14s ease; background: radial-gradient(120% 120% at 0% 0%, color-mix(in srgb, var(--fl-color, var(--accent)) 14%, transparent), transparent 60%); }
    .fl-mode-option:hover { transform: translateY(-2px); border-color: var(--fl-color, var(--accent)) !important; box-shadow: 0 10px 26px color-mix(in srgb, var(--fl-color, var(--accent)) 18%, transparent); }
    .fl-mode-option:hover::before { opacity: 1; }
    .fl-mode-option b { font-size: 16px; position: relative; }
    .fl-mode-option b::after { content: ' →'; color: var(--fl-color, var(--accent)); }
    .fl-mode-option span { color: var(--muted); font-size: 13px; position: relative; }
    .fl-continue { margin-bottom: 14px; }
    .fl-cost-line { font-size: 13px; color: var(--muted); }
    .fl-cost-bad { color: var(--danger); }

    /* Retention screen: numbered slot rail beside the squad list */
    .fl-retain-layout { display: grid; grid-template-columns: minmax(280px, 340px) minmax(0, 1fr); gap: 14px; align-items: start; }
    @media (max-width: 880px) { .fl-retain-layout { grid-template-columns: 1fr; } .fl-retain-slots-panel { position: static; } }
    .fl-retain-slots-panel { position: sticky; top: 14px; }
    .fl-retain-slots-panel h2 { margin: 0 0 4px; }
    .fl-retain-slots-hint { margin: 0 0 12px; font-size: 12.5px; }
    .fl-retain-slots { display: grid; gap: 6px; }
    .fl-slot { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: center; gap: 3px 10px; width: 100%; min-height: 46px; padding: 7px 12px; border-radius: var(--r-sm); text-align: left; font-size: 13px; }
    .fl-slot.empty { border: 1px dashed var(--line-strong); background: rgba(var(--surface-rgb), 0.45); color: var(--muted); }
    .fl-slot.filled { border: 1px solid rgba(var(--accent-rgb), 0.5); background: rgba(var(--accent-rgb), 0.08) !important; color: var(--text) !important; cursor: pointer; box-shadow: none; }
    .fl-slot.filled:hover { border-color: rgba(228, 84, 74, 0.6); background: rgba(228, 84, 74, 0.08) !important; }
    .fl-slot-label { grid-column: 1; font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); }
    .fl-slot-price { grid-column: 2; grid-row: 1; font-size: 12.5px; color: var(--muted); white-space: nowrap; }
    .fl-slot-player { grid-column: 1 / -1; display: flex; align-items: center; gap: 8px; min-width: 0; font-size: 13.5px; }
    .fl-slot-player b { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .fl-retain-summary { display: grid; gap: 8px; margin-top: 12px; padding-top: 12px; border-top: 1px dashed var(--line-strong); }
    .fl-retain-summary button { width: 100%; }
    .fl-chip-slot { border-color: rgba(var(--accent-rgb), 0.5); color: var(--accent); }

    /* Shared in-app confirm/alert dialog */
    .fl-player-row { display: flex; align-items: center; gap: 12px; width: 100%; text-align: left; padding: 8px 12px; background: var(--panel) !important; color: var(--text) !important; border: 1px solid var(--line) !important; border-radius: var(--r-sm); cursor: pointer; }
    .fl-player-row:hover { border-color: var(--accent-dim) !important; }
    .fl-player-row.picked { border-color: var(--accent) !important; background: rgba(var(--accent-rgb), 0.08) !important; }
    .fl-ovr { display: inline-grid; place-items: center; min-width: 34px; height: 34px; border-radius: 8px; background: rgba(var(--accent-rgb), 0.12); border: 1px solid rgba(var(--accent-rgb), 0.4); color: var(--accent); font-size: 14px; }
    .fl-ovr-big { min-width: 52px; height: 52px; font-size: 22px; }
    .fl-player-main { display: grid; gap: 1px; flex: 1; min-width: 0; }
    .fl-player-main small { color: var(--muted); }
    .fl-player-chips { display: flex; gap: 6px; }
    .fl-auction-layout { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr); gap: 14px; }
    .fl-lot-panel { grid-column: 1; }
    .fl-pulse-panel { grid-column: 1; }
    .fl-purse-panel { grid-column: 2; grid-row: 1; }
    .fl-ticker-panel { grid-column: 2; }
    .fl-mysquad-panel { grid-column: 1 / -1; }
    .fl-lot-player { display: flex; gap: 14px; align-items: flex-start; margin-bottom: 10px; }
    .fl-lot-id h3 { margin: 0 0 6px; font-size: 20px; }
    .fl-chip-os { border-color: rgba(255, 178, 64, 0.6); color: #ffb240; }
    .fl-bid-line { padding: 10px 12px; border-radius: var(--r-sm); background: var(--panel-2); border: 1px solid var(--line-strong); margin-bottom: 8px; }
    .fl-you-hold { color: var(--accent); font-weight: 700; }
    /* Fixed-height zones so the lot card never grows as bids arrive. */
    .fl-bid-log { display: grid; gap: 4px; margin-bottom: 8px; min-height: 70px; align-content: start; }
    .fl-log-row { display: flex; justify-content: space-between; font-size: 13px; color: var(--muted); padding: 2px 12px; }
    #flAuctionActions { display: flex; flex-wrap: nowrap; gap: 10px; margin-top: 16px; }
    #flAuctionActions button { flex: 1 1 0; min-width: 0; margin: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    #flAuctionActions .fl-pause-btn { flex: 0 0 auto; min-width: 48px; font-size: 15px; }
    #flAuctionStatus { min-height: 1.4em; margin: 12px 0 0; text-align: center; }
    #flAuctionStatus.fl-status-final { color: #ffb240; font-weight: 600; animation: flBidIn 220ms ease-out; }
    /* Lot card: stat tiles + overseas plane badge */
    #flLotCard { position: relative; }
    .fl-os-plane { position: absolute; top: 0; right: 0; width: 34px; height: 34px; display: grid; place-items: center; color: #ffb240; background: rgba(255, 178, 64, 0.10); border: 1px solid rgba(255, 178, 64, 0.45); border-radius: 999px; }
    .fl-os-plane svg { transform: rotate(45deg); }
    .fl-stat-tiles { display: grid; grid-template-columns: repeat(auto-fit, minmax(96px, 1fr)); gap: 8px; margin: 2px 0 8px; }
    .fl-stat-tile { display: grid; gap: 2px; padding: 8px 10px; border-radius: var(--r-sm); background: var(--panel-2); border: 1px solid rgba(255,255,255,0.08); }
    .fl-stat-tile b { font-size: 17px; }
    .fl-stat-tile small { color: var(--muted); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .fl-base-line { margin: 0 0 8px; font-size: 12px; }
    /* Auction desk dashboard */
    .fl-pulse-panel { align-self: start; }
    .fl-pulse-tiles { grid-template-columns: repeat(2, 1fr); margin-bottom: 12px; }
    .fl-meter { margin-bottom: 10px; }
    .fl-meter-head { display: flex; align-items: baseline; gap: 8px; font-size: 13px; margin-bottom: 4px; }
    .fl-meter-head b { margin-left: auto; }
    .fl-meter-head small { font-size: 11px; }
    .fl-bar { position: relative; height: 6px; border-radius: 999px; background: var(--panel-2); border: 1px solid rgba(255,255,255,0.07); overflow: visible; }
    .fl-bar-fill { position: absolute; inset: 0 auto 0 0; border-radius: 999px; background: rgba(var(--accent-rgb), 0.75); transition: width 300ms ease; }
    .fl-bar-marker { position: absolute; top: -3px; bottom: -3px; width: 2px; background: #ffb240; border-radius: 1px; }
    .fl-desk-label { font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); margin: 0 0 6px; }
    .fl-desk-divider { border-top: 1px dashed rgba(255,255,255,0.10); margin: 12px 0; }
    .fl-needs { display: flex; flex-wrap: wrap; gap: 6px; margin: 0 0 2px; }
    .fl-need { font-size: 12px; padding: 3px 10px; border-radius: 999px; border: 1px solid rgba(255, 178, 64, 0.45); color: #ffb240; }
    .fl-need-met { border-color: rgba(var(--accent-rgb), 0.5); color: var(--accent); }
    .fl-pulse-top .fl-log-row { padding-inline: 0; }
    @media (max-width: 640px) {
      #flAuctionActions { flex-wrap: wrap; }
      #flAuctionActions button { flex: 1 1 40%; }
    }
    .fl-log-row:first-child { animation: flBidIn 220ms ease-out; color: var(--text); }
    .fl-log-user { color: var(--accent); font-weight: 600; }
    .fl-going { margin-left: 8px; font-weight: 700; letter-spacing: 0.04em; color: #ffb240; animation: flBidIn 220ms ease-out; }
    .fl-continue-btn { border: 1px solid rgba(255, 178, 64, 0.65); color: #ffb240; background: rgba(255, 178, 64, 0.08); animation: flBidIn 220ms ease-out; }
    .fl-continue-btn:hover { background: rgba(255, 178, 64, 0.16); }
    .fl-purse-hint { margin: -4px 0 8px; font-size: 12px; }
    .fl-team-row { cursor: pointer; }
    .fl-team-row:hover td { background: rgba(255,255,255,0.05); }
    .fl-overlay-body { max-height: 64vh; overflow-y: auto; min-width: min(480px, 86vw); padding-right: 6px; }
    .fl-pool-set { margin: 14px 0 4px; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); }
    .fl-pool-set small { color: var(--muted); letter-spacing: normal; text-transform: none; }
    .fl-pool-no { min-width: 26px; color: var(--muted); font-size: 11px; text-align: right; }
    @keyframes flBidIn { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: none; } }
    .fl-squad-row { display: flex; align-items: center; gap: 10px; padding: 6px 10px; border-top: 1px dashed rgba(255,255,255,0.06); }
    .fl-price { font-weight: 700; white-space: nowrap; }
    .fl-hub-layout { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr); gap: 14px; }
    .fl-next-panel { grid-column: 1; }
    .fl-table-panel { grid-column: 2; grid-row: 1 / span 2; }
    .fl-bracket-panel { grid-column: 1; }
    .fl-results-panel { grid-column: 1; }
    .fl-leaders-panel { grid-column: 1 / -1; }
    .fl-schedule-panel { grid-column: 2; }
    .fl-squad-panel { grid-column: 1 / -1; }
    .fl-squad-panel #flSquadList { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 2px 14px; }
    /* Team tabs: hub Squads panel + auction-results overlay */
    .fl-squad-tabs { display: flex; flex-wrap: wrap; gap: 6px; margin: 4px 0 10px; }
    .fl-squad-tab { padding: 4px 12px !important; border-radius: 999px !important; border: 1px solid var(--line) !important; background: transparent !important; color: var(--muted) !important; font-weight: 700; font-size: 12px; cursor: pointer; box-shadow: none !important; }
    .fl-squad-tab:hover { color: var(--text) !important; border-color: var(--line-strong) !important; transform: none; filter: none; }
    .fl-squad-tab.active { color: var(--fl-color, var(--accent)) !important; border-color: currentColor !important; background: rgba(var(--surface-rgb), 0.6) !important; }
    .fl-today-tag { margin: 0 0 6px; font-size: 11px; letter-spacing: 0.14em; color: var(--accent); font-weight: 700; }
    .fl-status-chip { display: inline-flex; flex-direction: column; gap: 2px; margin-top: 8px; padding: 8px 12px; border-radius: 10px; border: 1px solid rgba(var(--accent-rgb), 0.30); border-left: 3px solid var(--accent); background: rgba(var(--accent-rgb), 0.07); }
    .fl-status-chip b { color: var(--text); font-size: 13px; font-weight: 800; }
    .fl-status-chip small { color: var(--muted); font-size: 12px; }
    .fl-playoff-row td:first-child { border-left: 3px solid rgba(var(--accent-rgb), 0.6); }
    .fl-bracket-row { display: grid; grid-template-columns: 92px minmax(0, 1fr); gap: 4px 10px; padding: 8px 10px; border: 1px solid rgba(255,255,255,0.08); border-radius: var(--r-sm); margin-bottom: 8px; }
    .fl-bracket-row small { grid-column: 2; }
    .fl-bracket-stage { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); align-self: center; }
    .fl-schedule { max-height: 420px; overflow-y: auto; display: grid; gap: 2px; padding-right: 6px; }
    .fl-sched-row { display: grid; grid-template-columns: 30px 46px minmax(0, 1fr); gap: 8px; align-items: baseline; padding: 4px 6px; border-top: 1px dashed rgba(255,255,255,0.06); }
    .fl-sched-row small { grid-column: 3; }
    .fl-sched-no { color: var(--muted); font-size: 11px; }
    .fl-sched-date { color: var(--muted); font-size: 12px; }
    .fl-sched-mine b { color: #ffd24d; }
    .fl-sched-done b { opacity: 0.85; }
    @media (max-width: 980px) {
      .fl-auction-layout, .fl-hub-layout { grid-template-columns: 1fr; }
      .fl-lot-panel, .fl-pulse-panel, .fl-purse-panel, .fl-ticker-panel, .fl-mysquad-panel,
      .fl-next-panel, .fl-table-panel, .fl-bracket-panel, .fl-results-panel, .fl-leaders-panel, .fl-schedule-panel, .fl-squad-panel { grid-column: 1; grid-row: auto; }
    }

    /* Franchise choose screen: resume vs new-season split */
    .fl-continue-main { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
    .fl-continue-main h2 { margin: 4px 0 4px; }
    .fl-continue-main p { margin: 0; }
    .fl-continue-label { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); font-weight: 700; }
    .fl-continue-actions button { width: auto; padding: 10px 22px; white-space: nowrap; }
    .fl-start-heading { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; margin: 18px 2px 10px; padding-top: 14px; border-top: 1px dashed var(--line-strong); }
    .fl-start-heading h2 { margin: 0; font-size: 16px; }
    .fl-start-heading p { margin: 0; font-size: 13px; }
    .fl-mode-warn { margin: 6px 0 0; color: var(--warn); }

    /* Franchise overseas-rule markers in the XI picker */
    .os-chip { display: inline-grid; place-items: center; width: 20px; height: 20px; font-size: 11px; line-height: 1; border-radius: 50%; white-space: nowrap; cursor: help; background: rgba(255, 178, 64, 0.14); color: #ffb240; border: 1px solid rgba(255, 178, 64, 0.45); }
    .os-counter { margin-left: 10px; padding: 2px 10px; border-radius: 10px; font-size: 12px; font-weight: 600; background: rgba(255, 178, 64, 0.1); color: #ffb240; border: 1px solid rgba(255, 178, 64, 0.35); white-space: nowrap; cursor: help; }
    .os-counter.os-over { background: rgba(228, 84, 74, 0.15); color: var(--danger); border-color: rgba(228, 84, 74, 0.5); }
