/* ═══════════════════════════════════════════════
   COMPONENTS.CSS — Cards, tables, stats v2 (Light)
   PropBetEdge NFL
═══════════════════════════════════════════════ */

/* ── STAT CARDS ── */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-bottom:1.5rem}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1rem;box-shadow:var(--shadow-card);transition:all .15s}
.stat-card:hover{box-shadow:var(--shadow-hover);border-color:var(--line2);transform:translateY(-1px)}
.stat-card-val{font-family:var(--font-display);font-size:30px;font-weight:900;color:var(--nfl-b);line-height:1;letter-spacing:-1px}
.stat-card-val.gold{color:var(--gold-b)}
.stat-card-val.dark{color:var(--ink)}
.stat-card-label{font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--ink4);margin-top:5px}
.stat-card-sub{font-size:11px;color:var(--ink4);margin-top:2px}

/* ── DATA TABLES ── */
.data-table-wrap{overflow-x:auto;border-radius:var(--r-lg);border:1px solid var(--line);box-shadow:var(--shadow-card)}
.data-table{width:100%;border-collapse:collapse;font-size:13px;background:var(--surface)}
.data-table thead tr{background:var(--surface-2);border-bottom:1px solid var(--line2)}
.data-table thead th{padding:10px 14px;text-align:left;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--ink4);white-space:nowrap;cursor:pointer;transition:color .12s}
.data-table thead th:hover{color:var(--nfl-b)}
.data-table thead th.sorted{color:var(--nfl-b)}
.data-table thead th.sorted::after{content:' ↓';font-size:9px}
.data-table thead th.sorted.asc::after{content:' ↑'}
.data-table tbody tr{border-bottom:1px solid var(--line);transition:background .1s}
.data-table tbody tr:last-child{border-bottom:none}
.data-table tbody tr:hover{background:var(--nfl-l)}
.data-table td{padding:11px 14px;color:var(--ink2);vertical-align:middle;white-space:nowrap}
.data-table td.bold{font-weight:600;color:var(--ink)}
.data-table td.mono{font-family:var(--font-mono);font-size:12px}
.data-table td.green{color:var(--success);font-weight:600}
.data-table td.gold{color:var(--gold-b);font-weight:600}
.data-table td.muted{color:var(--ink4)}
.data-table td.red{color:var(--danger);font-weight:600}
.dt-rank{width:32px;font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink4);text-align:center}
.dt-rank.top1{color:var(--gold-b);font-size:17px}
.dt-rank.top3{color:var(--warning)}
.dt-player{font-weight:600;color:var(--ink);cursor:pointer}
.dt-player:hover{color:var(--nfl-b);text-decoration:underline}
.dt-team-badge{display:inline-block;font-size:9px;font-weight:700;letter-spacing:.5px;padding:2px 8px;border-radius:4px;background:var(--surface-3);color:var(--ink3);border:1px solid var(--line)}

/* ── CARDS ── */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-card);overflow:hidden;transition:all .15s}
.card:hover{box-shadow:var(--shadow-hover);border-color:var(--line2)}
.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--surface-2)}
.card-body{padding:1.25rem}
.card-footer{padding:.875rem 1.25rem;border-top:1px solid var(--line);background:var(--surface-2)}

/* ── TEAM CARDS ── */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px}
.team-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.1rem;cursor:pointer;transition:all .18s;box-shadow:var(--shadow-card);position:relative;overflow:hidden}
.team-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--nfl-bright);transform:scaleX(0);transform-origin:left;transition:transform .2s}
.team-card:hover{box-shadow:var(--shadow-hover);border-color:var(--line2);transform:translateY(-2px)}
.team-card:hover::after{transform:scaleX(1)}
.tc-abbr{font-family:var(--font-display);font-size:30px;font-weight:900;color:var(--ink);letter-spacing:.5px;line-height:1;margin-bottom:3px}
.tc-name{font-size:11px;color:var(--ink3);line-height:1.3;margin-bottom:.5rem}
.tc-conf{font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:2px 8px;border-radius:99px;display:inline-block;margin-bottom:.5rem}
.tc-conf.afc{background:var(--afc-l);color:var(--afc)}
.tc-conf.nfc{background:var(--nfc-l);color:var(--nfc)}
.tc-record{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink2)}
.tc-coach{font-size:10px;color:var(--ink4);margin-top:2px}

