/* game.css — Hyperspace Armada
   Dashboard layout and widget styles.
   Links after _shared/style.css — overrides canvas sizing. */

/* ── Game-local color tokens (dark gradient anchors not in shared system) ── */
:root {
  --gd-green-dk:  #006e38;
  --gd-yellow-dk: #6a5000;
  --gd-orange-dk: #6a3000;
  --gd-red-dk:    #6a001a;
}

/* ── Shell ───────────────────────────────────────────────── */
.dashboard {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
}

/* ── Header ──────────────────────────────────────────────── */
.sys-hdr {
  height: 44px;
  background: linear-gradient(180deg, var(--color-panel-deep), var(--color-panel));
  border: 1px solid var(--color-border);
  border-bottom: none;
  display: flex;
  align-items: center;
  padding: 0 14px;
  gap: 14px;
  overflow: hidden;
}

.sys-title {
  font-size: 17px;
  letter-spacing: 5px;
  color: var(--color-primary);
  text-shadow: 0 0 18px rgba(0,212,255,.5);
  text-transform: uppercase;
  white-space: nowrap;
}

.sys-sub {
  font-size: 8px;
  letter-spacing: 2px;
  color: var(--color-text-dark);
  text-transform: uppercase;
}

.hdiv {
  width: 1px;
  height: 24px;
  background: var(--color-border);
  flex-shrink: 0;
}

.hstat {
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex-shrink: 0;
}

.hstat-lbl {
  font-size: 8px;
  letter-spacing: 1.5px;
  color: var(--color-text-dark);
  text-transform: uppercase;
}

.hstat-val {
  font-size: 15px;
  font-weight: bold;
  color: var(--color-bright);
  line-height: 1;
}

.hv-c { color: var(--color-primary); }
.hv-y { color: var(--color-accent); }
.hv-g { color: var(--color-success); }
.hv-r { color: var(--color-danger); }

.hdr-r {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 14px;
}

/* ── Main row ────────────────────────────────────────────── */
.sys-main {
  display: flex;
  /* Height is driven by the canvas-frame inside sys-game.
     Panels use align-self:stretch and overflow-y:auto so they
     never push the row taller than the canvas. */
  align-items: flex-start;
  overflow: hidden;
}

/* ── Side panels ─────────────────────────────────────────── */
.sys-panel {
  width: 186px;
  flex-shrink: 0;
  background: var(--color-panel);
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  overflow-y: auto;
  overflow-x: hidden;
  /* Height is constrained by sys-main which matches canvas height */
  align-self: stretch;
}

.sys-panel--l {
  border: 1px solid var(--color-border);
  border-right: none;
}

.sys-panel--r {
  border: 1px solid var(--color-border);
  border-left: none;
}

/* ── Widget ──────────────────────────────────────────────── */
.widget {
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border-dim);
  padding: 8px 10px;
  position: relative;
  flex-shrink: 0;
}

.widget::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,212,255,.2), transparent);
}

.wlbl {
  font-size: 8px;
  letter-spacing: 2px;
  color: var(--color-text-dark);
  text-transform: uppercase;
  margin-bottom: 5px;
  display: flex;
  align-items: center;
  gap: 5px;
}

.dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--color-primary);
  box-shadow: 0 0 5px var(--color-primary);
  animation: dot-blink 1.5s infinite;
}

.dot.r { background: var(--color-danger);  box-shadow: 0 0 5px var(--color-danger); }
.dot.g { background: var(--color-success); box-shadow: 0 0 5px var(--color-success); }
.dot.y { background: var(--color-accent);  box-shadow: 0 0 5px var(--color-accent); }
.dot.off { background: var(--color-text-dark); box-shadow: none; animation: none; }

@keyframes dot-blink { 0%,100%{opacity:1} 50%{opacity:.1} }

.wval {
  font-size: 22px;
  font-weight: bold;
  color: var(--color-primary);
  line-height: 1;
}

