/**
 * Builder Blitz CSS - 40mm Player Stage & Stage Navigation
 *
 * Styles for the multi-stage Blitz Builder flow:
 *   Stage 1: Team name + Positionals
 *   Stage 2: 32mm Skills (uses existing builder-cards styles)
 *   Stage 3: 40mm Players - Number & Skill assignment
 *
 * Follows existing builder patterns: builder-layout, picker-section,
 * builder-card, skill-modal, category-skills grid.
 *
 * @since 8.1.0
 * @updated 8.1.1 - Consistent styling with rest of builder
 */

/* ============================================= */
/* APP-CARD ADJUSTMENTS FOR BLITZ SUB-STAGES    */
/* Stats bar needs seamless join on skills/40mm  */
/* ============================================= */

.builder-app.stage-blitzSkills .app-card,
.builder-app.stage-blitz40mm .app-card {
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  border-bottom: none;
  overflow: visible;
  padding-bottom: 80px;
}

/* ============================================= */
/* PICKER HEADER BADGE                           */
/* ============================================= */

.picker-header-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.2em 0.65em;
  border-radius: var(--radius-sm, 4px);
  background: rgba(184, 154, 87, 0.15);
  color: var(--gold-500, #C9AD6A);
  border: 1px solid rgba(184, 154, 87, 0.3);
  letter-spacing: 0.03em;
}

.picker-header-badge.all-complete {
  background: rgba(76, 175, 80, 0.15);
  color: var(--success, #4CAF50);
  border-color: rgba(76, 175, 80, 0.3);
}

/* ============================================= */
/* 40mm PLAYER CARDS GRID                        */
/* Uses existing .builder-layout > .builder-pickers */
/* ============================================= */

.forty-players-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-4, 1rem);
  padding: var(--space-2, 0.5rem) 0;
}

/* ============================================= */
/* 40mm PLAYER CARD                              */
/* Extends .builder-card pattern from builder-cards.css */
/* ============================================= */

