/* ===== ROSTER AUDIT — DESIGN TOKENS ===== */
:root {
  color-scheme: dark;

  --ra-bg-primary: #080808;
  --ra-bg-secondary: #111111;
  --ra-bg-tertiary: #1a1a1a;
  --ra-bg-card: #111111;
  --ra-bg-hover: #1e1e1e;
  --ra-bg-input: #0d0d0d;

  --ra-border: #222222;
  --ra-border-hover: #333333;
  --ra-border-active: #444444;

  --ra-text-primary: #e8e8f0;
  --ra-text-secondary: #8888a0;
  --ra-text-muted: #555555;
  --ra-text-inverse: #080808;

  --ra-accent: #06b6d4;
  --ra-accent-hover: #0891b2;
  --ra-accent-muted: rgba(16, 185, 129, 0.15);

  --ra-green: #22c55e;
  --ra-green-muted: rgba(34, 197, 94, 0.15);
  --ra-red: #ef4444;
  --ra-red-muted: rgba(239, 68, 68, 0.15);
  --ra-yellow: #eab308;
  --ra-yellow-muted: rgba(234, 179, 8, 0.15);
  --ra-orange: #f97316;

  --ra-qb: #ef4444;
  --ra-rb: #22c55e;
  --ra-wr: #60a5fa;
  --ra-te: #f97316;
  --ra-pick: #a78bfa;

  --ra-grade-a: #22c55e;
  --ra-grade-b: #60a5fa;
  --ra-grade-c: #eab308;
  --ra-grade-d: #f97316;
  --ra-grade-f: #ef4444;

  --ra-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --ra-font-mono: 'Sora', sans-serif;

  --ra-radius-sm: 6px;
  --ra-radius: 10px;
  --ra-radius-lg: 14px;
  --ra-radius-xl: 20px;

  --ra-shadow: 0 2px 8px rgba(0,0,0,0.3);
  --ra-shadow-lg: 0 8px 32px rgba(0,0,0,0.4);

  --ra-transition: 150ms ease;
}

/* ===== BASE ===== */
.ra-app-container {
  font-family: var(--ra-font);
  color: var(--ra-text-primary);
  background: var(--ra-bg-primary);
  min-height: 60vh;
  padding: 24px 16px;
  -webkit-font-smoothing: antialiased;
  font-variant-numeric: tabular-nums;
  line-height: 1.5;
}

.ra-app-container *,
.ra-app-container *::before,
.ra-app-container *::after {
  box-sizing: border-box;
}

.ra-app-container a {
  color: var(--ra-accent);
  text-decoration: none;
}
.ra-app-container a:hover { text-decoration: underline; }

/* ===== LAYOUT ===== */
.ra-container { max-width: 1200px; margin: 0 auto; }
.ra-container-sm { max-width: 800px; margin: 0 auto; }
.ra-container-lg { max-width: 1400px; margin: 0 auto; }

.ra-grid { display: grid; gap: 16px; }
.ra-grid-2 { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }
.ra-grid-3 { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.ra-grid-4 { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }

.ra-flex { display: flex; align-items: center; gap: 8px; }
.ra-flex-between { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.ra-flex-col { display: flex; flex-direction: column; gap: 8px; }

/* ===== CARDS ===== */
.ra-card {
  background: var(--ra-bg-card);
  border: 1px solid var(--ra-border);
  border-radius: var(--ra-radius);
  padding: 20px;
  transition: border-color var(--ra-transition);
}
.ra-card:hover { border-color: var(--ra-border-hover); }
.ra-card-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--ra-border);
}
.ra-card-title {
  font-size: 15px; font-weight: 600; color: var(--ra-text-primary);
  letter-spacing: -0.01em;
}

/* ===== BUTTONS ===== */
.ra-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 8px 16px; border-radius: var(--ra-radius-sm); font-size: 14px;
  font-weight: 500; font-family: var(--ra-font); cursor: pointer;
  border: 1px solid transparent; transition: all var(--ra-transition);
  white-space: nowrap; line-height: 1.4;
}
.ra-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.ra-btn-primary {
  background: var(--ra-accent); color: #fff; border-color: var(--ra-accent);
}
.ra-btn-primary:hover:not(:disabled) { background: var(--ra-accent-hover); }

.ra-btn-secondary {
  background: var(--ra-bg-tertiary); color: var(--ra-text-primary); border-color: var(--ra-border);
}
.ra-btn-secondary:hover:not(:disabled) { background: var(--ra-bg-hover); border-color: var(--ra-border-hover); }

.ra-btn-ghost {
  background: transparent; color: var(--ra-text-secondary); border-color: transparent;
}
.ra-btn-ghost:hover:not(:disabled) { color: var(--ra-text-primary); background: var(--ra-bg-tertiary); }

.ra-btn-sm { padding: 5px 10px; font-size: 12px; }
.ra-btn-lg { padding: 12px 24px; font-size: 15px; }

/* ===== INPUTS ===== */
.ra-input {
  background: var(--ra-bg-input); border: 1px solid var(--ra-border);
  border-radius: var(--ra-radius-sm); padding: 9px 12px; font-size: 14px;
  color: var(--ra-text-primary); font-family: var(--ra-font); width: 100%;
  transition: border-color var(--ra-transition); outline: none;
}
.ra-input:focus { border-color: var(--ra-accent); }
.ra-input::placeholder { color: var(--ra-text-muted); }

.ra-select {
  appearance: none; background: var(--ra-bg-input) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%238888a0'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E") no-repeat right 8px center / 18px;
  border: 1px solid var(--ra-border); border-radius: var(--ra-radius-sm);
  padding: 8px 32px 8px 12px; font-size: 14px; color: var(--ra-text-primary);
  font-family: var(--ra-font); cursor: pointer; outline: none;
}
.ra-select:focus { border-color: var(--ra-accent); }

/* ===== BADGES ===== */
.ra-badge {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 2px 8px; border-radius: 4px; font-size: 11px; font-weight: 600;
  letter-spacing: 0.02em; text-transform: uppercase; line-height: 1.6;
}
.ra-badge-qb { background: rgba(239,68,68,0.15); color: var(--ra-qb); }
.ra-badge-rb { background: rgba(34,197,94,0.15); color: var(--ra-rb); }
.ra-badge-wr { background: rgba(96,165,250,0.15); color: var(--ra-wr); }
.ra-badge-te { background: rgba(249,115,22,0.15); color: var(--ra-te); }
.ra-badge-pick { background: rgba(167,139,250,0.2); color: var(--ra-pick); }

/* ===== GRADE BADGES ===== */
.ra-grade {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: var(--ra-radius-sm);
  font-size: 16px; font-weight: 700; letter-spacing: -0.02em;
}
.ra-grade-lg { width: 56px; height: 56px; font-size: 22px; border-radius: var(--ra-radius); }

.ra-grade-a, .ra-grade-a\+ { background: var(--ra-green-muted); color: var(--ra-green); }
.ra-grade-b, .ra-grade-b\+ { background: var(--ra-accent-muted); color: var(--ra-accent); }
.ra-grade-c, .ra-grade-c\+ { background: var(--ra-yellow-muted); color: var(--ra-yellow); }
.ra-grade-d, .ra-grade-d\+ { background: rgba(249,115,22,0.15); color: var(--ra-orange); }
.ra-grade-f { background: var(--ra-red-muted); color: var(--ra-red); }

/* ===== VALUE BAR ===== */
.ra-value-bar {
  height: 6px; background: var(--ra-bg-tertiary); border-radius: 3px; overflow: hidden;
}
.ra-value-bar-fill {
  height: 100%; border-radius: 3px; transition: width 600ms ease;
}

/* ===== TREND ===== */
.ra-trend { font-size: 12px; font-weight: 600; }
.ra-trend-up { color: var(--ra-green); }
.ra-trend-down { color: var(--ra-red); }
.ra-trend-flat { color: var(--ra-text-muted); }

/* ===== TABLE ===== */
.ra-table { width: 100%; border-collapse: collapse; }
.ra-table th {
  text-align: left; padding: 10px 12px; font-size: 11px;
  font-weight: 600; color: var(--ra-text-muted); text-transform: uppercase;
  letter-spacing: 0.04em; border-bottom: 1px solid var(--ra-border);
  background: var(--ra-bg-secondary); position: sticky; top: 0; z-index: 10;
}
.ra-table td {
  padding: 10px 12px; font-size: 14px; border-bottom: 1px solid var(--ra-border);
}
.ra-table tr:hover td { background: var(--ra-bg-hover); }
.ra-table th.sortable { cursor: pointer; user-select: none; }
.ra-table th.sortable:hover { color: var(--ra-text-primary); }

/* ===== TABS ===== */
.ra-tabs {
  display: flex; gap: 2px; background: var(--ra-bg-secondary);
  border-radius: var(--ra-radius-sm); padding: 3px; border: 1px solid var(--ra-border);
}
.ra-tab {
  padding: 7px 14px; border-radius: 4px; font-size: 12px; font-weight: 500;
  color: var(--ra-text-secondary); cursor: pointer; transition: all var(--ra-transition);
  border: none; background: none; font-family: var(--ra-font);
}
.ra-tab:hover { color: var(--ra-text-primary); }
.ra-tab.active { background: var(--ra-accent); color: #fff; font-weight: 600; box-shadow: var(--ra-shadow); }

/* ===== SETTINGS BAR ===== */
.ra-settings-bar {
  display: inline-flex; align-items: center; gap: 12px; flex-wrap: wrap;
  padding: 8px 16px; background: var(--ra-bg-secondary);
  border: 1px solid var(--ra-border); border-radius: var(--ra-radius);
  margin-bottom: 12px; vertical-align: top; margin-right: 8px;
}
.ra-tc-controls > .ra-settings-bar {
  display: flex; margin-right: 0;
}
.ra-fmt-mobile { display: none; }
.ra-settings-label {
  font-size: 11px; font-weight: 600; color: var(--ra-text-muted);
  text-transform: uppercase; letter-spacing: 0.04em;
}
.ra-toggle {
  display: flex; gap: 2px; background: var(--ra-bg-input);
  border-radius: 4px; padding: 2px; border: 1px solid var(--ra-border);
}
.ra-toggle-option {
  padding: 4px 10px; border-radius: 3px; font-size: 11px; font-weight: 600;
  cursor: pointer; color: var(--ra-text-muted); transition: all var(--ra-transition);
  border: none; background: none; font-family: var(--ra-font);
}
.ra-toggle-option.active {
  background: var(--ra-accent); color: #fff;
}
.ra-valuation-toggle {
  display: inline-flex; align-items: center;
}
.ra-valuation-toggle-options {
  display: flex; gap: 2px; background: var(--ra-bg-input);
  border-radius: 6px; padding: 3px; border: 1px solid var(--ra-border);
}
.ra-valuation-option {
  padding: 6px 16px; border-radius: 4px; font-size: 12px; font-weight: 600;
  cursor: pointer; color: var(--ra-text-muted); transition: all var(--ra-transition);
  border: none; background: none; font-family: var(--ra-font);
  white-space: nowrap; max-width: 180px; overflow: hidden; text-overflow: ellipsis;
}
.ra-valuation-option:hover:not(.active) {
  color: var(--ra-text-primary); background: rgba(255,255,255,0.04);
}
.ra-valuation-option.active {
  background: var(--ra-accent); color: #fff;
}
.ra-league-info-btn {
  background: none; border: none; cursor: pointer; font-size: 16px;
  color: var(--ra-text-muted); padding: 2px 6px; margin-left: 4px;
  transition: color var(--ra-transition); line-height: 1;
}
.ra-league-info-btn:hover { color: var(--ra-accent); }
.ra-league-info-popover {
  position: absolute; top: calc(100% + 8px); left: 0; z-index: 100;
  background: var(--ra-bg-secondary); border: 1px solid var(--ra-border);
  border-radius: 8px; padding: 16px; min-width: 280px; max-width: 340px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}
.ra-league-info-header {
  font-size: 14px; font-weight: 700; color: var(--ra-text-primary);
  margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px solid var(--ra-border);
}
.ra-league-info-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.ra-league-info-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: 4px 0;
}
.ra-league-info-label {
  font-size: 11px; font-weight: 600; color: var(--ra-text-muted);
  text-transform: uppercase; letter-spacing: 0.03em;
}
.ra-league-info-value {
  font-size: 14px; font-weight: 600; color: var(--ra-text-primary);
}
.ra-league-info-divider {
  height: 1px; background: var(--ra-border); margin: 10px 0;
}
.ra-league-info-slots {
  display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 8px;
}
.ra-league-info-slot {
  font-size: 11px; font-weight: 600; padding: 3px 8px;
  background: var(--ra-bg-input); border: 1px solid var(--ra-border);
  border-radius: 4px; color: var(--ra-text-secondary);
}
.ra-league-info-bench {
  display: flex; gap: 12px; font-size: 11px; color: var(--ra-text-muted);
}
.ra-preset-selector {
  display: inline-flex; align-items: center; position: relative;
}
.ra-preset-trigger {
  display: inline-flex; align-items: center;
  padding: 6px 12px; border-radius: 6px; font-size: 12px; font-weight: 600;
  font-family: var(--ra-font); cursor: pointer;
  color: var(--ra-text-muted); background: var(--ra-bg-input);
  border: 1px solid var(--ra-border); transition: all var(--ra-transition);
  white-space: nowrap;
}
.ra-preset-trigger:hover { border-color: var(--ra-accent); color: var(--ra-text-primary); }
.ra-preset-trigger.active { color: var(--ra-accent); border-color: var(--ra-accent); }
.ra-preset-dropdown {
  position: absolute; top: calc(100% + 6px); left: 0; z-index: 120;
  background: var(--ra-bg-secondary); border: 1px solid var(--ra-border);
  border-radius: 8px; padding: 4px; min-width: 260px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.35);
  max-height: 420px; overflow-y: auto;
}
.ra-preset-item {
  display: block; width: 100%; text-align: left;
  padding: 8px 12px; border-radius: 4px; font-size: 12px; font-weight: 500;
  font-family: var(--ra-font); cursor: pointer;
  color: var(--ra-text-secondary); background: none; border: none;
  transition: all 0.1s;
}
.ra-preset-item:hover { background: rgba(255,255,255,0.06); color: var(--ra-text-primary); }
.ra-preset-item.active { color: var(--ra-accent); font-weight: 700; }
.ra-preset-item.clear { color: var(--ra-text-muted); font-style: italic; border-bottom: 1px solid var(--ra-border); margin-bottom: 4px; border-radius: 4px 4px 0 0; }
.ra-preset-group-label {
  padding: 8px 12px 4px; font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--ra-text-muted); opacity: 0.6;
  border-top: 1px solid var(--ra-border); margin-top: 4px;
}
.ra-preset-group-label:first-child { border-top: none; margin-top: 0; }

