/*
 * Tactical components — mirror proovx.mobile/lib/tactical/*.dart patterns.
 * Web re-implementations as plain classes (no framework).
 */

/* ── Layout chrome ───────────────────────────────────────────────── */

.arg-shell {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.arg-header {
  display: flex;
  align-items: center;
  gap: var(--s-4);
  padding: var(--s-4) var(--s-5);
  border-bottom: var(--bw-default) solid var(--c-border-subtle);
  min-height: 56px;
}
.arg-header .mark {
  width: 28px; height: 28px; flex: 0 0 28px;
}
.arg-header .wordmark {
  font-family: var(--f-display);
  font-size: var(--t-md);
  font-weight: 700;
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--c-text-primary);
  margin-left: var(--s-2);
}
.arg-header .status {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-size: var(--t-xs);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--c-text-secondary);
  font-family: var(--f-data);
}
.arg-header .spacer { flex: 1; }

.arg-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: var(--s-6);
  max-width: 880px;
  width: 100%;
  margin: 0 auto;
  gap: var(--s-5);
}

.arg-footer {
  border-top: var(--bw-default) solid var(--c-border-subtle);
  padding: var(--s-4) var(--s-5);
  background: rgba(0,0,0,0.2);
}

/* ── Tactical button ─────────────────────────────────────────────── */

.tac-btn {
  --tac-accent: var(--c-amber);
  --tac-bg-alpha: 0.10;
  --tac-border-alpha: 0.50;
  --tac-text-alpha: 1.0;

  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  padding: 0 var(--s-4);
  min-height: 44px;
  border-radius: var(--br-md);
  border: var(--bw-default) solid color-mix(in srgb, var(--tac-accent) calc(var(--tac-border-alpha) * 100%), transparent);
  background: color-mix(in srgb, var(--tac-accent) calc(var(--tac-bg-alpha) * 100%), transparent);
  color: color-mix(in srgb, var(--tac-accent) calc(var(--tac-text-alpha) * 100%), transparent);
  font-family: var(--f-ui);
  font-size: var(--t-base);
  font-weight: 500;
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-soft),
              border-color var(--dur-fast) var(--ease-soft),
              transform 60ms var(--ease-snap);
}

.tac-btn:hover:not(:disabled) {
  --tac-bg-alpha: 0.14;
  --tac-border-alpha: 0.66;
}
.tac-btn:active:not(:disabled) {
  --tac-bg-alpha: 0.20;
  --tac-border-alpha: 0.80;
  transform: translateY(1px);
}
.tac-btn:disabled {
  --tac-bg-alpha: 0.03;
  --tac-border-alpha: 0.15;
  --tac-text-alpha: 0.35;
  cursor: not-allowed;
}

.tac-btn--secondary {
  --tac-accent: #ffffff;
  --tac-bg-alpha: 0.05;
  --tac-border-alpha: 0.12;
  --tac-text-alpha: 0.55;
}
.tac-btn--secondary:hover:not(:disabled) { --tac-text-alpha: 0.87; --tac-bg-alpha: 0.08; --tac-border-alpha: 0.20; }

.tac-btn--destructive { --tac-accent: var(--c-red); }

.tac-btn--full { width: 100%; }

.tac-btn .arrow {
  font-size: var(--t-md);
  margin-left: auto;
  opacity: 0.8;
}

.tac-btn--live {
  --tac-accent: var(--c-red);
  --tac-bg-alpha: 0.20;
  --tac-border-alpha: 0.60;
}

/* ── Tactical card ───────────────────────────────────────────────── */

.tac-card {
  background: var(--c-surface);
  border: var(--bw-default) solid var(--c-border-default);
  border-radius: var(--br-xl);
  padding: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.tac-card--accent {
  border-color: var(--c-amber-border);
  background: linear-gradient(180deg, var(--c-amber-fill), transparent 60%), var(--c-surface);
}

.tac-card__title {
  font-family: var(--f-ui);
  font-size: var(--t-sm);
  font-weight: 600;
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--c-text-secondary);
}

/* ── Tactical input ──────────────────────────────────────────────── */

.tac-field {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.tac-field__label {
  font-size: var(--t-xs);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--c-text-secondary);
}
.tac-input, .tac-select {
  appearance: none;
  background: var(--c-void);
  border: var(--bw-default) solid var(--c-border-default);
  color: var(--c-text-primary);
  font-family: var(--f-ui);
  font-size: var(--t-md);
  padding: var(--s-3) var(--s-4);
  border-radius: var(--br-md);
  transition: border-color var(--dur-fast) var(--ease-soft);
  min-height: 44px;
}
.tac-input:focus, .tac-select:focus {
  outline: none;
  border-color: var(--c-amber-border);
  box-shadow: 0 0 0 2px var(--c-amber-fill);
}
.tac-input[type="number"],
.tac-input.mono { font-family: var(--f-data); letter-spacing: var(--ls-wide); }

/* ── Tactical chip ───────────────────────────────────────────────── */

