/* ============================================================
   CONCEPTS PAGE
   ============================================================ */

/* --- Scarcity Toggle Row --- */
.concept-scarcity-row {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-top: 24px;
}

.concept-scarcity-toggle {
  display: flex;
  gap: 8px;
}

.concept-refresh-btn {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  font-family: var(--font);
  font-size: 0.65rem;
  font-weight: 700;
  padding: 6px 12px;
  cursor: pointer;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  transition: border-color 0.15s, color 0.15s;
  position: relative;
  overflow: hidden;
}

.concept-refresh-btn:hover {
  border-color: var(--primary);
  color: var(--primary);
}

.concept-refresh-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Pending state — fills upward to signal the user should click */
@keyframes concept-refresh-fill {
  from { background-size: 100% 0%; }
  to   { background-size: 100% 100%; }
}
@keyframes concept-refresh-glow {
  0%, 100% { box-shadow: 0 0 4px rgba(255, 255, 255, 0.1); }
  50%       { box-shadow: 0 0 12px rgba(255, 255, 255, 0.35); }
}

.concept-refresh-btn--pending {
  border-color: rgba(255, 255, 255, 0.75) !important;
  color: #ffffff !important;
  background-image: linear-gradient(0deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.18));
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: 100% 0%;
  animation:
    concept-refresh-fill 0.9s cubic-bezier(0.22, 1, 0.36, 1) forwards,
    concept-refresh-glow 1.4s 0.9s ease-in-out infinite;
}

.concept-refresh-btn--pending:hover {
  border-color: #ffffff !important;
  color: #ffffff !important;
}

.concept-scarcity-btn {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  font-family: var(--font);
  font-size: 0.7rem;
  font-weight: 700;
  padding: 6px 14px;
  cursor: pointer;
  letter-spacing: 0.5px;
  transition: all 0.15s;
}

.concept-scarcity-btn:hover {
  border-color: var(--scarcity-color);
  color: var(--scarcity-color);
}

.concept-scarcity-btn.active {
  border-color: var(--scarcity-color);
  color: var(--scarcity-color);
  background: color-mix(in srgb, var(--scarcity-color) 10%, transparent);
}

/* --- Lineup wrapper (slots + summary panel side-by-side) --- */
.concept-lineup-wrapper {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-top: 20px;
}

/* --- Lineup row --- */
.concept-lineup {
  display: flex;
  justify-content: center;
  gap: 16px;
}

.concept-lineup-wrapper {
  transition: opacity 0.2s ease;
}

.concept-lineup--loading {
  opacity: 0.4;
  pointer-events: none;
}

/* --- Card base --- */
.concept-card {
  --card-scarcity-color: var(--rarity-limited);
  width: 100%;
  aspect-ratio: 5 / 8;
  border: 2px solid var(--card-scarcity-color);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: transparent;
  box-shadow: inset 0 0 20px color-mix(in srgb, var(--card-scarcity-color) 8%, transparent),
    inset 0 0 6px color-mix(in srgb, var(--card-scarcity-color) 4%, transparent);
  position: relative;
  cursor: pointer;
  transition: border-color 0.15s, box-shadow 0.15s;
}

/* Scarcity-driven card colors */
.concept-lineup[data-scarcity="rare"] .concept-card { --card-scarcity-color: var(--rarity-rare); }
.concept-lineup[data-scarcity="super_rare"] .concept-card { --card-scarcity-color: var(--rarity-sr); }
.concept-lineup[data-scarcity="unique"] .concept-card { --card-scarcity-color: var(--rarity-unique); }

.concept-card:hover {
  border-color: #fff;
  box-shadow: inset 0 0 20px rgba(255, 255, 255, 0.06),
    0 0 12px color-mix(in srgb, var(--card-scarcity-color) 10%, transparent);
}

/* --- Position label --- */
.concept-card__label {
  position: absolute;
  top: 10px;
  left: 0;
  right: 0;
  text-align: center;
  font-size: 0.65rem;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 2px;
}

/* --- Empty state --- */
.concept-card__empty {
  width: 56px;
  height: 56px;
  border: 2px solid var(--muted);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  color: var(--muted);
  line-height: 1;
}

/* --- Filled state --- */
.concept-card--filled {
  background: rgba(255, 176, 0, 0.03);
}

/* --- Card image state (full card art from POST) --- */
.concept-card--card-img {
  padding: 0;
  overflow: hidden;
  border-color: transparent;
  box-shadow: none;
  background: transparent;
}

.concept-card__card-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 10px;
}

.concept-card__remove {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--error);
  border: none;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  font-family: var(--font);
  opacity: 0;
  transition: opacity 0.15s;
}

