:root {
  --bg: #050505;
  --bg-elev: #0f0f0f;
  --bg-elev-2: #181818;
  --border: #241d10;
  --border-strong: #3a2f1a;
  --gold: #d4af37;
  --gold-bright: #f5cf5e;
  --gold-dim: #8a7322;
  --blood: #a11c1c;
  --blood-bright: #d94545;
  --text: #ececec;
  --text-dim: #8a8a8a;
  --ok: #6ed19a;
}

* { box-sizing: border-box; }

/* ============ Cover (fake public site) ============ */
body.cover-locked > .site-header,
body.cover-locked > main,
body.cover-locked > .modal,
body.cover-locked > .toast-region { display: none !important; }
body.cover-locked .bg-grain,
body.cover-locked .scanlines { display: none; }

.cover-screen {
  position: fixed;
  inset: 0;
  z-index: 4000;
  background:
    radial-gradient(circle at 80% -10%, rgba(80, 130, 200, 0.18), transparent 60%),
    radial-gradient(circle at 0% 110%, rgba(60, 80, 110, 0.12), transparent 55%),
    linear-gradient(180deg, #0e1622 0%, #060a10 100%);
  color: #d8e2ee;
  font-family: "Rajdhani", "Segoe UI", system-ui, sans-serif;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
.cover-screen.hidden { display: none; }
.cover-screen.dissolving { animation: coverDissolve 0.6s ease forwards; }
@keyframes coverDissolve {
  0% { opacity: 1; filter: brightness(1); }
  60% { opacity: 0.4; filter: brightness(1.6) blur(0.5px); }
  100% { opacity: 0; filter: brightness(0.2) blur(2px); }
}
.cover-noise {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: radial-gradient(rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 3px 3px;
  opacity: 0.35;
}

.cover-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 36px;
  border-bottom: 1px solid rgba(160, 180, 210, 0.12);
}
.cover-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: default;
  user-select: none;
}
.cover-mark {
  background: #1c2a3c;
  color: #94b0d4;
  padding: 4px 8px;
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 2px;
  font-size: 1rem;
  border: 1px solid rgba(120, 150, 180, 0.3);
}
.cover-name {
  font-family: "Cinzel", "Georgia", serif;
  font-size: 1.05rem;
  letter-spacing: 0.6px;
  color: #c8d4e3;
}
.cover-dot {
  color: #6e8aab;
  cursor: pointer;
  margin-left: 1px;
}
.cover-nav { display: flex; gap: 22px; }
.cover-nav a {
  color: #95a5be;
  text-decoration: none;
  font-size: 0.9rem;
  letter-spacing: 0.5px;
}
.cover-nav a:hover { color: #d8e2ee; }

.cover-main { flex: 1; padding: 50px 36px 60px; max-width: 1180px; width: 100%; margin: 0 auto; position: relative; }

.cover-hero {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 40px;
  align-items: end;
  margin-bottom: 60px;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(120, 150, 180, 0.12);
}
.cover-hero-tag {
  display: inline-block;
  font-family: "Consolas", monospace;
  font-size: 0.72rem;
  color: #6e8aab;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 4px 8px;
  border: 1px solid rgba(120, 150, 180, 0.25);
  margin-bottom: 14px;
}
.cover-hero-title {
  font-family: "Cinzel", serif;
  font-size: 2.6rem;
  margin: 0 0 14px;
  letter-spacing: 0.5px;
  color: #e0e8f3;
  line-height: 1.15;
}
.cover-hero-sub {
  margin: 0 0 22px;
  color: #8499b3;
  font-size: 1.05rem;
  letter-spacing: 0.4px;
  line-height: 1.5;
}
.cover-hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.cover-cta {
  display: inline-block;
  padding: 11px 24px;
  background: #2a5285;
  color: #e8f0fa;
  text-decoration: none;
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 2px;
  font-size: 0.92rem;
  border: 1px solid #3d6da8;
  transition: background 0.15s ease, border-color 0.15s ease;
}
.cover-cta:hover { background: #356bb0; }
.cover-cta-ghost {
  background: transparent;
  color: #a8b8d0;
  border-color: rgba(120, 150, 180, 0.3);
}
.cover-cta-ghost:hover { background: rgba(60, 90, 130, 0.2); border-color: #3d6da8; color: #d8e2ee; }

.cover-hero-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.cover-stat {
  background: rgba(20, 30, 44, 0.55);
  border: 1px solid rgba(120, 150, 180, 0.12);
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: relative;
  overflow: hidden;
}
.cover-stat::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 28px;
  height: 2px;
  background: #3d6da8;
}
.cover-stat-num {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.85rem;
  letter-spacing: 1.5px;
  color: #d8e2ee;
}
.cover-stat-lbl {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  color: #6e8aab;
  text-transform: uppercase;
}

.cover-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 18px;
  margin-bottom: 50px;
}
.cover-card {
  background: rgba(20, 30, 44, 0.6);
  border: 1px solid rgba(120, 150, 180, 0.15);
  padding: 22px;
  position: relative;
  transition: border-color 0.15s ease;
}
.cover-card:hover { border-color: rgba(120, 150, 180, 0.3); }
.cover-card-icon {
  position: absolute;
  top: 12px;
  right: 16px;
  font-size: 1.4rem;
  color: rgba(120, 150, 180, 0.35);
  font-family: "Consolas", monospace;
}
.cover-card h3 {
  margin: 0 0 8px;
  color: #c8d4e3;
  font-family: "Cinzel", serif;
  font-size: 1.05rem;
  letter-spacing: 0.4px;
}
.cover-card p { margin: 0 0 12px; color: #8499b3; font-size: 0.92rem; line-height: 1.55; }
.cover-card-list {
  margin: 0;
  padding-left: 16px;
  color: #6e8aab;
  font-size: 0.84rem;
  line-height: 1.7;
  letter-spacing: 0.3px;
}
.cover-card-list li::marker { color: #3d6da8; }

/* Track section */
.cover-track {
  background: linear-gradient(180deg, rgba(20, 30, 44, 0.7) 0%, rgba(15, 22, 34, 0.7) 100%);
  border: 1px solid rgba(120, 150, 180, 0.15);
  padding: 26px 28px;
  margin-bottom: 40px;
  position: relative;
}
.cover-track::before {
  content: "";
  position: absolute;
  top: -1px; left: -1px;
  width: 14px; height: 14px;
  border-top: 2px solid #3d6da8;
  border-left: 2px solid #3d6da8;
}
.cover-track::after {
  content: "";
  position: absolute;
  bottom: -1px; right: -1px;
  width: 14px; height: 14px;
  border-bottom: 2px solid #3d6da8;
  border-right: 2px solid #3d6da8;
}
.cover-track-head h3 {
  margin: 0 0 6px;
  font-family: "Cinzel", serif;
  font-size: 1.2rem;
  color: #d8e2ee;
  letter-spacing: 0.5px;
}
.cover-track-head p {
  margin: 0 0 16px;
  color: #8499b3;
  font-size: 0.92rem;
}
.cover-track-head code {
  background: rgba(0, 0, 0, 0.4);
  padding: 1px 6px;
  border: 1px solid rgba(120, 150, 180, 0.2);
  font-family: "Consolas", monospace;
  font-size: 0.85rem;
  color: #95b0d4;
}
.cover-track-form {
  display: flex;
  gap: 8px;
  align-items: stretch;
}
.cover-track-input {
  flex: 1;
  background: rgba(8, 12, 18, 0.85);
  border: 1px solid rgba(120, 150, 180, 0.25);
  color: #e0e8f3;
  padding: 11px 14px;
  font-family: "Consolas", monospace;
  font-size: 0.95rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
.cover-track-input:focus { outline: none; border-color: #3d6da8; box-shadow: 0 0 0 1px rgba(80, 130, 200, 0.3); }
.cover-track-input::placeholder { color: #5a6a82; letter-spacing: 1.5px; }
.cover-track-btn {
  background: #2a5285;
  color: #e8f0fa;
  border: 1px solid #3d6da8;
  padding: 11px 22px;
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 2px;
  font-size: 0.95rem;
  cursor: pointer;
  transition: background 0.15s ease;
}
.cover-track-btn:hover { background: #356bb0; }
.cover-track-result {
  margin-top: 12px;
  font-family: "Consolas", monospace;
  font-size: 0.85rem;
  color: #d94545;
  letter-spacing: 0.5px;
  min-height: 1em;
}
.cover-track-result.ok { color: #6ed19a; }

/* Fleet section */
.cover-fleet {
  margin-bottom: 40px;
}
.cover-fleet-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 18px;
  border-bottom: 1px solid rgba(120, 150, 180, 0.12);
  padding-bottom: 8px;
}
.cover-fleet-head h3 {
  margin: 0;
  font-family: "Cinzel", serif;
  font-size: 1.2rem;
  color: #d8e2ee;
}
.cover-fleet-tag {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  color: #6e8aab;
}
.cover-fleet-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 18px;
}
.cover-fleet-cell {
  background: rgba(20, 30, 44, 0.45);
  border: 1px solid rgba(120, 150, 180, 0.1);
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cover-fleet-num {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.65rem;
  color: #d8e2ee;
  letter-spacing: 1.5px;
}
.cover-fleet-lbl {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  color: #6e8aab;
  text-transform: uppercase;
}
.cover-zones {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.cover-zones span {
  font-family: "Consolas", monospace;
  font-size: 0.74rem;
  letter-spacing: 1px;
  color: #95a5be;
  padding: 3px 9px;
  border: 1px solid rgba(120, 150, 180, 0.15);
  background: rgba(20, 30, 44, 0.4);
}

/* Pair: hours + testimonials */
.cover-pair {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 24px;
  margin-bottom: 40px;
}
.cover-hours, .cover-quotes {
  background: rgba(20, 30, 44, 0.55);
  border: 1px solid rgba(120, 150, 180, 0.12);
  padding: 22px 24px;
}
.cover-hours h3, .cover-quotes h3 {
  margin: 0 0 14px;
  font-family: "Cinzel", serif;
  color: #d8e2ee;
  font-size: 1.05rem;
}
.cover-hours ul {
  list-style: none;
  padding: 0;
  margin: 0 0 14px;
  font-family: "Consolas", monospace;
  font-size: 0.86rem;
  color: #95a5be;
}
.cover-hours li {
  display: flex;
  justify-content: space-between;
  padding: 5px 0;
  border-bottom: 1px dashed rgba(120, 150, 180, 0.1);
}
.cover-hours li:last-child { border-bottom: 0; }
.cover-closed { color: #d94545; }
.cover-hours-foot {
  margin: 0;
  font-size: 0.82rem;
  color: #6e8aab;
  font-style: italic;
}
.cover-quotes blockquote {
  margin: 0 0 16px;
  padding-left: 14px;
  border-left: 2px solid #3d6da8;
}
.cover-quotes blockquote:last-child { margin-bottom: 0; }
.cover-quotes p {
  margin: 0 0 6px;
  color: #b8c4d6;
  font-size: 0.92rem;
  line-height: 1.55;
  font-style: italic;
}
.cover-quotes cite {
  font-family: "Consolas", monospace;
  font-size: 0.75rem;
  color: #6e8aab;
  font-style: normal;
  letter-spacing: 1px;
}

.cover-notice {
  background: rgba(20, 30, 44, 0.4);
  border-left: 3px solid #3d6da8;
  padding: 14px 18px;
  color: #a8b8d0;
  font-size: 0.95rem;
}
.cover-notice strong { color: #d8e2ee; }

@media (max-width: 880px) {
  .cover-hero { grid-template-columns: 1fr; }
  .cover-fleet-grid { grid-template-columns: repeat(2, 1fr); }
  .cover-pair { grid-template-columns: 1fr; }
}

.cover-footer {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  padding: 18px 36px;
  border-top: 1px solid rgba(160, 180, 210, 0.1);
  color: #6a7a92;
  font-size: 0.78rem;
}
.cover-sep { color: #3a4a60; }
.cover-tail {
  font-family: "Consolas", monospace;
  letter-spacing: 0.5px;
  cursor: pointer;
  user-select: none;
}
.cover-tail:hover { color: #95a5be; }

/* ============ Boot screen (post-trigger animation) ============ */
.boot-screen {
  position: fixed;
  inset: 0;
  z-index: 4500;
  background: #050505;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Consolas", "Courier New", monospace;
  color: #e6e6e6;
  overflow: hidden;
}
.boot-screen.hidden { display: none; }
.boot-screen.fading-out { animation: bootFadeOut 0.5s ease forwards; }
@keyframes bootFadeOut {
  to { opacity: 0; transform: scale(1.02); }
}
.boot-screen::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    rgba(212, 175, 55, 0.03) 0px,
    rgba(212, 175, 55, 0.03) 1px,
    transparent 1px,
    transparent 3px
  );
  pointer-events: none;
}
.boot-glyph {
  position: absolute;
  font-family: "Cinzel", serif;
  font-size: 38vw;
  color: rgba(217, 69, 69, 0.04);
  user-select: none;
  pointer-events: none;
  text-shadow: 0 0 80px rgba(161, 28, 28, 0.1);
}
.boot-frame {
  position: relative;
  width: 90%;
  max-width: 760px;
  background: rgba(8, 8, 8, 0.92);
  border: 1px solid var(--gold-dim);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.6), 0 30px 80px rgba(0, 0, 0, 0.7);
  z-index: 1;
}
.boot-head {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 8px 14px;
  border-bottom: 1px solid rgba(212, 175, 55, 0.2);
  background: #0a0a0a;
}
.boot-head-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--gold-dim);
}
.boot-head-dot:nth-child(2) { background: #b3893a; }
.boot-head-dot:nth-child(3) { background: var(--blood); }
.boot-head-title {
  margin-left: 10px;
  font-size: 0.78rem;
  letter-spacing: 1.5px;
  color: var(--gold);
}
.boot-terminal {
  padding: 22px 24px 28px;
  min-height: 320px;
  font-size: 0.9rem;
  line-height: 1.6;
}
.boot-line {
  letter-spacing: 0.5px;
  white-space: pre-wrap;
  word-wrap: break-word;
}
.boot-line.success { color: var(--ok); }
.boot-line.warn { color: var(--gold-bright); }
.boot-line.error { color: var(--blood-bright); }
.boot-line.dim { color: var(--text-dim); }
.boot-cursor {
  display: inline-block;
  width: 8px;
  height: 1em;
  background: var(--gold);
  vertical-align: text-bottom;
  margin-left: 2px;
  animation: bootCursor 0.9s steps(2) infinite;
}
@keyframes bootCursor {
  0%, 50% { opacity: 1; }
  50.01%, 100% { opacity: 0; }
}
.boot-bar {
  display: inline-block;
  letter-spacing: 0;
  color: var(--gold);
}
.boot-bar .bar-fill { color: var(--ok); }
.boot-bar .bar-empty { color: var(--text-dim); }

/* ============ Lock screen (no session) ============ */
.lock-screen {
  position: fixed;
  inset: 0;
  z-index: 4400;
  background:
    radial-gradient(circle at 50% 0%, rgba(161, 28, 28, 0.18), transparent 55%),
    radial-gradient(circle at 50% 100%, rgba(161, 28, 28, 0.12), transparent 55%),
    #050505;
  color: var(--text);
  font-family: "Rajdhani", "Segoe UI", system-ui, sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  overflow: hidden;
}
.lock-screen.hidden { display: none; }
.lock-screen::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    rgba(212, 175, 55, 0.04) 0px,
    rgba(212, 175, 55, 0.04) 1px,
    transparent 1px,
    transparent 3px
  );
  pointer-events: none;
}
.lock-screen.granted .lock-status {
  color: var(--ok);
  text-shadow: 0 0 16px rgba(110, 209, 154, 0.8), 0 0 32px rgba(110, 209, 154, 0.5);
}
.lock-screen.granted .lock-warn-bar { background: var(--ok); }
.lock-screen.fading-out { animation: bootFadeOut 0.5s ease forwards; }

.lock-glyph {
  position: absolute;
  font-family: "Cinzel", serif;
  font-size: 42vw;
  color: rgba(217, 69, 69, 0.05);
  user-select: none;
  pointer-events: none;
  text-shadow: 0 0 80px rgba(161, 28, 28, 0.15);
}
.lock-frame {
  position: relative;
  width: 100%;
  max-width: 480px;
  background: rgba(8, 8, 8, 0.94);
  border: 1px solid var(--blood);
  padding: 28px 30px;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.6),
              0 30px 80px rgba(0, 0, 0, 0.7),
              0 0 60px rgba(161, 28, 28, 0.18);
  z-index: 1;
  clip-path: polygon(14px 0, 100% 0, 100% calc(100% - 14px), calc(100% - 14px) 100%, 0 100%, 0 14px);
}
.lock-head {
  text-align: center;
  margin-bottom: 18px;
}
.lock-warn-bar {
  display: block;
  width: 60px;
  height: 3px;
  background: var(--blood-bright);
  margin: 0 auto 14px;
  box-shadow: 0 0 10px rgba(217, 69, 69, 0.7);
  transition: background 0.3s ease, box-shadow 0.3s ease;
}
.lock-status {
  font-family: "Cinzel", serif;
  font-size: 1.7rem;
  letter-spacing: 4px;
  color: var(--blood-bright);
  margin: 0 0 6px;
  text-shadow: 0 0 12px rgba(217, 69, 69, 0.5);
  transition: color 0.3s ease, text-shadow 0.3s ease;
}
.lock-subtitle {
  margin: 0;
  font-family: "Consolas", monospace;
  font-size: 0.78rem;
  letter-spacing: 1.5px;
  color: var(--text-dim);
}
.lock-terminal {
  margin-bottom: 16px;
  background: #050505;
  border: 1px solid var(--border-strong);
  padding: 8px 12px;
  font-family: "Consolas", monospace;
  font-size: 0.82rem;
  color: var(--gold);
}
#lockForm input {
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--gold-bright);
  padding: 10px 12px;
  font-family: "Consolas", monospace;
  font-size: 0.95rem;
  width: 100%;
  letter-spacing: 1px;
  border-radius: 0;
}
#lockForm input:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold-dim), 0 0 12px rgba(212, 175, 55, 0.2);
}
#lockForm input::placeholder { color: #555; }
#lockForm .form-row.single {
  display: grid;
  grid-template-columns: 1fr;
  margin-bottom: 10px;
  gap: 10px;
}

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  font-family: "Rajdhani", "Segoe UI", system-ui, sans-serif;
  font-weight: 500;
  min-height: 100vh;
  overflow-x: hidden;
}

body {
  background:
    radial-gradient(ellipse at 50% -10%, rgba(161, 28, 28, 0.12), transparent 55%),
    radial-gradient(circle at 15% 20%, rgba(212, 175, 55, 0.06), transparent 50%),
    radial-gradient(circle at 85% 110%, rgba(161, 28, 28, 0.08), transparent 50%),
    var(--bg);
  position: relative;
}

/* Grainy noise overlay — gives the spray-paint grit */
.bg-grain {
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.35;
  mix-blend-mode: overlay;
  z-index: 1;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.4 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ---------- Scanlines (hacker overlay) ---------- */
.scanlines {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 3;
  background: repeating-linear-gradient(
    0deg,
    rgba(255, 255, 255, 0.035) 0px,
    rgba(255, 255, 255, 0.035) 1px,
    transparent 1px,
    transparent 3px
  );
  opacity: 0.6;
  animation: scanline-flicker 6s infinite;
}

@keyframes scanline-flicker {
  0%, 100% { opacity: 0.6; }
  4% { opacity: 0.45; }
  6% { opacity: 0.7; }
  8% { opacity: 0.55; }
}

/* ---------- Header / Brand ---------- */
.site-header {
  position: relative;
  z-index: 2;
  padding: 18px 40px 0;
  background:
    radial-gradient(ellipse at 0% 0%, rgba(161, 28, 28, 0.18) 0%, transparent 55%),
    radial-gradient(ellipse at 100% 100%, rgba(212, 175, 55, 0.08) 0%, transparent 55%),
    linear-gradient(180deg, #0a0707 0%, #050505 100%);
  border-bottom: 1px solid var(--border-strong);
}

.site-header::before {
  /* faint terminal scanline overlay just on the header */
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(0deg, rgba(212, 175, 55, 0.025) 0 1px, transparent 1px 3px);
  opacity: 0.7;
}
.site-header::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold) 20%, var(--blood-bright) 50%, var(--gold) 80%, transparent);
  opacity: 0.6;
}