/* ===== FORMAT TOGGLES ===== */
.ra-format-toggles {
  display: inline-flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.ra-ft-group {
  display: inline-flex; align-items: center; gap: 6px;
}
.ra-ft-label {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.05em; color: var(--ra-text-muted); user-select: none;
}
.ra-ft-pill {
  padding: 5px 14px; border-radius: 6px; font-size: 12px; font-weight: 600;
  font-family: var(--ra-font); cursor: pointer;
  color: var(--ra-text-muted); background: var(--ra-bg-input);
  border: 1px solid var(--ra-border); transition: all 0.15s;
}
.ra-ft-pill:hover { border-color: var(--ra-text-secondary); color: var(--ra-text-primary); }
.ra-ft-pill.active {
  color: #fff; border-color: transparent;
}
.ra-ft-pill.active.sf { background: var(--ra-accent); }
.ra-ft-pill.active.oneqb { background: #0891b2; }
/* Toggle switch */
.ra-ft-switch {
  position: relative; width: 36px; height: 20px; border-radius: 10px;
  background: var(--ra-bg-input); border: 1px solid var(--ra-border);
  cursor: pointer; transition: all 0.2s; padding: 0; flex-shrink: 0;
}
.ra-ft-switch:hover { border-color: var(--ra-text-muted); }
.ra-ft-switch.on { background: var(--ra-accent); border-color: var(--ra-accent); }
.ra-ft-switch-knob {
  position: absolute; top: 2px; left: 2px;
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--ra-text-muted); transition: all 0.2s;
}
.ra-ft-switch.on .ra-ft-switch-knob { left: 18px; background: #fff; }

/* ===== LEAGUE CHIP ===== */
.ra-league-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: 20px; font-size: 11px;
  color: var(--ra-text-secondary); background: rgba(34, 197, 94, 0.06);
  border: 1px solid rgba(34, 197, 94, 0.15); white-space: nowrap;
  flex-wrap: wrap;
}
.ra-league-chip-dot {
  width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
  background: var(--ra-green, #22c55e);
  box-shadow: 0 0 4px rgba(34, 197, 94, 0.5);
}
.ra-league-chip-name {
  font-weight: 700; color: var(--ra-green, #22c55e);
}
.ra-league-chip-sep {
  color: var(--ra-text-muted); opacity: 0.4;
}
.ra-league-chip-tags {
  color: var(--ra-text-muted); font-weight: 500;
}

/* ===== WARNINGS ===== */
.ra-warning {
  display: flex; gap: 10px; padding: 12px 14px;
  border-radius: var(--ra-radius-sm); margin-bottom: 8px;
  border-left: 3px solid;
}
.ra-warning-high { background: var(--ra-red-muted); border-color: var(--ra-red); }
.ra-warning-medium { background: var(--ra-yellow-muted); border-color: var(--ra-yellow); }
.ra-warning-low { background: rgba(5,150,105,0.1); border-color: #0891b2; }
.ra-warning-positive { background: var(--ra-green-muted); border-color: var(--ra-green); }
.ra-warning-title { font-size: 14px; font-weight: 600; color: var(--ra-text-primary); }
.ra-warning-message { font-size: 12px; color: var(--ra-text-secondary); margin-top: 2px; }

/* ===== SPINNER ===== */
.ra-spinner {
  display: inline-block; width: 20px; height: 20px;
  border: 2px solid var(--ra-border); border-top-color: var(--ra-accent);
  border-radius: 50%; animation: ra-spin 600ms linear infinite;
}
.ra-spinner-lg { width: 32px; height: 32px; border-width: 3px; }
@keyframes ra-spin { to { transform: rotate(360deg); } }

.ra-loading {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px; padding: 60px 20px; color: var(--ra-text-secondary); font-size: 14px;
}

/* ===== PILL CHIP ===== */
.ra-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; background: var(--ra-bg-tertiary);
  border: 1px solid var(--ra-border); border-radius: var(--ra-radius-xl);
  font-size: 14px; color: var(--ra-text-primary);
}
.ra-chip-remove {
  cursor: pointer; color: var(--ra-text-muted); font-size: 16px;
  line-height: 1; padding: 0; border: none; background: none;
}
.ra-chip-remove:hover { color: var(--ra-red); }

/* ===== PLAYER ROW ===== */
.ra-player-row {
  display: flex; align-items: center; gap: 10px; padding: 8px 12px;
  border-radius: var(--ra-radius-sm); cursor: pointer;
  transition: background var(--ra-transition);
}
.ra-player-row:hover { background: var(--ra-bg-hover); }
.ra-player-photo {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--ra-bg-tertiary); object-fit: cover;
  border: 2px solid var(--ra-border);
}
.ra-player-name { font-size: 14px; font-weight: 500; }
.ra-player-meta { font-size: 12px; color: var(--ra-text-secondary); }

/* ===== MODAL ===== */
.ra-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.7);
  z-index: 9999; display: flex; align-items: center; justify-content: center;
  padding: 20px; backdrop-filter: blur(4px);
}
.ra-modal {
  background: var(--ra-bg-card); border: 1px solid var(--ra-border);
  border-radius: var(--ra-radius-lg); max-width: 700px; width: 100%;
  max-height: 85vh; overflow-y: auto; box-shadow: var(--ra-shadow-lg);
}
.ra-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--ra-border);
}
.ra-modal-close {
  background: none; border: none; color: var(--ra-text-muted);
  font-size: 20px; cursor: pointer; padding: 4px;
}
.ra-modal-close:hover { color: var(--ra-text-primary); }
.ra-modal-body { padding: 20px; }

/* ===== TOOL HEADER ===== */
.ra-tool-header {
  margin-bottom: 24px;
}
.ra-tool-title {
  font-size: 24px; font-weight: 700; letter-spacing: -0.03em;
  color: var(--ra-text-primary); margin: 0 0 4px;
}
.ra-tool-subtitle {
  font-size: 14px; color: var(--ra-text-secondary); margin: 0;
}

/* ===== SEARCH ===== */
.ra-search-container { position: relative; }
.ra-search-results {
  position: absolute; top: 100%; left: 0; right: 0; z-index: 100;
  background: var(--ra-bg-card); border: 1px solid var(--ra-border);
  border-radius: var(--ra-radius); margin-top: 4px;
  max-height: 320px; overflow-y: auto; box-shadow: var(--ra-shadow-lg);
}

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
  .ra-app-container { padding: 16px 12px; }
  .ra-settings-bar { gap: 8px; padding: 10px 12px; font-size: 12px; display: flex; width: 100%; margin-right: 0; }
  /* Hide inline sync bar on mobile — header "Sync League" handles it.
     League-required pages override this below (they need the prominent connect bar). */
  .ra-sync-glow { display: none !important; }
  .ra-sync-wrap { display: none !important; }
  .ra-rankings-controls { display: block !important; }
  .ra-rankings-controls > .ra-settings-bar { display: flex !important; width: 100% !important; box-sizing: border-box !important; }
  .ra-fmt-desktop { display: none !important; }
  .ra-fmt-mobile { display: block !important; }
  .ra-fmt-mobile > .ra-settings-bar { display: flex !important; width: 100% !important; box-sizing: border-box !important; }
  .ra-sync-glow + .ra-settings-bar { display: flex !important; width: 100%; margin-left: 0; margin-right: 0 !important; }

  /* Format bar: hide "Format" label — 1QB/SF toggle is self-explanatory */
  .ra-settings-bar > .ra-settings-label:first-child { display: none; }
  /* Shrink remaining labels and gaps so it all fits on one line */
  .ra-settings-bar > .ra-settings-label { font-size: 10px; margin-left: 6px !important; }
  .ra-settings-bar .ra-toggle-option { padding: 4px 8px; font-size: 10px; }
  .ra-settings-bar .ra-select { width: 52px !important; padding: 3px 4px !important; font-size: 11px; }
  /* Only nowrap the format bar and tabs bar — connected sync bar still wraps */
  .ra-settings-bar:has(> .ra-toggle) { flex-wrap: nowrap; }
  .ra-settings-bar:has(> .ra-tabs) { flex-wrap: nowrap; }

  /* Tabs + search: keep on one line */
  .ra-tabs { flex-wrap: nowrap; flex-shrink: 0; }
  .ra-tab { padding: 5px 8px; font-size: 11px; white-space: nowrap; }
  .ra-settings-bar .ra-input:not(.ra-sync-input) { max-width: 100px !important; min-width: 70px; font-size: 11px; flex-shrink: 1; padding: 5px 8px; }

  .ra-grid-2, .ra-grid-3, .ra-grid-4 { grid-template-columns: 1fr; }
  .ra-table { font-size: 12px; }
  .ra-table th, .ra-table td { padding: 8px 6px; }
  .ra-tool-title { font-size: 20px; }
  .ra-modal { max-width: 100%; margin: 0 8px; }
  .ra-player-name { font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 120px; }
  .ra-player-meta { font-size: 10px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 120px; }
  .ra-table .ra-player-photo { width: 28px; height: 28px; }
  .ra-table .ra-flex { gap: 6px; }
  .ra-table td .ra-flex > span[style*="letter-spacing"] { display: none !important; }
}

/* ===== TRADE CALCULATOR — BOLD SPLIT DESIGN ===== */

/* Header */
.ra-tc-header { margin-bottom: 20px; text-align: center; }
.ra-tc-title {
  font-size: 24px; font-weight: 800; letter-spacing: -0.8px;
  color: var(--ra-text-primary); margin: 0 0 2px;
}
.ra-tc-subtitle {
  font-size: 12px; color: var(--ra-text-muted); font-weight: 400;
  font-style: italic; margin: 0;
}

/* The big split */
.ra-tc-split {
  display: grid; grid-template-columns: 1fr 1fr;
  border-radius: 20px; margin-bottom: 0;
  position: relative;
  background: var(--ra-bg-primary, #0c0e13);
  border: 1px solid rgba(255,255,255,0.06);
}
.ra-tc-vs-badge {
  display: flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08);
  font-size: 16px; color: #64748b; cursor: pointer;
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  z-index: 2; transition: all 0.15s;
}
.ra-tc-vs-badge:hover:not(.disabled) {
  background: rgba(6,182,212,0.12); border-color: rgba(6,182,212,0.3);
  color: #67e8f9;
}
.ra-tc-vs-badge.disabled { cursor: default; }

/* Split panels */
.ra-tc-split-panel { padding: 24px 14px; min-height: 240px; display: flex; flex-direction: column; }
.ra-tc-split-left {
  background: transparent;
  border: none; border-right: 1px solid rgba(255,255,255,0.06);
  border-radius: 0;
  padding-right: 8px;
}
.ra-tc-split-right {
  background: transparent;
  border: none;
  border-radius: 0;
  padding-left: 8px;
}