/* ── PICK CARDS ── */
.pick-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.25rem;box-shadow:var(--shadow-card);transition:all .15s;position:relative;overflow:hidden}
.pick-card::before{content:'';position:absolute;top:0;left:0;bottom:0;width:4px}
.pick-card.strong::before{background:var(--success)}
.pick-card.medium::before{background:var(--warning)}
.pick-card.lean::before{background:var(--ink4)}
.pick-card:hover{box-shadow:var(--shadow-hover);border-color:var(--line2)}
.pick-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:.875rem}
.pick-player{font-family:var(--font-display);font-size:20px;font-weight:900;color:var(--ink);text-transform:uppercase;letter-spacing:.3px;cursor:pointer}
.pick-player:hover{color:var(--nfl-b)}
.pick-team-badge{font-size:10px;color:var(--ink3)}
.pick-prop-label{font-size:12px;color:var(--ink3);font-weight:500;margin-bottom:4px}
.pick-line-row{display:flex;align-items:center;gap:10px}
.pick-line{font-family:var(--font-display);font-size:26px;font-weight:900;color:var(--ink);letter-spacing:.5px}
.pick-direction{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 12px;border-radius:99px}
.pick-direction.over{background:var(--success-l);color:var(--success)}
.pick-direction.under{background:var(--danger-l);color:var(--danger)}
.pick-odds{font-size:12px;color:var(--ink4);font-family:var(--font-mono)}
.pick-signals{display:flex;flex-wrap:wrap;gap:5px;margin-top:.875rem}
.pick-signal{font-size:10px;color:var(--ink3);background:var(--surface-3);border:1px solid var(--line);padding:3px 9px;border-radius:var(--r-xs)}
.pick-note{font-size:12px;color:var(--ink3);margin-top:.75rem;line-height:1.55;font-style:italic;padding-left:.875rem;border-left:2px solid var(--line2)}
.pick-ste-bar{margin-top:.875rem}
.pick-ste-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.pick-ste-label{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--ink4)}
.pick-ste-pct{font-size:13px;font-weight:700;color:var(--ink)}
.pick-conf-track{height:6px;background:var(--surface-3);border-radius:3px;overflow:hidden}
.pick-conf-fill{height:100%;border-radius:3px;transition:width .6s ease}
.pick-conf-fill.strong{background:var(--success)}
.pick-conf-fill.medium{background:var(--warning)}
.pick-conf-fill.lean{background:var(--ink4)}

/* ── HOF CARDS ── */
.hof-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:10px}
.hof-card{background:var(--surface);border:1px solid var(--line);border-top:3px solid var(--gold-b);border-radius:var(--r-lg);padding:1.1rem;box-shadow:var(--shadow-card);transition:all .15s}
.hof-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-1px)}
.hof-name{font-family:var(--font-display);font-size:16px;font-weight:800;color:var(--ink);text-transform:uppercase;letter-spacing:.3px;margin-bottom:3px;line-height:1.1}
.hof-pos-team{font-size:11px;color:var(--ink3);margin-bottom:.4rem}
.hof-year{font-size:10px;font-weight:600;color:var(--gold-b);margin-bottom:2px}
.hof-era{font-size:10px;color:var(--ink4)}
.hof-note{font-size:11px;color:var(--ink3);margin-top:.4rem;line-height:1.5}

/* ── SUPER BOWL CARDS ── */
.sb-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.25rem;box-shadow:var(--shadow-card);transition:all .15s;display:flex;flex-direction:column;gap:.5rem}
.sb-card:hover{box-shadow:var(--shadow-hover);border-color:var(--gold-b)}
.sb-number{font-family:var(--font-display);font-size:26px;font-weight:900;color:var(--gold-b);line-height:1}
.sb-date{font-size:10px;color:var(--ink4)}
.sb-winner{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink)}
.sb-score{font-family:var(--font-display);font-size:20px;font-weight:900;color:var(--nfl-b)}
.sb-loser{font-size:12px;color:var(--ink3)}
.sb-mvp{font-size:12px;color:var(--ink3)}
.sb-mvp strong{color:var(--gold-b);font-weight:600}
.sb-note{font-size:11px;color:var(--ink4);font-style:italic;line-height:1.4}