.header-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}

.brand {
  display: flex;
  align-items: center;
  gap: 18px;
  position: relative;
}
.brand::before {
  /* small left accent bar */
  content: "";
  position: absolute;
  left: -16px;
  top: 8px;
  bottom: 8px;
  width: 3px;
  background: linear-gradient(180deg, var(--blood-bright) 0%, var(--gold) 100%);
  box-shadow: 0 0 8px rgba(212, 175, 55, 0.5);
}

.brand-logo {
  width: 64px;
  height: 64px;
  object-fit: contain;
  filter: drop-shadow(0 0 14px rgba(161, 28, 28, 0.35));
  flex-shrink: 0;
}

.brand-text { display: flex; flex-direction: column; gap: 2px; }

.logo {
  margin: 0;
  font-family: "Bebas Neue", sans-serif;
  font-size: 2.4rem;
  letter-spacing: 5px;
  font-weight: 400;
  color: var(--text);
  line-height: 1;
  text-shadow: 0 2px 0 #000, 0 0 20px rgba(0, 0, 0, 0.8);
  position: relative;
  animation: glitch-text 7s infinite;
}

/* RGB-split glitch pseudo layers */
.logo::before, .logo::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0;
}
.logo::before { color: var(--blood-bright); animation: glitch-shift-r 7s infinite; }
.logo::after  { color: #4fd6ff;              animation: glitch-shift-b 7s infinite; }

@keyframes glitch-text {
  0%, 92%, 100% { transform: translate(0); }
  93% { transform: translate(-1px, 0.5px); }
  94% { transform: translate(1.5px, -0.5px); }
  95% { transform: translate(-1px, 0); }
  96% { transform: translate(0.5px, 1px); }
}
@keyframes glitch-shift-r {
  0%, 92%, 100% { opacity: 0; transform: translate(0); }
  93% { opacity: 0.55; transform: translate(-2px, 0); }
  95% { opacity: 0.4; transform: translate(-1px, 1px); }
  96% { opacity: 0; }
}
@keyframes glitch-shift-b {
  0%, 92%, 100% { opacity: 0; transform: translate(0); }
  93% { opacity: 0.45; transform: translate(2px, 0); }
  95% { opacity: 0.3; transform: translate(1px, -1px); }
  96% { opacity: 0; }
}

.logo .accent {
  color: var(--gold);
  text-shadow:
    0 0 20px rgba(212, 175, 55, 0.55),
    0 0 4px rgba(212, 175, 55, 0.9);
}

.tagline {
  margin: 0;
  color: var(--gold-dim);
  font-size: 0.7rem;
  letter-spacing: 4px;
  text-transform: uppercase;
  font-weight: 500;
  font-family: "Consolas", monospace;
}

/* ---------- Primary tabs (top nav) ---------- */
.primary-tabs {
  display: flex;
  gap: 4px;
  max-width: 1280px;
  margin: 14px auto 0;
  padding: 0 40px;
  position: relative;
  z-index: 2;
  border-bottom: 0;
}
.primary-tabs::before {
  /* leading prompt mark */
  content: "// nav ::";
  align-self: center;
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  color: var(--gold-dim);
  margin-right: 14px;
  margin-bottom: 0;
}
.primary-tabs .tab {
  background: transparent;
  border: 1px solid transparent;
  border-bottom-color: var(--border);
  color: var(--text-dim);
  padding: 10px 22px 10px 18px;
  font-size: 0.92rem;
  letter-spacing: 3px;
  text-transform: uppercase;
  cursor: pointer;
  transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease, transform 0.12s ease;
  font-family: "Bebas Neue", sans-serif;
  font-weight: 400;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.primary-tabs .tab::before {
  content: ">";
  font-family: "Consolas", monospace;
  color: var(--gold-dim);
  font-size: 0.85rem;
  transition: color 0.15s ease, transform 0.15s ease;
}
.primary-tabs .tab:hover {
  color: var(--gold-bright);
  background: rgba(212, 175, 55, 0.05);
  border-color: rgba(212, 175, 55, 0.2);
  border-bottom-color: var(--gold-dim);
}
.primary-tabs .tab:hover::before { color: var(--gold); transform: translateX(2px); }
.primary-tabs .tab.active {
  color: var(--gold-bright);
  background: linear-gradient(180deg, rgba(212, 175, 55, 0.16) 0%, rgba(212, 175, 55, 0.04) 100%);
  border: 1px solid var(--gold);
  border-bottom-color: transparent;
  box-shadow: 0 -4px 16px rgba(212, 175, 55, 0.18) inset;
  text-shadow: 0 0 12px rgba(212, 175, 55, 0.45);
}
.primary-tabs .tab.active::before {
  color: var(--blood-bright);
  text-shadow: 0 0 8px rgba(217, 69, 69, 0.6);
}
.primary-tabs .tab.active::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: -1px;
  height: 2px;
  background: var(--gold);
  box-shadow: 0 0 12px rgba(212, 175, 55, 0.6);
}

/* ---------- Sub-tabs (within IC / OOC) ---------- */
.sub-tabs {
  display: flex;
  gap: 2px;
  margin-top: 0;
  padding: 0 0 0 0;
  border-bottom: 1px solid var(--border);
  position: relative;
}
.sub-tabs::before {
  content: "//";
  align-self: center;
  font-family: "Consolas", monospace;
  font-size: 0.72rem;
  letter-spacing: 1.5px;
  color: var(--gold-dim);
  margin-right: 12px;
}
.subtab {
  background: transparent;
  border: 0;
  color: var(--text-dim);
  padding: 10px 18px;
  font-size: 0.85rem;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
  font-family: "Bebas Neue", sans-serif;
  font-weight: 400;
}
.subtab:hover { color: var(--gold-bright); background: rgba(212, 175, 55, 0.04); }
.subtab.active { color: var(--gold); border-bottom-color: var(--gold); text-shadow: 0 0 10px rgba(212, 175, 55, 0.3); }

main {
  max-width: 1280px;
  margin: 0 auto;
  padding: 36px 40px;
  position: relative;
  z-index: 2;
}

.panel, .subpanel { display: none; }
.panel.active, .subpanel.active { display: block; animation: fadeIn 0.25s ease; }

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

.section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 22px;
  gap: 16px;
  flex-wrap: wrap;
}

.section-head h2 {
  margin: 0;
  color: var(--gold);
  font-family: "Bebas Neue", sans-serif;
  font-weight: 400;
  letter-spacing: 4px;
  text-transform: uppercase;
  font-size: 1.8rem;
  text-shadow: 0 0 20px rgba(212, 175, 55, 0.15);
}

.ooc-badge {
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 3px;
  font-size: 0.85rem;
  color: var(--blood-bright);
  border: 1px solid var(--blood);
  padding: 3px 12px;
  border-radius: 2px;
  background: rgba(161, 28, 28, 0.1);
}

/* ---------- Buttons ---------- */
.btn {
  background: var(--bg-elev);
  color: var(--text);
  border: 1px solid var(--border-strong);
  padding: 9px 20px;
  font-size: 0.82rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 0;
  font-family: "Rajdhani", sans-serif;
  font-weight: 700;
  clip-path: polygon(6px 0, 100% 0, 100% calc(100% - 6px), calc(100% - 6px) 100%, 0 100%, 0 6px);
  transition: background 0.15s, color 0.15s, transform 0.08s;
}

.btn:hover {
  background: var(--bg-elev-2);
  color: var(--gold-bright);
}

.btn:active { transform: translateY(1px); }

.btn.primary {
  background: linear-gradient(180deg, var(--gold) 0%, #a0821c 100%);
  color: #15100a;
  border-color: var(--gold);
  font-weight: 700;
  box-shadow: 0 0 16px rgba(212, 175, 55, 0.25);
}

.btn.primary:hover {
  background: linear-gradient(180deg, var(--gold-bright) 0%, var(--gold) 100%);
  color: #000;
}

.btn.ghost {
  background: transparent;
  border-color: var(--border);
  color: var(--text-dim);
}
.btn.ghost:hover { color: var(--text); }

.btn.danger-ghost {
  background: transparent;
  border-color: transparent;
  color: var(--text-dim);
  padding: 4px 12px;
  letter-spacing: 1px;
  clip-path: none;
}
.btn.danger-ghost:hover {
  color: var(--blood-bright);
  background: rgba(161, 28, 28, 0.08);
}

/* ---------- Forms ---------- */
.form {
  background: linear-gradient(180deg, var(--bg-elev) 0%, #0a0a0a 100%);
  border: 1px solid var(--border);
  border-left: 3px solid var(--gold);
  padding: 20px;
  margin-bottom: 22px;
  position: relative;
}

.form::before {
  content: "";
  position: absolute;
  top: -1px; right: -1px;
  width: 14px; height: 14px;
  border-top: 2px solid var(--gold);
  border-right: 2px solid var(--gold);
}

.form.hidden { display: none; }

.form-row {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  margin-bottom: 10px;
}

.form input, .form select {
  background: var(--bg);
  border: 1px solid var(--border-strong);
  color: var(--text);
  padding: 10px 12px;
  font-family: "Rajdhani", sans-serif;
  font-size: 0.95rem;
  font-weight: 500;
  border-radius: 0;
}

.form input::placeholder { color: #555; }

.form input:focus, .form select:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold-dim), 0 0 12px rgba(212, 175, 55, 0.15);
}

.form-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 12px;
}

/* ---------- Tables ---------- */
.table-wrap {
  background: linear-gradient(180deg, var(--bg-elev) 0%, #0a0a0a 100%);
  border: 1px solid var(--border);
  position: relative;
}

.table-wrap::before, .table-wrap::after {
  content: "";
  position: absolute;
  width: 10px; height: 10px;
  border-color: var(--gold);
}
.table-wrap::before { top: -1px; left: -1px; border-top: 2px solid; border-left: 2px solid; }
.table-wrap::after { bottom: -1px; right: -1px; border-bottom: 2px solid; border-right: 2px solid; }

.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.95rem;
}

.data-table th {
  background: #0a0a0a;
  color: var(--gold);
  text-align: left;
  padding: 12px 16px;
  font-family: "Bebas Neue", sans-serif;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 0.85rem;
  border-bottom: 1px solid var(--border-strong);
}

.data-table td {
  padding: 11px 16px;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  font-weight: 500;
}

.data-table tbody tr { transition: background 0.12s; }
.data-table tbody tr:hover { background: rgba(212, 175, 55, 0.035); }
.data-table tbody tr:last-child td { border-bottom: none; }

.status-pill {
  display: inline-block;
  padding: 2px 10px;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  border: 1px solid;
  font-weight: 700;
  font-family: "Rajdhani", sans-serif;
}
.status-Active, .status-Collected { color: #7fd6a5; border-color: #2c5a40; background: rgba(110, 209, 154, 0.08); }
.status-Inactive { color: #9a9a9a; border-color: #444; background: rgba(255,255,255,0.03); }
.status-On\.Leave, .status-Pending { color: var(--gold); border-color: var(--gold-dim); background: rgba(212, 175, 55, 0.08); }
.status-KIA, .status-Lost, .status-Confiscated { color: var(--blood-bright); border-color: var(--blood); background: rgba(161, 28, 28, 0.12); }

.empty {
  color: var(--text-dim);
  text-align: center;
  padding: 36px 14px;
  margin: 0;
  font-style: italic;
  font-size: 0.95rem;
}

/* ---------- Radio Frequencies ---------- */
.freq-card {
  background: linear-gradient(180deg, var(--bg-elev) 0%, #070707 100%);
  border: 1px solid var(--border);
  border-top: 3px solid var(--gold);
  padding: 28px;
  position: relative;
}

.freq-card::before, .freq-card::after {
  content: "";
  position: absolute;
  width: 14px; height: 14px;
  border-color: var(--gold);
}
.freq-card::before { bottom: -1px; left: -1px; border-bottom: 2px solid; border-left: 2px solid; }
.freq-card::after { bottom: -1px; right: -1px; border-bottom: 2px solid; border-right: 2px solid; }

.freq-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 28px;
  gap: 16px;
  flex-wrap: wrap;
  padding-bottom: 18px;
  border-bottom: 1px dashed var(--border-strong);
}

/* ---------- Comms Console (radio freqs redesign) ---------- */
.comms-console {
  position: relative;
  border: 1px solid var(--gold-dim);
  background:
    radial-gradient(ellipse at 0% 0%, rgba(161, 28, 28, 0.12) 0%, transparent 55%),
    radial-gradient(ellipse at 100% 100%, rgba(212, 175, 55, 0.08) 0%, transparent 55%),
    linear-gradient(180deg, rgba(15, 15, 15, 0.95) 0%, rgba(6, 6, 6, 0.98) 100%);
  padding: 24px 28px 28px;
  overflow: hidden;
  isolation: isolate;
}
.comms-console::before, .comms-console::after {
  content: "";
  position: absolute;
  width: 14px; height: 14px;
  z-index: 2;
}
.comms-console::before { top: -1px; left: -1px; border-top: 2px solid var(--gold); border-left: 2px solid var(--gold); }
.comms-console::after { bottom: -1px; right: -1px; border-bottom: 2px solid var(--gold); border-right: 2px solid var(--gold); }
.comms-console > * { position: relative; z-index: 1; }
.comms-glyph {
  position: absolute;
  font-family: "Cinzel", serif;
  font-size: 26rem;
  line-height: 1;
  color: var(--gold);
  opacity: 0.04;
  right: -60px;
  bottom: -180px;
  user-select: none;
  pointer-events: none;
  text-shadow: 0 0 80px rgba(212, 175, 55, 0.4);
}

.comms-head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 24px;
  align-items: end;
  padding-bottom: 18px;
  margin-bottom: 18px;
  border-bottom: 1px dashed rgba(212, 175, 55, 0.18);
}

.comms-tag {
  display: block;
  font-family: "Consolas", monospace;
  font-size: 0.72rem;
  letter-spacing: 2.5px;
  color: var(--gold-dim);
  margin-bottom: 6px;
}
.comms-title {
  margin: 0 0 12px;
  font-family: "Cinzel", serif;
  font-size: 1.6rem;
  letter-spacing: 5px;
  color: var(--gold-bright);
  text-shadow: 0 0 18px rgba(212, 175, 55, 0.4);
}

.comms-strip {
  display: flex;
  align-items: end;
  gap: 4px;
  height: 28px;
}
.comms-strip-bar {
  width: 6px;
  background: linear-gradient(180deg, var(--gold) 0%, var(--blood) 100%);
  border-radius: 1px 1px 0 0;
  opacity: 0.7;
  animation: commsBar 1.4s ease-in-out infinite;
}
.comms-strip-bar:nth-child(1)  { height: 40%; animation-delay: 0s; }
.comms-strip-bar:nth-child(2)  { height: 70%; animation-delay: 0.1s; }
.comms-strip-bar:nth-child(3)  { height: 30%; animation-delay: 0.2s; }
.comms-strip-bar:nth-child(4)  { height: 90%; animation-delay: 0.3s; }
.comms-strip-bar:nth-child(5)  { height: 60%; animation-delay: 0.4s; }
.comms-strip-bar:nth-child(6)  { height: 35%; animation-delay: 0.5s; }
.comms-strip-bar:nth-child(7)  { height: 80%; animation-delay: 0.6s; }
.comms-strip-bar:nth-child(8)  { height: 50%; animation-delay: 0.7s; }
.comms-strip-bar:nth-child(9)  { height: 25%; animation-delay: 0.8s; }
.comms-strip-bar:nth-child(10) { height: 65%; animation-delay: 0.9s; }
.comms-strip-bar:nth-child(11) { height: 45%; animation-delay: 1s; }
.comms-strip-bar:nth-child(12) { height: 75%; animation-delay: 1.1s; }
@keyframes commsBar {
  0%, 100% { transform: scaleY(0.6); opacity: 0.5; }
  50%      { transform: scaleY(1.1); opacity: 1; }
}

.comms-status {
  background: rgba(0, 0, 0, 0.4);
  border: 1px solid var(--border-strong);
  padding: 10px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-family: "Consolas", monospace;
  font-size: 0.78rem;
}
.comms-status-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  letter-spacing: 1px;
}
.comms-status-row.dim { color: var(--text-dim); font-size: 0.74rem; }
.comms-status-led {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #555;
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.5);
}
.comms-status-led.is-live    { background: var(--ok); box-shadow: 0 0 0 2px rgba(110, 209, 154, 0.2), 0 0 12px var(--ok); animation: deckLed 1.6s ease-in-out infinite; }
.comms-status-led.is-stale   { background: var(--gold-dim); box-shadow: 0 0 0 2px rgba(212, 175, 55, 0.15); }
.comms-status-led.is-old     { background: var(--blood-bright); box-shadow: 0 0 0 2px rgba(217, 69, 69, 0.2), 0 0 8px var(--blood-bright); }
.comms-status-label { letter-spacing: 2px; }
.comms-status-led.is-live + .comms-status-label { color: var(--ok); }
.comms-status-led.is-stale + .comms-status-label { color: var(--gold-dim); }
.comms-status-led.is-old + .comms-status-label { color: var(--blood-bright); }
.comms-status-key {
  text-transform: uppercase;
  font-size: 0.68rem;
  letter-spacing: 1.5px;
  color: var(--text-dim);
}
.comms-status-val { color: var(--gold); }