.wval.sm { font-size: 16px; }
.wval.lg { font-size: 28px; }
.wval.g  { color: var(--color-success); }
.wval.y  { color: var(--color-accent); }
.wval.o  { color: var(--color-accent-2); }
.wval.r  { color: var(--color-danger); }

.wsub {
  font-size: 8px;
  letter-spacing: 1.5px;
  color: var(--color-text-dark);
  text-transform: uppercase;
  margin-top: 3px;
}

/* ── Progress bars ───────────────────────────────────────── */
.prog {
  height: 5px;
  background: var(--color-panel-deep);
  border: 1px solid var(--color-border-dim);
  margin-top: 6px;
  overflow: hidden;
}

.pf {
  height: 100%;
  transition: width .3s ease, background .5s ease;
}

.pf.c {
  background: linear-gradient(90deg, var(--color-primary-dark), var(--color-primary));
  box-shadow: 0 0 6px rgba(0,212,255,.35);
}

.pf.g {
  background: linear-gradient(90deg, var(--gd-green-dk), var(--color-success));
  box-shadow: 0 0 5px rgba(0,240,128,.3);
}

.pf.y {
  background: linear-gradient(90deg, var(--gd-yellow-dk), var(--color-accent));
}

.pf.o {
  background: linear-gradient(90deg, var(--gd-orange-dk), var(--color-accent-2));
  box-shadow: 0 0 5px rgba(255,153,51,.3);
}

.pf.r {
  background: linear-gradient(90deg, var(--gd-red-dk), var(--color-danger));
  box-shadow: 0 0 6px rgba(255,64,96,.4);
}

@keyframes crit-pulse { 0%,100%{opacity:1} 50%{opacity:.3} }
.pf.crit { animation: crit-pulse .6s infinite; }

/* ── Fleet status ────────────────────────────────────────── */
.fleet-list {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-top: 5px;
}

.fleet-ship {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 9px;
  letter-spacing: 1.5px;
  color: var(--color-text-dim);
  text-transform: uppercase;
  transition: opacity .3s;
}

.fleet-ship.located { opacity: 0.2; }

.fleet-ship-cells { display: flex; gap: 2px; }

.fleet-ship-cell {
  width: 10px;
  height: 10px;
  background: var(--color-primary);
  box-shadow: 0 0 4px rgba(0,212,255,.5);
}

.fleet-ship.located .fleet-ship-cell {
  background: var(--color-text-dark);
  box-shadow: none;
}

/* ── Log / command feed ──────────────────────────────────── */
.log-widget {
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.log-wrap {
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-height: 0;
  margin-top: 4px;
}

.log-e {
  font-size: 8px;
  letter-spacing: .8px;
  color: var(--color-text-dark);
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.6;
}

.log-e.fresh { color: var(--color-primary); }

/* ── Game center ─────────────────────────────────────────── */
.sys-game {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  background: var(--color-bg);
}

/* ── Canvas frame ────────────────────────────────────────── */
.canvas-frame {
  position: relative;
  border: 1px solid var(--color-border);
  border-bottom: none;
  overflow: hidden;
  background: var(--color-bg);
  flex-shrink: 0;
  /* width/height set by JS to match canvas attribute */
}

/* Corner accent brackets */
.canvas-frame::before,
.canvas-frame::after {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  z-index: 10;
  pointer-events: none;
}

.canvas-frame::before {
  top: 0; left: 0;
  border-top: 2px solid var(--color-primary);
  border-left: 2px solid var(--color-primary);
  box-shadow: -1px -1px 10px rgba(0,212,255,.3);
}

.canvas-frame::after {
  top: 0; right: 0;
  border-top: 2px solid var(--color-primary);
  border-right: 2px solid var(--color-primary);
  box-shadow: 1px -1px 10px rgba(0,212,255,.3);
}

.cbr, .cbl {
  position: absolute;
  width: 16px;
  height: 16px;
  z-index: 10;
  pointer-events: none;
}

.cbr {
  bottom: 0; right: 0;
  border-bottom: 2px solid var(--color-primary);
  border-right: 2px solid var(--color-primary);
  box-shadow: 1px 1px 10px rgba(0,212,255,.3);
}

.cbl {
  bottom: 0; left: 0;
  border-bottom: 2px solid var(--color-primary);
  border-left: 2px solid var(--color-primary);
  box-shadow: -1px 1px 10px rgba(0,212,255,.3);
}

.scanlines {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 4;
  background: repeating-linear-gradient(
    0deg, transparent, transparent 2px,
    rgba(0,0,0,.07) 2px, rgba(0,0,0,.07) 4px
  );
}

canvas#gameCanvas {
  display: block;
  width: 100%;
  height: 100%;
}