/* Divider header */
.ra-tc-divider-header {
  display: flex; align-items: center; gap: 14px; margin-bottom: 14px;
}
.ra-tc-dh-line { flex: 1; height: 1px; background: rgba(255,255,255,0.06); }
.ra-tc-dh-label {
  font-size: 11px; font-weight: 700; letter-spacing: 2px;
  color: var(--ra-text-secondary, #9ca3af); text-transform: uppercase;
  white-space: nowrap;
}

/* Inner card */
.ra-tc-inner-card {
  background: var(--ra-bg-secondary, #12141a);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px; padding: 6px 0 0;
  display: flex; flex-direction: column;
  flex: 1;
}
.ra-tc-inner-card .ra-search-container,
.ra-tc-inner-card > .ra-tc-search-wrap { padding: 6px 12px 10px; }

/* Side title — hide old style when divider-header is used */
.ra-tc-side-title { display: none; }

/* Override search input inside trade calc */
.ra-tc-split-panel .ra-input,
.ra-tc-split-panel .ra-search-container .ra-input {
  background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.06);
  border-radius: 8px; padding: 10px 12px; font-size: 14px;
  color: #f0f2f5;
}
.ra-tc-split-panel .ra-input:focus {
  border-color: rgba(16, 185, 129, 0.4); background: rgba(255,255,255,0.07);
}
.ra-tc-split-panel .ra-input::placeholder { color: rgba(255,255,255,0.3); }

/* Override theme/Elementor input styles inside Trade Database */
#ra-trade-database-app .ra-input,
#ra-trade-database-app .ra-search-container .ra-input,
#ra-trade-database-app input[type="text"] {
  background: var(--ra-bg-input, #0d0d0d) !important;
  border-color: var(--ra-border, #222) !important;
  border-radius: var(--ra-radius-sm, 6px);
  color: var(--ra-text-primary, #e8e8f0) !important;
  font-size: 14px; font-family: var(--ra-font);
  padding: 10px 12px;
}
#ra-trade-database-app .ra-input:focus,
#ra-trade-database-app input[type="text"]:focus {
  border-color: var(--ra-accent, #06b6d4) !important;
  background: rgba(255,255,255,0.04) !important;
  outline: none;
}
#ra-trade-database-app .ra-input::placeholder,
#ra-trade-database-app input[type="text"]::placeholder {
  color: var(--ra-text-muted, #555) !important;
}

/* Roster dropdown — scrollable full list */
.ra-tc-roster-dropdown {
  max-height: 320px; overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: rgba(255,255,255,0.08) transparent;
}

/* Pick controls */
.ra-tc-pick-controls {
  display: flex; gap: 6px; margin-top: 10px; flex-wrap: wrap;
}
.ra-tc-pick-sel {
  padding: 9px 12px; background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06); border-radius: 8px;
  color: var(--ra-text-secondary); font-size: 12px; font-weight: 500;
  font-family: var(--ra-font); appearance: none; -webkit-appearance: none;
  cursor: pointer; outline: none; color-scheme: dark;
}
.ra-tc-pick-add {
  padding: 9px 14px; background: transparent;
  border: 1.5px dashed rgba(16, 185, 129, 0.25); border-radius: 8px;
  color: var(--ra-accent); font-size: 12px; font-weight: 600;
  cursor: pointer; font-family: var(--ra-font);
  transition: all var(--ra-transition);
}
.ra-tc-pick-add:hover {
  border-color: var(--ra-accent); background: rgba(16, 185, 129, 0.05);
}

/* Chips area */
.ra-tc-chips { margin-top: 0; display: flex; flex-direction: column; gap: 0; }

/* ─── Asset Chip — flat row style ─── */
.ra-tc-asset-chip {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; border-radius: 0;
  background: transparent; border: none;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  transition: all var(--ra-transition); font-size: 14px;
}
.ra-tc-asset-chip:hover { background: rgba(255,255,255,0.02); }
.ra-tc-asset-chip.consolidation {
  background: rgba(249,115,22,0.04); border: 1px dashed rgba(249,115,22,0.2);
}
.ra-tc-asset-chip.consolidation:hover {
  background: rgba(249,115,22,0.07); border-color: rgba(249,115,22,0.3);
}
.ra-tc-consolidation-icon {
  width: 44px; height: 44px; border-radius: 10px; flex-shrink: 0;
  background: rgba(249,115,22,0.1); display: flex; align-items: center; justify-content: center;
  font-size: 18px;
}
.ra-tc-ac-photo {
  width: 44px; height: 44px; border-radius: 10px; flex-shrink: 0;
  background: rgba(255,255,255,0.05); object-fit: cover;
}
.ra-tc-ac-label { flex: 1; min-width: 0; font-weight: 500; color: var(--ra-text-primary); display: flex; align-items: center; gap: 6px; }
.ra-tc-ac-name { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 15px; font-weight: 600; color: var(--ra-text-primary, #e8eaed); }
.ra-tc-ac-war-badge { flex-shrink: 0; line-height: 1.2; }
.ra-tc-ac-badge {
  font-size: 10px; font-weight: 700; padding: 3px 6px; border-radius: 5px;
  text-transform: uppercase; letter-spacing: 0.5px; flex-shrink: 0;
}
.ra-tc-ac-badge.pick { background: rgba(5,150,105,0.15); color: #22d3ee; }
.ra-tc-ac-badge.pos-qb { background: rgba(239,68,68,0.15); color: #f87171; }
.ra-tc-ac-badge.pos-rb { background: rgba(6,182,212,0.15); color: #22d3ee; }
.ra-tc-ac-badge.pos-wr { background: rgba(6,182,212,0.15); color: #22d3ee; }
.ra-tc-ac-badge.pos-te { background: rgba(234,179,8,0.15); color: #facc15; }
.ra-tc-ac-values {
  display: flex; align-items: center; gap: 5px; flex-shrink: 0;
  font-family: var(--ra-font-mono); font-size: 16px;
}
.ra-tc-ac-adj { color: var(--ra-text-primary); font-weight: 700; }
.ra-tc-ac-meta {
  display: flex; gap: 4px; align-items: center; flex-shrink: 0;
  font-size: 12px; color: var(--ra-text-secondary, #94a3b8);
}
.ra-tc-ac-rank {
  font-family: var(--ra-font-mono); font-weight: 600;
}
.ra-tc-ac-team {
  font-weight: 600; opacity: 0.7;
  text-transform: uppercase; letter-spacing: 0.3px;
}
.ra-tc-ac-age { font-weight: 500; }
.ra-tc-ac-meta-sep { opacity: 0.35; }
.ra-tc-ac-x {
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); color: var(--ra-text-muted); cursor: pointer;
  font-size: 18px; padding: 2px 7px; line-height: 1; border-radius: 6px; opacity: 0.7; transition: all 0.15s;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.ra-tc-ac-x:hover { opacity: 1; color: #f97066; background: rgba(249,112,102,0.15); border-color: rgba(249,112,102,0.3); }

/* Subtotal + Bundle Adjustment (receipt style) */
.ra-tc-subtotal {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 8px; padding: 0 2px;
}
.ra-tc-subtotal-label {
  font-size: 10px; font-weight: 600; color: var(--ra-text-muted);
  text-transform: uppercase; letter-spacing: 0.5px;
}
.ra-tc-subtotal-val {
  font-family: var(--ra-font-mono); font-size: 12px; color: var(--ra-text-muted);
}
.ra-tc-bundle-adj {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 6px; padding: 8px 12px; border-radius: 8px;
  background: rgba(6,182,212,0.04); border: 1px dashed rgba(6,182,212,0.15);
}
.ra-tc-bundle-adj.consolidation {
  background: rgba(249,115,22,0.04); border: 1px dashed rgba(249,115,22,0.15);
}
.ra-tc-bundle-adj-label {
  font-size: 11px; font-weight: 600; color: var(--ra-green, #22c55e);
}
.ra-tc-bundle-adj.consolidation .ra-tc-bundle-adj-label {
  color: var(--ra-accent, #f97316);
}
.ra-tc-bundle-adj-val {
  font-family: var(--ra-font-mono); font-size: 14px; font-weight: 700; color: var(--ra-green, #22c55e);
}
.ra-tc-bundle-adj.consolidation .ra-tc-bundle-adj-val {
  color: var(--ra-accent, #f97316);
}

/* Side total */
/* Side footer — inside inner card */
.ra-tc-side-footer { margin-top: auto; padding: 10px 14px 10px; }

.ra-tc-side-total {
  padding-top: 0;
  border-top: none;
  display: flex; justify-content: flex-end; align-items: center;
}
.ra-tc-side-total-label {
  display: none;
}
.ra-tc-side-total-num {
  font-family: var(--ra-font-mono); font-size: 20px; font-weight: 700;
  display: flex; align-items: center; gap: 6px;
}
.ra-tc-side-total-num.green { color: var(--ra-green); }
.ra-tc-side-total-num.red { color: var(--ra-red); }

/* ─── Verdict Panel — below trade panels ─── */
/* ═══════ Verdict Badge — Color-coded Glow ═══════ */
.ra-tc-verdict-badge {
  display: flex; align-items: center; justify-content: center; gap: 14px;
  padding: 14px 28px; margin-top: -1px;
  border-radius: 0 0 16px 16px;
  border: 1px solid; border-top: none;
  position: relative; overflow: hidden;
  flex-wrap: wrap;
}
.ra-tc-verdict-badge::before {
  content: ''; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: 60%; height: 1px;
}
/* Win state */
.ra-tc-verdict-badge.win {
  background: linear-gradient(180deg, rgba(34,211,238,0.07) 0%, rgba(34,211,238,0.02) 100%);
  border-color: rgba(34,211,238,0.15);
}
.ra-tc-verdict-badge.win::before {
  background: linear-gradient(90deg, transparent, var(--ra-green), transparent);
}
/* Lose state */
.ra-tc-verdict-badge.lose {
  background: linear-gradient(180deg, rgba(249,112,102,0.07) 0%, rgba(249,112,102,0.02) 100%);
  border-color: rgba(249,112,102,0.15);
}
.ra-tc-verdict-badge.lose::before {
  background: linear-gradient(90deg, transparent, var(--ra-red), transparent);
}
/* Fair state */
.ra-tc-verdict-badge.fair {
  background: linear-gradient(180deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.01) 100%);
  border-color: rgba(255,255,255,0.08);
}
.ra-tc-verdict-badge.fair::before {
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
}
/* Arrow */
.ra-tc-vb-arrow { font-size: 16px; }
.ra-tc-vb-arrow.win { color: var(--ra-green); }
.ra-tc-vb-arrow.lose { color: var(--ra-red); }
/* Text (fallback for 1-for-1 trades) */
.ra-tc-vb-text {
  font-size: 14px; color: rgba(255,255,255,0.6);
}
.ra-tc-vb-text strong { font-weight: 700; }
.ra-tc-vb-text.win strong { color: var(--ra-green); }
.ra-tc-vb-text.lose strong { color: var(--ra-red); }
.ra-tc-vb-text.fair strong { color: var(--ra-text, #e2e8f0); }
/* Percentage pill (fallback) */
.ra-tc-vb-diff {
  font-family: var(--ra-font-mono); font-size: 12px; font-weight: 700;
  padding: 4px 12px; border-radius: 20px;
}
.ra-tc-vb-diff.win { background: rgba(34,211,238,0.12); color: var(--ra-green); }
.ra-tc-vb-diff.lose { background: rgba(249,112,102,0.12); color: var(--ra-red); }
.ra-tc-vb-diff.fair { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.5); }

/* ─── V5 Verdict Layout ──── */
.ra-tc-verdict-badge.v5 {
  flex-direction: column; align-items: center; gap: 12px; padding: 18px 28px;
}
.ra-tc-vb-v5-main {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 16px; border-radius: 10px;
  background: rgba(255,255,255,0.04);
}
.ra-tc-vb-v5-main .ra-tc-vb-arrow { font-size: 18px; font-weight: 800; }
.ra-tc-vb-v5-label { display: flex; flex-direction: column; }
.ra-tc-vb-v5-sublabel {
  font-size: 10px; font-weight: 600; letter-spacing: 0.5px;
  color: var(--ra-text-muted, #64748b);
}
.ra-tc-vb-v5-pick {
  font-size: 17px; font-weight: 800; color: var(--ra-text, #e2e8f0);
}
.ra-tc-vb-v5-details {
  display: flex; align-items: center; gap: 12px; font-size: 12px;
  width: 100%; justify-content: center;
}
.ra-tc-vb-v5-stat { color: var(--ra-text-muted, #64748b); }
.ra-tc-vb-v5-stat strong { font-weight: 600; color: var(--ra-text-secondary, #94a3b8); }
.ra-tc-vb-v5-balance { color: var(--ra-orange, #f97316) !important; font-weight: 700 !important; }
.ra-tc-vb-v5-sep { color: rgba(255,255,255,0.1); }

/* ─── Education Card ──── */
.ra-tc-edu-card {
  position: relative; margin-top: 10px; padding: 16px 20px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(124,58,237,0.06), rgba(6,182,212,0.04));
  border: 1px solid rgba(124,58,237,0.12);
}
.ra-tc-edu-dismiss {
  position: absolute; top: 10px; right: 12px;
  background: none; border: none; color: var(--ra-text-muted, #64748b);
  font-size: 18px; cursor: pointer; padding: 0; line-height: 1;
  transition: color 0.2s;
}
.ra-tc-edu-dismiss:hover { color: var(--ra-text, #e2e8f0); }
.ra-tc-edu-inner { display: flex; align-items: flex-start; gap: 12px; }
.ra-tc-edu-icon {
  width: 32px; height: 32px; border-radius: 8px; flex-shrink: 0;
  background: rgba(124,58,237,0.12);
  display: flex; align-items: center; justify-content: center; font-size: 16px;
}
.ra-tc-edu-content { flex: 1; min-width: 0; }
.ra-tc-edu-title {
  margin: 0 0 6px; font-size: 14px; font-weight: 700;
  color: var(--ra-purple-light, #67e8f9);
}
.ra-tc-edu-text {
  margin: 0 0 12px; font-size: 12px; line-height: 1.7;
  color: var(--ra-text-secondary, #94a3b8);
}
.ra-tc-edu-compare {
  display: flex; gap: 16px; padding: 10px 14px; border-radius: 10px;
  background: rgba(0,0,0,0.2);
}
.ra-tc-edu-compare-item {
  flex: 1; text-align: center; display: flex; flex-direction: column; gap: 2px;
}
.ra-tc-edu-compare-label {
  font-size: 9px; font-weight: 700; letter-spacing: 0.5px;
  color: var(--ra-text-muted, #64748b);
}
.ra-tc-edu-compare-value {
  font-size: 16px; font-weight: 800; color: var(--ra-text-secondary, #94a3b8);
}
.ra-tc-edu-compare-value.highlight { color: var(--ra-orange, #f97316); }
.ra-tc-edu-compare-sub {
  font-size: 10px; color: var(--ra-text-muted, #64748b); margin-top: 1px;
}
.ra-tc-edu-compare-divider { width: 1px; background: rgba(255,255,255,0.08); }
.ra-tc-edu-restore { text-align: center; margin-top: 6px; }
.ra-tc-edu-restore button {
  background: none; border: none; color: var(--ra-text-muted, #4b4b4b);
  font-size: 11px; cursor: pointer; text-decoration: underline; padding: 4px;
  font-family: var(--ra-font, 'Outfit', sans-serif);
}
.ra-tc-edu-restore button:hover { color: var(--ra-text-secondary, #94a3b8); }

.ra-tc-split.has-verdict { border-radius: 20px 20px 0 0; border-bottom: none; }
.ra-tc-split.has-verdict .ra-tc-split-left { border-radius: 0; }
.ra-tc-split.has-verdict .ra-tc-split-right { border-radius: 0; }

/* ═══════ Verdict Section — tug-of-war ═══════ */
.ra-tc-verdict-section {
  margin-top: -1px;
  background: var(--ra-bg-primary, #0c0e13);
  border: 1px solid rgba(255,255,255,0.06); border-top: none;
  border-radius: 0 0 20px 20px;
  padding: 4px 0 16px;
}
.ra-tc-verdict-section.has-actions .ra-tc-verdict-badge { border-radius: 0; border-bottom: none; }
/* Consolidation warning */
.ra-tc-consol-warn {
  max-width: 700px;
  margin: 0 auto 12px;
  padding: 8px 18px;
  font-size: 14px;
  color: rgba(255,255,255,0.35);
  text-align: center;
  line-height: 1.5;
  font-style: italic;
}
/* ═══════ Balance Button (legacy) ═══════ */
.ra-tc-balance-btn {
  display: block; width: 100%; padding: 10px 16px; margin-top: 0;
  background: rgba(34,211,238,0.08); border: 1px solid rgba(34,211,238,0.15); border-top: none;
  border-radius: 0 0 14px 14px; cursor: pointer; font-size: 12px; font-weight: 600;
  color: var(--ra-blue, #22d3ee); font-family: var(--ra-font, 'Outfit', sans-serif);
  transition: background 0.15s;
}
.ra-tc-balance-btn:hover { background: rgba(34,211,238,0.14); }

/* ═══════ Deal Playbook ═══════ */
.ra-tc-dp {
  background: rgba(0,0,0,0.3); border: 1px solid rgba(255,255,255,0.06);
  border-top: none; border-radius: 0 0 14px 14px; overflow: hidden;
}
.ra-tc-dp-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px 0;
}
.ra-tc-dp-title { font-size: 12px; font-weight: 600; color: var(--ra-text, #e2e8f0); }
.ra-tc-dp-close {
  background: none; border: none; color: var(--ra-muted, #7d8590);
  font-size: 11px; cursor: pointer; padding: 4px 8px;
  font-family: var(--ra-font, 'Outfit', sans-serif);
}
.ra-tc-dp-close:hover { color: var(--ra-text, #e2e8f0); }
.ra-tc-dp-empty {
  text-align: center; padding: 20px; color: var(--ra-muted, #7d8590); font-size: 12px;
}
/* Section */
.ra-tc-dp-section { padding: 8px 14px; display: flex; flex-direction: column; align-items: flex-start; }
.ra-tc-dp-section + .ra-tc-dp-section { border-top: 1px solid rgba(255,255,255,0.04); }
.ra-tc-dp-sec-head { display: flex; align-items: center; gap: 6px; }
.ra-tc-dp-sec-bar { width: 3px; height: 14px; border-radius: 2px; flex-shrink: 0; }
.ra-tc-dp-sec-label { font-size: 12px; font-weight: 700; }
.ra-tc-dp-sec-desc { font-size: 10px; color: var(--ra-muted, #7d8590); margin: 3px 0 6px 9px; }
/* Hero card */
.ra-tc-dp-hero {
  display: flex; align-items: center; gap: 8px; padding: 9px 12px;
  border-radius: 8px; margin-bottom: 4px; cursor: pointer;
  background: rgba(6,182,212,0.05); border: 1px solid rgba(6,182,212,0.12);
  transition: background 0.15s;
}
.ra-tc-dp-hero:hover { background: rgba(6,182,212,0.09); }
.ra-tc-dp-hero-assets { display: flex; gap: 4px; flex-wrap: wrap; align-items: center; }
.ra-tc-dp-hero-btn {
  padding: 5px 12px; border-radius: 6px; border: none;
  background: var(--ra-green, #22c55e); color: #000;
  font-size: 10px; font-weight: 700; cursor: pointer; white-space: nowrap;
  font-family: var(--ra-font, 'Outfit', sans-serif);
}
/* Result row */
.ra-tc-dp-row {
  display: flex; align-items: center; gap: 8px; padding: 6px 10px;
  border-radius: 6px; cursor: pointer;
  transition: background 0.15s; margin-bottom: 1px;
}
.ra-tc-dp-row:hover { background: rgba(255,255,255,0.04); }
.ra-tc-dp-row-bar { width: 3px; height: 18px; border-radius: 2px; flex-shrink: 0; opacity: 0.4; }
.ra-tc-dp-assets { display: flex; gap: 4px; flex-wrap: wrap; align-items: center; }

/* ═══════ Intensity Results (shared pill/add styles) ═══════ */
.ra-tc-ir-pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px 2px 3px; border-radius: 5px;
  background: rgba(255,255,255,0.04); border: 1px solid var(--ra-border, rgba(255,255,255,0.06));
  font-size: 11px;
}
.ra-tc-ir-plus { font-size: 10px; color: var(--ra-muted, #7d8590); font-weight: 600; }
.ra-tc-ir-pill-pos {
  font-size: 8px; font-weight: 700; padding: 1px 4px; border-radius: 3px;
}
.ra-tc-ir-pill-pos.qb { background: rgba(239,68,68,0.15); color: #f87171; }
.ra-tc-ir-pill-pos.rb { background: rgba(34,211,238,0.15); color: #67e8f9; }
.ra-tc-ir-pill-pos.wr { background: rgba(6,182,212,0.15); color: #22d3ee; }
.ra-tc-ir-pill-pos.te { background: rgba(234,179,8,0.15); color: #facc15; }
.ra-tc-ir-pill-pos.pick { background: rgba(6,182,212,0.15); color: #c084fc; }
.ra-tc-ir-pill-name { font-weight: 500; color: var(--ra-text, #e2e8f0); }
.ra-tc-ir-add {
  font-size: 15px; font-weight: 700; color: var(--ra-blue, #22d3ee); flex-shrink: 0;
}
/* Partner picker — control row */
.ra-tc-partner-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px; margin-bottom: 8px; flex-wrap: wrap;
}
.ra-tc-partner-left {
  display: flex; align-items: center; gap: 10px;
}
.ra-tc-partner-label {
  font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 1px; color: var(--ra-text-muted); white-space: nowrap;
}

/* Pick icon wrap for asset chip */
.ra-tc-ac-icon-wrap {
  width: 44px; height: 44px; border-radius: 10px; overflow: hidden;
  background: rgba(5,150,105,0.1); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; font-size: 18px;
}

/* ─── Keep old fairness classes for share page compat ─── */
.ra-tc-fairness { display: none; }
/* Needle */
.ra-tc-gauge-needle {
  position: absolute; top: -8px; bottom: -8px; width: 3px;
  background: #f1f5f9; border-radius: 2px;
  transform: translateX(-1.5px);
  transition: left 0.4s ease;
  box-shadow: 0 0 8px rgba(241,245,249,0.4);
  z-index: 2;
}
/* Arrow above needle */
.ra-tc-gauge-arrow {
  position: absolute; top: -16px; width: 0; height: 0;
  border-left: 6px solid transparent; border-right: 6px solid transparent;
  border-top: 7px solid #f1f5f9;
  transform: translateX(-6px);
  transition: left 0.4s ease;
  z-index: 2;
}

.ra-tc-fairness-labels {
  display: flex; justify-content: space-between; margin-top: 10px;
  font-family: var(--ra-font-mono); font-size: 14px; font-weight: 600;
}
.ra-tc-fairness-labels .green { color: var(--ra-green); }
.ra-tc-fairness-labels .red { color: var(--ra-red); }

/* CTA buttons */
/* Suggest Trade bar (standalone, no league synced) */
.ra-tc-suggest-bar {
  display: flex; align-items: center; justify-content: center; gap: 14px;
  margin-bottom: 8px; padding: 10px 20px;
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px; flex-wrap: wrap;
}
.ra-tc-suggest-label {
  font-size: 11px; font-weight: 700; letter-spacing: 0.8px;
  text-transform: uppercase; color: rgba(255,255,255,0.4);
}
.ra-tc-suggest-buttons { display: flex; gap: 8px; }
.ra-tc-suggest-inline {
  display: flex; align-items: center; gap: 10px;
}
.ra-tc-suggest-btn {
  padding: 7px 18px; border-radius: 8px; border: none; cursor: pointer;
  font-size: 14px; font-weight: 600; font-family: var(--ra-font);
  transition: opacity 0.2s, transform 0.15s;
}
.ra-tc-suggest-btn:hover:not(:disabled):not(.active) { opacity: 0.85; transform: translateY(-1px); }
.ra-tc-suggest-btn:hover:not(:disabled).active { opacity: 1; }
.ra-tc-suggest-btn:disabled { opacity: 0.5; cursor: wait; }
.ra-tc-suggest-btn.lowball { background: #1e1e1e; color: #22d3ee; }
.ra-tc-suggest-btn.lowball.active { background: #22d3ee; color: #0f0f0f; font-weight: 700; box-shadow: 0 0 16px rgba(34,211,238,0.45), inset 0 0 0 1px rgba(255,255,255,0.15); transform: scale(1.06); }
.ra-tc-suggest-btn.fair { background: #1a1a1a; color: #22d3ee; }
.ra-tc-suggest-btn.fair.active { background: #22d3ee; color: #0f0f0f; font-weight: 700; box-shadow: 0 0 16px rgba(74,222,128,0.45), inset 0 0 0 1px rgba(255,255,255,0.15); transform: scale(1.06); }
.ra-tc-suggest-btn.premium { background: #3d2e10; color: #fbbf24; }
.ra-tc-suggest-btn.premium.active { background: #fbbf24; color: #0f0f0f; font-weight: 700; box-shadow: 0 0 16px rgba(251,191,36,0.45), inset 0 0 0 1px rgba(255,255,255,0.15); transform: scale(1.06); }

.ra-tc-cta {
  text-align: center; margin: 20px 0;
  display: flex; gap: 10px; justify-content: center;
}
.ra-tc-btn-share {
  padding: 12px 24px; background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08); border-radius: 10px;
  color: var(--ra-text-secondary); font-size: 14px; font-weight: 500;
  cursor: pointer; font-family: var(--ra-font); transition: all var(--ra-transition);
}
.ra-tc-btn-share:hover { border-color: rgba(255,255,255,0.15); color: var(--ra-text-primary); }
.ra-tc-btn-report {
  padding: 12px 24px; background: linear-gradient(135deg, rgba(6,182,212,0.15), rgba(6,182,212,0.12));
  border: 1px solid rgba(6,182,212,0.25); border-radius: 10px;
  color: #e2e8f0; font-size: 14px; font-weight: 600;
  cursor: pointer; font-family: var(--ra-font); transition: all var(--ra-transition);
}
.ra-tc-btn-report:hover { border-color: rgba(6,182,212,0.45); background: linear-gradient(135deg, rgba(6,182,212,0.22), rgba(6,182,212,0.18)); }
.ra-tc-btn-report:disabled { opacity: 0.6; cursor: wait; }
.ra-tc-btn-reset {
  padding: 12px 24px; background: transparent;
  border: 1.5px solid rgba(255,255,255,0.08); color: var(--ra-text-muted);
  font-size: 14px; font-weight: 500; border-radius: 10px;
  cursor: pointer; font-family: var(--ra-font); transition: all var(--ra-transition);
}
.ra-tc-btn-reset:hover { border-color: rgba(255,255,255,0.15); color: var(--ra-text-secondary); }

/* Signals, analysis */
.ra-tc-signals {
  text-align: left; padding: 16px 0;
}
.ra-tc-signals-title {
  font-size: 14px; font-weight: 600; margin-bottom: 10px;
}
.ra-tc-analysis-text {
  font-size: 14px; line-height: 1.7; color: var(--ra-text-secondary); white-space: pre-wrap;
}

/* Partner picker */
.ra-tc-partner-dd { position: relative; flex: 1; max-width: 420px; min-width: 0; }
.ra-tc-partner-trigger {
  width: 100%; padding: 10px 14px; display: flex; align-items: center; justify-content: space-between; gap: 8px;
  background: var(--ra-bg-card, #13151a); border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px; color: #e2e8f0; font-size: 14px;
  font-family: var(--ra-font); cursor: pointer; text-align: left;
  transition: border-color var(--ra-transition); min-width: 0;
}
.ra-tc-partner-trigger > span:first-child {
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0;
}
.ra-tc-partner-trigger:hover { border-color: rgba(255,255,255,0.18); }
.ra-tc-partner-menu {
  position: absolute; top: calc(100% + 4px); left: 0; z-index: 100;
  min-width: 280px; width: max-content; max-width: 420px;
  background: var(--ra-bg-card, #13151a); border: 1px solid rgba(255,255,255,0.12);
  border-radius: 10px; padding: 4px 0; max-height: 260px; overflow-y: auto;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
}
.ra-tc-partner-option {
  padding: 9px 14px; color: #c8d0de; font-size: 14px; cursor: pointer;
  font-family: var(--ra-font); transition: background 0.15s; white-space: nowrap;
}
.ra-tc-partner-option:hover { background: rgba(255,255,255,0.08); color: #fff; }
.ra-tc-partner-option.selected { background: rgba(99,132,255,0.18); color: #fff; }
.ra-tc-partner-option.clear { color: #94a3b8; border-bottom: 1px solid rgba(255,255,255,0.06); }
.ra-tc-partner-select:hover { border-color: rgba(255,255,255,0.15); }
.ra-tc-partner-select:focus { border-color: rgba(6,182,212,0.4); }

/* Owned picks selector */
/* Dropdown picks integration */
.ra-tc-pick-row { display: flex; align-items: center; gap: 10px; }
.ra-tc-pick-icon {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  border-radius: 50%; background: rgba(6,182,212,0.1); font-size: 16px; flex-shrink: 0;
}
.ra-tc-slot-sel { padding: 5px 6px !important; font-size: 11px !important; min-width: 0; }

/* Share */
/* Share toast + native share */
.ra-tc-share-toast {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 20px; border-radius: 10px;
  background: rgba(34,211,238,0.1); border: 1px solid rgba(34,211,238,0.2);
  color: var(--ra-green); font-size: 14px; font-weight: 600;
  animation: ra-tc-fade-in 0.3s ease;
}
@keyframes ra-tc-fade-in { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }
.ra-tc-share-toast-icon { font-size: 15px; }
.ra-tc-share-toast-sub { font-size: 11px; color: var(--ra-text-muted); font-weight: 400; margin-left: 2px; }
.ra-tc-btn-native-share {
  width: 38px; height: 38px; border-radius: 10px;
  background: rgba(255,255,255,0.04); border: 1px solid var(--ra-border);
  color: var(--ra-text-muted); cursor: pointer; display: flex;
  align-items: center; justify-content: center; transition: all 0.15s;
}
.ra-tc-btn-native-share:hover { background: rgba(255,255,255,0.08); color: var(--ra-text-primary); }
.ra-tc-share-link-row {
  display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 6px;
}
.ra-tc-share-link {
  font-family: var(--ra-font-mono); font-size: 11px; color: var(--ra-blue, #22d3ee);
  cursor: pointer; text-decoration: underline; text-decoration-color: rgba(34,211,238,0.3);
}
.ra-tc-share-recopy {
  font-size: 10px; color: var(--ra-text-muted); cursor: pointer;
  padding: 2px 8px; border-radius: 4px; background: rgba(255,255,255,0.04);
}
.ra-tc-share-recopy:hover { background: rgba(255,255,255,0.08); }

/* Legacy compat - keep old classes working for share pages */
.ra-trade-sides { display: grid; grid-template-columns: 1fr auto 1fr; gap: 16px; align-items: start; }
.ra-trade-vs { display: flex; align-items: center; justify-content: center; padding-top: 40px; font-size: 14px; font-weight: 700; color: var(--ra-text-muted); }
.ra-trade-side { background: var(--ra-bg-card); border: 1px solid var(--ra-border); border-radius: var(--ra-radius); padding: 16px; min-height: 200px; }
.ra-trade-side-header { font-size: 14px; font-weight: 600; color: var(--ra-text-secondary); text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 12px; }
.ra-trade-result { background: var(--ra-bg-card); border: 1px solid var(--ra-border); border-radius: var(--ra-radius-lg); padding: 24px; margin-top: 20px; text-align: center; }

/* ===== TEAM ANALYZER ===== */
.ra-pos-grade-card {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 16px; background: var(--ra-bg-card); border: 1px solid var(--ra-border);
  border-radius: var(--ra-radius);
}
.ra-pos-grade-label { font-size: 12px; font-weight: 600; color: var(--ra-text-secondary); text-transform: uppercase; }

/* ===== POWER RANKINGS ===== */
.ra-power-rank {
  display: flex; align-items: center; gap: 12px; padding: 10px 14px;
  border-bottom: 1px solid var(--ra-border);
}
.ra-power-rank-num {
  font-size: 18px; font-weight: 700; color: var(--ra-text-muted);
  min-width: 30px; text-align: center;
}

@media (max-width: 768px) {
  .ra-trade-sides { grid-template-columns: 1fr; }
  .ra-trade-vs { display: none; }
  .ra-tc-split { grid-template-columns: 1fr; border-radius: 16px; }
  .ra-tc-split.has-verdict { border-radius: 16px 16px 0 0; }
  .ra-tc-split-left { border-radius: 0; border-right: none; border-bottom: 1px solid rgba(255,255,255,0.06); }
  .ra-tc-split-right { border-radius: 0; padding-left: 14px; }
  .ra-tc-split.has-verdict .ra-tc-split-right { border-radius: 0; }
  .ra-tc-vs-badge {
    position: relative; left: auto; top: auto; transform: none;
    margin: -12px auto; width: 28px; height: 28px; font-size: 14px;
  }
  .ra-tc-split-panel { padding: 20px 14px; }
  .ra-tc-verdict-badge { padding: 12px 16px; gap: 10px; flex-wrap: wrap; justify-content: center; }
  .ra-tc-verdict-badge.v5 { padding: 14px 16px; gap: 10px; }
  .ra-tc-vb-v5-main { padding: 6px 12px; gap: 8px; }
  .ra-tc-vb-v5-pick { font-size: 15px; }
  .ra-tc-vb-v5-details { gap: 8px; font-size: 11px; flex-wrap: wrap; justify-content: center; }
  .ra-tc-edu-card { padding: 14px 16px; margin-top: 8px; }
  .ra-tc-edu-inner { flex-direction: column; gap: 10px; }
  .ra-tc-edu-icon { width: 28px; height: 28px; font-size: 14px; }
  .ra-tc-edu-compare { gap: 10px; padding: 8px 10px; }
  .ra-tc-edu-compare-value { font-size: 14px; }
  .ra-tc-asset-chip { font-size: 14px; gap: 10px; padding: 10px 12px; }
  .ra-tc-ac-photo { width: 36px; height: 36px; border-radius: 8px; }
  .ra-tc-ac-icon-wrap { width: 36px; height: 36px; font-size: 16px; }
  .ra-tc-ac-name { font-size: 14px; }
  .ra-tc-ac-values { font-size: 14px; }
  .ra-tc-ac-x { font-size: 16px; padding: 1px 5px; }
  .ra-tc-partner-row { flex-wrap: wrap; }
  .ra-tc-partner-left { flex: 1; min-width: 0; white-space: nowrap; }
  .ra-tc-partner-trigger { padding: 8px 10px; font-size: 14px; white-space: nowrap; }
  .ra-tc-partner-label { font-size: 11px; letter-spacing: 0.5px; }
  .ra-tc-suggest-buttons { flex-wrap: wrap; }
  .ra-tc-partner-row .ra-tc-partner-select { flex: 1; max-width: none; }
  .ra-tc-dp-row { flex-wrap: wrap; }
  .ra-tc-dp-assets { min-width: 100%; }
  .ra-tc-dp-hero { flex-wrap: wrap; }
  .ra-tc-dp-hero-assets { min-width: 100%; margin-bottom: 4px; }
}

/* ===== PERFORMANCE ===== */
/* GPU-composite the spinner animation */
.ra-spinner {
  will-change: transform;
  contain: strict;
}
/* Long lists: skip rendering offscreen rows */
.ra-rankings-table tbody tr,
.ra-search-results .ra-player-row {
  content-visibility: auto;
  contain-intrinsic-size: auto 48px;
}
/* Reduce paint on hover transitions */
.ra-player-row,
.ra-chip,
.ra-btn {
  will-change: background-color;
}
/* Avoid layout shift from player photos */
.ra-player-photo {
  aspect-ratio: 1;
  object-fit: cover;
  background: var(--ra-bg-tertiary);
}

/* ===== SKELETON LOADING ===== */
/* Shows instantly in the server-rendered HTML while React downloads + boots.
   Auto-removed when React's createRoot() replaces the container innerHTML. */
@keyframes ra-shimmer {
  0% { background-position: -200px 0; }
  100% { background-position: 200px 0; }
}
.ra-skeleton {
  padding: 20px;
}
.ra-skeleton-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 20px; padding-bottom: 16px;
  border-bottom: 1px solid var(--ra-border);
}
.ra-skeleton-row {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--ra-border);
}
.ra-skeleton-bar, .ra-skeleton-pill {
  height: 14px;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--ra-bg-tertiary) 25%, var(--ra-bg-hover) 50%, var(--ra-bg-tertiary) 75%);
  background-size: 400px 100%;
  animation: ra-shimmer 1.5s ease-in-out infinite;
}
.ra-skeleton-pill {
  border-radius: 8px;
  flex-shrink: 0;
}

/* ===== MICRO-INTERACTIONS ===== */

/* Animated value bar — grows from left with spring ease */
.ra-bar-animated {
  transition: width 0.7s cubic-bezier(0.34, 1.2, 0.64, 1) !important;
}

/* Grade bounce-in */
.ra-grade-animated {
  will-change: transform, opacity;
}

/* Chip enter/exit */
.ra-chip {
  animation: ra-chip-in 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
@keyframes ra-chip-in {
  from { opacity: 0; transform: scale(0.8) translateY(4px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

/* Player row hover lift */
.ra-player-row {
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.ra-player-row:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

/* Card hover lift */
.ra-card-interactive {
  transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
  cursor: pointer;
}
.ra-card-interactive:hover {
  transform: translateY(-2px);
  border-color: var(--ra-accent);
  box-shadow: 0 4px 16px rgba(16, 185, 129, 0.08);
}

/* Button press feedback */
.ra-btn {
  transition: transform 0.1s ease, background 0.15s ease, box-shadow 0.15s ease;
}
.ra-btn:active {
  transform: scale(0.97);
}
.ra-btn-primary:hover {
  box-shadow: 0 2px 12px rgba(16, 185, 129, 0.25);
}

/* Trend badge pulse for big movers */
.ra-trend-hot {
  animation: ra-pulse 2s ease-in-out infinite;
}
@keyframes ra-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}

/* Tab indicator slide */
.ra-toggle-option {
  transition: background 0.2s ease, color 0.2s ease;
  position: relative;
}
.ra-toggle-option.active::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 20%;
  right: 20%;
  height: 2px;
  background: var(--ra-accent);
  border-radius: 1px;
  animation: ra-tab-slide 0.25s ease;
}
@keyframes ra-tab-slide {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

/* Tooltip base */
.ra-tooltip-trigger {
  position: relative;
  cursor: help;
  border-bottom: 1px dotted var(--ra-text-muted);
}
.ra-tooltip-trigger:hover .ra-tooltip {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.ra-tooltip {
  position: fixed;
  transform: translateX(-50%) translateY(-100%) translateY(-8px);
  background: var(--ra-bg-card);
  border: 1px solid var(--ra-border);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 12px;
  color: var(--ra-text-secondary);
  white-space: nowrap;
  max-width: 280px;
  white-space: normal;
  z-index: 99999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
  box-shadow: 0 4px 16px rgba(0,0,0,0.3);
}
.ra-tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: var(--ra-border);
}

/* Photo load-in */
.ra-player-photo {
  opacity: 0;
  animation: ra-img-in 0.3s ease forwards;
  animation-delay: 0.1s;
}
@keyframes ra-img-in {
  from { opacity: 0; transform: scale(0.9); }
  to   { opacity: 1; transform: scale(1); }
}

/* Search results dropdown */
.ra-search-results {
  animation: ra-dropdown 0.2s ease;
  transform-origin: top center;
}
@keyframes ra-dropdown {
  from { opacity: 0; transform: scaleY(0.95); }
  to   { opacity: 1; transform: scaleY(1); }
}

/* Notification toast entrance */
.ra-toast {
  animation: ra-toast-in 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
@keyframes ra-toast-in {
  from { opacity: 0; transform: translateY(20px) scale(0.95); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Loading dots alternative (for inline loading) */
.ra-loading-dots::after {
  content: '';
  animation: ra-dots 1.5s infinite;
}
@keyframes ra-dots {
  0%   { content: ''; }
  25%  { content: '.'; }
  50%  { content: '..'; }
  75%  { content: '...'; }
  100% { content: ''; }
}

/* Reduce motion for accessibility */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .ra-bar-animated { transition: none !important; }
  .ra-grade-animated { transition: none !important; }
}

/* ===== SEO — H1 + INTRO ===== */
.ra-page-title {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Visible to crawlers, hidden for users. */
.ra-seo-intro {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}


/* ===== SHARE PAGES ===== */
.ra-share-page { max-width: 720px; margin: 0 auto; padding: 20px 16px 40px; }
.ra-share-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.ra-share-back { color: var(--ra-text-muted); text-decoration: none; font-size: 14px; }
.ra-share-back:hover { color: var(--ra-accent); }
.ra-share-actions { display: flex; gap: 8px; }
.ra-share-page .ra-copy-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: 8px;
  background: rgba(34,211,238,0.1); border: 1px solid rgba(34,211,238,0.25);
  color: var(--ra-accent); font-size: 12px; font-weight: 600;
  cursor: pointer; font-family: var(--ra-font);
}
.ra-share-page .ra-copy-btn:hover { background: rgba(34,211,238,0.18); }

/* Share page: no remove buttons on chips */
.ra-share-page .ra-tc-asset-chip { cursor: default; }
.ra-share-page .ra-tc-asset-chip:hover { border-color: rgba(255,255,255,0.04); background: rgba(255,255,255,0.025); }

.ra-share-vote { margin: 24px 0; }
.ra-share-explanation, .ra-share-context { margin-bottom: 16px; }
.ra-share-explanation p { font-size: 14px; line-height: 1.6; color: var(--ra-text-secondary); }

.ra-share-cta { text-align: center; margin: 24px 0; display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.ra-share-cta-btn {
  padding: 12px 24px; border-radius: 10px; font-size: 14px; font-weight: 600;
  text-decoration: none; cursor: pointer; font-family: var(--ra-font);
  transition: all 0.15s; display: inline-block;
}
.ra-share-cta-btn.primary {
  background: rgba(34,211,238,0.12); border: 1px solid rgba(34,211,238,0.25);
  color: var(--ra-accent);
}
.ra-share-cta-btn.primary:hover {
  background: rgba(34,211,238,0.22); border-color: rgba(34,211,238,0.4);
  color: #fff;
}
.ra-share-cta-btn.secondary {
  background: rgba(255,255,255,0.04); border: 1px solid var(--ra-border);
  color: var(--ra-text-secondary);
}
.ra-share-cta-btn.secondary:hover {
  background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.12);
  color: #fff;
}

/* ===== COMPARISON SHARE ===== */
.ra-compare-header { display: grid; grid-template-columns: 1fr auto 1fr; gap: 16px; margin-bottom: 24px; align-items: center; }
@media (max-width: 560px) { .ra-compare-header { grid-template-columns: 1fr; } }
.ra-compare-player { text-align: center; padding: 20px; background: var(--ra-bg-card); border: 1px solid var(--ra-border); border-radius: 12px; }
.ra-compare-winner { border-color: var(--ra-green); }
.ra-compare-photo { width: 64px; height: 64px; border-radius: 50%; margin-bottom: 8px; }
.ra-compare-name { font-weight: 700; font-size: 16px; color: var(--ra-text-primary); }
.ra-compare-meta { font-size: 12px; color: var(--ra-text-muted); }
.ra-compare-vs { font-size: 24px; font-weight: 800; color: var(--ra-text-muted); text-align: center; }

.ra-compare-cats { padding: 16px 20px; }
.ra-compare-row { display: grid; grid-template-columns: 1fr auto 1fr; gap: 16px; padding: 10px 0; border-bottom: 1px solid var(--ra-border); align-items: center; }
.ra-compare-row:last-child { border-bottom: none; }
.ra-compare-val { font-size: 14px; font-weight: 600; color: var(--ra-text-secondary); }
.ra-compare-val:first-child { text-align: right; }
.ra-compare-val:last-child { text-align: left; }
.ra-compare-win { color: var(--ra-green) !important; font-weight: 700; }
.ra-compare-label { font-size: 12px; color: var(--ra-text-muted); text-align: center; text-transform: uppercase; letter-spacing: 0.5px; }

.ra-compare-score { display: flex; justify-content: center; align-items: center; gap: 16px; font-size: 48px; font-weight: 800; margin: 24px 0; }
.ra-compare-score-sep { color: var(--ra-text-muted); font-size: 32px; }

.ra-internal-links { margin-top: 24px; padding-top: 16px; border-top: 1px solid var(--ra-border); }
.ra-internal-links h3 { font-size: 14px; color: var(--ra-text-muted); margin-bottom: 8px; }
.ra-internal-links ul { list-style: none; padding: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.ra-internal-links li a { font-size: 12px; color: var(--ra-accent); text-decoration: none; padding: 4px 10px; border-radius: 6px; background: var(--ra-accent-muted); }
.ra-internal-links li a:hover { background: var(--ra-accent); color: #fff; }

/* ===== POSITION NAV ===== */
.ra-pos-nav { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 16px; }
.ra-pos-nav-link { padding: 6px 14px; border-radius: 6px; font-size: 14px; font-weight: 600; color: var(--ra-text-muted); text-decoration: none; background: var(--ra-bg-tertiary); }
.ra-pos-nav-link:hover { color: var(--ra-text-primary); }
.ra-pos-nav-active { background: var(--ra-accent); color: #fff !important; }

/* ===== SEO TABLE ===== */
.ra-table-wrap { overflow-x: auto; }
.ra-table-seo { width: 100%; font-size: 14px; }
.ra-table-seo td a { color: var(--ra-text-primary); text-decoration: none; }
.ra-table-seo td a:hover { color: var(--ra-accent); }
.ra-trend-up { color: var(--ra-green); font-weight: 600; }
.ra-trend-down { color: var(--ra-red); font-weight: 600; }

/* ─── Compact controls: merge sync bar + partner/format onto fewer lines ─── */
.ra-tc-controls {
  display: flex; align-items: stretch; gap: 8px; margin-bottom: 12px; flex-wrap: wrap;
}
.ra-tc-controls > .ra-settings-bar {
  margin-bottom: 0; flex: 1 1 auto; min-width: 0; display: flex; margin-right: 0;
}
.ra-tc-controls > .ra-sync-glow {
  flex: 1 1 0%; min-width: 200px; display: flex !important; width: auto; max-width: none; margin-right: 0 !important; max-height: none; align-self: stretch;
}
.ra-tc-controls > .ra-sync-glow ~ .ra-settings-bar {
  flex: 0 1 auto;
}
.ra-tc-controls > .ra-card {
  flex: 1 1 100%; margin-bottom: 0;
}
.ra-tc-controls > .ra-tc-partner-row {
  margin-bottom: 0; flex: 0 0 auto; padding: 0;
  background: var(--ra-bg-secondary);
  border: 1px solid var(--ra-border); border-radius: var(--ra-radius);
  padding: 8px 14px;
}
@media (max-width: 768px) {
  .ra-tc-controls { flex-direction: column; gap: 6px; }
  .ra-tc-controls > .ra-settings-bar { flex: 1 1 100%; }
  .ra-tc-controls > .ra-settings-bar:has(.ra-toggle) { flex-wrap: nowrap !important; }
  .ra-tc-controls > .ra-tc-partner-row { flex: 1 1 100%; }
  .ra-settings-bar #ra-screenshot-wrap { margin-left: auto; flex-shrink: 0; }
  .ra-settings-bar .ra-ss-btn { padding: 6px 8px !important; font-size: 10px !important; gap: 3px !important; border-radius: 6px !important; }
  .ra-settings-bar .ra-ss-btn svg { width: 16px !important; height: 16px !important; }
}

/* ─── Glow sync input — E4 seamless bar ─── */
.ra-sync-glow {
  padding: 0 !important;
  border-radius: 10px !important;
  border: 1.5px solid rgba(6,182,212,0.25) !important;
  transition: border-color 0.25s, box-shadow 0.25s;
  background: rgba(15,20,35,0.9) !important;
  box-shadow: 0 0 8px rgba(6,182,212,0.06);
  overflow: hidden;
  display: flex !important;
  align-items: center !important;
  gap: 0 !important;
  vertical-align: top;
  flex: 1 1 auto;
  width: 100%;
  min-width: 200px;
  margin-right: 12px !important;
}
.ra-sync-glow:focus-within {
  border-color: rgba(6,182,212,0.55) !important;
  box-shadow: 0 0 24px rgba(6,182,212,0.12);
}
.ra-sync-icon {
  font-size: 14px;
  padding: 0 4px 0 12px;
  flex-shrink: 0;
  line-height: 1;
}
.ra-sync-glow .ra-sync-input {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 12px 8px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #fff !important;
  min-width: 0;
}
.ra-sync-glow .ra-sync-input:focus {
  box-shadow: none !important;
  border: none !important;
}
.ra-sync-glow .ra-sync-input::placeholder {
  color: rgba(255,255,255,0.5);
  font-weight: 400;
}
.ra-sync-glow .ra-sync-btn {
  border-radius: 8px !important;
  padding: 9px 20px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  margin: 4px 4px 4px 0 !important;
  letter-spacing: 0.02em;
  flex-shrink: 0;
  background: linear-gradient(135deg, #06b6d4 0%, #06b6d4 100%) !important;
  border: none !important;
}
.ra-sync-glow .ra-sync-btn:hover {
  background: linear-gradient(135deg, #06b6d4 0%, #06b6d4 100%) !important;
}
@media (max-width: 768px) {
  .ra-sync-glow .ra-sync-input { padding: 10px 6px !important; font-size: 12px !important; }
  .ra-sync-glow .ra-sync-btn { padding: 8px 14px !important; font-size: 12px !important; }
  .ra-sync-icon { padding: 0 3px 0 10px; font-size: 12px; }
}

/* ─── Partner picker highlight when no partner selected ─── */
.ra-tc-partner-highlight {
  border: 1.5px solid rgba(6,182,212,0.4) !important;
  background: rgba(6,182,212,0.06) !important;
  border-radius: 12px !important;
  animation: ra-partner-pulse 2s ease-in-out infinite;
}
.ra-tc-partner-highlight .ra-tc-partner-label {
  color: #22d3ee !important;
}
.ra-tc-partner-highlight .ra-tc-partner-trigger {
  border-color: rgba(6,182,212,0.4) !important;
  background: rgba(6,182,212,0.08) !important;
}
@keyframes ra-partner-pulse {
  0%, 100% { box-shadow: 0 0 8px rgba(6,182,212,0.1); }
  50% { box-shadow: 0 0 20px rgba(6,182,212,0.2); }
}

/* ═══ Trade Report Mobile ═══ */
@media (max-width: 768px) {
  .ra-report {
    border-radius: 12px !important;
    padding: 0 !important;
    margin-top: 12px !important;
    border: none !important;
    overflow: hidden;
  }
  .ra-report-header {
    position: sticky !important; top: 0; z-index: 10;
    background: rgba(10,14,23,0.95) !important;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    padding: 10px 14px !important;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    margin-bottom: 0 !important;
  }
  .ra-report-header > div:first-child {
    flex-wrap: wrap !important; gap: 8px !important;
    margin-bottom: 0 !important;
  }
  .ra-rh-verdict {
    padding: 14px 14px 10px !important;
    margin-bottom: 8px !important;
    background: linear-gradient(180deg, rgba(6,182,212,0.04) 0%, transparent 100%);
  }
  .ra-rh-verdict > div:first-child {
    font-size: 24px !important;
  }
  .ra-rh-assets {
    flex-direction: row !important; gap: 0 !important;
    margin: 0 10px 8px !important; border-radius: 10px !important;
    overflow: hidden; border: 1px solid rgba(255,255,255,0.06) !important;
  }
  .ra-rh-assets > div {
    border-radius: 0 !important; border: none !important;
    padding: 10px 12px !important;
  }
  .ra-rh-assets > div + div {
    border-left: 1px solid rgba(255,255,255,0.06) !important;
  }
  .ra-report-section {
    margin: 0 10px 8px !important;
    padding: 12px 12px !important;
    border-radius: 10px !important;
  }
  .ra-report-section > div:first-child {
    margin-bottom: 10px !important;
  }
  /* Recharts responsive */
  .ra-report .recharts-responsive-container {
    max-width: 100% !important;
  }
  .ra-report .recharts-wrapper {
    max-width: 100% !important;
  }
  /* Force any fixed-width containers to be fluid */
  .ra-report [style*="width: 600"],
  .ra-report [style*="width: 700"],
  .ra-report [style*="width: 800"],
  .ra-report [style*="width: 500"],
  .ra-report [style*="minWidth: 500"],
  .ra-report [style*="minWidth: 600"] {
    width: 100% !important;
    min-width: 0 !important;
  }
  /* Buttons more compact on mobile */
  .ra-rh-share {
    padding: 5px 10px !important; font-size: 11px !important;
  }
}

/* ═══ Trade Report — Mobile Layout (Card Stack / Option A) ═══ */
@media (max-width: 768px) {
  /* Sticky header */
  .ra-report-header {
    position: sticky !important;
    top: 0;
    z-index: 10;
    background: rgba(10,14,23,0.95) !important;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    padding: 10px 14px !important;
    margin-bottom: 0 !important;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  .ra-rh-top { margin-bottom: 0 !important; flex-wrap: wrap; gap: 8px !important; }
  .ra-rh-title { font-size: 14px !important; }
  .ra-rh-share { padding: 5px 12px !important; font-size: 11px !important; }
  .ra-rh-verdict {
    margin: 8px 0 !important;
    padding: 8px 0;
    border-bottom: 1px solid rgba(255,255,255,0.04);
  }
  .ra-rh-verdict > div:first-child { font-size: 22px !important; }

  /* Asset columns — compact but side-by-side */
  .ra-rh-assets { gap: 6px !important; margin-bottom: 4px !important; }
  .ra-rh-assets > div { padding: 10px 10px !important; border-radius: 8px !important; }

  /* Section cards — edge-to-edge, no rounded corners */
  .ra-report .ra-report-section {
    margin: 0 !important;
    margin-bottom: 2px !important;
    border-radius: 0 !important;
    padding: 12px 14px !important;
    border-left: none !important;
    border-right: none !important;
  }
  .ra-report-section > div:first-child { margin-bottom: 10px !important; }

  /* Charts responsive */
  .ra-report-section svg { max-width: 100%; height: auto; }

  /* Grids compact */
  .ra-report-section div[style*="display: grid"] { gap: 6px !important; }

  /* Narrative text smaller */
  .ra-report-section div[style*="lineHeight: 1.5"],
  .ra-report-section div[style*="lineHeight: 1.6"] { font-size: 11px !important; }
}

/* Small phones (iPhone SE, etc.) */
@media (max-width: 390px) {
  .ra-report-header { padding: 8px 10px !important; }
  .ra-report-section { padding: 10px 10px !important; }
  .ra-rh-assets { flex-direction: column !important; }
  .ra-rh-verdict > div:first-child { font-size: 20px !important; }
}

/* ═══ Report loading animations ═══ */
@keyframes ra-skeleton-pulse {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 0.8; }
}
@keyframes ra-fade-in {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ═══ Synced league bar — mobile compact ═══ */
@media (max-width: 768px) {
  .ra-settings-bar .ra-sync-settings {
    flex-basis: 100%;
    order: 10;
    font-size: 10px !important;
    margin-top: 2px;
  }
  .ra-settings-bar .ra-sync-meta {
    margin-left: auto !important;
  }
  .ra-sync-username {
    display: none !important;
  }
  .ra-settings-bar > button:first-child {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 200px;
    min-width: 0;
  }
}

/* ═══ Prevent iOS Safari auto-zoom on input focus ═══ */
@media (max-width: 768px) {
  .ra-input,
  .ra-tc-split-panel .ra-input,
  .ra-search-container .ra-input,
  .ra-sync-glow .ra-sync-input,
  .ra-tc-partner-trigger,
  select.ra-select {
    font-size: 16px !important;
  }
}

/* ═══ Competitive Impact — mobile fit ═══ */
@media (max-width: 768px) {
  /* Top 3 cards: scale down to fit 3-across */
  .ra-comp-impact-cards {
    gap: 4px !important;
  }
  .ra-comp-impact-cards > div {
    padding: 10px 5px !important;
    min-width: 0;
    zoom: 0.82;
  }

  /* Bottom 5 position cards: horizontal scroll */
  .ra-comp-pos-cards {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom: 4px;
  }
  .ra-comp-pos-cards > div {
    min-width: 90px;
    flex-shrink: 0;
    scroll-snap-align: start;
  }
}
@media (max-width: 390px) {
  .ra-comp-impact-cards > div { zoom: 0.72; padding: 8px 4px !important; }
  .ra-comp-pos-cards > div { min-width: 80px; }
}

/* ═══ Lineup Impact — mobile: show only user lineup ═══ */
@media (max-width: 768px) {
  .ra-lineup-grid {
    grid-template-columns: 1fr !important;
  }
  /* In a 3-col grid, hide columns 2 (divider) and 3 (partner) */
  .ra-lineup-grid > :nth-child(3n+2),
  .ra-lineup-grid > :nth-child(3n) {
    display: none !important;
  }
}

/* ═══ Injury Risk — mobile: stack body map below summary ═══ */
@media (max-width: 768px) {
  .ra-inj-panel-row {
    flex-direction: column !important;
    gap: 12px !important;
  }
  .ra-inj-panel-body {
    width: 100% !important;
    flex-direction: row !important;
    flex-wrap: wrap;
    justify-content: center;
    padding: 12px !important;
  }
  /* Scale the SVG down */
  .ra-inj-panel-body svg {
    max-width: 140px;
    height: auto;
  }
}

/* ═══ Comparable Trades — mobile: single column ═══ */
@media (max-width: 768px) {
  .ra-comp-trades-grid {
    grid-template-columns: 1fr !important;
    gap: 6px !important;
  }
}

/* ═══ Injury Timeline cards — mobile: stack right side below ═══ */
@media (max-width: 768px) {
  .ra-inj-timeline-card {
    flex-wrap: wrap !important;
    gap: 6px !important;
    padding: 10px 12px !important;
  }
  .ra-inj-timeline-mid {
    flex-basis: calc(100% - 26px) !important;
  }
  .ra-inj-timeline-right {
    flex-basis: 100% !important;
    text-align: left !important;
    display: flex;
    gap: 8px;
    align-items: center;
    padding-left: 22px;
    border-top: 1px solid rgba(255,255,255,0.04);
    padding-top: 6px;
  }
}

/* ═══ Fit labels — hide on mobile ═══ */
@media (max-width: 768px) {
  .ra-fit-label {
    display: none !important;
  }
}

/* ═══ Injury Panel — mobile: tighten padding ═══ */
@media (max-width: 768px) {
  .ra-inj-player-panel {
    padding: 10px 8px !important;
  }
  .ra-inj-summary-card {
    padding: 12px 10px !important;
    margin-bottom: 10px !important;
  }
  .ra-inj-stat-row {
    gap: 6px !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
  }
  .ra-inj-stat-row > div {
    min-width: 0 !important;
    padding: 8px 6px !important;
  }
  .ra-inj-selector {
    gap: 4px !important;
    padding: 4px !important;
  }
  .ra-inj-selector > button {
    padding: 8px 6px !important;
    gap: 6px !important;
  }
}

/* ═══ Report Header — mobile: assets tighter ═══ */
@media (max-width: 768px) {
  .ra-rh-assets {
    gap: 6px !important;
    flex-direction: column !important;
  }
  .ra-rh-assets > div {
    padding: 8px 10px !important;
    border-radius: 8px !important;
  }
  .ra-rh-asset-row { gap: 4px !important; }
  .ra-rh-asset-age { display: none !important; }

  /* Pre-NFL cards: stack label above description */
  .ra-inj-prenfl-card {
    flex-wrap: wrap !important;
    gap: 6px !important;
    padding: 8px 10px !important;
  }
  .ra-inj-prenfl-card > div:first-child {
    font-size: 10px !important;
    padding: 2px 6px !important;
  }
  .ra-inj-prenfl-card > div:nth-child(2) {
    flex-basis: 100% !important;
    order: 3;
  }
  .ra-inj-prenfl-card > span:last-child {
    font-size: 10px !important;
    padding: 2px 6px !important;
  }
}

/* ═══ Trade calc chips — hide pos rank on mobile ═══ */
@media (max-width: 768px) {
  .ra-tc-ac-rank { display: none !important; }
}

/* ═══ Rankings — rank badge + pagination ═══ */
.ra-rank-badge {
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
  font-family: var(--ra-font-mono, monospace);
  letter-spacing: 0.02em;
}
.ra-pagination {
  flex-wrap: wrap;
  justify-content: center;
}
.ra-pagination .ra-btn-sm {
  padding: 4px 10px !important;
  font-size: 12px !important;
}
@media (max-width: 768px) {
  .ra-pagination .ra-btn-sm {
    padding: 4px 8px !important;
    font-size: 11px !important;
    min-width: 32px !important;
  }
}

/* ═══ Player page — full-bleed on mobile ═══ */
@media (max-width: 768px) {
  .ra-player-page-wrap,
  .ra-player-page-wrap .ra-container,
  .ra-player-page-wrap > .ra-container {
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
    box-sizing: border-box;
  }
}
@media (max-width: 768px) {
  .ra-player-page {
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
  }
  .ra-player-page .ra-container {
    padding-left: 0 !important;
    padding-right: 0 !important;
    max-width: 100% !important;
  }
}

/* ═══ Injury section — body map stacks on top on mobile ═══ */
@media (max-width: 700px) {
  .ra-injury-body-row {
    flex-direction: column-reverse !important;
  }
  .ra-injury-body-row .ra-injury-body-map {
    width: 100% !important;
    flex-shrink: 1 !important;
  }
}

/* ═══ Player page sections — full bleed on mobile ═══ */
@media (max-width: 700px) {
  .ra-player-page .ra-section-block {
    border-radius: 0 !important;
    border-left: none !important;
    border-right: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}

/* ═══ Mobile: text +1px, emojis -20% ═══ */
@media (max-width: 700px) {
  .ra-player-page .ra-container {
    zoom: 1.08;
  }
  .ra-player-page .ra-section-icon {
    font-size: 14px !important;
    margin-right: 8px !important;
  }
}



/* ═══ Player hero CTAs — desktop inline, mobile below rank strip ═══ */
.ra-player-cta-mobile { display: none; }
.ra-player-cta-desktop { display: block; }

@media (max-width: 700px) {
  .ra-player-cta-mobile { display: block; }
  .ra-player-cta-desktop { display: none; }
}

/* ═══════════════════════════════════════════════════════════════════
   CONNECT BAR STANDARDIZATION — v2.81
   ═══════════════════════════════════════════════════════════════════ */

/* ─── Prominent connect CTA on league-required pages (unconnected) ─── */
[data-league-required] .ra-sync-glow {
  width: 100% !important;
  max-width: 560px !important;
  min-width: 0 !important;
  max-height: none !important;
  margin: 0 auto 16px !important;
  padding: 0 !important;
  border-radius: 14px !important;
  border: 2px solid rgba(6,182,212,0.35) !important;
  background: linear-gradient(135deg, rgba(15,20,40,0.95) 0%, rgba(30,20,60,0.9) 100%) !important;
  box-shadow: 0 0 24px rgba(6,182,212,0.10), 0 4px 12px rgba(0,0,0,0.3) !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 0 !important;
  overflow: visible !important;
  display: flex !important;
}
[data-league-required] .ra-sync-glow .ra-sync-icon {
  display: none !important;
}
[data-league-required] .ra-sync-glow .ra-sync-input {
  padding: 16px 20px !important;
  font-size: 16px !important;
  text-align: center !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  max-width: none !important;
  width: 100% !important;
}
[data-league-required] .ra-sync-glow .ra-sync-input::placeholder {
  color: rgba(255,255,255,0.45);
  font-weight: 400;
}
[data-league-required] .ra-sync-glow .ra-sync-btn {
  margin: 12px 16px 16px !important;
  padding: 14px 32px !important;
  font-size: 15px !important;
  border-radius: 10px !important;
  letter-spacing: 0.03em;
}
/* Also style the "Select League" card when it appears on league-required pages */
[data-league-required] .ra-tc-controls > .ra-sync-glow {
  max-width: 560px !important;
}

/* ─── Connected state bar — keep normal on all pages ─── */
[data-league-required] .ra-settings-bar:not(.ra-sync-glow) {
  width: 100%;
  margin-right: 0;
}

/* ─── League History quick-connect pills ─── */
.ra-league-history {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 8px 0;
  align-items: center;
}
.ra-league-history-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--ra-text-muted, #94a3b8);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-right: 4px;
  white-space: nowrap;
}
.ra-league-history-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 12px;
  border-radius: 20px;
  border: 1px solid rgba(6,182,212,0.25);
  background: rgba(6,182,212,0.08);
  color: #a5f3fc;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
  font-family: inherit;
}
.ra-league-history-btn:hover {
  background: rgba(6,182,212,0.18);
  border-color: rgba(6,182,212,0.45);
  color: #cffafe;
}
.ra-league-history-btn .ra-lh-meta {
  font-size: 10px;
  color: var(--ra-text-muted, #94a3b8);
  font-weight: 400;
}
/* Prominent version: centered, larger */
[data-league-required] .ra-league-history {
  justify-content: center;
  padding: 0 20px 14px;
}
[data-league-required] .ra-league-history-btn {
  padding: 7px 16px;
  font-size: 14px;
  border-radius: 10px;
}

/* ─── Prominent header (injected as sibling before glow bar) ─── */
.ra-sync-prominent-header {
  text-align: center;
  padding: 20px 20px 12px;
}
.ra-sync-prominent-header .ra-sync-prompt-icon {
  font-size: 28px;
  margin-bottom: 8px;
  display: block;
}
.ra-sync-prominent-header .ra-sync-prompt-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--ra-text-primary, #e2e8f0);
  margin-bottom: 0;
}
/* Hide header when user clicks into the input */
[data-league-required]:has(.ra-sync-input:focus) .ra-sync-prominent-header {
  display: none;
}
/* Hide redundant React empty-state cards that sit next to the unconnected glow bar.
   When connected, React replaces glow with .ra-settings-bar, so this rule no longer matches. */
[data-league-required] .ra-sync-glow ~ .ra-card {
  display: none !important;
}

/* ─── Mobile fixes ─── */
@media (max-width: 768px) {
  .ra-sync-glow {
    display: none !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
  .ra-sync-glow .ra-sync-input {
    max-width: none !important;
    flex: 1 !important;
    min-width: 0 !important;
  }
  .ra-tc-controls {
    flex-direction: column !important;
    gap: 8px !important;
  }
  .ra-tc-controls > .ra-sync-glow {
    min-width: 0 !important;
    width: 100% !important;
  }
  .ra-settings-bar {
    flex-wrap: wrap !important;
    width: 100% !important;
    margin-right: 0 !important;
  }
  /* Prominent mode: tighten spacing on small screens */
  [data-league-required] .ra-sync-glow .ra-sync-input {
    padding: 14px 16px !important;
    font-size: 16px !important;
  }
  [data-league-required] .ra-sync-glow .ra-sync-btn {
    margin: 10px 12px 14px !important;
    padding: 12px 24px !important;
    font-size: 14px !important;
  }
  .ra-sync-prominent-header {
    padding: 16px 16px 8px;
  }
  .ra-sync-prominent-header .ra-sync-prompt-title { font-size: 15px; }
}

/* ─── Weekly Recap connect — match shared SyncBar look ─── */
.ra-rc-connect-v2 {
  background: rgba(15,20,35,0.9);
  border: 1.5px solid rgba(6,182,212,0.25);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 16px;
  transition: border-color 0.25s, box-shadow 0.25s;
}
.ra-rc-connect-v2:focus-within {
  border-color: rgba(6,182,212,0.55);
  box-shadow: 0 0 24px rgba(6,182,212,0.12);
}
.ra-rc-connect-v2 .ra-rc-input-row {
  display: flex;
  align-items: center;
  gap: 0;
}
.ra-rc-connect-v2 .ra-rc-icon {
  font-size: 14px;
  padding: 0 4px 0 12px;
  flex-shrink: 0;
  line-height: 1;
}
.ra-rc-connect-v2 input[type="text"] {
  background: transparent !important;
  border: none !important;
  padding: 12px 8px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #fff !important;
  flex: 1;
  min-width: 0;
  outline: none !important;
  box-shadow: none !important;
}
.ra-rc-connect-v2 input::placeholder { color: rgba(255,255,255,0.4); font-weight: 400; }
.ra-rc-connect-v2 select {
  background: transparent !important;
  border: none !important;
  padding: 12px 8px !important;
  font-size: 14px !important;
  color: #e2e8f0 !important;
  flex: 1;
  min-width: 0;
  outline: none !important;
  -webkit-appearance: none;
  appearance: none;
}
.ra-rc-connect-v2 select option { background: #1a1f2e; color: #e2e8f0; }
.ra-rc-connect-v2 .ra-rc-btn-connect {
  border-radius: 8px !important;
  padding: 9px 20px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  margin: 4px 4px 4px 0 !important;
  flex-shrink: 0;
  background: linear-gradient(135deg, #06b6d4 0%, #06b6d4 100%) !important;
  border: none !important;
  color: #fff !important;
  cursor: pointer;
  letter-spacing: 0.02em;
}
.ra-rc-connect-v2 .ra-rc-btn-connect:hover { background: linear-gradient(135deg, #06b6d4 0%, #06b6d4 100%) !important; }
.ra-rc-connect-v2 .ra-rc-btn-connect:disabled { opacity: 0.5; cursor: not-allowed; }
@media (max-width: 700px) {
  .ra-rc-connect-v2 input[type="text"] { font-size: 16px !important; padding: 10px 6px !important; }
  .ra-rc-connect-v2 select { font-size: 16px !important; }
  .ra-rc-connect-v2 .ra-rc-btn-connect { padding: 8px 14px !important; font-size: 12px !important; }
  .ra-rc-connect-v2 .ra-rc-icon { padding: 0 3px 0 10px; font-size: 12px; }
}

/* ===== TOOL PAGE HEADER — E1 Centered ===== */
.ra-tool-header {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
  padding: 20px 16px 16px;
}
.ra-tool-header-title {
  font-size: 26px;
  font-weight: 800;
  color: #f1f5f9;
  letter-spacing: -.6px;
  margin: 0;
  line-height: 1.2;
}
.ra-tool-header-sub {
  font-size: 15px;
  color: #94a3b8;
  line-height: 1.55;
  margin: 6px auto 0;
}
@media (max-width: 768px) {
  .ra-tool-header { padding: 16px 16px 12px; }
  .ra-tool-header-title { font-size: 21px; }
  .ra-tool-header-sub { font-size: 14px; }
}

/* ═══ Injury Compare leaderboard — mobile fix ═══ */
@media (max-width: 700px) {
  /* Collapse Grade (3rd) and Score (4th) columns to 0 width */
  #ra-injury-compare-app .ra-ic-lb-row {
    grid-template-columns: 22px 1fr 0 0 48px 48px 34px !important;
    gap: 2px !important;
    padding: 10px 10px !important;
  }
  #ra-injury-compare-app .ra-ic-lb-row > :nth-child(3),
  #ra-injury-compare-app .ra-ic-lb-row > :nth-child(4) {
    overflow: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
    font-size: 0 !important;
    line-height: 0 !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }
  /* Per year header: nowrap so it bleeds over the + column instead of wrapping */
  #ra-injury-compare-app .ra-ic-lb-row > :nth-child(6) {
    white-space: nowrap !important;
    overflow: visible !important;
  }
  /* Player name: prevent vertical stacking of metadata */
  #ra-injury-compare-app .ra-ic-lb-meta {
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
  /* Compare button: just show "+" */
  #ra-injury-compare-app .ra-ic-lb-row > :nth-child(7) {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
  #ra-injury-compare-app .ra-ic-lb-row > :nth-child(7) button {
    font-size: 0px !important;
    padding: 5px 8px !important;
    min-width: 0 !important;
    line-height: 1 !important;
  }
  #ra-injury-compare-app .ra-ic-lb-row > :nth-child(7) button::before {
    content: '+';
    font-size: 15px;
    font-weight: 700;
  }
  /* Hide "Most games missed" tab — 3rd button in any flex row that contains tab buttons */
  #ra-injury-compare-app button:nth-child(3):last-child {
    display: none !important;
  }
}

/* Fix tooltip clipping caused by content-visibility:auto on table rows */
.ra-tooltip-popup {
  position: fixed !important;
  z-index: 99999 !important;
}
.ra-rankings-table tbody tr,
.ra-search-results .ra-player-row {
  content-visibility: visible;
  contain-intrinsic-size: none;
}

/* ===== SITE HEADER (moved from inline) ===== */
#ra-site-header{background:#0b0b12;position:relative;z-index:1000;border-bottom:1px solid rgba(255,255,255,0.06)}
.ra-hdr-main{display:flex;align-items:center;padding:0 24px;height:56px;max-width:1400px;margin:0 auto}
.ra-hdr-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.ra-hdr-logo img{height:40px;width:auto;display:block}
.ra-hdr-nav{display:flex;align-items:center;gap:2px;flex:1;justify-content:center;min-width:0}
.ra-hdr-nav-link{padding:6px 13px;font-size:14px;font-weight:500;color:rgba(255,255,255,0.4);text-decoration:none;border-radius:6px;transition:color 0.15s,background 0.15s;white-space:nowrap;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
.ra-hdr-nav-link:hover{color:rgba(255,255,255,0.85);background:rgba(255,255,255,0.05)}
.ra-hdr-nav-link.ra-hdr-active{color:#fff;background:rgba(6,182,212,0.18)}
.ra-hdr-right{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:auto}
.ra-hdr-conn-wrap{position:relative}
.ra-hdr-connect{padding:6px 16px;font-size:12px;font-weight:600;color:#a5f3fc;background:rgba(6,182,212,0.18);border:1px solid rgba(6,182,212,0.3);border-radius:7px;cursor:pointer;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;transition:all 0.15s;white-space:nowrap}
.ra-hdr-connect:hover{background:rgba(6,182,212,0.28);border-color:rgba(6,182,212,0.5);color:#cffafe}
.ra-hdr-connect.synced{background:rgba(6,182,212,0.12);border-color:rgba(6,182,212,0.25);color:#a5f3fc}
.ra-hdr-connect.synced:hover{background:rgba(6,182,212,0.2);border-color:rgba(6,182,212,0.4)}
.ra-hdr-dropdown{display:none;position:absolute;right:0;top:calc(100% + 8px);background:#14141f;border:1px solid rgba(255,255,255,0.08);border-radius:12px;padding:14px;min-width:280px;z-index:100;box-shadow:0 12px 40px rgba(0,0,0,0.5)}
.ra-hdr-dropdown.open{display:block}
.ra-hdr-dd-row{display:flex;gap:8px;align-items:center}
.ra-hdr-dd-input{flex:1;padding:10px 12px !important;font-size:13px !important;border-radius:8px !important;border:1px solid rgba(255,255,255,0.08) !important;background:#0b0b14 !important;color:#e2e8f0 !important;outline:none !important;font-family:inherit;box-sizing:border-box;transition:border-color 0.15s;height:auto !important;min-height:0 !important;line-height:normal !important}
.ra-hdr-dd-input:focus{border-color:rgba(6,182,212,0.4) !important;box-shadow:none !important;background:#0b0b14 !important}
.ra-hdr-dd-input::placeholder{color:rgba(255,255,255,0.2) !important}
.ra-hdr-dd-go{padding:10px 20px;font-size:13px;font-weight:600;border:none;border-radius:8px;background:#06b6d4;color:#fff;cursor:pointer;font-family:inherit;white-space:nowrap;flex-shrink:0;transition:opacity 0.15s}
.ra-hdr-dd-go:hover{opacity:0.9}
.ra-hdr-dd-go:disabled{opacity:0.5;cursor:not-allowed}
.ra-hdr-dd-hint{font-size:11px;color:rgba(255,255,255,0.2);margin-top:8px}
.ra-hdr-dd-history{display:none;margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,0.05)}
.ra-hdr-dd-history.has-items{display:block}
.ra-hdr-dd-history-label{font-size:10px;font-weight:600;color:rgba(255,255,255,0.2);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:6px}
.ra-hdr-dd-history-list{display:flex;flex-wrap:wrap;gap:4px}
.ra-hdr-dd-history-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;border:1px solid rgba(6,182,212,0.15);background:rgba(6,182,212,0.06);color:#67e8f9;font-size:11px;font-weight:500;cursor:pointer;font-family:inherit;transition:all 0.15s;white-space:nowrap}
.ra-hdr-dd-history-btn:hover{background:rgba(6,182,212,0.14);border-color:rgba(6,182,212,0.3);color:#a5f3fc}
.ra-hdr-dd-history-btn .hh-meta{color:rgba(255,255,255,0.2);font-weight:400;font-size:10px}
.ra-hdr-dd-error{font-size:11px;color:#f87171;margin-top:6px;display:none}
.ra-hdr-dd-label{font-size:11px;font-weight:600;color:rgba(255,255,255,0.25);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:10px}
.ra-hdr-dd-league{display:flex;flex-direction:column;gap:1px;padding:8px 10px;border-radius:6px;cursor:pointer;transition:background 0.1s;border:none;background:none;width:100%;text-align:left;font-family:inherit}
.ra-hdr-dd-league:hover{background:rgba(255,255,255,0.06)}
.ra-hdr-dd-league .lg-name{font-size:13px;font-weight:500;color:rgba(255,255,255,0.85)}
.ra-hdr-dd-league .lg-meta{font-size:11px;color:rgba(255,255,255,0.35)}
.ra-hdr-dd-back,.ra-hdr-dd-switch,.ra-hdr-dd-disconnect{width:100%;padding:8px;font-size:12px;border-radius:6px;cursor:pointer;font-family:inherit;border:none;margin-top:6px;font-weight:500;transition:background 0.15s}
.ra-hdr-dd-back{background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.5)}
.ra-hdr-dd-back:hover{background:rgba(255,255,255,0.1)}
.ra-hdr-dd-switch{background:rgba(6,182,212,0.15);color:#67e8f9}
.ra-hdr-dd-switch:hover{background:rgba(6,182,212,0.25)}
.ra-hdr-dd-disconnect{background:rgba(239,68,68,0.08);color:rgba(248,113,113,0.8)}
.ra-hdr-dd-disconnect:hover{background:rgba(239,68,68,0.15)}
.ra-hdr-dd-current{font-size:13px;font-weight:500;color:#a5f3fc;margin-bottom:8px;padding:4px 0}
.ra-hdr-dd-syncing{font-size:12px;color:#22d3ee;padding:8px 0}
.ra-mob-league{display:none}
.ra-mob-nav{display:none}
.ra-mob-link{padding:5px 11px;font-size:12px;font-weight:500;color:rgba(255,255,255,0.4);text-decoration:none;border-radius:6px;white-space:nowrap;transition:color 0.15s,background 0.15s;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
.ra-mob-link:hover,.ra-mob-link:active{color:rgba(255,255,255,0.8);background:rgba(255,255,255,0.05)}
.ra-mob-link.ra-mob-active{color:#fff;background:rgba(6,182,212,0.18)}
@media(min-width:901px){.ra-mob-nav{display:none!important}.ra-mob-league{display:none!important}.ra-mob-dropdown{display:none!important}}
@media(max-width:900px){
  .ra-hdr-nav{display:none}
  .ra-mob-nav{display:flex;flex-wrap:wrap;gap:4px;padding:4px 12px 8px;justify-content:center;border-top:1px solid rgba(255,255,255,0.04)}
  .ra-hdr-main{padding:0 16px;height:48px}
  .ra-hdr-logo img{height:32px}
  .ra-hdr-connect{font-size:11px;padding:5px 12px}
  .ra-hdr-dropdown{right:-16px;min-width:calc(100vw - 32px);max-width:320px}
  .ra-hdr-main.ra-mob-synced{justify-content:center}
  .ra-hdr-main.ra-mob-synced .ra-hdr-right{display:none}
  .ra-mob-league.ra-mob-league-show{display:flex;align-items:center;gap:6px;padding:5px 14px;background:rgba(6,182,212,0.04);border-top:1px solid rgba(6,182,212,0.08)}
  .ra-mob-league-dot{width:6px;height:6px;border-radius:50%;background:#22d3ee;flex-shrink:0}
  .ra-mob-league-name{font-size:11px;font-weight:500;color:#a5f3fc;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
  .ra-mob-league-switch{background:none;border:none;font-size:10px;color:rgba(255,255,255,0.3);cursor:pointer;font-family:inherit;flex-shrink:0;padding:2px 4px}
  .ra-mob-league-switch:hover{color:rgba(255,255,255,0.6)}
  .ra-mob-dropdown{display:none;padding:8px 14px 12px;background:rgba(6,182,212,0.02);border-bottom:1px solid rgba(6,182,212,0.06)}
  .ra-mob-dropdown.open{display:block}
  .ra-mob-dropdown .ra-hdr-dd-league{display:flex;flex-direction:column;gap:1px;padding:8px 10px;border-radius:6px;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:inherit}
  .ra-mob-dropdown .ra-hdr-dd-league:hover,.ra-mob-dropdown .ra-hdr-dd-league:active{background:rgba(255,255,255,0.04)}
  .ra-mob-dropdown .lg-name{font-size:13px;font-weight:500;color:rgba(255,255,255,0.85)}
  .ra-mob-dropdown .lg-meta{font-size:11px;color:rgba(255,255,255,0.35)}
  .ra-mob-dropdown .ra-mob-dd-disconnect{width:100%;padding:8px;font-size:12px;border-radius:6px;cursor:pointer;font-family:inherit;border:none;margin-top:6px;font-weight:500;background:rgba(239,68,68,0.08);color:rgba(248,113,113,0.8)}
  .ra-mob-dropdown .ra-hdr-dd-syncing{font-size:12px;color:#22d3ee;padding:8px 0}
}
@media(max-width:400px){
  .ra-mob-nav{gap:3px;padding:4px 8px 8px}
  .ra-mob-link{padding:4px 8px;font-size:11px}
}


/* ===== SITE FOOTER (moved from inline) ===== */
#ra-site-footer{background:#0b0b12;border-top:1px solid rgba(255,255,255,0.04);position:relative;z-index:100}
.ra-ftr-inner{max-width:1100px;margin:0 auto;padding:40px 40px 32px}
.ra-ftr-cols{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
.ra-ftr-label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.25);margin-bottom:14px;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
.ra-ftr-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px 28px}
.ra-ftr-grid.ra-ftr-grid-2{grid-template-columns:1fr 1fr}
.ra-ftr-link{font-size:13px;color:rgba(255,255,255,0.45);text-decoration:none;padding:3px 0;display:block;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;transition:color 0.15s}
.ra-ftr-link:hover{color:rgba(255,255,255,0.75)}
.ra-ftr-col-co{min-width:120px}
.ra-ftr-col-co .ra-ftr-label{margin-bottom:8px}
.ra-ftr-bottom{margin-top:28px;padding-top:20px;border-top:1px solid rgba(255,255,255,0.04);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.ra-ftr-tagline{font-size:12px;color:rgba(255,255,255,0.2);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
.ra-ftr-copy{font-size:11px;color:rgba(255,255,255,0.12);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
@media(max-width:768px){
  .ra-ftr-inner{padding:28px 24px 24px}
  .ra-ftr-cols{flex-direction:column;gap:24px}
  .ra-ftr-grid{grid-template-columns:1fr 1fr;gap:4px 20px}
  .ra-ftr-bottom{flex-direction:column;align-items:flex-start;gap:4px}
}

/* ===== CONTACT FORM 7 — dark theme ===== */
.wpcf7 {
  max-width: 560px;
  margin: 0 auto;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}
.wpcf7 label {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: rgba(255,255,255,0.5);
  margin-bottom: 6px;
  letter-spacing: 0.02em;
}
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="url"],
.wpcf7 input[type="tel"],
.wpcf7 textarea {
  width: 100%;
  padding: 12px 14px;
  font-size: 15px;
  font-family: inherit;
  color: #e2e8f0;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px;
  outline: none;
  transition: border-color 0.15s, background 0.15s;
  box-sizing: border-box;
}
.wpcf7 input[type="text"]:focus,
.wpcf7 input[type="email"]:focus,
.wpcf7 input[type="url"]:focus,
.wpcf7 input[type="tel"]:focus,
.wpcf7 textarea:focus {
  border-color: rgba(6,182,212,0.5);
  background: rgba(255,255,255,0.06);
}
.wpcf7 input::placeholder,
.wpcf7 textarea::placeholder {
  color: rgba(255,255,255,0.35);
}
.wpcf7 textarea {
  min-height: 140px;
  resize: vertical;
}
.wpcf7 p {
  margin: 0 0 20px;
}
.wpcf7 input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 32px;
  font-size: 15px;
  font-weight: 700;
  font-family: inherit;
  color: #fff;
  background: linear-gradient(135deg, #06b6d4, #0891b2);
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.1s;
  letter-spacing: 0.02em;
}
.wpcf7 input[type="submit"]:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}
.wpcf7 input[type="submit"]:active {
  transform: scale(0.98);
}
.wpcf7-response-output {
  border-radius: 10px !important;
  padding: 12px 16px !important;
  font-size: 14px !important;
  margin: 16px 0 0 !important;
}
.wpcf7-not-valid-tip {
  font-size: 12px;
  color: #f87171;
  margin-top: 4px;
}
.wpcf7 .wpcf7-spinner {
  margin-left: 12px;
}

/* Trade Database: strip L6 league bar's own card styling when inside unified card */
#ra-trade-database-app .ra-settings-bar {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
  min-height: auto !important;
}
#ra-trade-database-app .ra-sync-glow {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
#ra-trade-database-app .ra-sync-settings {
  display: none !important;
}

/* Trade Database: compact connect bar when unsynced */
#ra-trade-database-app .ra-sync-glow .ra-sync-icon {
  font-size: 12px !important;
}
#ra-trade-database-app .ra-sync-glow .ra-sync-input {
  font-size: 12px !important;
  padding: 6px 10px !important;
  height: auto !important;
  min-height: 0 !important;
}
#ra-trade-database-app .ra-sync-glow .ra-sync-btn {
  font-size: 11px !important;
  padding: 5px 14px !important;
}

/* Trade Database: restore card styling for league selection view */
#ra-trade-database-app .ra-card {
  background: var(--ra-bg-card) !important;
  border: 1px solid var(--ra-border) !important;
  padding: 16px !important;
  border-radius: var(--ra-radius) !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* League Hub sub-tabs: responsive Head-to-Head / H2H */
.ra-htab-short { display: none; }
@media (max-width: 768px) {
  .ra-htab-full { display: none; }
  .ra-htab-short { display: inline; }
}