.comms-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 18px;
}
.comms-note {
  margin-left: auto;
  font-family: "Consolas", monospace;
  font-size: 0.74rem;
  color: var(--text-dim);
  letter-spacing: 1px;
  text-transform: lowercase;
}

@media (max-width: 880px) {
  .comms-head { grid-template-columns: 1fr; }
  .comms-strip { display: none; }
  .comms-note { margin-left: 0; flex: 1 100%; }
}

.label {
  display: block;
  color: var(--text-dim);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 3px;
  margin-bottom: 4px;
  font-family: "Bebas Neue", sans-serif;
}

.value {
  font-family: "Consolas", "Courier New", monospace;
  font-size: 1.05rem;
  color: var(--gold-bright);
  letter-spacing: 1px;
}

.freq-actions { display: flex; gap: 8px; }

.freq-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.freq-tile {
  background:
    linear-gradient(135deg, rgba(212, 175, 55, 0.05) 0%, transparent 60%),
    linear-gradient(180deg, #0e0e0e 0%, #050505 100%);
  border: 1px solid var(--border-strong);
  padding: 22px 14px 16px;
  position: relative;
  cursor: pointer;
  transition: border-color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
  clip-path: polygon(12px 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%, 0 12px);
  overflow: hidden;
  user-select: none;
}
.freq-tile::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(0deg, rgba(212, 175, 55, 0.04) 0 1px, transparent 1px 4px);
  pointer-events: none;
  opacity: 0.6;
}
.freq-tile:hover {
  border-color: var(--gold);
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(212, 175, 55, 0.15), 0 0 0 1px var(--gold-dim) inset;
}
.freq-tile:active { transform: translateY(0); }

.freq-tile .idx {
  position: absolute;
  top: 8px;
  left: 14px;
  font-size: 0.7rem;
  color: var(--gold);
  letter-spacing: 2.5px;
  font-family: "Consolas", monospace;
  font-weight: 600;
}
.freq-tile .copy-icon {
  position: absolute;
  top: 8px;
  right: 14px;
  font-family: "Consolas", monospace;
  color: var(--text-dim);
  font-size: 0.85rem;
  opacity: 0;
  transition: opacity 0.15s ease, color 0.15s ease;
}
.freq-tile:hover .copy-icon { opacity: 1; color: var(--gold); }
.freq-tile.is-copied .copy-icon { opacity: 1; color: var(--ok); }

.freq-tile .num {
  font-family: "Bebas Neue", "Consolas", monospace;
  font-size: 2.6rem;
  color: var(--gold);
  font-weight: 400;
  letter-spacing: 5px;
  text-align: center;
  text-shadow:
    0 0 14px rgba(212, 175, 55, 0.5),
    0 0 4px rgba(212, 175, 55, 0.95);
  line-height: 1;
  display: block;
  margin-top: 6px;
}

.freq-tile .signal {
  display: flex;
  justify-content: center;
  gap: 2px;
  margin-top: 12px;
  height: 10px;
  align-items: end;
}
.freq-tile .signal-bar {
  width: 4px;
  background: var(--gold-dim);
  opacity: 0.5;
  transition: opacity 0.2s ease, background 0.2s ease;
}
.freq-tile .signal-bar:nth-child(1) { height: 30%; }
.freq-tile .signal-bar:nth-child(2) { height: 50%; }
.freq-tile .signal-bar:nth-child(3) { height: 70%; }
.freq-tile .signal-bar:nth-child(4) { height: 90%; }
.freq-tile .signal-bar:nth-child(5) { height: 100%; }
.freq-tile:hover .signal-bar { background: var(--gold); opacity: 1; }

.freq-tile .channel-line {
  position: absolute;
  bottom: 8px;
  left: 14px;
  right: 14px;
  font-family: "Consolas", monospace;
  font-size: 0.62rem;
  letter-spacing: 1.5px;
  color: var(--text-dim);
  display: flex;
  justify-content: space-between;
  text-transform: uppercase;
}
.freq-tile.is-copied { border-color: var(--ok); box-shadow: 0 0 0 1px var(--ok), 0 6px 20px rgba(110, 209, 154, 0.18); }
.freq-tile.is-copied .num { color: var(--ok); text-shadow: 0 0 14px rgba(110, 209, 154, 0.6); }

.note {
  margin: 22px 0 0;
  color: var(--text-dim);
  font-size: 0.88rem;
  font-style: italic;
  letter-spacing: 0.3px;
}

/* ---------- Footer ---------- */
.site-footer {
  text-align: center;
  padding: 28px 20px;
  color: var(--text-dim);
  font-size: 0.78rem;
  letter-spacing: 3px;
  text-transform: uppercase;
  font-family: "Bebas Neue", sans-serif;
  border-top: 1px solid var(--border);
  margin-top: 50px;
  position: relative;
  z-index: 2;
}

.foot-accent {
  color: var(--blood-bright);
  font-family: serif;
  font-size: 1rem;
  margin: 0 4px;
}

/* ---------- Toast ---------- */
.toast {
  position: fixed;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--bg-elev-2);
  border: 1px solid var(--gold);
  color: var(--gold-bright);
  padding: 12px 22px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s, transform 0.2s;
  font-size: 0.85rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-family: "Bebas Neue", sans-serif;
  z-index: 1000;
  box-shadow: 0 0 20px rgba(212, 175, 55, 0.2);
}

.toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ---------- HUD (terminal info in header) ---------- */
.hud {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 5px;
  font-family: "Consolas", "Courier New", monospace;
  font-size: 0.76rem;
  letter-spacing: 1px;
  color: var(--text-dim);
  padding: 8px 14px 8px 18px;
  background: rgba(0, 0, 0, 0.4);
  border: 1px solid var(--border-strong);
  position: relative;
  min-width: 220px;
}
.hud::before, .hud::after {
  content: "";
  position: absolute;
  width: 8px; height: 8px;
}
.hud::before { top: -1px; left: -1px; border-top: 2px solid var(--gold-dim); border-left: 2px solid var(--gold-dim); }
.hud::after { bottom: -1px; right: -1px; border-bottom: 2px solid var(--gold-dim); border-right: 2px solid var(--gold-dim); }

.hud-line { line-height: 1.4; }
.hud-line.dim { color: #555; font-size: 0.7rem; }
.hud-val { font-weight: 700; }
.hud-locked { color: var(--blood-bright); text-shadow: 0 0 8px rgba(217, 69, 69, 0.5); }
.hud-granted { color: var(--ok); text-shadow: 0 0 8px rgba(110, 209, 154, 0.4); }

.hud-btn {
  margin-top: 4px;
  padding: 6px 14px;
  font-size: 0.72rem;
  letter-spacing: 2px;
  align-self: stretch;
  text-align: center;
}

.cursor {
  display: inline-block;
  margin-left: 1px;
  animation: blink 1s steps(2) infinite;
  color: var(--gold);
}

@keyframes blink { 50% { opacity: 0; } }

/* ---------- Auth state (locked/unlocked) ---------- */
body[data-auth="locked"] .requires-auth,
body[data-auth="locked"] .requires-admin,
body[data-auth="locked"] .requires-drops,
body[data-auth="locked"] .requires-edit-members,
body[data-auth="locked"] .requires-freqs-generate,
body[data-auth="locked"] .requires-command { display: none !important; }

body:not(.can-drops) .requires-drops { display: none !important; }
body:not(.can-freqs-generate) .requires-freqs-generate { display: none !important; }
body:not(.can-edit-members) .requires-edit-members { display: none !important; }
body:not(.is-admin) .requires-admin { display: none !important; }
body:not(.is-command) .requires-command { display: none !important; }

body[data-auth="locked"] #ic.active::before,
body[data-auth="locked"] #ooc.active::before {
  content: "[READ_ONLY_MODE // LOGIN_REQUIRED]";
  display: block;
  font-family: "Consolas", monospace;
  color: var(--blood-bright);
  font-size: 0.72rem;
  letter-spacing: 2px;
  margin-bottom: 18px;
  opacity: 0.7;
}

/* Row action cell */
.row-actions { white-space: nowrap; display: flex; gap: 6px; justify-content: flex-end; }
.row-actions .btn { padding: 4px 10px; font-size: 0.78rem; }

/* Self tag + dim text for admin list */
.self-tag {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 6px;
  font-size: 0.65rem;
  background: rgba(212, 175, 55, 0.15);
  border: 1px solid var(--gold-dim);
  color: var(--gold);
  border-radius: 2px;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.dim-text { color: var(--text-dim); }

/* Password-change modal */
.modal-hint.warn {
  color: var(--blood-bright);
  font-weight: 600;
}

/* ---------- Rank-gated visibility (allies + announcements) ---------- */
body:not(.can-ally-edit) .requires-ally-edit { display: none !important; }
body:not(.can-announce) .requires-announce { display: none !important; }

/* ---------- Allies ---------- */
.ally-name {
  font-family: "Cinzel", serif;
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--gold-bright);
}

.ally-status {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 2px;
  font-family: "Bebas Neue", sans-serif;
  font-size: 0.85rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  border-left: 3px solid transparent;
  background: rgba(255, 255, 255, 0.02);
  position: relative;
}
.ally-status::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.08;
  mix-blend-mode: overlay;
  background: currentColor;
}
.ally-good {
  color: var(--ok);
  border-left-color: var(--ok);
  box-shadow: inset 0 0 12px rgba(110, 209, 154, 0.15);
}
.ally-neutral {
  color: var(--text-dim);
  border-left-color: var(--text-dim);
}
.ally-upset {
  color: #e8c15a;
  border-left-color: #e8c15a;
  box-shadow: inset 0 0 12px rgba(232, 193, 90, 0.15);
}
.ally-beef {
  color: #e89048;
  border-left-color: #e89048;
  box-shadow: inset 0 0 12px rgba(232, 144, 72, 0.18);
}
.ally-war {
  color: var(--blood-bright);
  border-left-color: var(--blood-bright);
  background: rgba(161, 28, 28, 0.12);
  box-shadow: inset 0 0 16px rgba(217, 69, 69, 0.25);
  animation: warPulse 2.4s ease-in-out infinite;
}
@keyframes warPulse {
  0%, 100% { box-shadow: inset 0 0 16px rgba(217, 69, 69, 0.25); }
  50%      { box-shadow: inset 0 0 22px rgba(217, 69, 69, 0.5); }
}

/* ---------- Allies (status-grouped cards) ---------- */
.allies-wrap { display: flex; flex-direction: column; gap: 18px; }

.allies-summary {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}
.allies-summary-cell {
  background: linear-gradient(180deg, var(--bg-elev) 0%, #060606 100%);
  border: 1px solid var(--border);
  padding: 10px 14px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  position: relative;
  cursor: pointer;
  transition: border-color 0.15s ease, transform 0.12s ease;
}
.allies-summary-cell:hover { transform: translateY(-1px); }
.allies-summary-cell::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 28px; height: 2px;
  background: currentColor;
}
.allies-summary-num {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.55rem;
  letter-spacing: 1.5px;
  color: var(--text);
  line-height: 1;
}
.allies-summary-lbl {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
.allies-summary-cell.is-war      { color: var(--blood-bright); border-color: rgba(217, 69, 69, 0.4); }
.allies-summary-cell.is-beef     { color: #e89048; border-color: rgba(232, 144, 72, 0.4); }
.allies-summary-cell.is-upset    { color: #e8c15a; border-color: rgba(232, 193, 90, 0.4); }
.allies-summary-cell.is-neutral  { color: var(--text-dim); border-color: rgba(140, 140, 140, 0.3); }
.allies-summary-cell.is-good     { color: var(--ok); border-color: rgba(110, 209, 154, 0.4); }
.allies-summary-cell.is-active {
  background: rgba(212, 175, 55, 0.06);
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold-dim) inset;
}

.allies-toolbar { display: flex; gap: 12px; align-items: center; }
.allies-search {
  flex: 1;
  max-width: 360px;
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--gold-bright);
  padding: 9px 14px;
  font-family: "Consolas", monospace;
  font-size: 0.84rem;
  letter-spacing: 1px;
}
.allies-search:focus { outline: none; border-color: var(--gold); }
.allies-search::placeholder { color: #555; }

.allies-tiers { display: flex; flex-direction: column; gap: 22px; }

.allies-tier {
  border: 1px solid var(--border-strong);
  background: linear-gradient(180deg, rgba(15, 15, 15, 0.8) 0%, rgba(8, 8, 8, 0.9) 100%);
  position: relative;
  overflow: hidden;
}
.allies-tier::before, .allies-tier::after {
  content: "";
  position: absolute;
  width: 12px; height: 12px;
}
.allies-tier::before { top: -1px; left: -1px; border-top: 2px solid var(--gold); border-left: 2px solid var(--gold); }
.allies-tier::after { bottom: -1px; right: -1px; border-bottom: 2px solid var(--gold); border-right: 2px solid var(--gold); }

.allies-tier-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 22px;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.15) 100%);
  border-bottom: 1px dashed rgba(212, 175, 55, 0.2);
}
.allies-tier-title {
  display: flex;
  align-items: center;
  gap: 12px;
}
.allies-tier-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.5), 0 0 10px currentColor;
}
.allies-tier-label {
  font-family: "Cinzel", serif;
  font-size: 1.05rem;
  letter-spacing: 4px;
  text-transform: uppercase;
}
.allies-tier-sub {
  font-family: "Consolas", monospace;
  font-size: 0.72rem;
  letter-spacing: 1.5px;
  color: var(--text-dim);
}
.allies-tier-count {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.3rem;
  letter-spacing: 2px;
  padding: 2px 12px;
  border: 1px solid currentColor;
  background: rgba(0, 0, 0, 0.3);
}

/* Tier-specific accents */
.allies-tier.tier-war      { color: var(--blood-bright); border-color: rgba(217, 69, 69, 0.55); }
.allies-tier.tier-war::before, .allies-tier.tier-war::after { border-color: var(--blood-bright); }
.allies-tier.tier-war .allies-tier-label { text-shadow: 0 0 14px rgba(217, 69, 69, 0.65); animation: warPulse 2.4s ease-in-out infinite; }
.allies-tier.tier-beef     { color: #ff9c5e; border-color: rgba(232, 144, 72, 0.4); }
.allies-tier.tier-upset    { color: #f0d068; border-color: rgba(232, 193, 90, 0.35); }
.allies-tier.tier-neutral  { color: #9aa0a6; }
.allies-tier.tier-good     { color: #7fd6a5; border-color: rgba(110, 209, 154, 0.35); }

.allies-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 0;
}
.ally-card {
  padding: 14px 18px;
  border-right: 1px solid rgba(212, 175, 55, 0.05);
  border-bottom: 1px solid rgba(212, 175, 55, 0.05);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: background 0.12s ease;
  cursor: default;
}
.ally-card:hover { background: rgba(212, 175, 55, 0.04); }
.ally-card::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: currentColor;
  opacity: 0.7;
}
.ally-card-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}
.ally-card-name {
  font-family: "Cinzel", serif;
  color: var(--gold-bright);
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: 0.4px;
  margin: 0;
  word-break: break-word;
}
.ally-card-pill {
  font-family: "Bebas Neue", sans-serif;
  font-size: 0.7rem;
  letter-spacing: 2px;
  padding: 1px 8px;
  border: 1px solid currentColor;
  white-space: nowrap;
  flex-shrink: 0;
}
.ally-card-notes {
  color: var(--text);
  font-size: 0.86rem;
  line-height: 1.5;
  background: rgba(0, 0, 0, 0.35);
  border-left: 2px solid var(--gold-dim);
  padding: 6px 10px;
  word-wrap: break-word;
}
.ally-card-notes:empty { display: none; }
.ally-card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  color: var(--text-dim);
  letter-spacing: 0.5px;
}
.ally-card-actions { display: flex; gap: 4px; }
.ally-card-actions .btn { padding: 2px 8px; font-size: 0.7rem; letter-spacing: 1px; }

@media (max-width: 720px) {
  .allies-summary { grid-template-columns: repeat(2, 1fr); }
  .allies-grid { grid-template-columns: 1fr; }
}

/* ---------- Announcements ---------- */
.announce-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 12px;
}

.announce-card {
  background: linear-gradient(180deg, rgba(15, 15, 15, 0.92) 0%, rgba(8, 8, 8, 0.92) 100%);
  border: 1px solid var(--border-strong);
  border-left: 3px solid var(--gold);
  padding: 16px 20px 18px;
  position: relative;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.5), inset 0 0 30px rgba(212, 175, 55, 0.03);
}

.announce-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 14px;
  height: 14px;
  border-top: 1px solid var(--gold-bright);
  border-left: 1px solid var(--gold-bright);
  opacity: 0.6;
}
.announce-card::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 14px;
  height: 14px;
  border-bottom: 1px solid var(--gold-bright);
  border-right: 1px solid var(--gold-bright);
  opacity: 0.6;
}

.announce-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 4px;
}

.announce-title {
  margin: 0;
  font-family: "Cinzel", serif;
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--gold-bright);
  letter-spacing: 0.5px;
  line-height: 1.2;
}

.announce-del {
  padding: 3px 10px;
  font-size: 0.7rem;
  flex-shrink: 0;
}

.announce-meta {
  font-family: "Consolas", monospace;
  font-size: 0.72rem;
  color: var(--text-dim);
  letter-spacing: 1px;
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px dashed var(--border);
}
.announce-author { color: var(--gold-dim); }
.announce-sep { margin: 0 8px; opacity: 0.5; }