/* ── Control bar ─────────────────────────────────────────── */
.ctrl-bar {
  height: 32px;
  background: var(--color-panel);
  border: 1px solid var(--color-border);
  border-top: 1px solid var(--color-border-dim);
  border-bottom: none;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 0 10px;
  flex-shrink: 0;
}

#sound-btn, #reset-btn {
  background: transparent;
  border: 1px solid var(--color-primary);
  color: var(--color-primary);
  padding: 3px 10px;
  font-size: 8px;
  letter-spacing: 2px;
  cursor: pointer;
  font-family: var(--font-primary);
  text-transform: uppercase;
  transition: all .15s;
}

#sound-btn:hover, #reset-btn:hover {
  background: rgba(0,212,255,.08);
  box-shadow: 0 0 10px rgba(0,212,255,.2);
}

#scan-btn {
  background: transparent;
  border: 1px solid var(--color-success);
  color: var(--color-success);
  padding: 3px 10px;
  font-size: 8px;
  letter-spacing: 2px;
  cursor: pointer;
  font-family: var(--font-primary);
  text-transform: uppercase;
  transition: all .15s;
}

#scan-btn:hover:not(:disabled) {
  background: rgba(0,240,128,.08);
  box-shadow: 0 0 10px rgba(0,240,128,.2);
}

#scan-btn:disabled {
  opacity: 0.3;
  cursor: default;
}

#campaign-wipe-btn {
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 20;
  background: transparent;
  border: 1px solid var(--color-danger);
  color: var(--color-danger);
  padding: 5px 16px;
  font-size: 10px;
  letter-spacing: 2px;
  cursor: pointer;
  font-family: var(--font-primary);
  text-transform: uppercase;
  transition: all .15s;
}

#campaign-wipe-btn:hover {
  background: rgba(255,64,96,.08);
  box-shadow: 0 0 10px rgba(255,64,96,.2);
}

#wipe-btn {
  background: transparent;
  border: 1px solid var(--color-danger);
  color: var(--color-danger);
  padding: 3px 10px;
  font-size: 8px;
  letter-spacing: 2px;
  cursor: pointer;
  font-family: var(--font-primary);
  text-transform: uppercase;
  transition: all .15s;
  flex-shrink: 0;
}

#wipe-btn:hover {
  background: rgba(255,64,96,.08);
  box-shadow: 0 0 10px rgba(255,64,96,.2);
}

/* ── Footer ──────────────────────────────────────────────── */
.sys-ftr {
  height: 30px;
  background: linear-gradient(0deg, var(--color-bg-secondary), var(--color-panel));
  border: 1px solid var(--color-border);
  border-top: none;
  display: flex;
  align-items: center;
  padding: 0 14px;
  gap: 14px;
  overflow: hidden;
}

.flog {
  flex: 1;
  font-size: 8px;
  letter-spacing: 1px;
  color: var(--color-text-dark);
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  text-transform: uppercase;
}

.fstats {
  display: flex;
  gap: 16px;
  flex-shrink: 0;
}

.fstat {
  font-size: 9px;
  letter-spacing: 1.5px;
  color: var(--color-text-dark);
}

.fstat span { color: var(--color-bright); }
