/* ── RESET & BASE ─────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:        #ffffff;
  --bg2:       #f7f7f8;
  --border:    #e5e5e7;
  --border2:   #d1d1d6;
  --text:      #1c1c1e;
  --text2:     #6e6e73;
  --accent:    #534AB7;
  --accent-bg: #EEEDFE;
  --green:     #1D9E75;
  --green-bg:  #E1F5EE;
  --orange:    #BA7517;
  --orange-bg: #FAEEDA;
  --red:       #A32D2D;
  --red-bg:    #FCEBEB;
  --radius:    10px;
  --radius-sm: 6px;
}

body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 14px;
  color: var(--text);
  background: var(--bg);
  min-height: 100vh;
}

.app {
  max-width: 900px;
  margin: 0 auto;
  padding: 1.25rem 1rem 3rem;
}

.screen { display: none; }
.screen.active { display: block; }

/* ── TYPOGRAPHY ───────────────────────────────────────────────────────────── */
h1 { font-size: 20px; font-weight: 600; }
h2 { font-size: 17px; font-weight: 600; }
h3 { font-size: 14px; font-weight: 600; }
.subtitle { font-size: 12px; color: var(--text2); margin-top: 2px; }
.muted    { color: var(--text2); font-weight: 400; }
.hint     { font-size: 12px; color: var(--text2); margin-top: 6px; }

/* ── FORMS ────────────────────────────────────────────────────────────────── */
label { font-size: 12px; color: var(--text2); display: block; margin-bottom: 4px; }
input[type=text], select {
  width: 100%;
  padding: 8px 10px;
  font-size: 14px;
  border: 0.5px solid var(--border2);
  border-radius: var(--radius-sm);
  background: var(--bg);
  color: var(--text);
  font-family: inherit;
  outline: none;
}
input[type=text]:focus, select:focus { border-color: var(--accent); }

/* ── BUTTONS ──────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border: 0.5px solid var(--border2);
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--text);
  font-family: inherit;
  font-size: 14px;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.1s;
}
.btn:hover        { background: var(--bg2); }
.btn-primary      { background: var(--text); color: var(--bg); border-color: var(--text); }
.btn-primary:hover{ opacity: 0.85; background: var(--text); }
.btn-sm           { padding: 5px 12px; font-size: 12px; }
.btn-link         { background: none; border: none; cursor: pointer; font-size: 12px;
                    color: var(--accent); font-family: inherit; padding: 0; }
.btn-link:hover   { text-decoration: underline; }
.btn.confirmed    { opacity: 0.65; cursor: default; }

/* ── DIVIDER ──────────────────────────────────────────────────────────────── */
.divider { height: 0.5px; background: var(--border); margin: 1.25rem 0; }