.announce-body {
  color: var(--text);
  line-height: 1.55;
  font-size: 1rem;
  white-space: pre-wrap;
  word-wrap: break-word;
}

textarea {
  width: 100%;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 10px 12px;
  font-family: "Rajdhani", sans-serif;
  font-size: 1rem;
  resize: vertical;
  min-height: 80px;
  transition: border-color 0.2s;
}
textarea:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold);
}
textarea::placeholder { color: var(--text-dim); }

/* ---------- Home page (Command Deck) ---------- */
.cmd-deck {
  position: relative;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1.2fr;
  gap: 26px;
  align-items: center;
  padding: 28px 34px;
  margin-bottom: 22px;
  border: 1px solid var(--border-strong);
  background:
    radial-gradient(ellipse at 0% 50%, rgba(161, 28, 28, 0.18) 0%, transparent 55%),
    radial-gradient(ellipse at 100% 50%, rgba(212, 175, 55, 0.10) 0%, transparent 55%),
    linear-gradient(180deg, rgba(15, 15, 15, 0.95) 0%, rgba(6, 6, 6, 0.98) 100%);
  overflow: hidden;
  isolation: isolate;
}
.cmd-deck::before, .cmd-deck::after {
  content: "";
  position: absolute;
  width: 16px; height: 16px;
  z-index: 2;
}
.cmd-deck::before { top: -1px; left: -1px; border-top: 2px solid var(--gold); border-left: 2px solid var(--gold); }
.cmd-deck::after { bottom: -1px; right: -1px; border-bottom: 2px solid var(--gold); border-right: 2px solid var(--gold); }

.cmd-deck-grid-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(0deg, rgba(212, 175, 55, 0.04) 0 1px, transparent 1px 3px),
    repeating-linear-gradient(90deg, rgba(212, 175, 55, 0.025) 0 1px, transparent 1px 60px);
  mask-image: linear-gradient(180deg, transparent 0%, #000 30%, #000 70%, transparent 100%);
}

.cmd-deck-glyph {
  position: absolute;
  font-family: "Cinzel", serif;
  font-size: 24rem;
  line-height: 1;
  color: var(--gold);
  opacity: 0.05;
  right: -30px;
  bottom: -120px;
  user-select: none;
  pointer-events: none;
  text-shadow: 0 0 60px rgba(212, 175, 55, 0.4);
  animation: deckGlyphPulse 6s ease-in-out infinite;
}
@keyframes deckGlyphPulse {
  0%, 100% { opacity: 0.04; }
  50%      { opacity: 0.08; }
}

.cmd-deck-left, .cmd-deck-center, .cmd-deck-right {
  position: relative;
  z-index: 1;
}

.cmd-deck-prompt {
  font-family: "Consolas", monospace;
  font-size: 0.72rem;
  letter-spacing: 2.5px;
  color: var(--gold-dim);
  margin-bottom: 10px;
}
.cmd-deck-cursor {
  display: inline-block;
  background: var(--gold);
  color: var(--gold);
  width: 7px;
  margin-left: 2px;
  animation: deckCursor 1s steps(2) infinite;
}
@keyframes deckCursor {
  0%, 50% { opacity: 1; }
  50.01%, 100% { opacity: 0; }
}

.cmd-deck-welcome {
  margin: 0;
  font-family: "Cinzel", serif;
  font-weight: 800;
  font-size: 2.2rem;
  letter-spacing: 1px;
  line-height: 1.1;
  color: var(--text);
}
.cmd-deck-greet {
  display: block;
  font-size: 0.85rem;
  letter-spacing: 4px;
  color: var(--text-dim);
  font-weight: 400;
  text-transform: uppercase;
  font-family: "Consolas", monospace;
  margin-bottom: 4px;
}
.cmd-deck-user {
  color: var(--gold-bright);
  text-shadow: 0 0 28px rgba(212, 175, 55, 0.5);
}

.cmd-deck-meta {
  margin-top: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.cmd-deck-rank.rank-pill { font-size: 0.78rem; padding: 4px 10px; }
.cmd-deck-sep {
  color: var(--text-dim);
  font-family: "Consolas", monospace;
}
.cmd-deck-session {
  font-family: "Consolas", monospace;
  font-size: 0.78rem;
  letter-spacing: 1.5px;
  color: var(--text-dim);
}

/* Personal strike pips in the cmd deck */
.cmd-deck-strikes {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  padding: 3px 10px;
  background: rgba(0, 0, 0, 0.4);
  border: 1px solid var(--border-strong);
  font-family: "Consolas", monospace;
  font-size: 0.72rem;
  letter-spacing: 1.5px;
  color: var(--text-dim);
  text-transform: uppercase;
  width: fit-content;
}
.cmd-deck-strikes.hidden { display: none; }
.cmd-deck-strikes-label { color: var(--text-dim); }
.cmd-deck-strikes-pips {
  display: inline-flex;
  gap: 4px;
}
.cmd-deck-strikes-pip {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  border: 1px solid var(--text-dim);
  background: transparent;
}
.cmd-deck-strikes-pip.is-on {
  background: var(--blood-bright);
  border-color: var(--blood-bright);
  box-shadow: 0 0 6px rgba(217, 69, 69, 0.7);
}
.cmd-deck-strikes-text {
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 1.5px;
  font-size: 0.85rem;
  color: var(--gold);
}
.cmd-deck-strikes.has-strikes {
  border-color: rgba(217, 69, 69, 0.5);
  background: rgba(161, 28, 28, 0.12);
}
.cmd-deck-strikes.has-strikes .cmd-deck-strikes-text { color: var(--blood-bright); }
.cmd-deck-strikes.is-max .cmd-deck-strikes-text { animation: warPulse 2s ease-in-out infinite; }

/* Strike alert banner */
.strike-banner {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  padding: 12px 20px;
  margin-bottom: 18px;
  background: rgba(161, 28, 28, 0.18);
  border: 1px solid var(--blood-bright);
  border-left: 4px solid var(--blood-bright);
  font-family: "Consolas", monospace;
  color: var(--text);
}
.strike-banner.hidden { display: none; }
.strike-banner-tag {
  font-weight: 700;
  letter-spacing: 2px;
  color: var(--blood-bright);
}
.strike-banner-text {
  font-family: "Rajdhani", sans-serif;
  font-size: 1rem;
  letter-spacing: 0.5px;
  color: var(--text);
}
.strike-banner-text strong {
  color: var(--blood-bright);
  font-weight: 700;
  margin: 0 4px;
}
.strike-banner-meta {
  font-size: 0.78rem;
  color: var(--text-dim);
  letter-spacing: 0.5px;
}

/* Center: live clock */
.cmd-deck-center {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
}
.cmd-deck-time {
  font-family: "Bebas Neue", sans-serif;
  font-size: 3.6rem;
  letter-spacing: 6px;
  color: var(--gold-bright);
  line-height: 1;
  text-shadow: 0 0 24px rgba(212, 175, 55, 0.4);
}
.cmd-deck-date {
  font-family: "Consolas", monospace;
  font-size: 0.78rem;
  letter-spacing: 3px;
  color: var(--text-dim);
  text-transform: uppercase;
  display: inline-flex;
  gap: 10px;
  align-items: center;
}
.cmd-deck-tz {
  background: rgba(212, 175, 55, 0.08);
  border: 1px solid var(--gold-dim);
  padding: 1px 6px;
  color: var(--gold);
  font-size: 0.7rem;
}

/* Right: status + threat */
.cmd-deck-right {
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: flex-end;
}
.cmd-deck-online {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 12px;
  background: rgba(110, 209, 154, 0.06);
  border: 1px solid rgba(110, 209, 154, 0.35);
  font-family: "Consolas", monospace;
  font-size: 0.75rem;
  letter-spacing: 2px;
  color: var(--ok);
}
.cmd-deck-led {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ok);
  box-shadow: 0 0 0 2px rgba(110, 209, 154, 0.2), 0 0 10px var(--ok);
  animation: deckLed 1.6s ease-in-out infinite;
}
@keyframes deckLed {
  0%, 100% { box-shadow: 0 0 0 2px rgba(110, 209, 154, 0.2), 0 0 10px var(--ok); }
  50%      { box-shadow: 0 0 0 4px rgba(110, 209, 154, 0.3), 0 0 16px var(--ok); }
}

.cmd-deck-threat {
  width: 240px;
  background: rgba(0, 0, 0, 0.45);
  border: 1px solid var(--border-strong);
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cmd-deck-threat-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}
.cmd-deck-threat-label {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 2px;
  color: var(--text-dim);
}
.cmd-deck-threat-value {
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 2px;
  font-size: 1.05rem;
  color: var(--ok);
}
.cmd-deck-threat-bar {
  height: 6px;
  background: rgba(255, 255, 255, 0.05);
  position: relative;
  overflow: hidden;
}
.cmd-deck-threat-fill {
  display: block;
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--ok) 0%, #d6c456 50%, var(--blood-bright) 100%);
  transition: width 0.6s ease;
}
.cmd-deck-threat[data-level="quiet"]   .cmd-deck-threat-value { color: var(--ok); }
.cmd-deck-threat[data-level="caution"] .cmd-deck-threat-value { color: #d6c456; }
.cmd-deck-threat[data-level="elevated"] .cmd-deck-threat-value { color: #ff9c5e; }
.cmd-deck-threat[data-level="hostile"]  .cmd-deck-threat-value { color: var(--blood-bright); animation: warPulse 2s ease-in-out infinite; }

@media (max-width: 980px) {
  .cmd-deck { grid-template-columns: 1fr; gap: 18px; }
  .cmd-deck-right { align-items: flex-start; }
  .cmd-deck-threat { width: 100%; }
  .cmd-deck-time { font-size: 2.6rem; }
}

/* WAR alert banner */
.war-alert {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 20px;
  margin-bottom: 22px;
  background: rgba(161, 28, 28, 0.15);
  border: 1px solid var(--blood);
  border-left: 4px solid var(--blood-bright);
  font-family: "Consolas", monospace;
  color: var(--blood-bright);
  animation: warPulse 2.4s ease-in-out infinite;
}
.war-alert.hidden { display: none; }
.war-alert-tag {
  font-weight: 700;
  letter-spacing: 2px;
}
.war-alert-text {
  color: var(--text);
  font-family: "Rajdhani", sans-serif;
  font-size: 1rem;
  letter-spacing: 0.5px;
}

/* Home content grid */
.home-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 18px;
  margin-top: 22px;
}
.home-block {
  background: linear-gradient(180deg, rgba(15, 15, 15, 0.85) 0%, rgba(8, 8, 8, 0.9) 100%);
  border: 1px solid var(--border-strong);
  position: relative;
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.home-block::before, .home-block::after {
  content: "";
  position: absolute;
  width: 10px; height: 10px;
}
.home-block::before { top: -1px; left: -1px; border-top: 2px solid var(--gold-dim); border-left: 2px solid var(--gold-dim); }
.home-block::after { bottom: -1px; right: -1px; border-bottom: 2px solid var(--gold-dim); border-right: 2px solid var(--gold-dim); }
.home-block-announce { grid-column: 1 / 2; grid-row: 1 / 3; }
.home-block-situation { grid-column: 2 / 3; grid-row: 1 / 2; }
.home-block-loa { grid-column: 2 / 3; grid-row: 2 / 3; }
.home-block-actions { grid-column: 1 / 3; grid-row: 3 / 4; }

.home-block-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-bottom: 8px;
  border-bottom: 1px dashed rgba(212, 175, 55, 0.18);
}
.home-block-head h3 {
  margin: 0;
  font-family: "Cinzel", serif;
  letter-spacing: 3px;
  font-size: 0.95rem;
  color: var(--gold);
  text-transform: uppercase;
  flex: 1;
}
.home-block-tick {
  font-family: "Consolas", monospace;
  color: var(--gold-dim);
  font-size: 0.95rem;
  letter-spacing: 0;
}
.home-link {
  background: none;
  border: 1px solid transparent;
  color: var(--gold-dim);
  font-family: "Consolas", monospace;
  font-size: 0.72rem;
  letter-spacing: 1.5px;
  cursor: pointer;
  padding: 3px 8px;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.home-link:hover { color: var(--gold-bright); border-color: var(--gold-dim); }

@media (max-width: 980px) {
  .home-grid { grid-template-columns: 1fr; }
  .home-block-announce, .home-block-situation, .home-block-loa, .home-block-actions {
    grid-column: 1 / 2;
    grid-row: auto;
  }
}

/* Quick actions */
.home-actions-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
}
.home-action {
  background: linear-gradient(180deg, rgba(20, 16, 8, 0.55) 0%, rgba(8, 6, 3, 0.6) 100%);
  border: 1px solid var(--border-strong);
  padding: 16px 14px;
  cursor: pointer;
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 2.5px;
  color: var(--gold-bright);
  font-size: 0.95rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-align: center;
  transition: border-color 0.15s ease, transform 0.12s ease, background 0.15s ease, box-shadow 0.15s ease;
  position: relative;
  overflow: hidden;
  min-height: 90px;
}
.home-action::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 24px; height: 2px;
  background: var(--gold);
  opacity: 0.5;
  transition: width 0.2s ease, opacity 0.2s ease;
}
.home-action:hover {
  border-color: var(--gold);
  background: linear-gradient(180deg, rgba(40, 32, 12, 0.6) 0%, rgba(20, 16, 6, 0.55) 100%);
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.5);
}
.home-action:hover::before { width: 100%; opacity: 1; }
.home-action-icon {
  font-family: "Consolas", monospace;
  color: var(--gold);
  font-size: 1.5rem;
  line-height: 1;
}
.home-action-label { white-space: nowrap; }
.home-action-sub { display: none; }

/* Status strip — used inside home Ally Situation block */
.status-strip {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
}
.home-block .status-strip {
  grid-template-columns: repeat(5, 1fr);
}
.home-block .status-tile {
  min-height: auto;
  padding: 10px 8px 10px 10px;
  background: rgba(0, 0, 0, 0.35);
}
.home-block .status-tile-head {
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: 0;
}
.home-block .status-tile-label { font-size: 0.78rem; letter-spacing: 1.5px; }
.home-block .status-tile-count { font-size: 1.6rem; line-height: 1; }
.home-block .status-tile-body,
.home-block .status-more { display: none; }
.status-tile {
  background: rgba(10, 10, 10, 0.7);
  border: 1px solid var(--border);
  border-left: 3px solid transparent;
  padding: 12px 14px;
  min-height: 100px;
  display: flex;
  flex-direction: column;
  transition: background 0.2s;
}
.status-tile-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.status-tile-label {
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 2px;
  font-size: 0.95rem;
}
.status-tile-count {
  font-family: "Cinzel", serif;
  font-weight: 800;
  font-size: 1.4rem;
}
.status-tile-body {
  font-size: 0.82rem;
  line-height: 1.5;
  color: var(--text);
  flex-grow: 1;
}
.status-more {
  margin-top: 4px;
  font-family: "Consolas", monospace;
  font-size: 0.68rem;
  color: var(--text-dim);
  letter-spacing: 1px;
}
.status-tile.ally-good { border-left-color: var(--ok); }
.status-tile.ally-good .status-tile-label,
.status-tile.ally-good .status-tile-count { color: var(--ok); }
.status-tile.ally-neutral { border-left-color: var(--text-dim); }
.status-tile.ally-neutral .status-tile-label,
.status-tile.ally-neutral .status-tile-count { color: var(--text-dim); }
.status-tile.ally-upset { border-left-color: #e8c15a; }
.status-tile.ally-upset .status-tile-label,
.status-tile.ally-upset .status-tile-count { color: #e8c15a; }
.status-tile.ally-beef { border-left-color: #e89048; }
.status-tile.ally-beef .status-tile-label,
.status-tile.ally-beef .status-tile-count { color: #e89048; }
.status-tile.ally-war {
  border-left-color: var(--blood-bright);
  background: rgba(161, 28, 28, 0.08);
}
.status-tile.ally-war .status-tile-label,
.status-tile.ally-war .status-tile-count { color: var(--blood-bright); }

/* Home announcement card tweak */
.home-announce-card { border-left-width: 3px; }

/* Stats grid */
.home-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 10px;
  margin-bottom: 8px;
}
.stat-card {
  position: relative;
  background: linear-gradient(180deg, var(--bg-elev) 0%, #060606 100%);
  border: 1px solid var(--border-strong);
  padding: 16px 18px;
  text-align: left;
  color: var(--text);
  cursor: pointer;
  font-family: "Rajdhani", sans-serif;
  transition: border-color 0.2s ease, transform 0.15s ease, background 0.2s ease;
  overflow: hidden;
}
.stat-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 36px; height: 2px;
  background: var(--gold);
  transition: width 0.25s ease;
}
.stat-card:hover {
  border-color: var(--gold);
  transform: translateY(-2px);
  background: linear-gradient(180deg, rgba(30, 22, 4, 0.4) 0%, rgba(15, 12, 5, 0.4) 100%);
}
.stat-card:hover::before { width: 100%; }
.stat-card::after {
  content: "→";
  position: absolute;
  top: 14px;
  right: 16px;
  color: var(--gold-dim);
  font-size: 1.1rem;
  opacity: 0;
  transition: opacity 0.2s, transform 0.2s;
}
.stat-card:hover::after { opacity: 1; transform: translateX(2px); }
.stat-value {
  font-family: "Bebas Neue", sans-serif;
  font-weight: 400;
  font-size: 2.3rem;
  letter-spacing: 1.5px;
  color: var(--gold-bright);
  line-height: 1;
  margin-bottom: 6px;
  text-shadow: 0 0 16px rgba(212, 175, 55, 0.25);
}
.stat-label {
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 2.5px;
  font-size: 0.85rem;
  color: var(--text);
}
.stat-sub {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  color: var(--text-dim);
  letter-spacing: 1px;
  margin-top: 2px;
}

/* Responsive: collapse status strip on narrow screens */
@media (max-width: 760px) {
  .status-strip { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- Modal ---------- */
.modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.82);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2000;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  animation: fadeIn 0.2s ease;
}

.modal.hidden { display: none; }

.modal-card {
  background: linear-gradient(180deg, #0c0c0c 0%, #050505 100%);
  border: 1px solid var(--gold);
  width: 90%;
  max-width: 440px;
  padding: 22px;
  position: relative;
  box-shadow: 0 0 40px rgba(212, 175, 55, 0.15), 0 0 80px rgba(161, 28, 28, 0.1);
  clip-path: polygon(14px 0, 100% 0, 100% calc(100% - 14px), calc(100% - 14px) 100%, 0 100%, 0 14px);
}

.modal-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px dashed var(--border-strong);
}

.modal-title {
  font-family: "Consolas", monospace;
  color: var(--gold);
  font-size: 0.95rem;
  letter-spacing: 2px;
  font-weight: 700;
}

.modal-close {
  background: transparent;
  border: none;
  color: var(--text-dim);
  font-size: 1.4rem;
  cursor: pointer;
  padding: 0 6px;
  line-height: 1;
  font-family: inherit;
}
.modal-close:hover { color: var(--blood-bright); }

.terminal {
  background: #000;
  border: 1px solid var(--border-strong);
  padding: 10px 12px;
  margin-bottom: 16px;
  font-family: "Consolas", monospace;
  font-size: 0.82rem;
  color: var(--ok);
  min-height: 38px;
}

.term-line { letter-spacing: 0.5px; }

#authForm .form-row.single {
  display: grid;
  grid-template-columns: 1fr;
  margin-bottom: 10px;
  gap: 10px;
}

#authForm input {
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--gold-bright);
  padding: 10px 12px;
  font-family: "Consolas", monospace;
  font-size: 0.95rem;
  width: 100%;
  letter-spacing: 1px;
}

