/* Darkpool dashboard (M15) — cyberdeck 3-col layout.
 * Operator card (left) · loadouts (center) · recent battles + probes (right). */

body.dash-page {
  padding: 0;
  margin: 0;
  max-width: none;
}

.dash {
  min-height: 100vh;
  padding: 20px 28px 80px;
  position: relative;
}
.dash > * { position: relative; z-index: 2; }

/* ---- header / nav ---- */
.dash-header {
  display: flex;
  gap: 32px;
  align-items: flex-end;
  margin-bottom: 8px;
}
.dash-header__banner {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.05;
  color: var(--cyan);
  text-shadow: 0 0 6px var(--cyan-glow);
  margin: 0;
}
.dash-nav {
  display: flex;
  gap: 18px;
  border-top: 1px dashed var(--void-line);
  border-bottom: 1px dashed var(--void-line);
  padding: 6px 0;
  flex: 1;
  margin-bottom: 4px;
  align-items: center;
}
.dash-nav a {
  font-family: var(--font-display);
  font-size: 14px;
  letter-spacing: 0.08em;
  color: var(--bone-dim);
  text-decoration: none;
}
.dash-nav a:hover { color: var(--cyan); }
.dash-nav a.active {
  color: var(--bg);
  background: var(--magenta);
  padding: 2px 8px;
  text-shadow: none;
}
.dash-nav__user {
  margin-left: auto;
  font-family: var(--font-body);
  color: var(--bone);
  font-size: 14px;
}
.dash-nav__user .ash { color: var(--ash); margin-right: 4px; }
.dash-nav__logout {
  background: transparent;
  border: 1px solid var(--void-line);
  color: var(--bone-dim);
  font-family: var(--font-display);
  font-size: 12px;
  padding: 2px 8px;
  cursor: pointer;
}
.dash-nav__logout:hover {
  border-color: var(--magenta);
  color: var(--magenta);
}

/* ---- alerts ---- */
.dash-alert {
  border: 1px solid var(--rust);
  background: rgba(255, 138, 60, 0.06);
  color: var(--rust);
  padding: 8px 14px;
  margin: 8px 0;
  font-family: var(--font-body);
  font-size: 16px;
}
.dash-alert a {
  color: var(--rust);
  text-decoration: underline;
}

/* ---- status bar ---- */
.status-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 0;
  align-items: center;
  font-size: 14px;
  border: 1px solid var(--void-line);
  padding: 6px 14px;
  margin: 8px 0 16px;
  background: linear-gradient(90deg, rgba(255,79,216,0.04), rgba(92,242,255,0.04));
  font-family: var(--font-body);
}
.status-bar__cell {
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
}
.status-bar__cell + .status-bar__cell::before {
  content: "·";
  color: var(--ash);
  margin: 0 14px;
}
.status-bar__cell--right { margin-left: auto; }

/* ---- main grid ---- */
.dash__grid {
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr) minmax(260px, 320px);
  gap: 16px;
  align-items: start;
}
.dash__col-left,
.dash__col-center,
.dash__col-right {
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-width: 0;
}

/* ---- shared panel frame ---- */
.px-frame {
  border: 1px solid var(--void-line);
  background: var(--bg-panel);
}
.px-frame--mag { border-color: var(--magenta-deep); }
.px-frame--cyan { border-color: var(--cyan-deep); }

/* ---- operator card ---- */
.op-card {
  padding: 14px 16px 16px;
  background: linear-gradient(180deg, rgba(255,79,216,0.05), rgba(92,242,255,0.03));
  border: 1px solid var(--magenta-deep);
  box-shadow: inset 0 0 0 1px rgba(255,79,216,0.1);
}
.op-card__head {
  display: flex; justify-content: space-between; align-items: baseline;
  border-bottom: 1px dashed var(--void-line);
  padding-bottom: 6px; margin-bottom: 12px;
  font-size: 13px;
}
.op-card__name-row {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 14px;
}
.op-card__name {
  font-family: var(--font-display);
  color: var(--magenta);
  text-shadow: 0 0 6px var(--magenta-glow);
  font-size: 32px;
  line-height: 1;
}
.op-card__specialty {
  font-family: var(--font-body);
  color: var(--bone-dim);
  font-size: 14px;
  margin-top: 2px;
}
.op-card__specialty .ash { color: var(--ash); }

