/* css/game.css - final game styles for combat, missions, shipyard */

/* ─── EPIC COMBAT ─── */
.combat-overlay {
  position: fixed; inset: 0;
  z-index: 90;
  animation: scene-fade-in 0.5s ease-out;
}
.combat-backdrop {
  position: absolute; inset: 0;
  background: radial-gradient(circle at center, rgba(30, 5, 15, 0.5), rgba(0, 0, 0, 0.92));
}
.combat-canvas { position: absolute; inset: 0; }
.combat-ui {
  position: relative; width: 100%; height: 100%;
  display: flex; flex-direction: column;
  padding: 20px;
  pointer-events: none;
}
.combat-ui > * { pointer-events: auto; }

.combat-enemy-bar, .combat-player-bar {
  background: rgba(10, 5, 24, 0.85);
  backdrop-filter: blur(8px);
  border: 1px solid var(--border-gold);
  border-radius: 6px;
  padding: 14px 20px;
  width: 480px;
  max-width: 90vw;
}
.combat-enemy-bar {
  align-self: center;
  border-color: rgba(255, 68, 102, 0.5);
  margin-bottom: auto;
}
.combat-player-bar {
  align-self: center;
  border-color: rgba(94, 215, 255, 0.5);
  margin-top: auto;
  margin-bottom: 10px;
}
.combat-name {
  font-size: 14px; color: var(--gold);
  letter-spacing: 0.1em;
  margin-bottom: 10px;
  display: flex; align-items: center; gap: 10px;
}
.combat-class {
  font-size: 10px; color: var(--text-dim);
  letter-spacing: 0.2em; text-transform: uppercase;
  padding: 2px 8px; border: 1px solid var(--border-soft);
  border-radius: 10px;
}
.combat-bars { display: flex; flex-direction: column; gap: 4px; margin-bottom: 6px; }
.combat-bar {
  height: 10px; background: rgba(255, 255, 255, 0.05);
  border-radius: 5px; overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.05);
}
.combat-hp {
  height: 100%;
  background: linear-gradient(to right, #ff4466, #ff8899);
  transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 0 8px rgba(255, 68, 102, 0.4);
}
.combat-shield {
  height: 100%;
  background: linear-gradient(to right, #3a9ac8, #5ed7ff);
  transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 0 8px rgba(94, 215, 255, 0.4);
}
.combat-numbers {
  font-family: var(--font-mono, monospace);
  font-size: 11px;
  color: var(--text-dim);
  letter-spacing: 0.1em;
}

.combat-log {
  align-self: center;
  font-size: 14px;
  color: var(--text);
  text-align: center;
  max-width: 600px;
  margin: 20px 0;
  font-style: italic;
  min-height: 80px;
}
.combat-log div { opacity: 0.5; transition: opacity 0.3s; margin: 4px 0; }
.combat-log div.log-latest {
  opacity: 1; color: var(--gold);
  font-size: 16px; font-weight: 500;
  text-shadow: 0 0 20px rgba(248, 216, 120, 0.5);
  animation: log-flash 0.4s ease-out;
}

@keyframes log-flash {
  0% { transform: scale(1); }
  50% { transform: scale(1.05); }
  100% { transform: scale(1); }
}

.combat-actions {
  align-self: center;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 8px;
  width: 100%;
  max-width: 720px;
  margin-bottom: 14px;
}
.combat-ability-btn {
  background: rgba(10, 5, 24, 0.85);
  backdrop-filter: blur(8px);
  border: 1px solid var(--border-soft);
  border-left: 3px solid var(--gold);
  color: var(--text);
  padding: 12px 14px;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s;
  font-family: inherit;
  text-align: left;
  display: flex; flex-direction: column; gap: 2px;
}
.combat-ability-btn:hover:not(:disabled) {
  background: rgba(248, 216, 120, 0.12);
  transform: translateY(-2px);
  box-shadow: 0 4px 20px rgba(248, 216, 120, 0.2);
}
.combat-ability-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.combat-ability-name { font-size: 13px; color: var(--gold); font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; }
.combat-ability-desc { font-size: 10px; color: var(--text-dim); font-style: italic; }
.combat-flee-btn { border-left-color: var(--text-dim); }
.combat-flee-btn .combat-ability-name { color: var(--text-dim); }

/* ─── MISSIONS BOARD ─── */
.missions-overlay {
  position: fixed; inset: 0;
  z-index: 85;
  animation: scene-fade-in 0.3s ease-out;
  display: flex; align-items: center; justify-content: center;
}
.missions-overlay.closing { animation: scene-fade-out 0.25s ease-in forwards; }
.missions-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.8); backdrop-filter: blur(12px); cursor: pointer; }

.missions-panel {
  position: relative;
  background: var(--bg-void);
  border: 1px solid var(--gold);
  border-radius: 8px;
  width: 900px; max-width: 94vw;
  max-height: 88vh;
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: 0 0 80px rgba(248, 216, 120, 0.2);
}
.missions-header { display: flex; align-items: center; justify-content: space-between; padding: 24px 32px; border-bottom: 1px solid var(--border-soft); }
.missions-title { font-family: var(--font-display); font-size: 22px; color: var(--gold); letter-spacing: 0.15em; }
.missions-subtitle { font-size: 11px; letter-spacing: 0.2em; color: var(--text-dim); margin-top: 4px; }

.mission-active-banner {
  background: rgba(123, 255, 154, 0.08);
  border-left: 3px solid var(--green);
  padding: 14px 24px;
  display: flex; align-items: center; gap: 16px;
  font-size: 13px;
  color: var(--text);
}
.mission-active-banner strong { color: var(--green); margin-right: 4px; }
.btn-small {
  margin-left: auto;
  background: transparent;
  border: 1px solid var(--green);
  color: var(--green);
  padding: 6px 14px;
  border-radius: 4px;
  font-family: inherit;
  font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
}
.btn-small:hover { background: var(--green); color: var(--bg-void); }