#authForm input:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold-dim), 0 0 12px rgba(212, 175, 55, 0.2);
}

#authForm input::placeholder { color: #555; }

#pwForm .form-row.single {
  display: grid;
  grid-template-columns: 1fr;
  margin-bottom: 10px;
  gap: 10px;
}
#pwForm input {
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--gold-bright);
  padding: 10px 12px;
  font-family: "Consolas", monospace;
  font-size: 0.95rem;
  width: 100%;
  letter-spacing: 1px;
  border-radius: 0;
}
#pwForm input:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold-dim), 0 0 12px rgba(212, 175, 55, 0.2);
}
#pwForm input::placeholder { color: #555; }

/* Rank-change modal */
.rank-modal-meta {
  display: flex;
  gap: 14px;
  margin-bottom: 14px;
  padding: 10px 12px;
  background: rgba(0, 0, 0, 0.4);
  border-left: 2px solid var(--gold-dim);
}
.rank-modal-meta > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
}
.rank-meta-lbl {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-dim);
}
.rank-meta-val {
  font-family: "Cinzel", serif;
  color: var(--gold-bright);
  font-size: 0.95rem;
  letter-spacing: 0.5px;
}
#rankForm select {
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--gold-bright);
  padding: 10px 12px;
  font-family: "Consolas", monospace;
  font-size: 0.95rem;
  width: 100%;
  letter-spacing: 1px;
  border-radius: 0;
  cursor: pointer;
}
#rankForm select:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold-dim), 0 0 12px rgba(212, 175, 55, 0.2);
}
#rankForm select option { background: #0a0a0a; color: var(--gold-bright); padding: 6px; }

#mapPointForm .form-row.single {
  display: grid;
  grid-template-columns: 1fr;
  margin-bottom: 10px;
  gap: 10px;
}
#mapPointForm input[type="text"] {
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--gold-bright);
  padding: 10px 12px;
  font-family: "Consolas", monospace;
  font-size: 0.95rem;
  width: 100%;
  letter-spacing: 1px;
  border-radius: 0;
}
#mapPointForm input[type="text"]:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold-dim), 0 0 12px rgba(212, 175, 55, 0.2);
}
#mapPointForm input[type="text"]::placeholder { color: #555; }
#mapPointForm textarea {
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--text);
  font-family: "Consolas", monospace;
  font-size: 0.9rem;
  padding: 10px 12px;
  letter-spacing: 0.5px;
  min-height: 90px;
}
#mapPointForm textarea:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold-dim), 0 0 12px rgba(212, 175, 55, 0.2);
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 12px;
}

.modal-hint {
  margin: 10px 0 0;
  font-family: "Consolas", monospace;
  font-size: 0.78rem;
  color: var(--text-dim);
  letter-spacing: 0.5px;
  min-height: 1em;
}

.modal-hint.error { color: var(--blood-bright); }
.modal-hint.ok { color: var(--ok); }

/* ---------- Freq tile decode state ---------- */
.freq-tile.decoding .num {
  color: var(--blood-bright);
  text-shadow: 0 0 10px rgba(217, 69, 69, 0.5);
  filter: blur(0.4px);
}

/* ---------- Remember me checkbox (auth modal) ---------- */
.remember-row { margin-top: -4px; }
.remember-check {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  user-select: none;
  font-family: "Consolas", monospace;
  font-size: 0.78rem;
  color: var(--text-dim);
  letter-spacing: 1px;
}
.remember-check input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.remember-box {
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 1px solid var(--gold-dim);
  background: rgba(0, 0, 0, 0.5);
  position: relative;
  transition: border-color 0.15s, background 0.15s;
}
.remember-check:hover .remember-box { border-color: var(--gold); }
.remember-check input:checked + .remember-box {
  border-color: var(--gold);
  background: rgba(212, 175, 55, 0.2);
}
.remember-check input:checked + .remember-box::after {
  content: "×";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Cinzel", serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--gold-bright);
  line-height: 1;
}
.remember-check input:focus-visible + .remember-box {
  outline: 1px solid var(--gold-bright);
  outline-offset: 2px;
}
.remember-text { color: var(--text); }

/* ---------- Drop Map ---------- */
.dropmap-head-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}
.dropmap-hint {
  font-family: "Consolas", monospace;
  font-size: 0.76rem;
  letter-spacing: 1px;
}

.dropmap-head-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.dropmap-search-wrap { position: relative; }
.dropmap-search-input {
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--gold-bright);
  padding: 7px 12px;
  font-family: "Consolas", monospace;
  font-size: 0.82rem;
  letter-spacing: 1px;
  border-radius: 0;
  width: 240px;
}
.dropmap-search-input:focus { outline: none; border-color: var(--gold); }
.dropmap-search-input::placeholder { color: #555; }
.dropmap-search-results {
  position: absolute;
  top: calc(100% + 2px);
  left: 0;
  right: 0;
  background: rgba(10, 8, 8, 0.97);
  border: 1px solid var(--gold);
  max-height: 280px;
  overflow-y: auto;
  z-index: 30;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.6);
}
.dropmap-search-results.hidden { display: none; }
.dropmap-search-result {
  padding: 6px 10px;
  font-family: "Rajdhani", sans-serif;
  font-size: 0.88rem;
  color: var(--text);
  cursor: pointer;
  border-bottom: 1px solid rgba(212, 175, 55, 0.08);
  display: flex;
  align-items: center;
  gap: 8px;
}
.dropmap-search-result:last-child { border-bottom: 0; }
.dropmap-search-result:hover,
.dropmap-search-result.is-active {
  background: rgba(212, 175, 55, 0.12);
  color: var(--gold-bright);
}
.dropmap-search-result .sr-kind {
  font-family: "Consolas", monospace;
  font-size: 0.66rem;
  letter-spacing: 1px;
  color: var(--gold);
  min-width: 30px;
}
.dropmap-search-result.is-sub .sr-kind { color: var(--text-dim); }
.dropmap-search-result .sr-parent {
  margin-left: auto;
  color: var(--text-dim);
  font-size: 0.74rem;
  font-style: italic;
}
.dropmap-search-empty {
  padding: 8px 10px;
  font-family: "Consolas", monospace;
  font-size: 0.76rem;
  color: var(--text-dim);
  font-style: italic;
}

.dropmap-wrap {
  width: 100%;
  max-width: min(1000px, calc(100vh - 220px));
  margin: 0 auto;
}

.dropmap-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  border: 1px solid var(--gold-dim);
  background: #0a0808;
  overflow: hidden;
  cursor: crosshair;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.6), 0 10px 40px rgba(0, 0, 0, 0.5);
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
}
.dropmap-frame.is-panning { cursor: grabbing; }

.dropmap-transform {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

.dropmap-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  pointer-events: none;
  user-select: none;
  -webkit-user-drag: none;
  image-rendering: auto;
}

.dropmap-points {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.dropmap-zoom {
  position: absolute;
  top: 10px;
  right: 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  z-index: 15;
}
.dropmap-zoom-btn {
  width: 30px;
  height: 30px;
  background: rgba(10, 8, 8, 0.85);
  color: var(--gold);
  border: 1px solid var(--gold-dim);
  font-family: "Consolas", monospace;
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: border-color 0.12s ease, color 0.12s ease, background 0.12s ease;
}
.dropmap-zoom-btn:hover {
  border-color: var(--gold);
  color: var(--gold-bright);
  background: rgba(20, 16, 12, 0.95);
}
.dropmap-zoom-btn:active { transform: translateY(1px); }

.dropmap-point {
  position: absolute;
  width: 28px;
  height: 28px;
  padding: 0;
  background: transparent;
  border: 0;
  transform: translate(-50%, -100%);
  pointer-events: auto;
  cursor: pointer;
  color: var(--blood-bright);
  transition: transform 0.12s ease;
}

.dropmap-pin {
  display: block;
  width: 16px;
  height: 16px;
  margin: 6px auto 0;
  background: var(--blood-bright);
  border: 2px solid var(--gold);
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  box-shadow:
    0 0 0 2px rgba(0, 0, 0, 0.6),
    0 0 8px rgba(217, 69, 69, 0.7),
    0 0 16px rgba(217, 69, 69, 0.3);
}

.dropmap-point::after {
  content: "";
  position: absolute;
  bottom: -3px;
  left: 50%;
  width: 6px;
  height: 3px;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 50%;
  transform: translateX(-50%);
  filter: blur(2px);
}

.dropmap-point:hover {
  transform: translate(-50%, -100%) scale(1.15);
  z-index: 5;
}
.dropmap-point:hover .dropmap-pin {
  box-shadow:
    0 0 0 2px rgba(0, 0, 0, 0.6),
    0 0 14px rgba(217, 69, 69, 0.9),
    0 0 28px rgba(217, 69, 69, 0.5);
}

.dropmap-point-label {
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(-4px);
  white-space: nowrap;
  padding: 2px 7px;
  background: rgba(10, 8, 8, 0.55);
  color: var(--gold-bright);
  border: 1px solid rgba(212, 175, 55, 0.35);
  font-family: "Cinzel", serif;
  font-size: 0.7rem;
  letter-spacing: 1px;
  pointer-events: none;
  opacity: 0.5;
  transition: opacity 0.12s ease, background 0.12s ease, border-color 0.12s ease;
  z-index: 6;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.9);
}
.dropmap-point:hover .dropmap-point-label {
  opacity: 1;
  background: rgba(10, 8, 8, 0.95);
  border-color: var(--gold-dim);
}

/* Popup anchored to pin */
.dropmap-popup {
  position: absolute;
  z-index: 20;
  transform: translate(12px, -50%);
  width: 280px;
  max-width: 80vw;
  background: rgba(14, 12, 12, 0.97);
  border: 1px solid var(--gold);
  padding: 14px 16px 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.7);
  color: var(--text);
}
.dropmap-popup.hidden { display: none; }
.dropmap-popup.flip-x { transform: translate(calc(-100% - 12px), -50%); }
.dropmap-popup.flip-y { transform: translate(12px, calc(-100% + 12px)); }
.dropmap-popup.flip-x.flip-y { transform: translate(calc(-100% - 12px), calc(-100% + 12px)); }

.dropmap-popup::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 12px; height: 12px;
  border-top: 1px solid var(--gold);
  border-left: 1px solid var(--gold);
}
.dropmap-popup::after {
  content: "";
  position: absolute;
  bottom: 0; right: 0;
  width: 12px; height: 12px;
  border-bottom: 1px solid var(--gold);
  border-right: 1px solid var(--gold);
}

.dropmap-popup-close {
  position: absolute;
  top: 6px;
  right: 8px;
  background: transparent;
  border: 0;
  color: var(--text-dim);
  font-size: 1.2rem;
  cursor: pointer;
  line-height: 1;
  padding: 2px 6px;
}
.dropmap-popup-close:hover { color: var(--blood-bright); }

.dropmap-popup-title {
  font-family: "Cinzel", serif;
  font-size: 1rem;
  color: var(--gold-bright);
  margin: 0 20px 6px 0;
  letter-spacing: 0.5px;
}

.dropmap-popup-meta {
  display: flex;
  gap: 6px;
  font-size: 0.72rem;
  color: var(--text-dim);
  letter-spacing: 0.5px;
  margin-bottom: 10px;
  font-family: "Consolas", monospace;
}

.dropmap-popup-notes {
  font-size: 0.86rem;
  line-height: 1.5;
  color: var(--text);
  padding: 8px 10px;
  background: rgba(0, 0, 0, 0.35);
  border-left: 2px solid var(--gold-dim);
  margin-bottom: 12px;
  word-wrap: break-word;
}

.dropmap-popup-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}
.dropmap-popup-actions .btn { padding: 4px 12px; font-size: 0.78rem; }

/* Sub-spots list inside main popup */
.dropmap-popup-subs {
  border-top: 1px dashed rgba(212, 175, 55, 0.3);
  padding-top: 10px;
  margin-bottom: 10px;
}
.dropmap-popup-subs.hidden { display: none; }
.dropmap-subs-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6px;
}
.dropmap-subs-label {
  font-family: "Consolas", monospace;
  font-size: 0.72rem;
  letter-spacing: 1.5px;
  color: var(--gold);
  text-transform: uppercase;
}
.dropmap-subs-add { padding: 2px 8px; font-size: 0.72rem; letter-spacing: 0.5px; }
.dropmap-subs-list {
  list-style: none;
  padding: 0;
  margin: 0;
  max-height: 140px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.dropmap-subs-list li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  padding: 4px 8px;
  background: rgba(0, 0, 0, 0.35);
  border-left: 2px solid var(--gold-dim);
  font-size: 0.8rem;
  cursor: pointer;
  transition: background 0.12s ease, border-color 0.12s ease;
}
.dropmap-subs-list li:hover {
  background: rgba(20, 16, 12, 0.7);
  border-left-color: var(--gold);
}
.dropmap-subs-list .sub-title {
  color: var(--text);
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dropmap-subs-list .sub-marker {
  color: var(--gold);
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
}
.dropmap-subs-list .sub-empty {
  color: var(--text-dim);
  font-style: italic;
  font-size: 0.78rem;
  padding: 4px 0;
  cursor: default;
  background: transparent;
  border: 0;
  text-align: center;
  justify-content: center;
}

/* Sub-spot pins */
.dropmap-point.is-sub .dropmap-pin {
  width: 11px;
  height: 11px;
  background: var(--gold);
  border-color: var(--blood-bright);
  box-shadow:
    0 0 0 2px rgba(0, 0, 0, 0.6),
    0 0 6px rgba(212, 175, 55, 0.6),
    0 0 12px rgba(212, 175, 55, 0.3);
}
.dropmap-point.is-sub {
  width: 22px;
  height: 22px;
}
.dropmap-point.is-sub .dropmap-point-label {
  font-size: 0.66rem;
  color: var(--gold);
}

/* Add-mode banner */
.dropmap-addmode-banner {
  position: absolute;
  top: 10px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(10, 8, 8, 0.9);
  border: 1px solid var(--blood-bright);
  color: var(--gold-bright);
  padding: 6px 14px;
  font-family: "Consolas", monospace;
  font-size: 0.78rem;
  letter-spacing: 1px;
  z-index: 25;
  box-shadow: 0 0 16px rgba(161, 28, 28, 0.35);
}
.dropmap-addmode-banner.hidden { display: none; }
.dropmap-addmode-banner kbd {
  background: #050505;
  border: 1px solid var(--gold-dim);
  padding: 0 4px;
  font-size: 0.7rem;
  color: var(--gold);
}

/* Hide map edit controls for users below Spirit */
body:not(.can-map-edit) #popupEdit,
body:not(.can-map-edit) #popupDelete,
body:not(.can-map-edit) .dropmap-popup-actions,
body:not(.can-map-edit) #popupAddSub,
body:not(.can-map-edit) .dropmap-frame { cursor: default; }
body:not(.can-map-edit) #popupEdit,
body:not(.can-map-edit) #popupDelete,
body:not(.can-map-edit) .dropmap-popup-actions,
body:not(.can-map-edit) #popupAddSub { display: none !important; }
body:not(.can-map-edit) .dropmap-hint { display: none; }

/* ---------- Drop form: items rows ---------- */
.drop-items-block {
  border: 1px solid var(--border-strong);
  background: rgba(0, 0, 0, 0.25);
  margin-bottom: 10px;
}
.drop-items-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 10px;
  border-bottom: 1px dashed rgba(212, 175, 55, 0.2);
}
.drop-items-label {
  font-family: "Consolas", monospace;
  font-size: 0.74rem;
  letter-spacing: 1.5px;
  color: var(--gold);
  text-transform: uppercase;
}
.drop-items-add { padding: 2px 10px; font-size: 0.74rem; letter-spacing: 0.5px; }
.drop-items-rows { padding: 8px 10px; display: flex; flex-direction: column; gap: 6px; }
.drop-item-row {
  display: grid;
  grid-template-columns: 1fr 90px 28px;
  gap: 8px;
  align-items: center;
}
.drop-item-row select,
.drop-item-row input {
  background: var(--bg);
  border: 1px solid var(--border-strong);
  color: var(--text);
  padding: 8px 10px;
  font-family: "Rajdhani", sans-serif;
  font-size: 0.92rem;
  border-radius: 0;
}
.drop-item-row select:focus,
.drop-item-row input:focus {
  outline: none;
  border-color: var(--gold);
}
.drop-item-remove {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--blood-bright);
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  padding: 4px 0;
  height: 100%;
}
.drop-item-remove:hover { border-color: var(--blood-bright); background: rgba(161, 28, 28, 0.15); }
.drop-item-remove:disabled { opacity: 0.3; cursor: not-allowed; }