.op-card__rank { margin-bottom: 14px; }
.op-card__rank-line {
  display: flex; align-items: baseline; gap: 10px; margin-bottom: 4px;
}
.op-card__rank-label {
  font-family: var(--font-display);
  color: var(--cyan);
  text-shadow: 0 0 6px var(--cyan-glow);
  font-size: 22px;
}
.op-card__rank-pts {
  font-family: var(--font-body);
  color: var(--bone-dim);
  font-size: 14px;
}
.op-card__bar {
  display: grid;
  grid-template-columns: repeat(20, 1fr);
  gap: 2px;
  height: 10px;
  margin: 4px 0;
}
.op-card__bar-cell {
  border: 1px solid var(--cyan-deep);
  background: transparent;
  opacity: 0.4;
}
.op-card__bar-cell.is-on {
  background: var(--cyan);
  opacity: 1;
}
.op-card__ladder {
  margin-top: 4px;
  font-family: var(--font-body);
  color: var(--bone-dim);
  font-size: 13px;
}
.op-card__ladder .bone { color: var(--bone); }

.op-card__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  margin-bottom: 14px;
  padding: 10px 0;
  border-top: 1px dashed var(--void-line);
  border-bottom: 1px dashed var(--void-line);
}
.op-stat {
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  min-width: 0;
}
.op-stat__label {
  font-family: var(--font-display);
  font-size: 9px;
  letter-spacing: 0.05em;
  color: var(--ash);
  text-transform: uppercase;
}
.op-stat__value {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1;
  color: var(--bone);
  font-variant-numeric: tabular-nums;
}
.op-stat__value .ash { color: var(--ash); font-size: 14px; }

