/*
 * ============================================================
 * LEFT FOR THE VULTURES — Character Builder App Styles
 * Imports design system tokens + components, adds app layout.
 * ============================================================
 */

@import url('../design-system/tokens.css');
@import url('../design-system/components.css');

/* This app has no separate topbar — the stat bar IS the topbar.
   Override the token so step-nav and anything else that uses --topbar-height
   sticks below the stat bar instead of overlapping it. */
:root {
  --topbar-height: var(--stat-block-height);
}

/* ── Selected card — much stronger visual treatment ─────────────────────── */
/* Overrides the design-system default which is too subtle to notice at a glance */

.card--selected {
  background: rgba(139, 74, 42, 0.22) !important;
  border: 2px solid var(--color-rust-bright) !important;
  box-shadow:
    0 0 0 1px var(--color-rust-mid),
    0 0 18px var(--glow-ember-mid),
    0 0 6px var(--glow-ember-strong),
    inset 3px 0 0 var(--color-rust-bright) !important;
  transform: translateY(-1px);
}

.card--selected::before {
  background: linear-gradient(
    to right,
    transparent 5%,
    var(--color-rust-mid) 20%,
    var(--color-rust-bright) 50%,
    var(--color-rust-mid) 80%,
    transparent 95%
  ) !important;
}

/* ── App Shell ──────────────────────────────────────────── */

.app {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  max-width: 1200px;
  margin: 0 auto;
}

/* ── Stat Bar (top, sticky) ─────────────────────────────── */

.stat-bar {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
}


/* Ashes budget in stat bar */
.stat-bar__ashes {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-left: auto;
  padding: var(--space-1) var(--space-3);
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border-dim);
  border-radius: var(--radius-md);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  white-space: nowrap;
}

.stat-bar__ashes-value {
  font-size: var(--text-base);
  font-weight: var(--weight-bold);
  color: var(--color-bronze-bright);
}

.stat-bar__ashes-value--low {
  color: var(--color-blood-bright);
}

.stat-bar__ashes-value--zero {
  color: var(--color-text-faint);
}

/* ── Step Content Area ──────────────────────────────────── */

.step-content {
  flex: 1;
  padding: var(--space-5) var(--space-4);
}

.step-pane {
  display: none;
}

.step-pane--active {
  display: block;
  animation: fadeIn var(--duration-normal) var(--ease-out);
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Step Header ────────────────────────────────────────── */

.step-header {
  margin-bottom: var(--space-6);
}

.step-header__title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--color-text-heading);
  letter-spacing: var(--tracking-wide);
  margin-bottom: var(--space-2);
}

.step-header__desc {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  font-style: italic;
  line-height: var(--leading-relaxed);
}

/* ── Identity Form (Step 1) ─────────────────────────────── */

.identity-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  max-width: 480px;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.form-group__label {
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--color-text-label);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

/* ── Archetype Banner ───────────────────────────────────── */

.archetype-banner {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-parchment);
  border: 1px solid var(--color-border-base);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-4);
}

.archetype-banner__label {
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
}

.archetype-banner__name {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--color-rust-bright);
}

.archetype-banner__clear {
  margin-left: auto;
}

/* ── Breed Selection (Step 2) ───────────────────────────── */

.breed-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--space-4);
}

/* Let benefit text wrap inside breed/size cards */
#breed-grid .card__footer,
#size-grid .card__footer {
  display: block;
  overflow: hidden;
}

#breed-grid .card__footer .badge,
#size-grid .card__footer .badge {
  display: block;
  white-space: normal;
  height: auto;
  line-height: 1.4;
  text-align: left;
  padding: var(--space-1) var(--space-2);
  width: 100%;
  word-break: break-word;
}

/* ── Size Selection (Step 3) ────────────────────────────── */

.size-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}

.size-choice {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.size-choice .btn {
  width: auto;
  flex: 1;
}

.size-choice .btn--active {
  background: var(--color-rust-mid);
  border-color: var(--color-rust-bright);
  color: var(--color-text-heading);
}

/* ── Ashes Distribution (Step 4) ────────────────────────── */

.ashes-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
}

@media (max-width: 768px) {
  .ashes-layout {
    grid-template-columns: 1fr;
  }
}