.concept-card:hover .concept-card__remove {
  opacity: 1;
}

/* --- Slot wrapper (card + controls) --- */
.concept-slot {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1 1 0;
  min-width: 0;
  max-width: 225px;
}

.concept-slot__controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  margin-top: 4px;
  padding: 10px 25px;
}

/* Bonus % input (left side) */
.concept-slot__bonus {
  display: flex;
  align-items: center;
  height: 32px;
}

.concept-slot__bonus-input {
  width: 48px;
  height: 100%;
  background: var(--hover-bg);
  border: 1px solid var(--border);
  border-radius: 4px 0 0 4px;
  padding: 0 4px;
  font-family: var(--font);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--primary);
  text-align: center;
  outline: none;
  -moz-appearance: textfield;
  transition: border-color 0.15s;
}

.concept-slot__bonus-input::-webkit-inner-spin-button,
.concept-slot__bonus-input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.concept-slot__bonus-input:focus {
  border-color: var(--rarity-limited);
}

.concept-slot__bonus-pct {
  height: 100%;
  display: flex;
  align-items: center;
  padding: 0 6px;
  background: var(--hover-bg);
  border: 1px solid var(--border);
  border-left: none;
  border-radius: 0 4px 4px 0;
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 700;
}

/* Captain circle (right side) */
.concept-slot__captain {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: none;
  background: var(--hover-bg);
  color: var(--muted);
  font-family: var(--font);
  font-size: 1.3rem;
  font-weight: 900;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s;
}

.concept-slot__captain:hover {
  background: rgba(255, 176, 0, 0.15);
  color: var(--rarity-limited);
}

.concept-slot__captain.active {
  background: var(--rarity-limited);
  color: #000;
}

.concept-card__avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: contain;
  object-position: center bottom;
  margin-top: 28px;
  margin-bottom: 12px;
  background: var(--hover-bg);
}

.concept-card__player-name {
  font-size: 0.85rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 90%;
  margin-bottom: 4px;
}

.concept-card__player-meta {
  font-size: 0.7rem;
  color: var(--muted);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 90%;
  margin-bottom: 8px;
}

.concept-card__player-l10 {
  font-size: 1rem;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.06);
}

.concept-card__player-l10.score-perfect { color: var(--score-perfect); text-shadow: 0 0 8px rgba(255, 215, 0, 0.6); }
.concept-card__player-l10.score-elite { color: var(--score-elite); }
.concept-card__player-l10.score-great { color: var(--score-great); }
.concept-card__player-l10.score-good { color: var(--score-good); }
.concept-card__player-l10.score-ok { color: var(--score-ok); }
.concept-card__player-l10.score-poor { color: var(--score-poor); }
.concept-card__player-l10.score-terrible { color: var(--score-terrible); }

/* --- Score badges (below card) --- */
.concept-slot__badges {
  --pct-high: #00a749;
  --pct-mid: #d6b614;
  --pct-low: #dc1a0f;

  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 4px;
  background: var(--card-bg);
  border-radius: var(--card-radius);
  padding: 8px 12px;
  width: 100%;
}

.concept-badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.concept-badge__label {
  font-size: 0.6rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-weight: 700;
}

.concept-badge__value {
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1;
  width: 2.8rem;
  height: 2.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  color: #fff;
}

.concept-badge__bar {
  width: 100%;
  height: 3px;
  background: var(--hover-bg);
  border-radius: 2px;
  overflow: hidden;
}

.concept-badge__bar-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.3s ease;
}

.concept-badge__pct {
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--text-secondary);
}