.tac-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 4px var(--s-3);
  border-radius: var(--br-full);
  background: var(--c-surface);
  border: var(--bw-default) solid var(--c-border-default);
  font-size: var(--t-xs);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--c-text-secondary);
  font-family: var(--f-data);
}
.tac-chip--amber { border-color: var(--c-amber-border); color: var(--c-amber-light); background: var(--c-amber-fill); }
.tac-chip--gold  { border-color: var(--c-gold-border); color: var(--c-gold); background: var(--c-gold-fill); }
.tac-chip--red   { border-color: var(--c-red-border); color: var(--c-red); background: var(--c-red-fill); }

/* ── Dot indicator ───────────────────────────────────────────────── */

.dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: var(--br-full);
  background: var(--c-text-tertiary);
}
.dot--amber { background: var(--c-amber); box-shadow: 0 0 8px var(--c-amber); }
.dot--gold  { background: var(--c-gold);  box-shadow: 0 0 8px var(--c-gold); }
.dot--red   { background: var(--c-red); animation: pulse 1s ease-in-out infinite; }

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.35; }
}

/* ── Deep ping indicator (loading) — mimics TacticalButton's DeepPingIndicator */

.tac-ping {
  --ping-size: 14px;
  position: relative;
  display: inline-block;
  width: var(--ping-size); height: var(--ping-size);
}
.tac-ping::before,
.tac-ping::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1.5px solid currentColor;
  opacity: 0.7;
  animation: ping 1.2s cubic-bezier(0, 0, 0.2, 1) infinite;
}
.tac-ping::after { animation-delay: 0.6s; }

@keyframes ping {
  0%   { transform: scale(0.4); opacity: 1; }
  80%, 100% { transform: scale(1); opacity: 0; }
}

/* ── Chat bubble (for voice transcripts) ─────────────────────────── */

.msg {
  max-width: 82%;
  padding: var(--s-3) var(--s-4);
  border-radius: var(--br-xl);
  font-size: var(--t-md);
  line-height: var(--lh-body);
  white-space: pre-wrap;
  word-wrap: break-word;
  border: var(--bw-default) solid var(--c-border-subtle);
}
.msg--user {
  align-self: flex-end;
  background: var(--c-amber-fill);
  border-color: var(--c-amber-border);
  color: var(--c-text-primary);
  border-bottom-right-radius: var(--br-sm);
}
.msg--assistant {
  align-self: flex-start;
  background: var(--c-surface);
  border-bottom-left-radius: var(--br-sm);
}
.msg--pending::after {
  content: '▍';
  margin-left: 2px;
  color: var(--c-text-tertiary);
  animation: blink 0.8s steps(2) infinite;
}
.msg--tool {
  align-self: center;
  background: var(--c-surface);
  border-color: var(--c-border-default);
  font-family: var(--f-data);
  font-size: var(--t-xs);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--c-text-secondary);
  padding: 6px var(--s-3);
  border-radius: var(--br-full);
}
.msg--tool .tool-name { color: var(--c-gold); margin-right: var(--s-2); }

@keyframes blink { 0%, 50% { opacity: 1; } 50.01%, 100% { opacity: 0; } }

/* ── Chat list ───────────────────────────────────────────────────── */

.chat-list {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  overflow-y: auto;
  padding: var(--s-4) 0;
}

/* ── Voice control row ───────────────────────────────────────────── */

.voice-bar {
  display: flex;
  align-items: center;
  gap: var(--s-4);
}
.voice-bar .level {
  flex: 1;
  height: 6px;
  background: var(--c-surface);
  border-radius: var(--br-full);
  overflow: hidden;
  position: relative;
}
.voice-bar .level > span {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, var(--c-amber), var(--c-gold));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 60ms linear;
}

/* ── Empty state ─────────────────────────────────────────────────── */

.empty-state {
  margin: auto;
  text-align: center;
  color: var(--c-text-tertiary);
  max-width: 420px;
  padding: var(--s-8);
}
.empty-state .mark {
  width: 64px; height: 64px; margin: 0 auto var(--s-5);
  opacity: 0.75;
  filter: drop-shadow(0 0 14px var(--c-amber-fill));
}
.empty-state h2 { color: var(--c-text-secondary); margin-bottom: var(--s-2); }
.empty-state p { font-size: var(--t-base); color: var(--c-text-tertiary); }

/* ── Divider ─────────────────────────────────────────────────────── */

.divider {
  height: 1px;
  background: var(--c-border-subtle);
  margin: var(--s-5) 0;
}
.divider--labeled {
  display: flex; align-items: center; gap: var(--s-3);
  color: var(--c-text-tertiary);
  font-size: var(--t-xs);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
}
.divider--labeled::before,
.divider--labeled::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--c-border-subtle);
}

/* ── Utility ─────────────────────────────────────────────────────── */

.stack { display: flex; flex-direction: column; gap: var(--s-3); }
.stack--lg { gap: var(--s-5); }
.row { display: flex; align-items: center; gap: var(--s-3); }
.row--wrap { flex-wrap: wrap; }
.row--between { justify-content: space-between; }
.flex-1 { flex: 1; }
.meta {
  font-family: var(--f-data);
  font-size: var(--t-xs);
  letter-spacing: var(--ls-wide);
  color: var(--c-text-tertiary);
}