.ashes-section {
  padding: var(--space-4);
  background: var(--color-bg-panel);
  border: 1px solid var(--color-border-dim);
  border-radius: var(--radius-md);
}

.ashes-section__title {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  color: var(--color-text-heading);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-border-dim);
}

/* Attribute row */
.attr-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--color-border-subtle);
}

.attr-row:last-child {
  border-bottom: none;
}

.attr-row__name {
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  color: var(--color-text-label);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  width: 120px;
  flex-shrink: 0;
}

.attr-row__controls {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.attr-row__btn {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border-dim);
  border-radius: var(--radius-sm);
  color: var(--color-text-secondary);
  font-family: var(--font-mono);
  font-size: var(--text-lg);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
}

.attr-row__btn:hover:not(:disabled) {
  background: var(--color-bg-hover);
  border-color: var(--color-border-base);
  color: var(--color-text-primary);
}

.attr-row__btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.attr-row__value {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  color: var(--color-text-heading);
  width: 36px;
  text-align: center;
}

.attr-row__cost {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  margin-left: auto;
  white-space: nowrap;
}

/* Burden row (PH/MH) */
.burden-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--color-border-subtle);
}

.burden-row:last-child {
  border-bottom: none;
}

.burden-row__name {
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  color: var(--color-text-label);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  width: 120px;
  flex-shrink: 0;
}

.burden-row__controls {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.burden-row__value {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  color: var(--color-text-heading);
  width: 36px;
  text-align: center;
}

.burden-row__derived {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-sage-text);
  margin-left: var(--space-2);
}

/* ── Discipline & Mastery Picker ────────────────────────── */

.disc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.disc-group-label {
  grid-column: 1 / -1;
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  padding: var(--space-2) 0 var(--space-1);
  border-bottom: 1px solid var(--color-border-subtle);
}

.mastery-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  max-height: 400px;
  overflow-y: auto;
}

.mastery-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-3);
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border-dim);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
}

.mastery-item:hover {
  background: var(--color-bg-hover);
  border-color: var(--color-border-base);
}

.mastery-item--selected {
  border-color: var(--color-rust-mid);
  background: rgba(139, 69, 19, 0.1);
}

.mastery-item--free {
  border-color: var(--color-sage-text);
  background: rgba(90, 130, 60, 0.08);
}

.mastery-item--breed-free {
  border-color: #7a9e6a;
  background: rgba(90, 150, 60, 0.12);
  box-shadow: inset 2px 0 0 #7a9e6a;
}

.mastery-item__info {
  flex: 1;
  min-width: 0;
}

.mastery-item__name {
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--color-text-heading);
}

.mastery-item__desc {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
  margin-top: var(--space-1);
}

.mastery-item__tags {
  display: flex;
  gap: var(--space-1);
  flex-wrap: wrap;
  margin-top: var(--space-1);
}

.mastery-item__cost {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-bronze-bright);
  white-space: nowrap;
  flex-shrink: 0;
}

/* Filter tabs for mastery discipline */
.mastery-filter {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-3);
}

.mastery-filter__tab {
  padding: var(--space-1) var(--space-3);
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border-dim);
  border-radius: var(--radius-sm);
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

.mastery-filter__tab:hover {
  background: var(--color-bg-hover);
  color: var(--color-text-primary);
}

.mastery-filter__tab--active {
  background: var(--color-rust-dim);
  border-color: var(--color-rust-mid);
  color: var(--color-text-heading);
}

/* ── Equipment Picker (Step 5) ──────────────────────────── */

.equip-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
}

@media (max-width: 768px) {
  .equip-layout {
    grid-template-columns: 1fr;
  }
}

.equip-slots {
  display: flex;
  gap: var(--space-1);
  margin-bottom: var(--space-4);
}

.equip-slot {
  width: 28px;
  height: 28px;
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border-dim);
  border-radius: var(--radius-sm);
  transition: background var(--duration-fast) var(--ease-out);
}

.equip-slot--filled {
  background: var(--color-rust-dim);
  border-color: var(--color-rust-mid);
}

.equip-category {
  margin-bottom: var(--space-4);
}