.forty-player-card {
  display: flex;
  flex-direction: column;
  background: linear-gradient(145deg, rgba(50, 58, 70, 0.98) 0%, rgba(38, 44, 54, 0.95) 100%);
  border: 1px solid rgba(90, 100, 115, 0.5);
  border-radius: var(--radius-sm, 6px);
  padding: var(--space-3, 0.75rem);
  transition: all var(--transition-fast, 0.15s ease);
  position: relative;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

/* Left accent bar — matches pos-card.big-guy pattern */
.forty-player-card::before {
  content: '';
  position: absolute;
  top: 5px;
  left: 0;
  bottom: 5px;
  width: 3px;
  background: linear-gradient(180deg, var(--pos-big-guy, #7050A0), var(--pos-big-guy-dark, #503870));
  border-radius: 0 2px 2px 0;
  transition: all var(--transition-fast, 0.15s ease);
}

.forty-player-card:hover {
  border-color: var(--gold-600, #B89A57);
  background: linear-gradient(145deg, rgba(58, 66, 78, 0.98) 0%, rgba(45, 52, 62, 0.95) 100%);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3), 0 0 12px rgba(112, 80, 160, 0.15);
}

.forty-player-card:hover::before {
  background: linear-gradient(180deg, var(--pos-big-guy-light, #9070C0), var(--pos-big-guy, #7050A0));
}

/* Complete state — green accent like builder-card.has-qty */
.forty-player-card.complete {
  border-color: var(--success, #4CAF50);
  background: linear-gradient(145deg, rgba(45, 55, 42, 0.95) 0%, rgba(28, 34, 26, 0.9) 100%);
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.3), 0 0 10px rgba(76, 175, 80, 0.12);
}

.forty-player-card.complete::before {
  background: linear-gradient(180deg, var(--success, #4CAF50), #2e7d32);
}

/* ---- Header ---- */

.forty-player-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-2, 0.5rem);
  padding-bottom: var(--space-2, 0.5rem);
  border-bottom: 1px solid rgba(60, 68, 78, 0.3);
}

.forty-player-name {
  font-family: var(--font-heading, 'Oswald', sans-serif);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-primary, #E7DFCF);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.forty-player-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.5rem;
  font-weight: 600;
  padding: var(--space-1, 0.25rem) 0.25rem;
  border-radius: var(--radius-xs, 3px);
  line-height: 1;
  background: rgba(112, 80, 160, 0.3);
  color: rgba(190, 170, 220, 0.95);
  border: 1px solid rgba(112, 80, 160, 0.4);
}

/* ---- Number Picker Button ---- */
/* Matches existing .inline-num-btn / .bg-num-btn patterns */

.forty-player-number {
  margin-bottom: var(--space-2, 0.5rem);
}

.forty-player-num-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0.5rem 0.75rem;
  background: rgba(20, 24, 28, 0.7);
  border: 1px solid rgba(112, 80, 160, 0.35);
  border-radius: var(--radius-sm, 6px);
  color: var(--text-secondary, #C4B79F);
  font-size: 0.85rem;
  cursor: pointer;
  transition: all var(--transition-fast, 0.15s ease);
}

.forty-player-num-btn:hover {
  border-color: var(--gold-600, #B89A57);
  color: var(--gold-400, #E4D7B8);
  background: rgba(184, 154, 87, 0.1);
}

.forty-player-num-btn.has-number {
  background: linear-gradient(135deg, rgba(184, 154, 87, 0.2), rgba(140, 85, 35, 0.15));
  border-color: rgba(184, 154, 87, 0.5);
  color: var(--gold-400, #E4D7B8);
}

.forty-player-num-btn.picker-open {
  border-color: var(--gold-600, #B89A57);
  box-shadow: 0 0 6px rgba(184, 154, 87, 0.3);
}

.forty-player-num-btn .num-label {
  font-size: 0.75rem;
  opacity: 0.7;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.forty-player-num-btn .num-value {
  font-family: var(--font-heading, 'Oswald', sans-serif);
  font-size: 1rem;
  font-weight: 700;
  color: var(--gold-500, #C9AD6A);
}

/* ---- Skill Slots ---- */
/* Grid matching the builder-card aesthetic */

.forty-player-skills-label {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  color: var(--text-secondary, #C4B79F);
  margin-bottom: var(--space-1, 0.25rem);
  opacity: 0.7;
}

.forty-player-skills {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2, 0.5rem);
  margin-bottom: var(--space-2, 0.5rem);
}

.forty-skill-slot {
  display: flex;
}

.forty-skill-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 52px;
  padding: 0.4rem;
  border-radius: var(--radius-sm, 6px);
  cursor: pointer;
  transition: all var(--transition-fast, 0.15s ease);
  text-align: center;
}

/* Empty slot — dashed border like builder empty states */
.forty-skill-btn.empty {
  background: rgba(20, 24, 28, 0.5);
  border: 1px dashed rgba(90, 100, 115, 0.4);
  color: var(--text-secondary, #C4B79F);
  font-size: 0.75rem;
}

.forty-skill-btn.empty:hover {
  border-color: var(--gold-600, #B89A57);
  background: rgba(184, 154, 87, 0.08);
  color: var(--gold-500, #C9AD6A);
}

.forty-skill-btn.empty i {
  font-size: 0.9rem;
  margin-bottom: 2px;
  opacity: 0.5;
}

/* Filled slot — matches builder-card.has-qty styling */
.forty-skill-btn.filled {
  background: linear-gradient(145deg, rgba(45, 38, 32, 0.95) 0%, rgba(28, 24, 20, 0.9) 100%);
  border: 1px solid rgba(184, 154, 87, 0.5);
  color: var(--text-primary, #E7DFCF);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2), 0 0 6px rgba(184, 154, 87, 0.08);
}

.forty-skill-btn.filled:hover {
  border-color: var(--gold-600, #B89A57);
  background: linear-gradient(145deg, rgba(55, 46, 38, 0.95) 0%, rgba(35, 30, 24, 0.9) 100%);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3), 0 0 10px rgba(184, 154, 87, 0.15);
}

.forty-skill-btn .skill-code {
  font-family: var(--font-heading, 'Oswald', sans-serif);
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--gold-500, #C9AD6A);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.forty-skill-btn .skill-name {
  font-size: 0.6rem;
  opacity: 0.7;
  margin-top: 1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

/* ---- Status Badge ---- */

.forty-player-status {
  text-align: center;
  padding-top: var(--space-2, 0.5rem);
  border-top: 1px solid rgba(60, 68, 78, 0.3);
  margin-top: auto;
}

.status-incomplete {
  color: var(--warning, #FFA726);
  font-size: 0.75rem;
  font-weight: 600;
}

.status-complete {
  color: var(--success, #4CAF50);
  font-size: 0.75rem;
  font-weight: 600;
}

/* ============================================= */
/* 40mm SKILL PICKER MODAL                       */
/* Uses existing .skill-modal + .builder-card    */
/* .skill-card pattern from builder-star.css     */
/* ============================================= */

/* The modal already uses .skill-modal class from builder-star.css.
   Skills inside use standard .builder-card .skill-card pattern.
   Category sections use standard .skill-category + .category-skills. */

/* Modal skill cards: click-to-select (no qty buttons) */
#fortySkillsGrid .builder-card.skill-card {
  cursor: pointer;
  padding: 0.6rem 0.4rem;
  align-items: center;
  justify-content: center;
}

#fortySkillsGrid .builder-card.skill-card:hover {
  border-color: var(--gold-600, #B89A57);
  background: rgba(184, 154, 87, 0.1);
  transform: translateY(-1px);
}

/* Already-assigned skills — dimmed with dashed border */
#fortySkillsGrid .builder-card.skill-card.already-assigned {
  opacity: 0.4;
  border-style: dashed;
  border-color: rgba(184, 154, 87, 0.4);
  cursor: not-allowed;
  pointer-events: none;
}

/* Category sections in 40mm modal */
#fortySkillsGrid .skill-category {
  margin-bottom: var(--space-3, 0.75rem);
}

#fortySkillsGrid .category-header {
  font-family: var(--font-heading, 'Oswald', sans-serif);
  font-size: 0.85rem;
  font-weight: 600;
  padding: 0.375rem 0.75rem;
  margin-bottom: 6px;
  border-radius: var(--radius-sm, 4px);
  color: var(--text-primary, #E7DFCF);
}

#fortySkillsGrid .category-skills {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
  gap: var(--space-2, 0.5rem);
}

#fortySkillsGrid .skill-category.hidden {
  display: none;
}

/* Skill count indicator in modal footer — matches roster pattern */
.skill-count-indicator {
  display: flex;
  align-items: center;
  gap: 0.15rem;
  font-family: var(--font-heading, 'Oswald', sans-serif);
  font-size: 0.95rem;
  font-weight: 700;
  padding: 0.3rem 0.6rem;
  background: rgba(184, 154, 87, 0.15);
  border-radius: var(--radius-sm, 4px);
  border: 1px solid rgba(184, 154, 87, 0.3);
}

.skill-count-indicator .count-current {
  color: var(--gold-400, #E4D7B8);
}

.skill-count-indicator .count-separator {
  color: var(--text-secondary, #C4B79F);
  opacity: 0.6;
}

.skill-count-indicator .count-max {
  color: var(--text-secondary, #C4B79F);
}

/* ============================================= */
/* INTRO CHIP - 40mm VARIANT                     */
/* ============================================= */

.intro-chip--40mm {
  background: rgba(112, 80, 160, 0.2) !important;
  border-color: rgba(112, 80, 160, 0.4) !important;
  color: rgba(190, 170, 220, 0.95) !important;
}

/* ============================================= */
/* RESPONSIVE                                    */
/* ============================================= */

@media (max-width: 480px) {
  .forty-players-grid {
    grid-template-columns: 1fr;
    gap: var(--space-3, 0.75rem);
  }

  .forty-player-skills {
    grid-template-columns: 1fr 1fr;
  }

  #fortySkillsGrid .category-skills {
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
  }
}

@media (min-width: 768px) {
  .forty-players-grid {
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  }
}