.concept-badge--empty .concept-badge__value { background: var(--hover-bg); }
.concept-badge--perfect .concept-badge__value { background: linear-gradient(135deg, #ffd700, #fff4a3, #ffd700); background-size: 200% 200%; animation: perfectShimmer 2.5s ease-in-out infinite; box-shadow: 0 0 6px rgba(255, 215, 0, 0.5); color: #000; }
.concept-badge--elite .concept-badge__value { background: var(--score-elite); }
.concept-badge--great .concept-badge__value { background: var(--score-great); }
.concept-badge--good .concept-badge__value { background: var(--score-good); }
.concept-badge--ok .concept-badge__value { background: var(--score-ok); }
.concept-badge--poor .concept-badge__value { background: var(--score-poor); }
.concept-badge--terrible .concept-badge__value { background: var(--score-terrible); }

/* --- Price pills (below badges) --- */
.concept-slot__prices {
  display: flex;
  gap: 6px;
  width: 100%;
  margin-top: 4px;
}

.concept-price-pill {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  background: var(--card-bg);
  border-radius: var(--card-radius);
  padding: 8px 6px;
}

.concept-price-pill__label {
  font-size: 0.6rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 700;
}

.concept-price-pill__value {
  font-size: 0.85rem;
  font-weight: 700;
  white-space: nowrap;
}

/* --- Score chart (full-width below lineup) --- */
.concept-score-chart-section {
  margin-top: 12px;
}

.concept-score-chart-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}

.concept-all-played-toggle {
  padding: 4px 10px;
  border-radius: 12px;
  border: 1px solid var(--muted);
  background: transparent;
  color: var(--muted);
  font-family: "JetBrains Mono", monospace;
  font-size: 0.6rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.2s ease;
}

.concept-all-played-toggle:hover {
  border-color: var(--text);
  color: var(--text);
}

.concept-all-played-toggle.active {
  border-color: #00ff88;
  color: #00ff88;
  background: rgba(0, 255, 136, 0.08);
}

.concept-chart-lb-select {
  flex: 1;
  min-width: 0;
}

.concept-chart-lb-label {
  font-size: 0.65rem;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.concept-score-chart-title {
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
}

.concept-score-chart-wrap {
  width: 100%;
  height: 420px;
  background: var(--card-bg);
  border-radius: var(--card-radius);
  padding: 12px 10px 6px;
}

.concept-score-chart-wrap canvas {
  width: 100% !important;
  height: 100% !important;
}

/* --- Summary panel (right of cards) --- */
.concept-summary-panel {
  width: 225px;
  flex-shrink: 0;
  background: var(--card-bg);
  border-radius: var(--card-radius);
  padding: 16px 10px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.concept-summary__title {
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  text-align: center;
  margin-bottom: 12px;
}

.concept-summary__cards {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.concept-summary__card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  background: var(--hover-bg);
  border-radius: var(--card-radius);
  padding: 14px 10px;
}

.concept-summary__value {
  font-size: 1.3rem;
  font-weight: 700;
}

.concept-summary__label {
  font-size: 0.65rem;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.concept-summary__note {
  font-size: 0.6rem;
  color: var(--muted);
  margin-top: 2px;
}

.concept-summary__pct {
  font-size: 0.85rem;
  font-weight: 400;
  color: var(--muted);
}

.concept-apply-power-btn {
  margin-top: 10px;
  width: 100%;
  padding: 8px 16px;
  border-radius: 20px;
  border: 1px solid var(--muted);
  background: transparent;
  color: var(--text);
  font-family: "JetBrains Mono", monospace;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.concept-apply-power-btn:hover {
  border-color: var(--text);
  background: rgba(255, 255, 255, 0.05);
}

.concept-apply-power-btn--pending {
  border-color: rgba(255, 255, 255, 0.75) !important;
  color: #ffffff !important;
  background-image: linear-gradient(0deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.18));
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: 100% 0%;
  animation:
    concept-refresh-fill 0.9s cubic-bezier(0.22, 1, 0.36, 1) forwards,
    concept-refresh-glow 1.4s 0.9s ease-in-out infinite;
}

.concept-apply-power-btn--pending:hover {
  border-color: #ffffff !important;
  color: #ffffff !important;
}

/* ============================================================
   DRAWER — Player Picker
   ============================================================ */

.concept-drawer-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.6);
  z-index: 1000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}

.concept-drawer-backdrop.active {
  opacity: 1;
  pointer-events: all;
}

.concept-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: 400px;
  height: 100%;
  background: var(--dropdown-bg);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.25s cubic-bezier(0.32, 0.72, 0, 1);
  z-index: 1001;
}

.concept-drawer-backdrop.active .concept-drawer {
  transform: translateX(0);
}

/* Drawer header */
.concept-drawer__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 20px 16px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.concept-drawer__title {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--rarity-limited);
  letter-spacing: 1.5px;
  text-transform: uppercase;
}

.concept-drawer__close {
  background: transparent;
  border: none;
  color: var(--muted);
  font-size: 1.5rem;
  cursor: pointer;
  line-height: 1;
  padding: 2px 6px;
  font-family: var(--font);
  transition: color 0.15s;
}

.concept-drawer__close:hover {
  color: var(--error);
}