.equip-category__title {
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  margin-bottom: var(--space-2);
  padding-bottom: var(--space-1);
  border-bottom: 1px solid var(--color-border-subtle);
}

.equipped-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.equipped-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border-dim);
  border-radius: var(--radius-sm);
}

.equipped-item__name {
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  color: var(--color-text-heading);
  flex: 1;
}

.equipped-item__slots {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
}

.equipped-item__remove {
  background: none;
  border: none;
  color: var(--color-text-faint);
  cursor: pointer;
  font-size: var(--text-base);
  padding: var(--space-1);
  transition: color var(--duration-fast);
}

.equipped-item__remove:hover {
  color: var(--color-blood-bright);
}

/* ── Summary / Export ───────────────────────────────────── */

.step-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: var(--space-6);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border-dim);
}

/* ── Twice-Blooded picker ───────────────────────────────── */

.twice-blooded-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-top: var(--space-4);
}

@media (max-width: 600px) {
  .twice-blooded-row {
    grid-template-columns: 1fr;
  }
}

/* ── Chosen items summary ───────────────────────────────── */

.chosen-summary {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.choice-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 2px var(--space-2);
  background: rgba(139, 69, 19, 0.12);
  border: 1px solid var(--color-rust-mid);
  border-radius: 3px;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-text-primary);
  line-height: 1.4;
}

.choice-tag__remove {
  background: none;
  border: none;
  color: var(--color-text-faint);
  cursor: pointer;
  font-size: 0.85rem;
  line-height: 1;
  padding: 0 2px;
  margin-left: 2px;
}

.choice-tag__remove:hover {
  color: var(--color-blood-bright);
}

/* Selected masteries summary strip */
.mastery-chosen-summary {
  margin-bottom: var(--space-3);
  padding: var(--space-2) var(--space-3);
  background: rgba(139, 69, 19, 0.05);
  border: 1px solid var(--color-border-dim);
  border-radius: 4px;
}

.mastery-chosen-summary:empty {
  display: none;
}

/* "Selected (N)" filter tab — slightly distinct tint */
.mastery-filter__tab--selected-view {
  border-color: var(--color-rust-mid);
  color: var(--color-rust-bright);
}

.mastery-filter__tab--selected-view.mastery-filter__tab--active {
  background: var(--color-rust-dim);
  color: var(--color-text-heading);
}

/* "Breed Bonus" filter tab */
.mastery-filter__tab--breed {
  border-color: #7a9e6a;
  color: var(--color-sage-text);
}

.mastery-filter__tab--breed.mastery-filter__tab--active {
  background: rgba(90, 150, 60, 0.15);
  color: var(--color-text-heading);
}

/* ── Mastery detail drawer (inline expand) ──────────────── */

.mastery-item__detail {
  display: none;
  padding-top: var(--space-2);
  border-top: 1px solid var(--color-border-subtle);
  margin-top: var(--space-2);
}

.mastery-item--expanded .mastery-item__detail {
  display: block;
}

/* ── Mobile layout ──────────────────────────────────────────
   On small screens the stat bar identity section eats too much
   horizontal space and hides the right-hand stats. Hide the
   name/class block so all six stat values fit in one row.
   The step-nav already scrolls horizontally so EQUIPMENT
   remains reachable by swiping.                              */
@media (max-width: 600px) {
  .stat-bar__identity {
    display: none;
  }

  .stat-bar__stat {
    min-width: 52px;
    padding: 0 var(--space-2);
  }

  .stat-bar__ashes {
    padding: 0 var(--space-2);
  }
}

/* ── Forbidden Knowledge warning ────────────────────────── */

.fk-warning {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: rgba(139, 30, 30, 0.15);
  border: 1px solid var(--color-blood-dim);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-blood-bright);
  margin-top: var(--space-2);
}

/* ── Human attribute choice ─────────────────────────────── */

.human-attr-choice {
  margin-top: var(--space-3);
  padding: var(--space-3);
  background: var(--color-bg-parchment);
  border: 1px solid var(--color-border-base);
  border-radius: var(--radius-sm);
}

.human-attr-choice__title {
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  color: var(--color-text-label);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  margin-bottom: var(--space-2);
}

.human-attr-choice__options {
  display: flex;
  gap: var(--space-2);
}