.op-card__energy { margin-bottom: 14px; }
.op-card__energy-head {
  display: flex; align-items: baseline; gap: 10px; margin-bottom: 6px;
  flex-wrap: wrap;
  font-size: 13px;
  color: var(--bone-dim);
  font-family: var(--font-body);
}
.op-card__energy-head .label {
  font-family: var(--font-display);
  font-size: 12px;
  color: var(--ash);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.op-card__energy-head .count {
  font-family: var(--font-display);
  font-size: 18px;
  color: var(--bone);
}
.op-card__energy-head .count .ash { color: var(--ash); }
.op-card__energy-bar {
  display: grid;
  grid-template-columns: repeat(15, 1fr);
  gap: 2px;
  height: 16px;
}
.op-card__energy-cell {
  border: 1px solid var(--magenta-deep);
  background: transparent;
}
.op-card__energy-cell.is-on {
  background: var(--magenta);
  box-shadow: 0 0 4px var(--magenta-glow);
}
.op-card__attack-form { margin: 0; }
.op-card__attack {
  width: 100%;
  padding: 12px 16px 10px;
  font-family: var(--font-display);
  font-size: 16px;
  letter-spacing: 0.1em;
  background: transparent;
  color: var(--bone);
  border: 1px solid var(--magenta);
  cursor: pointer;
  text-transform: uppercase;
  transition: background 80ms linear, color 80ms linear, transform 60ms linear;
}
.op-card__attack:hover:not(:disabled) {
  background: var(--magenta);
  color: var(--bg);
}
.op-card__attack:active:not(:disabled) { transform: translate(1px, 1px); }
.op-card__attack:disabled {
  border-color: var(--ash);
  color: var(--ash);
  cursor: not-allowed;
}
.op-card__attack-note {
  margin: 6px 0 0;
  font-family: var(--font-body);
  color: var(--ash);
  font-size: 13px;
  text-align: center;
}

/* ---- refill energy (soft-launch helper) ---- */
.op-card__refill-form { margin: 0 0 8px; }
.op-card__refill {
  width: 100%;
  padding: 8px 12px 6px;
  font-family: var(--font-display);
  font-size: 13px;
  letter-spacing: 0.1em;
  background: transparent;
  color: var(--cyan);
  border: 1px dashed var(--cyan);
  cursor: pointer;
  text-transform: uppercase;
  transition: background 80ms linear, color 80ms linear, transform 60ms linear;
}
.op-card__refill:hover:not(:disabled) {
  background: var(--cyan);
  color: var(--bg);
}
.op-card__refill:active:not(:disabled) { transform: translate(1px, 1px); }
.op-card__refill:disabled {
  border-color: var(--ash);
  color: var(--ash);
  cursor: not-allowed;
}
.op-card__refill-note {
  margin: 4px 0 0;
  font-family: var(--font-body);
  color: var(--ash);
  font-size: 11px;
  text-align: center;
  opacity: 0.7;
}

/* ---- loadout panels ---- */
.loadout-panel {
  padding: 12px 14px;
  border: 1px solid var(--void-line);
  background: var(--bg-panel);
}
.loadout-panel--mag { border-color: var(--magenta-deep); }
.loadout-panel--cyan { border-color: var(--cyan-deep); }

.panel-head {
  display: flex; justify-content: space-between; align-items: baseline;
  border-bottom: 1px dashed var(--void-line);
  padding-bottom: 6px; margin-bottom: 10px;
  white-space: nowrap;
}
.panel-head__title {
  font-family: var(--font-display);
  font-size: 13px;
  letter-spacing: 0.05em;
  color: var(--ash);
  text-transform: uppercase;
}
.panel-head__meta {
  font-family: var(--font-display);
  font-size: 13px;
}
.panel-head__meta--mag { color: var(--magenta); text-shadow: 0 0 6px var(--magenta-glow); }
.panel-head__meta--cyan { color: var(--cyan); text-shadow: 0 0 6px var(--cyan-glow); }
.panel-head__meta--dim { color: var(--bone-dim); }

.loadout-panel__slots {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.slot-card {
  border: 1px solid var(--void-line);
  background: rgba(0,0,0,0.3);
  padding: 10px 12px;
  display: flex; flex-direction: column; gap: 8px;
  min-height: 110px;
  position: relative;
  min-width: 0;
  transition: border-color 120ms, background 120ms;
}
.slot-card--attack:hover { border-color: var(--magenta); }
.slot-card--defense:hover { border-color: var(--cyan); }
.slot-card--empty {
  border-style: dashed;
  align-items: center;
  justify-content: center;
  color: var(--ash);
  font-family: var(--font-body);
}
.slot-card__head {
  display: flex; align-items: center; gap: 8px; min-width: 0;
}
.slot-card__head-text { min-width: 0; overflow: hidden; }
.slot-card__name {
  font-family: var(--font-display);
  color: var(--bone);
  font-size: 14px;
  line-height: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.slot-card__type {
  font-family: var(--font-body);
  color: var(--ash);
  font-size: 12px;
  margin-top: 2px;
}
.slot-card__stats {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
  font-family: var(--font-display);
  margin-top: auto;
  border-top: 1px dashed var(--void-line);
  padding-top: 8px;
}
.slot-stat {
  display: flex; flex-direction: column; align-items: flex-start; gap: 2px;
}
.slot-stat__lbl {
  font-size: 10px;
  letter-spacing: 0.06em;
  line-height: 1;
  color: var(--ash);
}
.slot-stat__val {
  font-size: 16px;
  line-height: 1;
  color: var(--bone);
  font-variant-numeric: tabular-nums;
}
.slot-stat--inert .slot-stat__val,
.slot-stat--inert .slot-stat__lbl {
  color: var(--ash);
  text-decoration: line-through;
  text-decoration-color: rgba(90, 79, 120, 0.5);
}

/* ---- bench ---- */
.bench-panel {
  padding: 12px 14px;
  border: 1px solid var(--void-line);
  background: var(--bg-panel);
}

/* ---- shared data table ---- */
.data-tbl {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-body);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}
.data-tbl thead th {
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: 0.08em;
  color: var(--ash);
  font-weight: normal;
  text-align: left;
  padding: 4px 8px 6px;
  border-bottom: 1px dashed var(--void-line);
  text-transform: uppercase;
}
.data-tbl thead th.num { text-align: right; }
.data-tbl tbody td {
  padding: 6px 8px;
  border-bottom: 1px solid var(--void-line);
  vertical-align: middle;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--bone);
}
.data-tbl tbody td.num { text-align: right; }
.data-tbl tbody tr:last-child td { border-bottom: none; }

.bench-tbl col.col-art { width: 28px; }
.bench-tbl col.col-name { width: auto; }
.bench-tbl col.col-role { width: 52px; }
.bench-tbl col.col-type { width: 96px; }
.bench-tbl col.col-stat { width: 50px; }
.bench-tr--attack td:first-child { box-shadow: inset 3px 0 0 var(--magenta-deep); }
.bench-tr--defense td:first-child { box-shadow: inset 3px 0 0 var(--cyan-deep); }
.bench-tr--empty td { color: var(--ash); font-style: italic; }
.bench-tr__art { padding-left: 8px; padding-right: 0; }
.bench-tr__art svg { display: block; }
.bench-tr__name {
  font-family: var(--font-display);
  color: var(--bone);
}
.bench-tr__role {
  font-family: var(--font-display);
  text-transform: uppercase;
}
.bench-tr__role--attack { color: var(--magenta); }
.bench-tr__role--defense { color: var(--cyan); }
.bench-tr__type {
  display: flex;
  align-items: center;
  gap: 6px;
}
.bench-tr__type-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  flex: none;
  background: currentColor;
}