.drop-items-cell { min-width: 110px; }
.drop-items-summary {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 1.5px;
  color: var(--gold-bright);
  font-size: 1.05rem;
}
.drop-items-summary .num { color: var(--gold); }
.drop-items-summary .lbl {
  color: var(--text-dim);
  font-family: "Consolas", monospace;
  font-size: 0.74rem;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.drop-items-summary .sp {
  display: block;
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1px;
  color: var(--gold);
  margin-top: 1px;
}
.drop-tax-cell { font-family: "Bebas Neue", sans-serif; letter-spacing: 1px; color: var(--gold); }

/* Price block in form */
.drop-price-block {
  border: 1px solid var(--border-strong);
  background: rgba(0, 0, 0, 0.25);
  padding: 10px 12px;
  margin-bottom: 10px;
}
.drop-price-row {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) minmax(120px, 1fr) minmax(160px, 1.4fr);
  gap: 12px;
  align-items: end;
}
.drop-price-field { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.drop-price-label {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  color: var(--gold);
  text-transform: uppercase;
}
.drop-price-input {
  display: flex;
  align-items: stretch;
  border: 1px solid var(--border-strong);
  background: var(--bg);
}
.drop-price-prefix {
  background: #050505;
  color: var(--gold);
  padding: 8px 10px;
  border-right: 1px solid var(--border-strong);
  font-family: "Consolas", monospace;
  font-size: 0.95rem;
}
.drop-price-input input {
  border: 0;
  background: transparent;
  color: var(--gold-bright);
  padding: 8px 10px;
  flex: 1;
  font-family: "Consolas", monospace;
  font-size: 0.95rem;
  width: 100%;
  min-width: 0;
}
.drop-price-input input:focus { outline: none; }
.drop-price-input:focus-within { border-color: var(--gold); }
.drop-price-fill {
  background: rgba(0, 0, 0, 0.4);
  border: 0;
  border-left: 1px solid var(--border-strong);
  color: var(--gold);
  padding: 0 10px;
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1px;
  cursor: pointer;
  transition: color 0.12s ease, background 0.12s ease;
}
.drop-price-fill:hover { color: var(--gold-bright); background: rgba(212, 175, 55, 0.08); }
.drop-price-sp {
  border-top: 1px dashed rgba(212, 175, 55, 0.15);
  padding-top: 4px !important;
  margin-top: 3px;
  color: var(--gold-bright) !important;
}
.drop-price-sp span:last-child {
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 1.5px;
  font-size: 0.95rem;
  color: var(--gold-bright);
}
.drop-price-field select {
  background: var(--bg);
  border: 1px solid var(--border-strong);
  color: var(--text);
  padding: 8px 10px;
  font-family: "Rajdhani", sans-serif;
  font-size: 0.92rem;
  border-radius: 0;
}
.drop-price-totals {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-left: 10px;
  border-left: 1px dashed rgba(212, 175, 55, 0.25);
  font-family: "Consolas", monospace;
  font-size: 0.86rem;
  align-self: stretch;
  justify-content: center;
}
.drop-price-row-line { display: flex; justify-content: space-between; gap: 12px; color: var(--text); }
.drop-price-row-line .dim { color: var(--text-dim); }
.drop-price-total { color: var(--gold-bright); font-size: 0.98rem; padding-top: 3px; border-top: 1px solid rgba(212, 175, 55, 0.2); margin-top: 2px; }

/* Price cell in table */
.drop-price-cell {
  font-family: "Consolas", monospace;
  font-size: 0.86rem;
  white-space: nowrap;
  line-height: 1.25;
}
.drop-price-cell .dpc-total {
  color: var(--gold-bright);
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 1px;
  font-size: 1rem;
  display: block;
}
.drop-price-cell .dpc-sub {
  color: var(--text-dim);
  font-size: 0.7rem;
  letter-spacing: 0.5px;
}
.drop-price-cell.is-zero .dpc-total { color: var(--text-dim); }

/* Progress indicator */
.col-progress { width: 40px; text-align: center; font-size: 0.7rem; color: var(--gold-dim); }
.drop-progress-cell { text-align: center; }
.drop-progress-dot {
  display: inline-block;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: var(--text-dim);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.5);
  vertical-align: middle;
}
.drop-progress-dot.is-pending { background: #6b6b6b; }
.drop-progress-dot.is-collected {
  background: var(--gold);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.5), 0 0 6px rgba(212, 175, 55, 0.55);
}
.drop-progress-dot.is-complete {
  background: var(--ok);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.5), 0 0 8px rgba(110, 209, 154, 0.7);
}
.drop-progress-dot.is-bad {
  background: var(--blood-bright);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.5), 0 0 8px rgba(217, 69, 69, 0.6);
}
.drop-progress-label {
  display: inline-block;
  margin-left: 6px;
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text-dim);
}
.drop-progress-dot.is-complete + .drop-progress-label { color: var(--ok); }
.drop-progress-dot.is-collected + .drop-progress-label { color: var(--gold); }
.drop-progress-dot.is-bad + .drop-progress-label { color: var(--blood-bright); }

.drop-collected-cell { text-align: center; }
.drop-mark-cell { padding-top: 8px; padding-bottom: 8px; }
.drop-mark-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}
.drop-mark-name {
  font-family: "Rajdhani", sans-serif;
  font-size: 0.86rem;
  color: var(--text);
  white-space: nowrap;
}
.drop-mark-name.is-disabled { color: var(--text-dim); }
.drop-mark-toggle .drop-collected-toggle:not(:checked) + .drop-mark-name { color: var(--text-dim); font-style: italic; }

.cell-time {
  white-space: nowrap;
  font-family: "Consolas", monospace;
  font-size: 0.8rem;
  color: var(--text-dim);
  letter-spacing: 0.5px;
}
.cell-location {
  max-width: 180px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cell-notes {
  max-width: 240px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text-dim);
  font-size: 0.86rem;
}

/* Drops table specifics — compact so everything fits without horizontal scroll */
#drops .data-table th,
#drops .data-table td { padding: 8px 10px; white-space: nowrap; }
#drops .data-table { font-size: 0.88rem; }
#drops .data-table td { vertical-align: middle; }

/* Stack checkbox above name so collected/delivered/paid columns stay narrow */
#drops .drop-mark-cell { padding-top: 6px; padding-bottom: 6px; }
#drops .drop-mark-toggle {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  cursor: pointer;
}
#drops .drop-mark-name {
  font-size: 0.7rem;
  letter-spacing: 0.4px;
  max-width: 96px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: center;
}
#drops .col-progress { width: 28px; padding-left: 8px; padding-right: 4px; }
#drops .drop-progress-cell { padding-left: 8px; padding-right: 4px; }
#drops .cell-location { max-width: 140px; }
#drops .cell-notes { max-width: 160px; }
#drops .row-actions { white-space: nowrap; }
#drops .row-actions .btn { padding: 3px 8px; font-size: 0.74rem; }

.drop-collected-toggle {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border: 1px solid var(--gold-dim);
  background: #050505;
  cursor: pointer;
  position: relative;
  vertical-align: middle;
  transition: border-color 0.12s ease, background 0.12s ease;
}
.drop-collected-toggle:hover { border-color: var(--gold); }
.drop-collected-toggle:checked {
  background: var(--ok);
  border-color: var(--gold);
}
.drop-collected-toggle:checked::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 1px;
  width: 5px;
  height: 9px;
  border: solid #050505;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
#collectForm input[type="text"] {
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--gold-bright);
  padding: 10px 12px;
  font-family: "Consolas", monospace;
  font-size: 0.95rem;
  width: 100%;
  letter-spacing: 1px;
  border-radius: 0;
}
#collectForm input[type="text"]:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold-dim), 0 0 12px rgba(212, 175, 55, 0.2);
}
#collectForm input[type="text"]::placeholder { color: #555; }

/* Clickable rows */
tr.drop-row { cursor: pointer; transition: background 0.1s ease; }
tr.drop-row:hover { background: rgba(212, 175, 55, 0.05); }
tr.drop-row .row-actions .btn { cursor: pointer; }

/* Toolbar with search */
.drops-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.drops-search {
  flex: 1;
  max-width: 360px;
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--gold-bright);
  padding: 8px 12px;
  font-family: "Consolas", monospace;
  font-size: 0.84rem;
  letter-spacing: 1px;
  border-radius: 0;
}
.drops-search:focus { outline: none; border-color: var(--gold); }
.drops-search::placeholder { color: #555; }
.drops-search-count {
  font-family: "Consolas", monospace;
  font-size: 0.74rem;
  color: var(--text-dim);
  letter-spacing: 1px;
}

/* Drop detail modal */
.drop-detail-card { max-width: 580px; }
.drop-detail-body { display: flex; flex-direction: column; gap: 14px; }
.drop-detail-section { display: flex; flex-direction: column; gap: 6px; }
.drop-detail-label {
  font-family: "Consolas", monospace;
  font-size: 0.72rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--gold);
}
.drop-detail-items {
  display: flex;
  flex-direction: column;
  gap: 3px;
  background: rgba(0, 0, 0, 0.35);
  border-left: 2px solid var(--gold-dim);
  padding: 8px 12px;
}
.drop-detail-items .dd-item {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-family: "Rajdhani", sans-serif;
  font-size: 0.95rem;
}
.drop-detail-items .dd-item-qty {
  font-family: "Bebas Neue", sans-serif;
  color: var(--gold);
  font-size: 1rem;
  letter-spacing: 1px;
  min-width: 38px;
}
.drop-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 16px;
}
.drop-detail-grid > div { display: flex; flex-direction: column; gap: 2px; }
.drop-detail-grid .dd-grid-wide { grid-column: 1 / -1; }
.dd-label {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-dim);
}
.dd-val {
  font-family: "Rajdhani", sans-serif;
  font-size: 0.95rem;
  color: var(--text);
  word-break: break-word;
}
.dd-val.dim { color: var(--text-dim); font-style: italic; }
.drop-detail-notes {
  background: rgba(0, 0, 0, 0.35);
  border-left: 2px solid var(--gold-dim);
  padding: 8px 12px;
  font-size: 0.92rem;
  line-height: 1.5;
  word-wrap: break-word;
  white-space: pre-wrap;
}
.drop-detail-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  border-top: 1px dashed rgba(212, 175, 55, 0.2);
  padding-top: 10px;
}

/* ---------- Items picker (modal) ---------- */
.items-picker {
  border: 1px solid var(--border-strong);
  background: #050505;
  display: flex;
  flex-direction: column;
}
.items-picker-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-bottom: 1px dashed rgba(212, 175, 55, 0.25);
}
.items-picker-label {
  font-family: "Consolas", monospace;
  font-size: 0.74rem;
  letter-spacing: 1.5px;
  color: var(--gold);
  text-transform: uppercase;
  white-space: nowrap;
}
.items-picker-search {
  flex: 1;
  background: #0a0a0a;
  border: 1px solid var(--border);
  color: var(--gold-bright);
  padding: 4px 8px;
  font-family: "Consolas", monospace;
  font-size: 0.78rem;
  letter-spacing: 0.5px;
  border-radius: 0;
  min-width: 0;
}
.items-picker-search:focus {
  outline: none;
  border-color: var(--gold-dim);
}
.items-picker-selected {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 8px 10px;
  border-bottom: 1px dashed rgba(212, 175, 55, 0.25);
  min-height: 28px;
}
.items-picker-selected:empty::before {
  content: "no items selected";
  color: var(--text-dim);
  font-family: "Consolas", monospace;
  font-size: 0.74rem;
  font-style: italic;
}
.items-picker-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(161, 28, 28, 0.18);
  border: 1px solid rgba(217, 69, 69, 0.45);
  color: var(--gold-bright);
  font-family: "Rajdhani", sans-serif;
  font-size: 0.78rem;
  padding: 1px 6px 1px 8px;
  letter-spacing: 0.5px;
  cursor: default;
}
.items-picker-chip button {
  background: transparent;
  border: 0;
  color: var(--blood-bright);
  font-size: 0.95rem;
  line-height: 1;
  padding: 0 2px;
  cursor: pointer;
}
.items-picker-chip button:hover { color: #ff6b6b; }
.items-picker-categories {
  max-height: 240px;
  overflow-y: auto;
  padding: 4px 0;
}
.items-picker-cat { border-bottom: 1px solid rgba(212, 175, 55, 0.08); }
.items-picker-cat:last-child { border-bottom: 0; }
.items-picker-cat-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: transparent;
  border: 0;
  color: var(--gold);
  font-family: "Bebas Neue", sans-serif;
  font-size: 0.95rem;
  letter-spacing: 2px;
  padding: 6px 12px;
  cursor: pointer;
  text-align: left;
}
.items-picker-cat-head:hover { background: rgba(212, 175, 55, 0.05); }
.items-picker-cat-arrow {
  font-family: "Consolas", monospace;
  color: var(--gold-dim);
  font-size: 0.78rem;
  transition: transform 0.15s ease;
}
.items-picker-cat.open .items-picker-cat-arrow { transform: rotate(90deg); }
.items-picker-cat-count {
  color: var(--text-dim);
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1px;
  margin-left: auto;
  margin-right: 8px;
}
.items-picker-cat-list {
  display: none;
  padding: 2px 12px 8px 18px;
}
.items-picker-cat.open .items-picker-cat-list { display: block; }
.items-picker-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 3px 0;
  font-family: "Rajdhani", sans-serif;
  font-size: 0.86rem;
  color: var(--text);
  cursor: pointer;
  user-select: none;
}
.items-picker-row:hover { color: var(--gold-bright); }
.items-picker-row input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 12px;
  height: 12px;
  border: 1px solid var(--gold-dim);
  background: #050505;
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
}
.items-picker-row input[type="checkbox"]:checked {
  background: var(--gold);
  border-color: var(--gold-bright);
}
.items-picker-row input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  inset: 2px;
  background: #050505;
}
.items-picker-row.is-checked { color: var(--gold-bright); }
.items-picker-cat.is-empty { display: none; }

/* Items list inside popup */
.dropmap-popup-items {
  margin-bottom: 10px;
}
.dropmap-popup-items.hidden { display: none; }
.dropmap-popup-items-label {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 4px;
  display: block;
}
.dropmap-popup-items-list {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
}
.dropmap-popup-item-tag {
  background: rgba(161, 28, 28, 0.16);
  border: 1px solid rgba(217, 69, 69, 0.4);
  color: var(--gold-bright);
  font-family: "Rajdhani", sans-serif;
  font-size: 0.74rem;
  padding: 1px 6px;
  letter-spacing: 0.5px;
}

/* ---------- Tier badges (IC / OOC) ---------- */
.tier-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  font-family: "Cinzel", serif;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  border-radius: 2px;
  border: 1px solid currentColor;
  background: rgba(0, 0, 0, 0.4);
  flex-shrink: 0;
}
.tier-badge::before {
  font-family: "Consolas", monospace;
  font-size: 0.75rem;
  opacity: 0.9;
}
.tier-badge-ic {
  color: var(--blood-bright);
  text-shadow: 0 0 6px rgba(217, 69, 69, 0.4);
}
.tier-badge-ic::before { content: "鬼"; font-family: "Cinzel", serif; font-size: 0.9rem; }
.tier-badge-ooc {
  color: var(--gold);
}
.tier-badge-ooc::before { content: "⚙"; font-size: 0.85rem; }

/* Home announcement card tier accent */
.home-announce-card.tier-ic { border-left-color: var(--blood); cursor: pointer; }
.home-announce-card.tier-ooc { border-left-color: var(--gold-dim); cursor: pointer; }
.home-announce-card { transition: transform 0.12s ease, border-left-color 0.2s; }
.home-announce-card:hover { transform: translateX(2px); }
.home-announce-card.tier-ic:hover { border-left-color: var(--blood-bright); }
.home-announce-card.tier-ooc:hover { border-left-color: var(--gold); }

#homeAnnounce { display: flex; flex-direction: column; gap: 14px; }

/* Announce card head: title left, badge right */
.home-announce-card .announce-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

/* ---------- Auth/role gating helpers ---------- */
body:not(.is-low-command) .requires-low-command { display: none !important; }
body:not(.is-high-command) .requires-high-command { display: none !important; }

/* ---------- Drop-Map-Only role: lock the UI to just the map ---------- */
body.is-dropmap-only .primary-tabs .tab:not([data-tab="ic"]) { display: none !important; }
body.is-dropmap-only .sub-tabs .subtab:not([data-subtab="dropmap"]) { display: none !important; }
body.is-dropmap-only #home,
body.is-dropmap-only #ooc,
body.is-dropmap-only #admin,
body.is-dropmap-only #members,
body.is-dropmap-only #announcements,
body.is-dropmap-only #allies,
body.is-dropmap-only #drops { display: none !important; }
body.is-dropmap-only .home-link,
body.is-dropmap-only .home-actions-grid,
body.is-dropmap-only .strike-banner,
body.is-dropmap-only .war-alert { display: none !important; }
/* Header pseudo-prompt swap so it's clear this is a locked terminal */
body.is-dropmap-only .primary-tabs::before { content: "// secure :: dropmap_terminal"; color: var(--blood-bright); }
body.is-dropmap-only #ic { padding-top: 0; }

/* ---------- Account Management ---------- */
.acct-head-actions { display: flex; align-items: center; gap: 14px; }
.acct-head-tag {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  color: var(--blood-bright);
  text-transform: uppercase;
  padding: 3px 10px;
  border: 1px solid rgba(217, 69, 69, 0.4);
  background: rgba(161, 28, 28, 0.1);
}