/* ── RECORD CARDS ── */
.records-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}
.record-card{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--nfl-bright);border-radius:var(--r-lg);padding:1.1rem;box-shadow:var(--shadow-card);transition:all .15s}
.record-card:hover{box-shadow:var(--shadow-hover);border-left-color:var(--nfl-b)}
.record-stat{font-family:var(--font-display);font-size:26px;font-weight:900;color:var(--nfl-b);line-height:1}
.record-holder{font-size:14px;font-weight:600;color:var(--ink);margin:.2rem 0 2px}
.record-desc{font-size:11px;color:var(--ink3)}
.record-year{font-size:10px;color:var(--ink5);margin-top:3px;font-family:var(--font-mono)}
.record-note{font-size:10px;color:var(--ink4);margin-top:4px;line-height:1.4;font-style:italic}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;padding:8px 18px;border-radius:var(--r-md);transition:all .15s;cursor:pointer;border:none;letter-spacing:.1px}
.btn-primary{background:var(--nfl-b);color:#fff;box-shadow:0 1px 2px rgba(0,0,0,.15)}
.btn-primary:hover{background:var(--nfl-bright);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-secondary{background:var(--surface);color:var(--ink);border:1px solid var(--line2);box-shadow:var(--shadow-xs)}
.btn-secondary:hover{background:var(--surface-3);border-color:var(--line3)}
.btn-gold{background:var(--gold-b);color:#fff}
.btn-gold:hover{background:var(--gold);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink3);border:1px solid var(--line)}
.btn-ghost:hover{background:var(--surface-3);color:var(--ink)}
.btn-sm{font-size:12px;padding:5px 12px}
.btn-xs{font-size:11px;padding:4px 10px;border-radius:var(--r-sm)}

/* ── BADGES ── */
.badge{display:inline-block;font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:3px 9px;border-radius:99px}
.badge-live{background:var(--success-l);color:var(--success)}
.badge-off{background:var(--surface-3);color:var(--ink4);border:1px solid var(--line)}
.badge-soon{background:var(--warning-l);color:var(--warning)}
.badge-afc{background:var(--afc-l);color:var(--afc)}
.badge-nfc{background:var(--nfc-l);color:var(--nfc)}
.badge-hof{background:var(--gold-ll);color:var(--gold-b)}
.badge-record{background:var(--nfl-ll);color:var(--nfl-b)}
.badge-strong{background:var(--success-l);color:var(--success)}
.badge-medium{background:var(--warning-l);color:var(--warning)}
.badge-lean{background:var(--surface-3);color:var(--ink4);border:1px solid var(--line)}

/* ── FILTERS ── */
.filter-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:1rem;align-items:center}
.filter-chip{font-size:11px;font-weight:600;padding:5px 13px;border-radius:99px;cursor:pointer;background:var(--surface);color:var(--ink3);border:1px solid var(--line);transition:all .12s;-webkit-tap-highlight-color:transparent;box-shadow:var(--shadow-xs)}
.filter-chip:hover{border-color:var(--line2);color:var(--ink)}
.filter-chip.active{background:var(--nfl-b);border-color:var(--nfl-b);color:#fff;box-shadow:0 2px 6px rgba(22,101,52,.25)}
.filter-search{flex:1;min-width:180px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:7px 12px;font-size:12px;color:var(--ink);outline:none;transition:all .15s;box-shadow:var(--shadow-xs)}
.filter-search:focus{border-color:var(--nfl-bright);box-shadow:0 0 0 3px var(--nfl-glow)}
.filter-search::placeholder{color:var(--ink4)}

/* ── INFO BOXES ── */
.info-box{background:var(--nfl-l);border:1px solid var(--line-green);border-radius:var(--r-md);padding:1rem 1.25rem;margin-bottom:1rem}
.info-box-title{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--nfl-b);margin-bottom:.35rem}
.info-box-text{font-size:13px;color:var(--ink2);line-height:1.6}
.info-box.warning{background:var(--warning-l);border-color:var(--line-gold)}
.info-box.warning .info-box-title{color:var(--gold-b)}

/* ── DIVISION HEADER ── */
.division-header{display:flex;align-items:center;gap:8px;padding:.6rem 1rem;background:var(--surface-2);border-radius:var(--r-sm);margin-bottom:.75rem;border:1px solid var(--line)}
.div-conf{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:2px 8px;border-radius:3px}
.div-conf.afc{background:var(--afc-l);color:var(--afc)}
.div-conf.nfc{background:var(--nfc-l);color:var(--nfc)}
.div-name{font-family:var(--font-display);font-size:15px;font-weight:800;color:var(--ink);text-transform:uppercase;letter-spacing:.3px}

/* ── GRID LAYOUTS ── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.picks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
@media(max-width:700px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}}

/* ── DIVIDER ── */
hr,.divider{border:none;border-top:1px solid var(--line);margin:1.5rem 0}

/* ── EMPTY STATE ── */
.empty-state{text-align:center;padding:4rem 2rem}
.empty-icon{font-size:40px;margin-bottom:1rem;opacity:.35}
.empty-text{font-size:15px;color:var(--ink3);font-weight:500}
.empty-sub{font-size:13px;color:var(--ink4);margin-top:.4rem}

/* ── MODAL OVERLAY ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:900;display:flex;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(4px)}
.modal{background:var(--surface);border-radius:var(--r-2xl);box-shadow:var(--shadow-xl);max-width:860px;width:100%;max-height:90vh;overflow-y:auto;animation:popIn .2s ease}
.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--surface);z-index:1}
.modal-title{font-family:var(--font-display);font-size:22px;font-weight:900;color:var(--ink);text-transform:uppercase}
.modal-close{width:32px;height:32px;border-radius:50%;background:var(--surface-3);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:var(--ink3);transition:all .12s}
.modal-close:hover{background:var(--danger-l);color:var(--danger)}
.modal-body{padding:1.5rem}

/* ── PROSPECT CARDS ── */
.prospect-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.prospect-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.1rem;box-shadow:var(--shadow-card);cursor:pointer;transition:all .15s}
.prospect-card:hover{box-shadow:var(--shadow-hover);border-color:var(--line2);transform:translateY(-1px)}
.prospect-rank{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:1px;color:var(--ink4);text-transform:uppercase;margin-bottom:4px}
.prospect-name{font-family:var(--font-display);font-size:20px;font-weight:900;color:var(--ink);text-transform:uppercase;letter-spacing:.3px;line-height:1.1;margin-bottom:3px}
.prospect-meta{font-size:11px;color:var(--ink3);margin-bottom:.65rem}
.prospect-grade{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 10px;border-radius:99px;margin-bottom:.75rem}
.prospect-grade.elite{background:var(--success-l);color:var(--success)}
.prospect-grade.first{background:var(--nfl-ll);color:var(--nfl-b)}
.prospect-grade.second{background:var(--warning-l);color:var(--warning)}
.prospect-grade.third{background:var(--surface-3);color:var(--ink3);border:1px solid var(--line)}
.prospect-measurables{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.prospect-meas{text-align:center;background:var(--surface-3);border-radius:var(--r-sm);padding:5px}
.prospect-meas-val{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--ink);line-height:1}
.prospect-meas-lbl{font-size:9px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--ink4);margin-top:2px}

