:root {
            --bg: #0f1923;
            --surface: #1a2733;
            --surface2: #243442;
            --surface3: #2d3f4f;
            --accent: #00d4aa;
            --accent-dim: rgba(0, 212, 170, 0.15);
            --red: #ff4757;
            --red-dim: rgba(255, 71, 87, 0.15);
            --yellow: #ffc048;
            --yellow-dim: rgba(255, 192, 72, 0.15);
            --blue: #4da6ff;
            --purple: #a855f7;
            --purple-dim: rgba(168, 85, 247, 0.18);
            --text: #e8edf2;
            --text-dim: #cdd8e1;
            --text-muted: #9eafbd;
            --qb: #c084fc;
            --qb-dim: rgba(192, 132, 252, 0.2);
                   --rb: #00d4aa;
            --rb-dim: rgba(0, 212, 170, 0.2);
            --wr: #ffc048;
            --wr-dim: rgba(255, 192, 72, 0.2);
            --te: #4da6ff;
            --te-dim: rgba(77, 166, 255, 0.2);
            --border: rgba(255,255,255,0.08);
        }

        * { margin: 0; padding: 0; box-sizing: border-box; }

        body {
            font-family: -apple-system, BlinkMacSystemFont, 'Inter', sans-serif;
            background: var(--bg);
            color: var(--text);
            min-height: 100vh;
            padding-top: env(safe-area-inset-top);
            padding-bottom: env(safe-area-inset-bottom);
            -webkit-user-select: none;
            user-select: none;
        }

        .header {
            background: var(--surface);
            border-bottom: 1px solid var(--border);
            padding: 10px 12px;
            display: flex;
            align-items: center;
            justify-content: flex-start;
            position: sticky;
            top: 0;
            z-index: 100;
        }

              .logo { font-size: 0.95rem; font-weight: 700; color: var(--accent); }
        .header-actions { display: flex; gap: 6px; align-items: center; width: 100%; }
        .btn {
            padding: 6px 10px;
            border: none;
            border-radius: 5px;
            font-size: 0.72rem;
            font-weight: 600;
            cursor: pointer;
            -webkit-tap-highlight-color: transparent;
        }

        .btn-accent { background: var(--accent); color: var(--bg); }
        .btn-surface { background: var(--surface2); color: var(--text); }
        .btn-danger { background: var(--red-dim); color: var(--red); }
        @keyframes syncSpin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
        .sync-spinning { animation: syncSpin 0.7s linear infinite; }

        .slot-bar {
            background: var(--surface);
            border-bottom: 1px solid var(--border);
            padding: 8px 12px;
            display: flex;
            align-items: center;
            gap: 10px;
            font-size: 0.76rem;
            overflow-x: auto;
        }

        .slot-bar label { color: var(--text-dim); white-space: nowrap; }
        .slot-bar .value { color: var(--accent); font-weight: 700; }

        .slot-input {
            width: 52px;
            padding: 4px;
            border-radius: 4px;
            border: 1px solid var(--surface3);
            background: var(--bg);
            color: var(--accent);
            font-size: 0.8rem;
            font-weight: 700;
            text-align: center;
            -webkit-appearance: none;
            appearance: none;
        }

        .slot-input:focus { outline: none; border-color: var(--accent); }
        .bar-divider { width: 1px; height: 14px; background: var(--surface3); }

        .status-badge {
            display: flex;
            align-items: center;
            gap: 4px;
            font-size: 0.68rem;
            color: var(--text-dim);
            white-space: nowrap;
        }

                .upnext-soon { color: var(--yellow) !important; font-weight: 800; font-size: 0.74rem; }
        .upnext-clock {
            color: #fff !important; font-weight: 800; font-size: 0.78rem;
            background: var(--red); padding: 3px 9px; border-radius: 5px;
            animation: clockPulse 0.9s ease-in-out infinite;
        }
        @keyframes clockPulse {
            0%,100% { box-shadow: 0 0 0 0 rgba(255,71,87,0.55); }
            50%     { box-shadow: 0 0 0 6px rgba(255,71,87,0); }
        }

        .tabs {
            display: flex;
            background: var(--surface);
            border-bottom: 1px solid var(--border);
            position: sticky;
            top: 44px;
            z-index: 99;
        }

        .tab {
            flex: 1;
            padding: 9px 2px;
            text-align: center;
            font-size: 0.68rem;
            font-weight: 600;
            cursor: pointer;
            border-bottom: 2px solid transparent;
            color: var(--text-dim);
            -webkit-tap-highlight-color: transparent;
        }

        .tab.active { border-bottom-color: var(--accent); color: var(--accent); }

        .panel { display: none; flex-direction: column; overflow: hidden; }
        .panel.active { display: flex; }

            .search-input {
            width: 100%;
            padding: 9px 12px;
            border-radius: 6px;
            border: 1px solid var(--surface3);
            background: var(--bg);
            color: var(--text);
            font-size: 0.88rem;
            -webkit-user-select: text;
            user-select: text;
        }

        .search-input:focus { outline: none; border-color: var(--accent); }
        .search-input::placeholder { color: var(--text-muted); }
    
                .board-counts {
            display: flex; gap: 14px; align-items: center;
            padding: 4px 12px;
            background: var(--surface2);
            border-bottom: 1px solid var(--border);
            font-size: 0.64rem; color: var(--text-dim);
            overflow-x: auto;
        }
        .board-counts .bc-item b { font-size: 0.74rem; }
        .board-counts .bc-total { margin-left: auto; color: var(--text-dim); }

        .board-scroll {
            flex: 1;
            overflow-y: auto;
            overflow-x: auto;
            -webkit-overflow-scrolling: touch;
        }


                .board-table {
            width: 100%;
            min-width: 480px;
            border-collapse: collapse;
            font-size: 0.84rem;
        }

        .board-table th {
            background: var(--surface2);
            padding: 5px 3px;
            text-align: center;
            font-size: 0.62rem;
            color: var(--text-dim);
            text-transform: uppercase;
            position: sticky;
            top: 0;
            z-index: 10;
            white-space: nowrap;
        }

        .board-table td {
            padding: 6px 3px;
            border-bottom: 1px solid var(--border);
            text-align: center;
            white-space: nowrap;
        }
        /* LIVE DRAFT BOARD POPUP */
        .lb-table { border-collapse: collapse; font-size: 0.6rem; white-space: nowrap; }
        .lb-table th, .lb-table td {
            border: 1px solid var(--border);
            padding: 3px 5px; text-align: left;
        }
        .lb-table th {
            background: var(--surface2); color: var(--text-dim);
            text-align: center; position: sticky; top: 0; z-index: 2;
        }
        .lb-rd {
            background: var(--surface2); color: var(--text-dim);
            text-align: center; font-weight: 700;
            position: sticky; left: 0; z-index: 1;
        }
        .lb-cell { color: var(--text); }
        .lb-cell .lb-pos { font-weight: 700; }
        .lb-mycol { background: var(--accent-dim); }
        .lb-next { outline: 2px solid var(--accent); outline-offset: -2px; }


        .board-table tr.current-pick { background: var(--accent-dim); }
        .board-table tr.filled { background: var(--surface); }

                .td-round { color: var(--text-dim); width: 20px; }
        .td-pick { color: var(--text-dim); width: 24px; }
                .td-cap { color: var(--yellow); font-weight: 400; width: 24px; }
                                                                               .td-player { text-align: left; font-weight: 500; max-width: 32px; overflow: hidden; }
        .pname { display: inline-block; white-space: nowrap; }
        .pname.fit1 { font-size: 0.68rem; }
        .pname.fit2 { font-size: 0.60rem; }
        .pname.fit3 { font-size: 0.54rem; letter-spacing: -0.2px; }
        .td-pos { width: 26px; }
               .td-team { color: var(--text-dim); width: 44px; }
        .td-qbstk { width: 46px; }
        .td-wk { width: 28px; font-size: 0.68rem; color: var(--text-dim); }
        .td-bye { color: var(--text-dim); width: 22px; }
        .td-val { width: 26px; font-weight: 700; }
        .td-remove { width: 18px; }


        .pos-tag {
            display: inline-block;
            padding: 1px 5px;
            border-radius: 3px;
            font-size: 0.62rem;
            font-weight: 700;
        }

        .pos-QB { background: var(--qb-dim); color: var(--qb); }
        .pos-RB { background: var(--rb-dim); color: var(--rb); }
        .pos-WR { background: var(--wr-dim); color: var(--wr); }
        .pos-TE { background: var(--te-dim); color: var(--te); }

        .qbstk-yes {
            display: inline-block;
            padding: 1px 5px;
            border-radius: 3px;
            font-size: 0.6rem;
            font-weight: 700;
            background: rgba(255,255,255,0.15);
            color: #ffffff;
            border: 1px solid rgba(255,255,255,0.3);
        }

        .val-pos { color: var(--accent); }
        .val-neg { color: var(--red); }
        .val-zero { color: var(--text-dim); }

        .btn-remove {
            background: none;
            border: none;
            color: var(--text-muted);
            font-size: 0.85rem;
            cursor: pointer;
            padding: 2px 4px;
        }
        .ranks-subtabs {
            display: flex; gap: 0; margin: 4px 0 8px;
            border-bottom: 1px solid var(--border);
        }
        .ranks-subtab {
            flex: 1; text-align: center; padding: 7px;
            font-size: 0.78rem; font-weight: 600; color: var(--text-dim);
            cursor: pointer; border-bottom: 2px solid transparent;
            transition: all 0.12s;
        }
        .ranks-subtab:hover { color: var(--text); }
        .ranks-subtab.active {
            color: var(--accent); border-bottom-color: var(--accent);
        }

        .btn-remove:active { color: var(--red); }
                .empty-slot { color: var(--text-muted); font-style: italic; font-size: 0.72rem; }

               .td-wk-bb-qb {
            font-weight: 800;
            color: #00ffcc;
            background: var(--accent-dim);
            border-radius: 3px;
        }
        .td-wk-bb-team {
            font-weight: 800;
            color: #ffffff;
            background: var(--accent-dim);
            border-radius: 3px;
        }
        .pw-bb { color: var(--accent); font-weight: 700; }
        .pw-bb-names { color: var(--text); font-weight: 400; }
        /* RANKINGS */
        .ranks-filters {
            display: flex;
            gap: 6px;
            padding: 8px 12px;
            background: var(--surface);
            border-bottom: 1px solid var(--border);
            overflow-x: auto;
            align-items: center;
        }

        .rank-chip {
            padding: 5px 14px;
            border-radius: 16px;
            font-size: 0.74rem;
            font-weight: 600;
            border: 1px solid var(--surface3);
            background: transparent;
            color: var(--text-dim);
            cursor: pointer;
            white-space: nowrap;
            -webkit-tap-highlight-color: transparent;
        }
		        .team-filter-input {
            padding: 5px 10px;
            border-radius: 16px;
            font-size: 0.74rem;
            font-weight: 600;
            border: 1px solid var(--surface3);
            background: var(--bg);
            color: var(--text);
            width: 80px;
            -webkit-user-select: text;
            user-select: text;
        }
        .team-filter-input:focus { outline: none; border-color: var(--blue); }
        .team-filter-input::placeholder { color: var(--text-muted); font-weight: 400; }


        .rank-chip.active { border-color: var(--accent); background: var(--accent-dim); color: var(--accent); }
        .rank-chip.active-qb { border-color: var(--qb); background: var(--qb-dim); color: var(--qb); }
        .rank-chip.active-rb { border-color: var(--rb); background: var(--rb-dim); color: var(--rb); }
        .rank-chip.active-wr { border-color: var(--wr); background: var(--wr-dim); color: var(--wr); }
        .rank-chip.active-te { border-color: var(--te); background: var(--te-dim); color: var(--te); }
    
        .ranks-scroll {
            flex: 1;
            overflow-y: auto;
            -webkit-overflow-scrolling: touch;
        }

              .ranks-table {
            width: 100%;
            border-collapse: collapse;
            font-size: 0.88rem;
        }
                          .ranks-table th {
            background: var(--surface2);
            padding: 5px 4px;
            font-size: 0.70rem;
            color: var(--text-dim);
            text-transform: uppercase;
            position: sticky;
            top: 0;
            z-index: 10;
            cursor: pointer;
            white-space: nowrap;
        }

        .ranks-table th.sortable:active { color: var(--accent); }
        .ranks-table th .sort-arrow { font-size: 0.6rem; opacity: 0.6; }

            .ranks-table td {  
            padding: 5px 4px;
            border-bottom: 1px solid var(--border);
            white-space: nowrap;
        }
        .ranks-table tr.drafted { opacity: 0.3; }
        .ranks-table tr:active { background: var(--surface2); }
        .rt-rank { color: #7dd3fc; text-align: center; width: 28px; font-size: 0.78rem; font-weight: 700; }
        .rt-lu { color: #e879f9; text-align: center; width: 28px; font-size: 0.78rem; font-weight: 700; }
        .rt-adp { color: var(--text-dim); text-align: center; width: 36px; font-size: 0.78rem; }
        .rt-pos { text-align: center; width: 36px; }
        .rt-player { font-weight: 500; font-size: 0.92rem; max-width: 100px; overflow: hidden; text-overflow: ellipsis; }
               .rt-team { color: var(--text-dim); text-align: center; width: 34px; font-size: 0.78rem; }
        .rt-cap { text-align: center; width: 40px; color: var(--yellow); font-weight: 700; }
        .rt-bye { color: var(--text-dim); text-align: center; width: 36px; }

        .scroll-panel {
            padding: 12px;
            overflow-y: auto;
            -webkit-overflow-scrolling: touch;
            flex: 1;
        }

        .section-title {
            font-size: 0.72rem;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            color: var(--text-dim);
            margin: 14px 0 8px;
            padding-bottom: 4px;
            border-bottom: 1px solid var(--border);
        }

        .section-title:first-child { margin-top: 0; }
        .section-title.hl { color: var(--purple); }

          .qbstack-card {
            background: transparent;
            border: 1px solid var(--purple);
            border-radius: 8px;
            padding: 10px 12px;
            margin-bottom: 8px;
        }
        .qbstack-head {
            display: flex;
            align-items: center;
            gap: 8px;
            margin-bottom: 6px;
        }

            .qbstack-team { font-size: 0.92rem; font-weight: 700; color: #ffffff; }
        .qbstack-qb {
            font-size: 0.81rem;
            font-weight: 600;
            color: var(--qb);
            background: var(--qb-dim);
            border: 1px solid var(--qb);
            padding: 3px 8px;
            border-radius: 4px;
        }

        .qbstack-skill {
            font-size: 0.74rem;
            color: var(--text-dim);
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
        }
                                                      .qbstack-playoffs {
            margin-top: 6px;
            font-size: 0.68rem;
            color: var(--text);
            display: flex;
            gap: 8px;
            flex-wrap: nowrap;
            justify-content: space-between;
        }
        .qbstack-playoffs .pw {
            min-width: 0;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
        .qbstack-playoffs .pw { display: flex; gap: 4px; }
               .qbstack-playoffs .pw-label { color: var(--text-dim); font-weight: 600; }
        .stack-table { width: 100%; border-collapse: collapse; font-size: 0.74rem; }
        .stack-table th {
            padding: 5px 6px; text-align: center; font-size: 0.64rem;
            color: var(--text-dim); border-bottom: 1px solid var(--border);
        }
        .stack-table td { padding: 6px; border-bottom: 1px solid var(--border); text-align: center; }
        .stack-table .st-team { text-align: left; font-weight: 700; }
        .stack-table .st-count { font-weight: 700; color: var(--accent); }

        .no-data { font-size: 0.8rem; color: var(--text-muted); padding: 16px 0; text-align: center; }

        .cap-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 6px;
            margin-bottom: 12px;
        }

        .cap-card {
            background: var(--surface);
            border-radius: 6px;
            padding: 8px 6px;
            text-align: center;
            border: 1px solid var(--border);
        }

        .cap-card .cc-pos { font-size: 0.66rem; font-weight: 700; margin-bottom: 2px; }
        .cap-card .cc-count { font-size: 0.66rem; color: var(--text-dim); }
        .cap-card .cc-val { font-size: 1rem; font-weight: 700; margin: 2px 0; }
        .cap-card .cc-range { font-size: 0.6rem; color: var(--text-muted); }
        .cap-card.in-range { border-color: var(--accent); }
        .cap-card.over { border-color: var(--red); }
        .cap-card.under { border-color: var(--yellow); }

        .cap-bar-row { display: flex; align-items: center; margin-bottom: 8px; gap: 6px; }
               .cap-bar-label { width: 44px; font-size: 0.7rem; font-weight: 700; text-align: right; }

        .cap-bar-track {
            flex: 1; height: 20px;
            background: var(--surface);
            border-radius: 4px;
            position: relative;
            overflow: hidden;
        }
                .cap-bar-range-marker {
            position: absolute; top: 0; height: 100%;
            border-left: 2px solid rgba(255,255,255,0.85);
            border-right: 2px solid rgba(255,255,255,0.85);
            background: rgba(255,255,255,0.06);
            z-index: 3;
            pointer-events: none;
        }
        .cap-bar-range-marker::before,
        .cap-bar-range-marker::after {
            content: ''; position: absolute; top: 0; width: 2px; height: 100%;
            background: rgba(0,0,0,0.35);
        }
        .cap-bar-range-marker::before { left: -1px; }
        .cap-bar-range-marker::after  { right: -1px; }
               .cap-bar-fill {
            position: relative;
            z-index: 1;
            height: 100%;
            border-radius: 4px;
            transition: width 0.3s;
            display: flex;
            align-items: center;
            justify-content: flex-end;
            padding-right: 4px;
            font-size: 0.6rem;
            font-weight: 700;
            color: var(--bg);
        }
        .fill-qb { background: var(--qb); }
        .fill-rb { background: var(--rb); }
        .fill-wr { background: var(--wr); }
        .fill-te { background: var(--te); }
        .cap-bar-info { width: 65px; font-size: 0.66rem; color: var(--text-dim); }

        .cap-total-row {
            background: var(--surface);
            border-radius: 6px;
            padding: 10px 12px;
            display: flex;
            justify-content: space-between;
            margin-top: 10px;
        }
        .cap-total-row span:first-child { font-size: 0.76rem; color: var(--text-dim); }
        .cap-total-row span:last-child { font-size: 0.95rem; font-weight: 700; color: var(--accent); }

        .bye-table { width: 100%; border-collapse: collapse; font-size: 0.74rem; }
        .bye-table th {
            padding: 5px 6px; text-align: center; font-size: 0.64rem;
            color: var(--text-dim); border-bottom: 1px solid var(--border);
        }
        .bye-table td { padding: 5px 6px; text-align: center; border-bottom: 1px solid var(--border); }
        .bye-table .bye-wk { text-align: left; color: var(--text-dim); font-weight: 600; }
        .bc-0 { color: var(--text-muted); }
        .bc-1 { color: var(--accent); }
        .bc-2 { color: var(--yellow); font-weight: 700; }
        .bc-3 { color: var(--red); font-weight: 700; }

        @media (min-width: 768px) {
            .tabs { display: none; }
            .main-wrap { display: flex; height: calc(100vh - 88px); }
            .panel-board, .panel-ranks { display: flex !important; }
            .panel-board { flex: 2; border-right: 1px solid var(--border); }
            .panel-ranks { flex: 1.3; border-right: 1px solid var(--border); max-width: 400px; }
            .panel-side { display: flex !important; flex: 1; max-width: 340px; overflow-y: auto; -webkit-overflow-scrolling: touch; padding: 12px; flex-direction: column; }
            .mobile-only { display: none !important; }
        }

        @media (max-width: 767px) {
            .desktop-only { display: none !important; }
            .panel-side { display: none !important; }
        }
        .settings-overlay {
            display: none;
            position: fixed; inset: 0;
            background: rgba(0,0,0,0.6);
            z-index: 500;
            align-items: flex-start;
            justify-content: center;
            padding-top: 60px;
        }
        .settings-panel {
            background: var(--surface);
            border: 1px solid var(--surface3);
            border-radius: 10px;
            padding: 14px;
            width: 90%; max-width: 340px;
            max-height: 80vh; overflow-y: auto;
        }
        .settings-head {
            display: flex; justify-content: space-between; align-items: center;
            font-weight: 700; color: var(--accent); margin-bottom: 12px;
        }
        .settings-divider {
            font-size: 0.66rem; text-transform: uppercase; color: var(--text-dim);
            margin: 12px 0 6px; padding-top: 8px; border-top: 1px solid var(--border);
        }
        .slider-row { margin-bottom: 10px; }
        .slider-row label {
            display: flex; justify-content: space-between;
            font-size: 0.74rem; color: var(--text-dim); margin-bottom: 3px;
        }
                .slider-row label span { color: var(--accent); font-weight: 700; }
        .slider-row label .def { color: var(--text-muted); font-weight: 400; font-size: 0.66rem; }

        .slider-row input[type=range] { width: 100%; accent-color: var(--accent); }
        .info-ic {
            display: inline-block;
            width: 15px; height: 15px;
            line-height: 15px; text-align: center;
            border-radius: 50%;
            background: var(--surface3);
            color: var(--text-dim);
            font-size: 0.62rem; font-weight: 700;
            cursor: pointer; margin-left: 3px;
            -webkit-tap-highlight-color: transparent;
        }
        .info-ic:active { background: var(--accent); color: var(--bg); }
        .info-txt {
            display: none;
            font-size: 0.66rem;
            line-height: 1.4;
            color: var(--text-dim);
            background: var(--bg);
            border-left: 2px solid var(--accent);
            border-radius: 0 4px 4px 0;
            padding: 6px 8px;
            margin: 4px 0 6px;
        }
		        .info-txt code {
            display: block;
            margin-top: 4px;
            font-family: 'SF Mono', ui-monospace, Menlo, monospace;
            font-size: 0.62rem;
            color: var(--accent);
            background: rgba(0,0,0,0.25);
            padding: 4px 6px;
            border-radius: 3px;
            white-space: pre-wrap;
        }
             .info-slider {
            display: block;
            margin-top: 5px;
            font-size: 0.64rem;
            font-style: italic;
            color: var(--text);
        }
         .preset-bar { display: flex; gap: 6px; align-items: center; margin-bottom: 5px; }
        .preset-status { font-size: 0.64rem; color: var(--text-dim); min-height: 14px; margin-bottom: 6px; }
        .preset-status.dirty { color: var(--yellow); font-weight: 600; }
        .data-row { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }

        .data-btn { flex-shrink: 0; min-width: 150px; text-align: center; }
        .data-status { font-size: 0.66rem; color: var(--text-dim); }

                .smart-filters {
            display: flex; gap: 6px; margin-bottom: 8px;
            overflow-x: auto; -webkit-overflow-scrolling: touch;
        }
        .smart-pick-head {
            font-size: 0.72rem; color: var(--text-dim);
            margin-bottom: 8px; padding-bottom: 6px; border-bottom: 1px solid var(--border);
        }

        .smart-pick-head b { color: var(--accent); }
       .rec-card {
            background: var(--surface); border: 1px solid var(--border);
            border-radius: 8px; padding: 8px 10px; margin-bottom: 7px;
            display: flex; align-items: center; gap: 8px;
        }
                    .rec-card.queued {
            background: rgba(99, 102, 241, 0.22) !important;
            border-color: #818cf8 !important;
            box-shadow: inset 0 0 0 1.5px #818cf8;
        }
        .ranks-table tr.queued td {
            background: rgba(99, 102, 241, 0.22) !important;
        }
        .rec-rank { font-size: 0.9rem; font-weight: 800; color: var(--text-dim); width: 18px; }
        .rec-main { flex: 1; min-width: 0; }
        .rec-name { font-size: 0.82rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
        .rec-tags { font-size: 0.63rem; color: var(--text-dim); display: flex; flex-wrap: wrap; gap: 5px; margin-top: 2px; }
        .rec-tag { background: none; padding: 1px 3px; border-radius: 3px; }
        .rec-tag.t-tstack { color: var(--blue); font-weight: 700; }
        .rec-tag.t-val { color: var(--accent); font-weight: 600; }
        .rec-tag.t-bb { color: var(--accent); }
        .rec-tag.t-over { color: var(--red); font-weight: 600; }
        .targets-table { width: 100%; border-collapse: collapse; margin-bottom: 14px; }
        .targets-table th {
            font-size: 0.58rem; color: var(--text-dim); text-transform: uppercase;
            padding: 2px 3px; text-align: center; border-bottom: 1px solid var(--border);
        }
        .targets-table td { text-align: center; padding: 3px 2px; }
        .targets-table .tgt-pos { font-weight: 700; text-align: left; padding-left: 4px; }
        .tgt-input {
            width: 46px; padding: 4px; border-radius: 4px;
            border: 1px solid var(--surface3); background: var(--bg);
            color: var(--text); font-size: 0.74rem; font-weight: 600; text-align: center;
            -webkit-appearance: none; appearance: none;
        }
        .tgt-input:focus { outline: none; border-color: var(--accent); }
        .tgt-def { font-size: 0.55rem; color: var(--text-muted); margin-top: 1px; }
        .rec-tag.t-need { color: var(--rb); }
	        .rec-tag.t-rank { color: var(--qb); }
              .rec-avail { font-size: 1.0rem; font-weight: 700; text-align: center; width: 46px; margin-right: 2px; }
              .rec-btns { display: flex; flex-direction: column; gap: 3px; flex-shrink: 0; width: 24px; align-items: center; }
              .rec-btns button { font-size: 0.6rem; padding: 3px 2px; border: none; border-radius: 4px; cursor: pointer; }
              .rec-btns .rec-hide { background: none; color: var(--red); font-size: 1.7rem; font-weight: 700; padding: 0; line-height: 1; width: 100%; }
        .rec-hide:active { opacity: 0.6; }
        .sc-hi   { color: #00d4aa; font-weight: 800; }
        .sc-mid  { color: #6fe0c6; font-weight: 700; }
        .sc-low  { color: #ffc048; font-weight: 700; }
        .sc-min  { color: #ff8a5c; font-weight: 600; }
        .sc-zero { color: var(--text-muted); font-weight: 600; }
            .ranks-table tr.taken { opacity: 0.47; }

        .undo-bar {
            position: fixed;
            bottom: 20px;
            left: 50%;
            transform: translateX(-50%);
            background: var(--surface2);
            padding: 8px 14px;
            border-radius: 8px;
            display: none;
            align-items: center;
            gap: 10px;
            z-index: 200;
            box-shadow: 0 4px 20px rgba(0,0,0,0.5);
            border: 1px solid var(--border);
        }
                 .undo-bar.show { display: flex; }
        .live-ticker {
            position: fixed;
            bottom: 0;
            left: 0;
            right: 0;
            background: var(--surface2);
            border-top: 1px solid var(--border);
            padding: 6px 12px;
            font-size: 0.74rem;
            color: var(--text-dim);
            display: none;
            align-items: center;
            gap: 8px;
            z-index: 150;
        }
        .live-ticker.show { display: flex; }
        .live-ticker .lt-pick { color: var(--text-muted); font-weight: 600; }
        .live-ticker .lt-name { color: var(--text); font-weight: 700; font-size: 0.82rem; }
        .live-ticker .lt-pos { font-weight: 700; }
        .undo-bar span { font-size: 0.78rem; }
        /* Startup draft selector — closed-box polish only */
        .startup-select {
            width: 100%;
            padding: 11px 38px 11px 13px;
            font-size: 0.82rem;
            font-weight: 600;
            color: var(--text);
            background: var(--bg);
            border: 1px solid var(--surface3);
            border-radius: 9px;
            -webkit-appearance: none;
            appearance: none;
            cursor: pointer;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239eafbd' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
            background-repeat: no-repeat;
            background-position: right 13px center;
            transition: border-color .15s, box-shadow .15s;
        }
        .startup-select:focus {
            outline: none;
            border-color: var(--accent);
            box-shadow: 0 0 0 3px var(--accent-dim);
        }
		.roster-popup {
            display: none;
            position: fixed;
            inset: 0;
            background: rgba(0,0,0,0.6);
            z-index: 300;
            align-items: flex-start;
            justify-content: center;
            padding-top: 60px;
        }
        .roster-popup.show { display: flex; }
        .roster-panel {
            background: var(--surface);
            border: 1px solid var(--surface3);
            border-radius: 10px;
            padding: 14px;
            width: 92%;
            max-width: 360px;
            max-height: 80vh;
            overflow-y: auto;
        }
        .roster-pos-header {
            font-size: 1.1rem;
            font-weight: 800;
            color: #fff;
            margin: 14px 0 6px;
            letter-spacing: 0.5px;
        }
        .roster-pos-header:first-child { margin-top: 0; }
        .roster-player-row {
            display: flex;
            align-items: center;
            padding: 6px 0;
            border-bottom: 1px solid var(--border);
            gap: 8px;
        }
        .roster-player-name { flex: 1; font-size: 0.84rem; font-weight: 600; }
        .roster-player-meta { font-size: 0.7rem; color: var(--text-dim); text-align: right; line-height: 1.5; }