.acct-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.acct-summary-cell {
  background: linear-gradient(180deg, var(--bg-elev) 0%, #060606 100%);
  border: 1px solid var(--border);
  padding: 10px 14px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  position: relative;
}
.acct-summary-cell::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 28px; height: 2px;
  background: currentColor;
}
.acct-summary-num {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.55rem;
  letter-spacing: 1.5px;
  color: var(--text);
  line-height: 1;
}
.acct-summary-lbl {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  color: var(--text-dim);
  text-transform: uppercase;
}
.acct-summary-cell.tier-high    { color: #ff5e5e; border-color: rgba(217, 69, 69, 0.4); }
.acct-summary-cell.tier-low     { color: var(--gold-bright); border-color: rgba(212, 175, 55, 0.4); }
.acct-summary-cell.tier-training{ color: #b58aff; border-color: rgba(154, 107, 255, 0.35); }
.acct-summary-cell.tier-members { color: #9aa0a6; }
.acct-summary-cell.tier-pending { color: var(--gold); border-color: rgba(212, 175, 55, 0.4); }
.acct-summary-cell.tier-unlinked{ color: var(--blood-bright); border-color: rgba(217, 69, 69, 0.4); }

.acct-toolbar { display: flex; gap: 10px; margin-bottom: 14px; }
.acct-search {
  flex: 1;
  max-width: 340px;
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--gold-bright);
  padding: 9px 14px;
  font-family: "Consolas", monospace;
  font-size: 0.84rem;
  letter-spacing: 1px;
}
.acct-search:focus { outline: none; border-color: var(--gold); }
.acct-search::placeholder { color: #555; }

.acct-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 12px;
}
.acct-card {
  position: relative;
  background: linear-gradient(180deg, rgba(15, 15, 15, 0.85) 0%, rgba(8, 8, 8, 0.9) 100%);
  border: 1px solid var(--border-strong);
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: border-color 0.12s ease;
}
.acct-card::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--rank-color, var(--text-dim));
  opacity: 0.7;
}
.acct-card:hover { border-color: rgba(212, 175, 55, 0.3); }
.acct-card.is-locked { opacity: 0.55; }
.acct-card-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.acct-card-name {
  margin: 0;
  font-family: "Cinzel", serif;
  color: var(--gold-bright);
  font-size: 1.1rem;
  font-weight: 600;
  letter-spacing: 0.5px;
  word-break: break-word;
}
.acct-card-name .acct-self {
  display: inline-block;
  margin-left: 6px;
  padding: 0 6px;
  font-family: "Consolas", monospace;
  font-size: 0.65rem;
  letter-spacing: 1.5px;
  color: var(--gold);
  background: rgba(212, 175, 55, 0.1);
  border: 1px solid var(--gold-dim);
  text-transform: uppercase;
}
.acct-card-rank.rank-pill { font-size: 0.78rem; padding: 3px 10px; }
.acct-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  font-family: "Consolas", monospace;
  font-size: 0.74rem;
  letter-spacing: 0.5px;
  color: var(--text-dim);
  border-top: 1px dashed rgba(212, 175, 55, 0.12);
  border-bottom: 1px dashed rgba(212, 175, 55, 0.12);
  padding: 8px 0;
}
.acct-card-meta-cell { display: flex; flex-direction: column; gap: 2px; min-width: 100px; }
.acct-card-meta-key {
  font-size: 0.66rem;
  letter-spacing: 1.5px;
  color: var(--gold-dim);
  text-transform: uppercase;
}
.acct-card-meta-val { color: var(--text); word-break: break-word; }
.acct-card-roster {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: "Consolas", monospace;
  font-size: 0.74rem;
  letter-spacing: 1px;
  padding: 4px 8px;
  border: 1px solid var(--border-strong);
  background: rgba(0, 0, 0, 0.3);
}
.acct-card-roster.is-linked { color: var(--ok); border-color: rgba(110, 209, 154, 0.35); }
.acct-card-roster.is-unlinked { color: var(--blood-bright); border-color: rgba(217, 69, 69, 0.35); }
.acct-card-roster.is-mismatch { color: #f0d068; border-color: rgba(232, 193, 90, 0.4); }
.acct-card-roster::before {
  content: "●";
  font-size: 0.6rem;
}
.acct-card-pending {
  font-family: "Consolas", monospace;
  font-size: 0.74rem;
  letter-spacing: 1px;
  color: var(--gold);
  padding: 3px 8px;
  border: 1px solid var(--gold-dim);
  background: rgba(212, 175, 55, 0.06);
  text-transform: uppercase;
}
.acct-card-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.acct-card-actions .btn { padding: 4px 10px; font-size: 0.76rem; }

/* Recruitment toggle */
.acct-recruit {
  display: grid;
  grid-template-columns: auto auto 1fr;
  align-items: center;
  gap: 6px 10px;
  padding: 6px 10px;
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid var(--border-strong);
  cursor: pointer;
  user-select: none;
  font-family: "Consolas", monospace;
  font-size: 0.76rem;
  letter-spacing: 0.5px;
  color: var(--text-dim);
  transition: border-color 0.12s ease, background 0.12s ease;
}
.acct-recruit:hover { border-color: rgba(212, 175, 55, 0.35); }
.acct-recruit input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 14px;
  height: 14px;
  border: 1px solid var(--gold-dim);
  background: #050505;
  cursor: pointer;
  position: relative;
  margin: 0;
}
.acct-recruit input[type="checkbox"]:checked {
  background: var(--gold);
  border-color: var(--gold-bright);
}
.acct-recruit input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  inset: 2px;
  background: #050505;
}
.acct-recruit input[type="checkbox"]:disabled { opacity: 0.4; cursor: not-allowed; }
.acct-recruit-label {
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 2px;
  font-size: 0.85rem;
  color: var(--text);
  text-transform: uppercase;
}
.acct-recruit-hint {
  grid-column: 3 / 4;
  font-size: 0.7rem;
  color: var(--text-dim);
  font-style: italic;
}
.acct-recruit.is-on {
  border-color: var(--gold);
  background: rgba(212, 175, 55, 0.06);
}
.acct-recruit.is-on .acct-recruit-label { color: var(--gold-bright); }

/* HC intrusion banner */
.intrusion-banner {
  position: sticky;
  top: 0;
  z-index: 1500;
  background: linear-gradient(180deg, rgba(40, 30, 5, 0.98) 0%, rgba(20, 15, 3, 0.98) 100%);
  border-bottom: 2px solid var(--gold);
  box-shadow: 0 6px 20px rgba(212, 175, 55, 0.3);
  font-family: "Consolas", monospace;
  color: var(--gold-bright);
  animation: warPulse 2.4s ease-in-out infinite;
}
.intrusion-banner.hidden { display: none !important; }
.intrusion-banner.is-breach {
  background: linear-gradient(180deg, rgba(80, 8, 8, 0.98) 0%, rgba(40, 4, 4, 0.98) 100%);
  border-bottom-color: var(--blood-bright);
  box-shadow: 0 6px 24px rgba(217, 69, 69, 0.5);
}
.intrusion-banner.is-trace {
  background: linear-gradient(180deg, rgba(20, 20, 20, 0.98) 0%, rgba(8, 8, 8, 0.98) 100%);
  border-bottom-color: var(--text-dim);
  box-shadow: none;
  animation: none;
}
.intrusion-banner-inner {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 18px;
  max-width: 1280px;
  margin: 0 auto;
}
.intrusion-icon {
  width: 28px; height: 28px;
  border: 2px solid currentColor;
  display: flex; align-items: center; justify-content: center;
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.1rem;
  flex-shrink: 0;
}
.intrusion-banner.is-breach .intrusion-icon { color: var(--blood-bright); }
.intrusion-text { flex: 1; min-width: 0; }
.intrusion-title {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.1rem;
  letter-spacing: 3px;
  color: inherit;
}
.intrusion-banner.is-breach .intrusion-title { color: var(--blood-bright); text-shadow: 0 0 12px rgba(217, 69, 69, 0.7); }
.intrusion-meta {
  font-size: 0.78rem;
  letter-spacing: 1px;
  color: var(--text-dim);
}
.intrusion-banner.is-breach .intrusion-meta { color: rgba(255, 200, 200, 0.85); }
.intrusion-progress-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 220px;
  flex-shrink: 0;
}
.intrusion-progress-bar {
  flex: 1;
  height: 6px;
  background: rgba(255, 255, 255, 0.08);
  position: relative;
  overflow: hidden;
}
.intrusion-progress-fill {
  display: block;
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--gold) 0%, var(--blood-bright) 100%);
  transition: width 0.3s ease;
}
.intrusion-banner.is-breach .intrusion-progress-fill { background: var(--blood-bright); }
.intrusion-progress-pct {
  font-family: "Bebas Neue", sans-serif;
  font-size: 0.95rem;
  letter-spacing: 1.5px;
  color: inherit;
  min-width: 38px;
  text-align: right;
}
.intrusion-banner .btn { padding: 4px 12px; font-size: 0.78rem; }
.intrusion-dismiss { padding: 2px 10px; font-size: 1rem; }

/* Intruder Tokens manager (in admin panel) */
.intruder-mgr {
  margin-top: 28px;
  padding: 22px 24px;
  background:
    radial-gradient(ellipse at 0% 0%, rgba(217, 69, 69, 0.12) 0%, transparent 55%),
    linear-gradient(180deg, rgba(20, 8, 8, 0.85) 0%, rgba(8, 4, 4, 0.95) 100%);
  border: 1px solid rgba(217, 69, 69, 0.4);
  position: relative;
}
.intruder-mgr::before, .intruder-mgr::after {
  content: ""; position: absolute; width: 12px; height: 12px;
}
.intruder-mgr::before { top: -1px; left: -1px; border-top: 2px solid var(--blood-bright); border-left: 2px solid var(--blood-bright); }
.intruder-mgr::after { bottom: -1px; right: -1px; border-bottom: 2px solid var(--blood-bright); border-right: 2px solid var(--blood-bright); }
body:not(.is-high-command) .intruder-mgr { display: none; }

.intruder-create {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.intruder-create input[type="text"], .intruder-create select {
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--gold-bright);
  padding: 9px 12px;
  font-family: "Consolas", monospace;
  font-size: 0.86rem;
  letter-spacing: 0.5px;
}
.intruder-create input[type="text"] { flex: 1; min-width: 200px; }
.intruder-create input:focus, .intruder-create select:focus { outline: none; border-color: var(--blood-bright); }