/* ── BADGES ───────────────────────────────────────────────────────────────── */
.badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
  white-space: nowrap;
}
.badge-nac   { background: #E6F1FB; color: #0C447C; }
.badge-com   { background: var(--green-bg); color: #085041; }
.badge-extra { background: var(--orange-bg); color: #712B13; }
.badge-b     { background: var(--accent-bg); color: #3C3489; }
.badge-a     { background: var(--orange-bg); color: #633806; }
.badge-p     { background: #FBEAF0; color: #72243E; }

/* ── HOME ─────────────────────────────────────────────────────────────────── */
.home-header { display: flex; align-items: center; gap: 12px; margin-bottom: 1.25rem; }
.home-logo   { font-size: 28px; width: 44px; height: 44px; background: var(--accent-bg);
               border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

.name-row         { margin-bottom: 4px; }
.name-input-group { display: flex; gap: 8px; align-items: center; max-width: 380px; }
.name-input-group input { flex: 1; }

.section-header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 10px; }
.section-meta   { font-size: 12px; color: var(--text2); }

.room-group       { margin-bottom: 12px; }
.room-group-label { font-size: 11px; font-weight: 600; color: var(--text2);
                    text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 6px; }

.sala-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  border: 0.5px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: 6px;
  cursor: pointer;
  transition: border-color 0.12s, background 0.12s;
  background: var(--bg);
}
.sala-row:hover      { border-color: var(--accent); background: var(--accent-bg); }
.sala-dot            { width: 8px; height: 8px; border-radius: 50%; background: var(--green);
                       flex-shrink: 0; animation: pulse 2s infinite; }
.sala-dot.dot-orange { background: var(--orange); }
.sala-info           { flex: 1; }
.sala-name           { font-size: 14px; font-weight: 500; }
.sala-meta           { font-size: 12px; color: var(--text2); margin-top: 1px; }
.sala-badge          { font-size: 11px; padding: 3px 10px; border-radius: 20px; white-space: nowrap; }
.sala-badge-free     { background: var(--green-bg); color: #085041; }
.sala-badge-full     { background: var(--orange-bg); color: #633806; }
.sala-empty          { cursor: default; opacity: 0.6; }
.sala-empty:hover    { border-color: var(--border); background: var(--bg); }

.priv-tabs { display: flex; border: 0.5px solid var(--border); border-radius: var(--radius-sm);
             overflow: hidden; margin-bottom: 12px; width: fit-content; }
.tab { padding: 7px 16px; font-size: 13px; cursor: pointer; background: transparent;
       border: none; color: var(--text2); font-family: inherit; }
.tab.active { background: var(--text); color: var(--bg); }

.inline-row  { display: flex; gap: 10px; align-items: flex-end; flex-wrap: wrap; }
.field-group { flex: 1; min-width: 140px; }

/* ── LOBBY ────────────────────────────────────────────────────────────────── */
.lobby-topbar    { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 12px; }
.lobby-code-row  { display: flex; align-items: center; gap: 8px; margin-top: 4px; }
.code-label      { font-size: 12px; color: var(--text2); }
.code-value      { font-size: 18px; font-weight: 600; letter-spacing: 4px; }

.countdown-wrap {
  background: var(--bg2);
  border: 0.5px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 16px;
  margin-bottom: 14px;
}
.cd-top    { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
.cd-title  { font-size: 13px; font-weight: 600; }
.cd-connected { font-size: 12px; color: var(--text2); }
.cd-digits { display: flex; align-items: center; justify-content: center; gap: 4px; margin: 6px 0 4px; }
.cd-unit   { text-align: center; }
.cd-num    { font-size: 36px; font-weight: 600; line-height: 1; font-variant-numeric: tabular-nums; }
.cd-sep    { font-size: 30px; font-weight: 300; color: var(--text2); padding-bottom: 12px; }
.cd-lbl    { font-size: 10px; color: var(--text2); text-transform: uppercase; letter-spacing: 1px; }
.prog-bar  { height: 3px; background: var(--border); border-radius: 2px; overflow: hidden; margin-top: 6px; }
.prog-fill { height: 100%; border-radius: 2px; background: var(--accent); transition: width 1s linear; }
.cd-footer { display: flex; justify-content: space-between; margin-top: 5px; font-size: 11px; color: var(--text2); }

.managers-header { display: flex; align-items: center; justify-content: space-between;
                   gap: 8px; margin-bottom: 4px; flex-wrap: wrap; }

.manager-list { display: flex; flex-direction: column; gap: 5px; max-height: 380px; overflow-y: auto; }

.manager-row {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 9px 12px;
  border-radius: var(--radius-sm);
  border: 0.5px solid var(--border);
  background: var(--bg2);
  transition: background 0.1s, border-color 0.1s;
}
.manager-row.me       { opacity: 0.5; }
.manager-row.ai-slot.slot-free { border-color: var(--accent); background: var(--accent-bg); cursor: pointer; }
.manager-row.ai-slot.slot-free:hover { background: #e0defc; border-color: var(--accent); }
.manager-row.ai-slot.slot-free .slot-empty { color: var(--accent); font-weight: 500; }
.manager-row.ai-slot.slot-free .pos-num { color: var(--accent); }
.manager-row.ai-slot.slot-free .mdot-wait { background: var(--accent); }
.manager-row.draggable-row { cursor: grab; }
.manager-row.draggable-row:active { cursor: grabbing; }
.manager-row.dragging { opacity: 0.4; border-style: dashed; }

.drag-handle  { font-size: 16px; color: var(--text2); cursor: grab; flex-shrink: 0; line-height: 1; }
.pos-badge    { font-size: 11px; font-weight: 700; width: 18px; text-align: center;
                color: var(--text2); flex-shrink: 0; }
.manager-name { flex: 1; font-size: 13px; font-weight: 500; }
.slot-empty   { flex: 1; font-size: 13px; color: var(--text2); }
.mdot         { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.mdot-on      { background: var(--green); }
.mdot-wait    { background: var(--orange); animation: pulse 1.4s infinite; }
.tag-me  { font-size: 11px; background: var(--green-bg); color: #085041; padding: 2px 8px; border-radius: 4px; }
.tag-ok  { font-size: 11px; color: var(--text2); }
.tag-ai  { font-size: 11px; background: var(--orange-bg); color: #633806; padding: 2px 8px; border-radius: 4px; }

/* ── DRAFT ────────────────────────────────────────────────────────────────── */
.draft-topbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.round-dots   { display: flex; gap: 3px; }
.round-dot    { width: 20px; height: 20px; border-radius: 50%; border: 0.5px solid var(--border);
                display: flex; align-items: center; justify-content: center; font-size: 10px; color: var(--text2); }
.round-dot.done    { background: var(--text); color: var(--bg); border-color: var(--text); }
.round-dot.current { border-color: var(--accent); color: var(--accent); font-weight: 700; }

.ai-thinking { display: flex; align-items: center; gap: 8px; padding: 8px 12px;
               background: var(--accent-bg); border-radius: var(--radius-sm);
               font-size: 13px; color: var(--accent); margin-bottom: 8px; }
.dots span { animation: blink 1.2s infinite; }
.dots span:nth-child(2) { animation-delay: 0.2s; }
.dots span:nth-child(3) { animation-delay: 0.4s; }

.turn-banner { display: flex; align-items: center; justify-content: space-between;
               background: var(--bg2); border-radius: var(--radius); padding: 12px 16px; margin-bottom: 12px; }
.turn-left   { flex: 1; }
.turn-info   { font-size: 12px; color: var(--text2); }
.turn-name   { font-size: 15px; font-weight: 600; margin: 2px 0 4px; }
.turn-right  { text-align: right; min-width: 140px; }
.budget-label  { font-size: 11px; color: var(--text2); }
.budget-amount { font-size: 15px; font-weight: 600; }
.budget-bar    { height: 3px; background: var(--border); border-radius: 2px; margin-top: 4px;
                 width: 140px; margin-left: auto; }
.budget-fill   { height: 100%; border-radius: 2px; transition: width 0.3s; }
.pick-timer    { height: 2px; background: var(--border); border-radius: 2px; overflow: hidden;
                 width: 200px; margin-top: 4px; }
.pick-timer-fill { height: 100%; border-radius: 2px; }

.draft-layout { display: grid; grid-template-columns: 1fr 280px; gap: 12px; }

.filter-bar  { display: flex; gap: 5px; margin-bottom: 7px; flex-wrap: wrap; align-items: center; }
.filter-btn  { padding: 3px 10px; font-size: 12px; border: 0.5px solid var(--border);
               border-radius: 20px; cursor: pointer; background: transparent;
               color: var(--text2); font-family: inherit; }
.filter-btn.active { background: var(--text); color: var(--bg); border-color: var(--text); }
.search-input { padding: 5px 9px; font-size: 12px; border: 0.5px solid var(--border);
                border-radius: var(--radius-sm); background: transparent; color: var(--text);
                width: 150px; font-family: inherit; outline: none; }
.search-input:focus { border-color: var(--accent); }

.player-list { max-height: 440px; overflow-y: auto; border: 0.5px solid var(--border);
               border-radius: var(--radius); }
.player-row  { display: flex; align-items: center; gap: 7px; padding: 8px 11px;
               border-bottom: 0.5px solid var(--border); transition: background 0.1s; }
.player-row:last-child { border-bottom: none; }
.player-row.pickable       { cursor: pointer; }
.player-row.pickable:hover { background: var(--accent-bg); }
.player-row.selected       { opacity: 0.3; pointer-events: none; cursor: default; }
.player-row.invalid        { opacity: 0.25; cursor: not-allowed; }
.player-name  { flex: 1; font-size: 13px; font-weight: 500; }
.player-price { font-size: 12px; color: var(--text2); min-width: 80px; text-align: right; }

.cinfo { font-size: 11px; color: var(--text2); display: flex; gap: 10px; flex-wrap: wrap; margin-top: 6px; }
.cok   { color: var(--green); }
.cerr  { color: var(--red); }

.team-panel { display: flex; flex-direction: column; gap: 4px; max-height: 520px; overflow-y: auto; }
.team-card  { background: var(--bg2); border-radius: var(--radius-sm); padding: 7px 10px;
              border: 0.5px solid var(--border); }
.team-card.my-team      { border-color: var(--green); }
.team-card.current-turn { border-color: var(--accent); background: var(--accent-bg); }
.team-header       { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
.team-title        { font-size: 11px; font-weight: 600; }
.team-budget-small { font-size: 10px; color: var(--text2); }
.team-slots { display: flex; gap: 2px; flex-wrap: wrap; }
.slot       { font-size: 9px; padding: 1px 4px; border-radius: 3px; background: var(--bg);
              border: 0.5px solid var(--border); color: var(--text2); white-space: nowrap;
              max-width: 72px; overflow: hidden; text-overflow: ellipsis; }
.slot.filled { background: var(--text); color: var(--bg); border-color: var(--text); }

.log-wrap  { margin-top: 12px; }
.log-title { font-size: 12px; color: var(--text2); margin-bottom: 4px; font-weight: 500; }
.draft-log { max-height: 110px; overflow-y: auto; }
.log-entry { font-size: 11px; color: var(--text2); padding: 3px 0; border-bottom: 0.5px solid var(--border); }
.log-entry:last-child { border-bottom: none; }
.log-pick  { color: var(--text); font-weight: 600; }

/* ── RESULTS ──────────────────────────────────────────────────────────────── */
.results-topbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.results-grid   { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 10px; }
.result-card    { background: var(--bg); border: 0.5px solid var(--border); border-radius: var(--radius); padding: 12px 14px; }
.result-header  { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.result-spent   { font-size: 11px; color: var(--text2); }
.result-player  { display: flex; justify-content: space-between; align-items: center;
                  padding: 3px 0; border-bottom: 0.5px solid var(--border); }
.result-player:last-of-type { border-bottom: none; }
.result-player-info { display: flex; gap: 5px; align-items: center; font-size: 12px; }
.result-price   { font-size: 11px; color: var(--text2); }
.result-footer  { margin-top: 8px; padding-top: 6px; border-top: 0.5px solid var(--border);
                  font-size: 11px; color: var(--text2); }

/* ── ANIMATIONS ───────────────────────────────────────────────────────────── */
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.35} }
@keyframes blink { 0%,100%{opacity:0.2} 50%{opacity:1} }

/* ── RESPONSIVE ───────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .draft-layout  { grid-template-columns: 1fr; }
  .team-panel    { max-height: 200px; }
  .inline-row    { flex-direction: column; }
  .round-dots    { display: none; }
  .pick-timer    { width: 140px; }
  .player-row    { padding: 12px 11px; }
  .sala-row      { padding: 13px 14px; }
}
/* ── PROYECCIONES & WATCHLIST ─────────────────────────────────────────────── */
.player-proj {
  font-size: 11px;
  font-weight: 600;
  color: var(--accent);
  background: var(--accent-bg);
  padding: 1px 5px;
  border-radius: 4px;
  margin-right: 4px;
  min-width: 32px;
  text-align: center;
}

.star-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 13px;
  padding: 0 2px;
  opacity: 0.2;
  transition: opacity 0.15s;
  flex-shrink: 0;
  line-height: 1;
}
.star-btn:hover   { opacity: 0.6; }
.star-btn.starred { opacity: 1; }

.player-row.watchlisted { background: #fffbe6; }

/* ── BANDERAS ─────────────────────────────────────────────────────────────── */
.flag-icon {
  width: 15px;
  height: 10px;
  object-fit: cover;
  border-radius: 2px;
  flex-shrink: 0;
  vertical-align: middle;
}
.flag-extra {
  width: 15px;
  height: 10px;
}
.badge-com {
  background: var(--accent-bg);
  color: #3C3489;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 5px;
  border-radius: 4px;
}

/* ── RESULTADOS MEJORADOS ─────────────────────────────────────────────────── */
.result-card-me {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent-bg);
}
.result-rank-name {
  display: flex;
  align-items: center;
  gap: 8px;
}
.result-medal {
  font-size: 20px;
  line-height: 1;
  flex-shrink: 0;
}
.result-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 6px;
  gap: 8px;
}
.result-score-wrap {
  text-align: right;
  flex-shrink: 0;
}
.result-score-num {
  font-size: 18px;
  font-weight: 700;
  color: var(--accent);
  display: block;
  line-height: 1.1;
}
.result-score-lbl {
  font-size: 10px;
  color: var(--text2);
}
.result-score-bar-wrap {
  height: 4px;
  background: var(--border);
  border-radius: 2px;
  margin-bottom: 8px;
  overflow: hidden;
}
.result-score-bar {
  height: 100%;
  background: var(--accent);
  border-radius: 2px;
  transition: width 0.6s ease;
}
.result-player-right {
  display: flex;
  align-items: center;
  gap: 8px;
}
.result-proj {
  font-size: 11px;
  font-weight: 600;
  color: var(--accent);
  background: var(--accent-bg);
  padding: 1px 5px;
  border-radius: 4px;
  min-width: 28px;
  text-align: center;
}
.result-footer {
  display: flex;
  justify-content: space-between;
  margin-top: 8px;
  padding-top: 6px;
  border-top: 0.5px solid var(--border);
  font-size: 11px;
  color: var(--text2);
}
.result-export-btn {
  width: 100%;
  margin-top: 10px;
  justify-content: center;
  color: var(--accent);
  border-color: var(--accent);
}
.result-export-btn:hover {
  background: var(--accent-bg);
}

/* ── FILTER BAR OPCIÓN B ──────────────────────────────────────────────────── */
.filter-bar-b       { flex-direction: column; gap: 6px; padding: 0; }
.filter-row         { display: flex; gap: 5px; align-items: center; }
.filter-sep         { width: 0.5px; height: 16px; background: var(--border2); margin: 0 2px; flex-shrink: 0; }

/* ── CHIPS DE CALOR ───────────────────────────────────────────────────────── */
.player-chip {
  font-size: 11px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 4px;
  min-width: 34px;
  text-align: center;
  flex-shrink: 0;
}
.player-chip-gold   { background: #FEF3C7; color: #92400E; font-weight: 700; }
.player-chip-elite  { background: var(--accent-bg); color: var(--accent); }
.player-chip-green  { background: var(--green-bg);  color: #085041; }
.player-chip-amber  { background: var(--orange-bg); color: #633806; }
.player-chip-red    { background: var(--red-bg);    color: #791F1F; }
.player-chip-none   { background: var(--bg2);       color: var(--text2); }