/* ── STE SIGNAL BARS ── */
.ste-signal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.ste-signal-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:1rem;box-shadow:var(--shadow-card)}
.ste-signal-name{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--ink3);margin-bottom:.5rem}
.ste-signal-score{font-family:var(--font-display);font-size:28px;font-weight:900;color:var(--ink);line-height:1;margin-bottom:.4rem}
.ste-signal-bar{height:6px;background:var(--surface-3);border-radius:3px;overflow:hidden;margin-bottom:.4rem}
.ste-signal-fill{height:100%;border-radius:3px;transition:width .7s ease}
.ste-signal-detail{font-size:11px;color:var(--ink4);line-height:1.5}

/* ── EDGE METER ── */
.edge-meter{display:flex;align-items:center;gap:10px}
.edge-track{flex:1;height:8px;background:var(--surface-3);border-radius:4px;overflow:hidden;position:relative}
.edge-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--nfl-bright),var(--nfl-vivid));transition:width .6s ease}
.edge-label{font-size:11px;font-weight:700;color:var(--nfl-b);min-width:36px;text-align:right}

/* ── HOF YEAR GROUPS ── */
.hof-year-group { margin-bottom: 2rem; }
.hof-year-header {
  font-family: var(--font-display); font-size: 16px; font-weight: 800;
  text-transform: uppercase; letter-spacing: .5px; color: var(--ink);
  margin-bottom: .75rem; padding: .5rem 0; border-bottom: 2px solid var(--gold-b);
  display: flex; align-items: center; justify-content: space-between;
}
.hof-year-count {
  font-size: 11px; font-weight: 500; color: var(--ink4);
  font-family: var(--font-body); text-transform: none; letter-spacing: 0;
}
/* ── SB BADGE ── */
.badge-sb { background: var(--gold-ll); color: var(--gold-b); border: 1px solid var(--line-gold); }