/* ---- recent battles ---- */
.recent-tbl col.col-when { width: 44px; }
.recent-tbl col.col-result { width: 60px; }
.recent-tbl col.col-vs { width: auto; }
.recent-tbl col.col-score { width: 72px; }
.recent-tbl col.col-delta { width: 50px; }
.recent-tr { transition: background 100ms; }
.recent-tr a {
  display: block;
  width: 100%;
  color: inherit;
  text-decoration: none;
}
.recent-tr--win td:first-child { box-shadow: inset 3px 0 0 var(--acid); }
.recent-tr--loss td:first-child { box-shadow: inset 3px 0 0 var(--rust); }
.recent-tr:hover { background: rgba(92,242,255,0.04); }
.recent-tr__when { color: var(--ash); }
.recent-tr__result {
  font-family: var(--font-display);
  text-transform: uppercase;
}
.recent-tr__result--win { color: var(--acid); }
.recent-tr__result--loss { color: var(--rust); }
.recent-tr__delta {
  font-family: var(--font-display);
}
.recent-tr__delta--up { color: var(--acid); }
.recent-tr__delta--down { color: var(--rust); }
.recent-empty {
  color: var(--ash);
  font-style: italic;
  font-family: var(--font-body);
  padding: 12px 4px;
}

/* ---- probes ---- */
.probes-panel {
  padding: 12px 14px;
  border: 1px solid var(--void-line);
  background: var(--bg-panel);
}
.probes-panel__list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-height: 180px;
  font-family: var(--font-body);
}
.probes-line {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 13px;
  color: var(--bone-dim);
  transition: opacity 200ms;
}
.probes-line .ash { color: var(--ash); }
.probes-cursor {
  color: var(--magenta);
  font-family: var(--font-body);
  font-size: 13px;
  animation: probes-blink 1s steps(1) infinite;
}
@keyframes probes-blink { 0%, 49% { opacity: 1; } 50%, 100% { opacity: 0; } }

/* ---- responsive ---- */
@media (max-width: 1280px) {
  .loadout-panel__slots { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 1100px) {
  .dash__grid { grid-template-columns: 1fr 1fr; }
  .dash__col-right { grid-column: 1 / -1; flex-direction: row; }
  .dash__col-right > * { flex: 1; }
  .loadout-panel__slots { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 800px) {
  .dash__grid { grid-template-columns: 1fr; }
  .dash__col-right { flex-direction: column; }
  .loadout-panel__slots { grid-template-columns: 1fr; }
}

/* ---- mobile header (shared by dashboard / inventory / defense / leaderboard / reward) ---- */
@media (max-width: 640px) {
  .dash { padding: 12px 14px 64px; }
  .dash-header {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  .dash-header__banner {
    font-size: 11px;
    align-self: center;
    text-align: center;
  }
  .dash-nav {
    flex-wrap: wrap;
    gap: 6px 12px;
    padding: 8px 0;
  }
  .dash-nav a {
    font-size: 12px;
    letter-spacing: 0.06em;
  }
  .dash-nav__user {
    margin-left: 0;
    font-size: 12px;
  }
  .dash-nav__logout { font-size: 11px; }
  /* status bar: drop the "·" separators when wrapping; use gap instead */
  .status-bar {
    gap: 4px 14px;
    font-size: 13px;
    padding: 6px 10px;
  }
  .status-bar__cell + .status-bar__cell::before { display: none; }
  .status-bar__cell--right { margin-left: 0; }
}
@media (max-width: 380px) {
  .dash-header__banner { font-size: 10px; }
  .dash-nav { gap: 4px 10px; }
  .dash-nav a { font-size: 11px; }
}
@media (max-width: 640px) {
  /* panel headers (// DEFENSE LOG + description) wrap onto their own lines */
  .panel-head {
    flex-direction: column;
    align-items: flex-start;
    white-space: normal;
    gap: 2px;
  }
  .panel-head__meta {
    font-size: 11px;
    line-height: 1.3;
  }
}

/* Rarity glyphs on dashboard cards (slot cards + bench rows). Reversible:
   delete this block + the spans `.slot-card__rarity` / `.bench-tr__rarity`
   in dashboard.html to undo. */
.slot-card__rarity {
  font-size: 12px;
  letter-spacing: 0.04em;
  margin-right: 4px;
  color: var(--bone-dim);
}
.bench-tr__rarity {
  display: inline-block;
  font-size: 10px;
  margin-right: 2px;
  vertical-align: middle;
  color: var(--bone-dim);
}
.slot-card__rarity--common, .bench-tr__rarity--common { color: var(--ash); }
.slot-card__rarity--rare,   .bench-tr__rarity--rare   { color: var(--cyan); }
.slot-card__rarity--epic,   .bench-tr__rarity--epic   { color: #c08aff; }
.slot-card__rarity--mythic, .bench-tr__rarity--mythic {
  color: #ffd86b;
  text-shadow: 0 0 4px rgba(255,216,107,0.5);
}