.missions-grid {
  padding: 20px 32px;
  overflow-y: auto;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}

.mission-card {
  background: rgba(248, 216, 120, 0.04);
  border: 1px solid var(--border-soft);
  border-left: 3px solid var(--gold);
  border-radius: 4px;
  padding: 16px 18px;
  transition: all 0.2s;
  display: flex; flex-direction: column; gap: 10px;
}
.mission-card:hover { background: rgba(248, 216, 120, 0.1); }
.mission-header { display: flex; align-items: center; gap: 10px; }
.mission-icon {
  font-size: 20px; color: var(--gold);
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--border-soft);
  border-radius: 50%;
}
.mission-title-text { font-size: 14px; color: var(--text); font-weight: 500; flex: 1; }
.mission-faction { font-size: 10px; letter-spacing: 0.2em; }
.mission-danger {
  font-size: 12px;
  color: #ffb040;
  letter-spacing: 0.1em;
  font-family: monospace;
}
.mission-footer { display: flex; justify-content: space-between; align-items: center; margin-top: auto; }
.mission-reward {
  font-family: var(--font-mono, monospace);
  font-size: 16px; color: var(--green);
  font-weight: 500;
}

/* ─── SHIPYARD ─── */
.shipyard-overlay {
  position: fixed; inset: 0; z-index: 85;
  animation: scene-fade-in 0.3s ease-out;
  display: flex; align-items: center; justify-content: center;
}
.shipyard-overlay.closing { animation: scene-fade-out 0.25s ease-in forwards; }
.shipyard-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.8); backdrop-filter: blur(12px); cursor: pointer; }

.shipyard-panel {
  position: relative; background: var(--bg-void);
  border: 1px solid var(--gold); border-radius: 8px;
  width: 1100px; max-width: 96vw; max-height: 92vh;
  overflow: hidden; display: flex; flex-direction: column;
  box-shadow: 0 0 80px rgba(248, 216, 120, 0.2);
}
.shipyard-header { display: flex; align-items: center; justify-content: space-between; padding: 20px 28px; border-bottom: 1px solid var(--border-soft); gap: 20px; }
.shipyard-title { font-family: var(--font-display); font-size: 22px; color: var(--gold); letter-spacing: 0.15em; }
.shipyard-subtitle { font-size: 11px; letter-spacing: 0.2em; color: var(--text-dim); margin-top: 4px; }
.shipyard-credits-box { text-align: right; }
.shipyard-credits-label { font-size: 10px; letter-spacing: 0.3em; color: var(--text-dim); }
.shipyard-credits { font-family: var(--font-mono, monospace); font-size: 18px; color: var(--green); font-weight: 500; margin-top: 2px; }

.shipyard-tiers { display: flex; gap: 4px; padding: 14px 28px; border-bottom: 1px solid var(--border-soft); }
.shipyard-tier {
  background: rgba(248, 216, 120, 0.04);
  border: 1px solid var(--border-soft);
  color: var(--text-dim);
  padding: 8px 18px; border-radius: 4px;
  font-family: inherit; font-size: 11px; letter-spacing: 0.15em;
  cursor: pointer; transition: all 0.2s;
}
.shipyard-tier:hover { color: var(--text); border-color: var(--border-gold); }
.shipyard-tier.active { color: var(--gold); background: rgba(248, 216, 120, 0.15); border-color: var(--gold); }

.shipyard-grid {
  padding: 20px 28px; overflow-y: auto;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 14px;
}
.shipyard-card {
  background: rgba(248, 216, 120, 0.04);
  border: 1px solid var(--border-soft);
  border-left: 3px solid var(--gold);
  border-radius: 4px;
  padding: 16px 18px;
  display: flex; flex-direction: column; gap: 10px;
  transition: all 0.2s;
}
.shipyard-card:hover { background: rgba(248, 216, 120, 0.1); border-color: var(--gold); }
.shipyard-card.owned { border-left-color: var(--green); background: rgba(123, 255, 154, 0.06); }
.shipyard-card.active { border-left-color: var(--cyan); background: rgba(94, 215, 255, 0.08); }
.shipyard-card.unaffordable { opacity: 0.45; }

.shipyard-card-header { display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.shipyard-card-name { font-size: 15px; color: var(--text); font-weight: 500; }
.shipyard-card-class {
  font-size: 10px; letter-spacing: 0.2em;
  color: var(--text-dim); text-transform: uppercase;
}

.shipyard-stats { display: flex; flex-direction: column; gap: 4px; padding: 6px 0; border-top: 1px solid var(--border-soft); border-bottom: 1px solid var(--border-soft); }
.stat-bar { display: grid; grid-template-columns: 60px 1fr 40px; gap: 8px; align-items: center; font-size: 10px; }
.stat-bar span { color: var(--text-dim); letter-spacing: 0.1em; }
.stat-bar .bar { background: rgba(255,255,255,0.05); height: 4px; border-radius: 2px; overflow: hidden; }
.stat-bar .bar > div { height: 100%; transition: width 0.3s; }
.stat-bar b { font-family: var(--font-mono, monospace); color: var(--gold); text-align: right; font-weight: 500; }

.shipyard-footer { display: flex; justify-content: space-between; align-items: center; margin-top: auto; }
.shipyard-price { font-family: var(--font-mono, monospace); font-size: 14px; color: var(--gold); font-weight: 500; }