/* Drawer search */
.concept-drawer__search-wrap {
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.concept-drawer__search {
  width: 100%;
  background: var(--input-bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 10px 14px;
  font-family: var(--font);
  font-size: 0.85rem;
  color: var(--primary);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
}

.concept-drawer__search::placeholder {
  color: var(--muted);
}

.concept-drawer__search:focus {
  border-color: var(--rarity-limited);
  box-shadow: var(--input-focus-glow);
  background: var(--input-focus-bg);
}

/* Drawer results */
.concept-drawer__results {
  flex: 1;
  overflow-y: auto;
  scrollbar-color: var(--muted) transparent;
}

.concept-drawer__hint {
  padding: 32px 20px;
  text-align: center;
  color: var(--muted);
  font-size: 0.8rem;
}

.concept-drawer__result {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 20px;
  cursor: pointer;
  transition: background 0.1s;
  border-bottom: 1px solid var(--divider);
}

.concept-drawer__result:hover {
  background: var(--hover-bg);
}

.concept-drawer__result-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  object-fit: contain;
  object-position: center bottom;
  flex-shrink: 0;
  background: var(--hover-bg);
}

.concept-drawer__result-info {
  display: flex;
  flex-direction: column;
  min-width: 0;
  flex: 1;
}

.concept-drawer__result-name {
  font-size: 0.85rem;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.concept-drawer__result-meta {
  font-size: 0.7rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.concept-drawer__result-l10 {
  font-size: 0.8rem;
  font-weight: 700;
  flex-shrink: 0;
  padding: 3px 8px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.06);
}

.concept-drawer__result-l10.score-perfect { color: var(--score-perfect); text-shadow: 0 0 8px rgba(255, 215, 0, 0.6); }
.concept-drawer__result-l10.score-elite { color: var(--score-elite); }
.concept-drawer__result-l10.score-great { color: var(--score-great); }
.concept-drawer__result-l10.score-good { color: var(--score-good); }
.concept-drawer__result-l10.score-ok { color: var(--score-ok); }
.concept-drawer__result-l10.score-poor { color: var(--score-poor); }
.concept-drawer__result-l10.score-terrible { color: var(--score-terrible); }

/* ============================================================
   MOBILE
   ============================================================ */

@media (max-width: 768px) {
  /* Stack lineup + summary panel vertically */
  .concept-lineup-wrapper {
    flex-direction: column;
    align-items: stretch;
  }

  .concept-lineup {
    gap: 10px;
    flex-wrap: wrap;
  }

  .concept-slot {
    flex: 0 0 calc(33.33% - 8px);
    max-width: none;
  }

  .concept-card__avatar {
    width: 60px;
    height: 60px;
    margin-top: 24px;
    margin-bottom: 8px;
  }

  .concept-card__player-name {
    font-size: 0.75rem;
  }

  .concept-card__player-meta {
    font-size: 0.6rem;
  }

  .concept-card__player-l10 {
    font-size: 0.85rem;
  }

  /* Summary panel goes full-width below cards */
  .concept-summary-panel {
    width: 100%;
  }

  .concept-summary__cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  /* Slot controls */
  .concept-slot__controls {
    padding: 8px 8px;
  }

  .concept-slot__bonus-input {
    width: 36px;
    font-size: 0.8rem;
  }

  /* Score badges */
  .concept-badge__value {
    font-size: 0.85rem;
    width: 2.2rem;
    height: 2.2rem;
  }

  .concept-badge__label {
    font-size: 0.55rem;
  }

  /* Price pills */
  .concept-price-pill__label {
    font-size: 0.55rem;
  }

  .concept-price-pill__value {
    font-size: 0.75rem;
  }

  /* Chart section */
  .concept-score-chart-header {
    flex-wrap: wrap;
    gap: 8px;
  }

  .concept-score-chart-wrap {
    height: 300px;
  }

  /* Scarcity toggle */
  .concept-scarcity-row {
    flex-wrap: wrap;
  }

  .concept-scarcity-btn {
    font-size: 0.6rem;
    padding: 5px 10px;
  }

  /* Drawer full-width */
  .concept-drawer {
    width: 100%;
  }

  /* Remove button always visible on touch */
  .concept-card__remove {
    opacity: 1;
  }
}

@media (max-width: 480px) {
  .concept-slot {
    flex: 0 0 calc(50% - 6px);
  }

  .concept-card__avatar {
    width: 50px;
    height: 50px;
  }

  .concept-card__label {
    font-size: 0.55rem;
  }

  /* Even smaller badges */
  .concept-badge__value {
    font-size: 0.75rem;
    width: 1.9rem;
    height: 1.9rem;
  }

  .concept-slot__badges {
    padding: 6px 6px;
    gap: 4px;
  }

  .concept-price-pill {
    padding: 6px 4px;
  }

  /* Chart shorter on small phones */
  .concept-score-chart-wrap {
    height: 250px;
  }

  /* Summary cards stack to single column */
  .concept-summary__cards {
    grid-template-columns: 1fr;
  }

  .concept-summary__value {
    font-size: 1.1rem;
  }
}