.intruder-list { display: flex; flex-direction: column; gap: 8px; }
.intruder-row {
  display: grid;
  grid-template-columns: auto 1fr auto auto auto;
  gap: 12px;
  align-items: center;
  padding: 10px 14px;
  background: rgba(0, 0, 0, 0.4);
  border: 1px solid var(--border-strong);
  border-left: 3px solid var(--text-dim);
  font-family: "Consolas", monospace;
  font-size: 0.82rem;
}
.intruder-row.status-armed { border-left-color: var(--gold); }
.intruder-row.status-cracking { border-left-color: var(--gold-bright); animation: warPulse 2s ease-in-out infinite; }
.intruder-row.status-breached { border-left-color: var(--blood-bright); }
.intruder-row.status-locked { border-left-color: #6ed19a; opacity: 0.7; }
.intruder-row.status-expired,
.intruder-row.status-revoked { opacity: 0.5; }

.intruder-status {
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 1.5px;
  font-size: 0.82rem;
  color: var(--gold);
  padding: 1px 8px;
  border: 1px solid currentColor;
  background: rgba(0, 0, 0, 0.3);
}
.intruder-row.status-cracking .intruder-status { color: var(--gold-bright); }
.intruder-row.status-breached .intruder-status { color: var(--blood-bright); animation: warPulse 2s ease-in-out infinite; }
.intruder-row.status-locked .intruder-status { color: var(--ok); }
.intruder-row.status-expired .intruder-status,
.intruder-row.status-revoked .intruder-status { color: var(--text-dim); }

.intruder-token {
  letter-spacing: 1.5px;
  color: var(--gold-bright);
  font-weight: 700;
}
.intruder-row .intruder-meta {
  color: var(--text-dim);
  font-size: 0.74rem;
  letter-spacing: 0.5px;
}
.intruder-row .intruder-meta strong { color: var(--text); font-weight: 500; }
.intruder-row .btn { padding: 4px 10px; font-size: 0.76rem; }
.intruder-url-modal-text {
  font-family: "Consolas", monospace;
  background: #050505;
  border: 1px solid var(--gold);
  padding: 10px 14px;
  color: var(--gold-bright);
  font-size: 0.92rem;
  letter-spacing: 1px;
  word-break: break-all;
  margin: 8px 0 12px;
}

/* Cover access codes editor */
.cover-codes-mgr {
  margin-top: 32px;
  padding: 22px 24px;
  background: linear-gradient(180deg, rgba(15, 15, 15, 0.85) 0%, rgba(8, 8, 8, 0.9) 100%);
  border: 1px solid var(--border-strong);
  position: relative;
}
.cover-codes-mgr::before, .cover-codes-mgr::after {
  content: ""; position: absolute; width: 12px; height: 12px;
}
.cover-codes-mgr::before { top: -1px; left: -1px; border-top: 2px solid var(--gold-dim); border-left: 2px solid var(--gold-dim); }
.cover-codes-mgr::after { bottom: -1px; right: -1px; border-bottom: 2px solid var(--gold-dim); border-right: 2px solid var(--gold-dim); }
.cc-head { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px dashed rgba(212, 175, 55, 0.18); }
.cc-tag { font-family: "Consolas", monospace; font-size: 0.72rem; letter-spacing: 2px; color: var(--gold-dim); text-transform: uppercase; }
.cc-title { margin: 0; font-family: "Cinzel", serif; font-size: 1.05rem; letter-spacing: 3px; color: var(--gold-bright); text-transform: uppercase; }
.cc-sub { font-family: "Consolas", monospace; font-size: 0.74rem; letter-spacing: 0.5px; color: var(--text-dim); }

.cc-list { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.cc-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.cc-row input {
  flex: 1;
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--gold-bright);
  padding: 9px 12px;
  font-family: "Consolas", monospace;
  font-size: 0.92rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
.cc-row input:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 1px var(--gold-dim); }
.cc-row-rm {
  background: transparent;
  border: 1px solid var(--border-strong);
  color: var(--blood-bright);
  padding: 6px 12px;
  font-family: "Consolas", monospace;
  font-size: 0.95rem;
  cursor: pointer;
  line-height: 1;
}
.cc-row-rm:hover { border-color: var(--blood-bright); background: rgba(161, 28, 28, 0.15); }

.cc-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.cc-actions .btn { padding: 6px 14px; font-size: 0.82rem; }
.cc-hint {
  font-family: "Consolas", monospace;
  font-size: 0.74rem;
  color: var(--text-dim);
  letter-spacing: 0.5px;
}
.cc-hint.ok { color: var(--ok); }
.cc-hint.error { color: var(--blood-bright); }

/* Hide editor for non-HC */
body:not(.is-high-command) .cover-codes-mgr { display: none; }

/* Rank-color borders on cards */
.acct-card.rank-shadow-lord { --rank-color: #ff3b3b; }
.acct-card.rank-underlord { --rank-color: #ff7a3c; }
.acct-card.rank-hand-of-the-lord { --rank-color: #f5c14d; }
.acct-card.rank-hand-of-the-underlord { --rank-color: #e89b3c; }
.acct-card.rank-oni { --rank-color: #b480ff; }
.acct-card.rank-spirit { --rank-color: #5ad6d6; }
.acct-card.rank-demon { --rank-color: #ff7cc8; }
.acct-card.rank-phantom { --rank-color: #9a6bff; }
.acct-card.rank-ghost { --rank-color: #f0e050; }
.acct-card.rank-shadow { --rank-color: #5ab8ff; }
.acct-card.rank-the-lost { --rank-color: #9aa0a6; }

/* ---------- Watch List (High Command only) ---------- */
.watch-list {
  border: 1px solid var(--blood);
  background:
    radial-gradient(ellipse at 0% 0%, rgba(161, 28, 28, 0.18) 0%, transparent 55%),
    linear-gradient(180deg, rgba(20, 6, 6, 0.85) 0%, rgba(8, 4, 4, 0.9) 100%);
  position: relative;
  padding: 16px 22px 18px;
}
.watch-list[hidden] { display: none; }
.watch-list::before, .watch-list::after {
  content: ""; position: absolute; width: 12px; height: 12px;
}
.watch-list::before { top: -1px; left: -1px; border-top: 2px solid var(--blood-bright); border-left: 2px solid var(--blood-bright); }
.watch-list::after { bottom: -1px; right: -1px; border-bottom: 2px solid var(--blood-bright); border-right: 2px solid var(--blood-bright); }
.watch-list-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px dashed rgba(217, 69, 69, 0.3);
}
.watch-list-flag {
  font-size: 1.3rem;
  color: var(--blood-bright);
  text-shadow: 0 0 14px rgba(217, 69, 69, 0.7);
  animation: warPulse 2.4s ease-in-out infinite;
}
.watch-list-title {
  margin: 0;
  font-family: "Cinzel", serif;
  letter-spacing: 4px;
  font-size: 1.05rem;
  color: var(--blood-bright);
  text-shadow: 0 0 10px rgba(217, 69, 69, 0.5);
}
.watch-list-sub {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  color: var(--text-dim);
  text-transform: uppercase;
}
.watch-list-count {
  margin-left: auto;
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.4rem;
  letter-spacing: 2px;
  color: var(--blood-bright);
  background: rgba(161, 28, 28, 0.15);
  border: 1px solid var(--blood);
  padding: 2px 12px;
}
.watch-list-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 10px;
}
.watch-card {
  background: rgba(20, 8, 8, 0.65);
  border: 1px solid rgba(217, 69, 69, 0.35);
  padding: 10px 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  cursor: pointer;
  transition: border-color 0.12s ease, background 0.12s ease;
}
.watch-card:hover { border-color: var(--blood-bright); background: rgba(40, 12, 12, 0.7); }
.watch-card-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}
.watch-card-name {
  font-family: "Cinzel", serif;
  color: var(--gold-bright);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.4px;
  margin: 0;
}
.watch-card-rank {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  color: var(--text-dim);
}
.watch-card-reason {
  color: var(--text);
  font-size: 0.85rem;
  font-style: italic;
  word-break: break-word;
}
.watch-card-meta {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 0.5px;
  color: var(--text-dim);
}

/* ---------- Roster (Member List) ---------- */
.roster-wrap { display: flex; flex-direction: column; gap: 22px; }
.roster-summary {
  display: flex;
  gap: 12px;
  align-items: stretch;
  flex-wrap: wrap;
}
.roster-summary-cell {
  background: linear-gradient(180deg, var(--bg-elev) 0%, #0a0a0a 100%);
  border: 1px solid var(--border);
  padding: 12px 18px;
  min-width: 110px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  position: relative;
}
.roster-summary-cell::before {
  content: "";
  position: absolute;
  top: -1px; left: -1px;
  width: 8px; height: 8px;
  border-top: 2px solid var(--gold);
  border-left: 2px solid var(--gold);
}
.roster-summary-num {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.7rem;
  letter-spacing: 1.5px;
  color: var(--gold-bright);
  line-height: 1;
}
.roster-summary-lbl {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  color: var(--text-dim);
  text-transform: uppercase;
}
.roster-summary-search {
  margin-left: auto;
  display: flex;
  align-items: center;
  flex: 1;
  max-width: 320px;
}
.roster-summary-search input {
  width: 100%;
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--gold-bright);
  padding: 10px 14px;
  font-family: "Consolas", monospace;
  font-size: 0.84rem;
  letter-spacing: 1px;
}
.roster-summary-search input:focus { outline: none; border-color: var(--gold); }
.roster-summary-search input::placeholder { color: #555; }

.roster-tiers { display: flex; flex-direction: column; gap: 22px; }

.roster-section {
  border: 1px solid var(--border-strong);
  background: linear-gradient(180deg, rgba(15, 15, 15, 0.85) 0%, rgba(8, 8, 8, 0.85) 100%);
  position: relative;
  overflow: hidden;
}
.roster-section::before, .roster-section::after {
  content: "";
  position: absolute;
  width: 12px; height: 12px;
}
.roster-section::before { top: -1px; left: -1px; border-top: 2px solid var(--gold); border-left: 2px solid var(--gold); }
.roster-section::after { bottom: -1px; right: -1px; border-bottom: 2px solid var(--gold); border-right: 2px solid var(--gold); }

.roster-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 22px;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.2) 100%);
  border-bottom: 1px dashed rgba(212, 175, 55, 0.25);
}
.roster-section-title { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; min-width: 0; }
.roster-section-label {
  font-family: "Cinzel", serif;
  font-size: 1.1rem;
  letter-spacing: 4px;
  color: var(--gold);
  text-transform: uppercase;
}
.roster-section-sub {
  font-family: "Consolas", monospace;
  font-size: 0.74rem;
  letter-spacing: 1.5px;
  color: var(--text-dim);
}
.roster-section-count {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.4rem;
  letter-spacing: 2px;
  color: var(--gold-bright);
  background: rgba(212, 175, 55, 0.08);
  padding: 2px 12px;
  border: 1px solid rgba(212, 175, 55, 0.25);
}

/* Tier-specific accents */
.roster-section.tier-high { border-color: rgba(217, 69, 69, 0.45); }
.roster-section.tier-high .roster-section-label { color: #ff5e5e; text-shadow: 0 0 12px rgba(217, 69, 69, 0.45); }
.roster-section.tier-high .roster-section-count { color: #ff8585; border-color: rgba(217, 69, 69, 0.45); background: rgba(217, 69, 69, 0.1); }
.roster-section.tier-low { border-color: rgba(212, 175, 55, 0.4); }
.roster-section.tier-low .roster-section-label { color: var(--gold-bright); text-shadow: 0 0 8px rgba(212, 175, 55, 0.3); }
.roster-section.tier-training { border-color: rgba(154, 107, 255, 0.35); }
.roster-section.tier-training .roster-section-label { color: #b58aff; text-shadow: 0 0 8px rgba(154, 107, 255, 0.35); }
.roster-section.tier-members .roster-section-label { color: #c8c8c8; }

.roster-section-body { display: flex; flex-direction: column; }

.roster-card {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: 18px;
  padding: 14px 22px 14px 26px;
  border-bottom: 1px solid rgba(212, 175, 55, 0.06);
  align-items: center;
  cursor: pointer;
  transition: background 0.12s ease, transform 0.12s ease;
  position: relative;
  user-select: none;
}
.roster-card::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--rank-color, var(--text-dim));
  opacity: 0.7;
  transition: opacity 0.12s ease, width 0.12s ease;
}
.roster-card:hover { background: rgba(212, 175, 55, 0.04); }
.roster-card:hover::before { opacity: 1; width: 4px; }
.roster-card:last-child { border-bottom: 0; }

.roster-card-pos {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.5rem;
  letter-spacing: 1.5px;
  color: var(--text-dim);
  text-align: center;
  line-height: 1;
}
.roster-card-body { min-width: 0; }
.roster-card-top {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.roster-card-name {
  margin: 0;
  font-family: "Cinzel", serif;
  font-size: 1.15rem;
  color: var(--gold-bright);
  letter-spacing: 0.6px;
  font-weight: 600;
}
.roster-card-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
  flex-wrap: wrap;
  font-size: 0.84rem;
}
.roster-card-phone {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 1.5px;
  color: var(--text);
  font-size: 0.95rem;
}
.roster-card-phone::before {
  content: "✆";
  color: var(--gold-dim);
  font-size: 0.95rem;
}
.roster-card-flag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: "Consolas", monospace;
  font-size: 0.72rem;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  padding: 2px 8px;
  border: 1px solid rgba(212, 175, 55, 0.15);
  background: rgba(0, 0, 0, 0.3);
  color: var(--text-dim);
}
.roster-card-flag.is-yes {
  color: var(--gold-bright);
  border-color: rgba(212, 175, 55, 0.4);
  background: rgba(212, 175, 55, 0.08);
}
.roster-card-flag .flag-mark {
  font-size: 0.85rem;
  line-height: 1;
}
.roster-card-flag.is-yes .flag-mark { color: var(--ok); }

.roster-card-notes {
  margin-top: 10px;
  padding: 9px 12px;
  background: rgba(0, 0, 0, 0.4);
  border-left: 2px solid var(--gold-dim);
  color: var(--text);
  font-size: 0.88rem;
  line-height: 1.55;
  word-wrap: break-word;
  display: none;
}
.roster-card.has-notes .roster-card-name::after {
  content: "›";
  margin-left: 8px;
  color: var(--gold-dim);
  transition: transform 0.15s ease, color 0.15s ease;
  display: inline-block;
}
.roster-card.is-expanded .roster-card-name::after { transform: rotate(90deg); color: var(--gold); }
.roster-card.is-expanded .roster-card-notes { display: block; }

.roster-card-actions {
  display: flex;
  gap: 6px;
  align-items: center;
}
.roster-card-actions .btn { padding: 4px 12px; font-size: 0.78rem; }

/* Strike pips on the card */
.roster-strikes {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  cursor: pointer;
  padding: 2px 6px;
  border: 1px solid transparent;
  transition: border-color 0.12s ease;
}
.roster-strikes:hover { border-color: rgba(217, 69, 69, 0.4); }
.roster-strikes-pip {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: 1px solid var(--text-dim);
  background: transparent;
}
.roster-strikes-pip.is-on {
  background: var(--blood-bright);
  border-color: var(--blood-bright);
  box-shadow: 0 0 6px rgba(217, 69, 69, 0.7);
}
.roster-strikes-label {
  font-family: "Consolas", monospace;
  font-size: 0.66rem;
  letter-spacing: 1px;
  color: var(--text-dim);
  margin-left: 4px;
  text-transform: uppercase;
}
.roster-strikes.is-warn .roster-strikes-label { color: #ff9c5e; }
.roster-strikes.is-max .roster-strikes-label { color: var(--blood-bright); }
body:not(.is-low-command) .roster-strikes { cursor: default; }
body:not(.is-low-command) .roster-strikes:hover { border-color: transparent; }

/* Flag indicator on card (high command only via parent rule) */
.roster-flag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  color: var(--blood-bright);
  background: rgba(161, 28, 28, 0.18);
  border: 1px solid rgba(217, 69, 69, 0.4);
  padding: 1px 6px;
  text-transform: uppercase;
  cursor: pointer;
}
.roster-flag::before { content: "⚑"; }
.roster-flag:hover { background: rgba(217, 69, 69, 0.25); }
body:not(.is-high-command) .roster-flag { display: none !important; }

/* Manage Member modal */
.member-manage-card { max-width: 540px; }
.mm-section {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px dashed rgba(212, 175, 55, 0.18);
}
.mm-section:first-of-type { border-top: 0; padding-top: 8px; margin-top: 8px; }
.mm-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.mm-section-label {
  font-family: "Consolas", monospace;
  letter-spacing: 2px;
  color: var(--gold);
  font-size: 0.78rem;
  text-transform: uppercase;
}
.mm-strike-count {
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 1.5px;
  color: var(--gold-bright);
  font-size: 1rem;
}
.mm-strike-pips {
  display: inline-flex;
  gap: 8px;
  margin-bottom: 8px;
}
.mm-strike-pip {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid var(--text-dim);
  background: transparent;
}
.mm-strike-pip.is-on {
  background: var(--blood-bright);
  border-color: var(--blood);
  box-shadow: 0 0 12px rgba(217, 69, 69, 0.7);
}
.mm-strike-meta, .mm-flag-meta {
  font-family: "Consolas", monospace;
  font-size: 0.78rem;
  color: var(--text-dim);
  letter-spacing: 0.5px;
  margin-bottom: 8px;
  word-wrap: break-word;
}
.mm-strike-meta strong, .mm-flag-meta strong { color: var(--gold); font-weight: 500; }
.mm-section-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.mm-section-actions .btn { padding: 5px 12px; font-size: 0.78rem; }
.mm-flag-state {
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 2px;
  font-size: 1rem;
  padding: 1px 10px;
  border: 1px solid currentColor;
  background: rgba(0, 0, 0, 0.3);
}
.mm-flag-state.is-flagged { color: var(--blood-bright); }
.mm-flag-state.is-clear { color: var(--ok); }
.mm-inline-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 8px;
}
.mm-inline-label {
  font-family: "Consolas", monospace;
  font-size: 0.7rem;
  letter-spacing: 1.5px;
  color: var(--gold-dim);
  text-transform: uppercase;
}
.mm-inline-field input[type="text"] {
  background: #050505;
  border: 1px solid var(--border-strong);
  color: var(--text);
  font-family: "Consolas", monospace;
  font-size: 0.86rem;
  padding: 7px 10px;
  width: 100%;
  letter-spacing: 0.5px;
  border-radius: 0;
}
.mm-inline-field input[type="text"]:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold-dim);
}
.mm-inline-field input[type="text"]::placeholder { color: #555; }

/* Rank-color border accents on cards */
.roster-card.rank-shadow-lord { --rank-color: #ff3b3b; }
.roster-card.rank-underlord { --rank-color: #ff7a3c; }
.roster-card.rank-hand-of-the-lord { --rank-color: #f5c14d; }
.roster-card.rank-hand-of-the-underlord { --rank-color: #e89b3c; }
.roster-card.rank-oni { --rank-color: #b480ff; }
.roster-card.rank-spirit { --rank-color: #5ad6d6; }
.roster-card.rank-demon { --rank-color: #ff7cc8; }
.roster-card.rank-phantom { --rank-color: #9a6bff; }
.roster-card.rank-ghost { --rank-color: #f0e050; }
.roster-card.rank-shadow { --rank-color: #5ab8ff; }
.roster-card.rank-the-lost { --rank-color: #9aa0a6; }

@media (max-width: 720px) {
  .roster-card { grid-template-columns: 40px 1fr; }
  .roster-card-actions { grid-column: 1 / -1; padding-left: 56px; }
  .roster-summary-cell { min-width: 80px; padding: 10px 12px; }
  .roster-summary-search { max-width: 100%; }
}

.check-yes {
  display: inline-block;
  width: 22px;
  height: 22px;
  line-height: 20px;
  border: 1px solid var(--ok);
  color: var(--ok);
  border-radius: 2px;
  text-align: center;
  font-weight: 700;
  background: rgba(80, 200, 120, 0.08);
}
.check-no {
  color: var(--text-dim);
  opacity: 0.5;
}

.check-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border: 1px solid rgba(212, 175, 55, 0.2);
  background: rgba(18, 15, 15, 0.5);
  color: var(--text);
  font-size: 0.85rem;
  letter-spacing: 0.5px;
  cursor: pointer;
  user-select: none;
  flex: 1;
}
.check-label input[type="checkbox"] {
  accent-color: var(--gold);
  width: 16px;
  height: 16px;
}

.roster-foot td {
  background: rgba(212, 175, 55, 0.06);
  border-top: 2px solid var(--gold-dim) !important;
  font-family: "Cinzel", serif;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-size: 0.85rem;
  color: var(--gold);
  padding: 12px 14px;
}
.roster-foot td:last-child {
  text-align: right;
  font-family: "Bebas Neue", monospace;
  font-size: 1.3rem;
  color: var(--gold-bright);
  letter-spacing: 3px;
}

/* Rank pill */
.rank-pill {
  display: inline-block;
  padding: 3px 10px;
  font-family: "Cinzel", serif;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 1.2px;
  border-radius: 2px;
  border: 1px solid currentColor;
  background: rgba(0, 0, 0, 0.35);
  white-space: nowrap;
}

/* Per-rank colors (high → low) */
.rank-pill.rank-shadow-lord {
  color: #ff3b3b;
  border-color: #ff3b3b;
  background: rgba(255, 59, 59, 0.12);
  text-shadow: 0 0 8px rgba(255, 59, 59, 0.55);
}
.rank-pill.rank-underlord {
  color: #ff7a3c;
  border-color: #ff7a3c;
  background: rgba(255, 122, 60, 0.1);
}
.rank-pill.rank-hand-of-the-lord {
  color: #f5c14d;
  border-color: #f5c14d;
  background: rgba(245, 193, 77, 0.1);
}
.rank-pill.rank-hand-of-the-underlord {
  color: #e89b3c;
  border-color: #e89b3c;
  background: rgba(232, 155, 60, 0.1);
}
.rank-pill.rank-oni {
  color: #b480ff;
  border-color: #b480ff;
  background: rgba(180, 128, 255, 0.12);
}
.rank-pill.rank-spirit {
  color: #5ad6d6;
  border-color: #5ad6d6;
  background: rgba(90, 214, 214, 0.1);
}
.rank-pill.rank-demon {
  color: #ff7cc8;
  border-color: #ff7cc8;
  background: rgba(255, 124, 200, 0.1);
}
.rank-pill.rank-phantom {
  color: #9a6bff;
  border-color: #9a6bff;
  background: rgba(154, 107, 255, 0.1);
}
.rank-pill.rank-ghost {
  color: #f0e050;
  border-color: #f0e050;
  background: rgba(240, 224, 80, 0.1);
}
.rank-pill.rank-shadow {
  color: #5ab8ff;
  border-color: #5ab8ff;
  background: rgba(90, 184, 255, 0.1);
}
.rank-pill.rank-the-lost {
  color: #9aa0a6;
  border-color: #9aa0a6;
  background: rgba(154, 160, 166, 0.08);
}

/* ---------- LOA (Leave of Absence) ---------- */
.loa-note {
  color: var(--text-dim);
  font-size: 0.82rem;
  margin: 10px 0 20px;
  padding: 10px 14px;
  border-left: 2px solid var(--gold-dim);
  background: rgba(212, 175, 55, 0.04);
}

.field-label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.72rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-dim);
  flex: 1;
}

.loa-section { margin-top: 28px; }

.loa-section-title {
  font-family: "Cinzel", serif;
  font-size: 0.95rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 12px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--gold-dim);
}

.loa-list {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
}

.loa-card {
  position: relative;
  background: rgba(18, 15, 15, 0.75);
  border: 1px solid rgba(212, 175, 55, 0.18);
  border-left: 3px solid var(--gold-dim);
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.loa-card.loa-status-pending { border-left-color: #e8c15a; }
.loa-card.loa-status-approved { border-left-color: var(--ok); }
.loa-card.loa-status-denied { border-left-color: var(--blood-bright); opacity: 0.7; }

.loa-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.loa-card-id {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.loa-user {
  font-family: "Cinzel", serif;
  font-weight: 600;
  font-size: 1rem;
  color: var(--gold-bright);
  letter-spacing: 0.5px;
}

.loa-pill {
  display: inline-block;
  padding: 2px 8px;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  border-radius: 2px;
  border: 1px solid currentColor;
}
.loa-pending { color: #e8c15a; }
.loa-approved { color: var(--ok); }
.loa-denied { color: var(--blood-bright); }

.loa-countdown {
  font-family: "Bebas Neue", "Consolas", monospace;
  font-size: 1.1rem;
  color: var(--gold);
  letter-spacing: 2px;
  padding: 2px 10px;
  background: rgba(212, 175, 55, 0.08);
  border: 1px solid var(--gold-dim);
  border-radius: 2px;
}
.loa-countdown.ended { color: var(--text-dim); opacity: 0.6; }

.loa-range {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 10px;
  font-size: 0.82rem;
  color: var(--text);
}
.loa-range-label {
  font-size: 0.68rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-dim);
}
.loa-range-val { color: var(--gold-bright); }
.loa-range-sep { color: var(--gold-dim); font-weight: 700; }

.loa-reason {
  background: rgba(0, 0, 0, 0.3);
  border-left: 2px solid var(--gold-dim);
  padding: 8px 12px;
  font-size: 0.88rem;
}
.loa-reason-label {
  display: block;
  font-size: 0.65rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-bottom: 4px;
}
.loa-reason-body {
  color: var(--text);
  line-height: 1.5;
}

.loa-card-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 2px;
}
.loa-approved-by {
  font-size: 0.72rem;
  color: var(--text-dim);
  font-style: italic;
}
.loa-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-left: auto;
}
.loa-actions .btn { padding: 4px 10px; font-size: 0.78rem; }

/* Home :: On Leave strip */
.loa-strip {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}
.loa-tile {
  background: rgba(18, 15, 15, 0.7);
  border: 1px solid rgba(212, 175, 55, 0.2);
  border-left: 3px solid var(--gold);
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.loa-tile-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}
.loa-tile-user {
  font-family: "Cinzel", serif;
  font-weight: 600;
  color: var(--gold-bright);
  letter-spacing: 0.5px;
}
.loa-tile-countdown {
  font-size: 0.95rem;
  padding: 1px 8px;
}
.loa-tile-end {
  font-size: 0.76rem;
  color: var(--text-dim);
  letter-spacing: 0.5px;
}
.loa-tile-reason {
  font-size: 0.82rem;
  color: var(--text);
  padding-top: 4px;
  border-top: 1px dashed rgba(212, 175, 55, 0.15);
  line-height: 1.4;
}

/* ---------- Responsive ---------- */
@media (max-width: 720px) {
  .site-header { padding: 20px; }
  main { padding: 24px 20px; }
  .tabs { padding: 0 20px; }
  .header-inner { gap: 16px; }
  .hud { align-items: flex-start; width: 100%; }
  .brand { gap: 14px; }
  .brand-logo { width: 64px; height: 64px; }
  .logo { font-size: 2.2rem; letter-spacing: 3px; }
  .tagline { font-size: 0.7rem; letter-spacing: 2px; }
  .freq-tile .num { font-size: 1.8rem; letter-spacing: 3px; }
  .data-table { font-size: 0.85rem; }
  .data-table th, .data-table td { padding: 8px 10px; }
  .loa-list { grid-template-columns: 1fr; }
  .loa-strip { grid-template-columns: 1fr; }
}
