/* ===== FXA shared base =====
 * Universal resets, header chrome, sidebar nav rail, aside config panel,
 * form primitives, buttons, pills, tables, modals. Apps can layer their own
 * specifics on top.
 */

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: var(--fxa-font);
  background: var(--fxa-bg);
  color: var(--fxa-text);
  font-size: var(--fxa-text-base);
}

a {
  color: var(--fxa-accent);
  text-decoration: none;
}
a:hover {
  color: var(--fxa-accent-hover);
}

/* ----- Header bar ----- */
header.fxa-header {
  padding: 8px 16px;
  background: var(--fxa-surface);
  border-bottom: 1px solid var(--fxa-border);
  display: flex;
  align-items: center;
  gap: var(--fxa-gap-md);
  height: var(--fxa-header-height);
}
header.fxa-header h1 {
  margin: 0;
  font-size: var(--fxa-text-lg);
  font-weight: 600;
}
.spacer {
  flex: 1;
}

/* Pills (header status chips, secondary nav) */
.pill {
  font-size: var(--fxa-text-xs);
  padding: 3px 8px;
  border-radius: var(--fxa-radius-pill);
  background: var(--fxa-surface-active);
  color: var(--fxa-text-muted);
  font-family: var(--fxa-font-mono);
}
.pill.ok {
  background: var(--fxa-success-bg);
  color: var(--fxa-success);
}
.pill.err {
  background: var(--fxa-danger-bg);
  color: var(--fxa-danger);
}
a.pill {
  text-decoration: none;
}

/* ----- Top tab nav (algo1-style) ----- */
nav.fxa-tabs {
  display: flex;
  gap: 4px;
}
.fxa-tabs .tab {
  background: transparent;
  border: 1px solid transparent;
  color: var(--fxa-text-muted);
  padding: 6px 12px;
  font-size: var(--fxa-text-sm);
  font-weight: 500;
  border-radius: var(--fxa-radius);
  cursor: pointer;
}
.fxa-tabs .tab:hover {
  color: var(--fxa-text);
  background: var(--fxa-surface-active);
}
.fxa-tabs .tab.active {
  background: var(--fxa-surface-active);
  color: var(--fxa-text);
  border-color: var(--fxa-border);
}

/* ----- Sidebar rail nav (left rail with tabs going down) ----- */
nav.fxa-rail {
  width: var(--fxa-rail-width);
  background: var(--fxa-surface);
  border-right: 1px solid var(--fxa-border);
  padding: 12px 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  overflow-y: auto;
  flex-shrink: 0;
}
.fxa-rail .rail-btn {
  background: transparent;
  border: 1px solid transparent;
  color: var(--fxa-text-muted);
  padding: 7px 12px;
  font-size: var(--fxa-text-sm);
  font-weight: 500;
  border-radius: var(--fxa-radius);
  cursor: pointer;
  text-align: left;
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: inherit;
}
.fxa-rail .rail-btn:hover {
  color: var(--fxa-text);
  background: var(--fxa-surface-active);
}
.fxa-rail .rail-btn.active {
  background: var(--fxa-surface-active);
  color: var(--fxa-text);
  border-color: var(--fxa-border);
}
.fxa-rail .rail-section {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--fxa-text-muted);
  padding: 12px 12px 6px;
}

/* ----- Aside config panel (right of rail / left of main) ----- */
aside.config {
  background: var(--fxa-surface);
  border-right: 1px solid var(--fxa-border);
  padding: 12px 14px;
  overflow-y: auto;
  width: var(--fxa-config-width);
  flex-shrink: 0;
}
aside.config h3 {
  font-size: var(--fxa-text-xs);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--fxa-text-muted);
  margin: 0 0 8px;
}
aside.config hr {
  border: none;
  border-top: 1px solid var(--fxa-border-subtle);
  margin: 14px 0;
}

/* ----- Form primitives ----- */
label {
  display: block;
  margin-bottom: 8px;
}
label > span {
  display: block;
  color: var(--fxa-text-muted);
  margin-bottom: 4px;
  font-size: var(--fxa-text-xs);
}
label.checkline {
  display: flex;
  align-items: center;
  gap: 8px;
}
label.checkline > span {
  margin: 0;
}
label.checkline input {
  width: auto;
}

input,
select,
textarea {
  width: 100%;
  background: var(--fxa-surface-2);
  border: 1px solid var(--fxa-border);
  color: var(--fxa-text);
  padding: 5px 8px;
  border-radius: var(--fxa-radius-sm);
  font-family: inherit;
  font-size: var(--fxa-text-sm);
}
input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--fxa-accent);
}
textarea {
  font-family: var(--fxa-font-mono);
  min-height: 60px;
}
input[type="checkbox"],
input[type="radio"] {
  width: auto;
  accent-color: var(--fxa-accent);
}

button {
  background: var(--fxa-surface-2);
  border: 1px solid var(--fxa-border);
  color: var(--fxa-text);
  padding: 5px 12px;
  border-radius: var(--fxa-radius-sm);
  font-family: inherit;
  font-size: var(--fxa-text-sm);
  font-weight: 600;
  cursor: pointer;
}
button:hover {
  background: var(--fxa-surface-active);
}
button.primary {
  background: var(--fxa-success-strong);
  border-color: var(--fxa-success-strong);
  color: white;
}
button.primary:hover {
  background: var(--fxa-success-strong-hover);
}
button.primary:disabled {
  background: var(--fxa-border);
  border-color: var(--fxa-border);
  color: var(--fxa-text-muted);
  cursor: not-allowed;
}
button.ghost {
  background: transparent;
  color: var(--fxa-text-muted);
}
button.ghost:hover {
  color: var(--fxa-text);
  background: var(--fxa-surface-active);
}
button.danger {
  background: var(--fxa-danger-strong);
  border-color: var(--fxa-danger-strong);
  color: white;
  padding: 3px 8px;
  font-size: var(--fxa-text-xs);
}
button.accent {
  background: var(--fxa-accent);
  border-color: var(--fxa-accent);
  color: white;
}
button.accent:hover {
  background: var(--fxa-accent-hover);
  border-color: var(--fxa-accent-hover);
}

.muted {
  color: var(--fxa-text-muted);
  font-weight: 400;
  font-family: var(--fxa-font-mono);
  font-size: var(--fxa-text-xs);
}

/* ----- Tables ----- */
table.fxa-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fxa-text-sm);
}
table.fxa-table th,
table.fxa-table td {
  padding: 4px 8px;
  text-align: right;
  border-bottom: 1px solid var(--fxa-border-subtle);
  white-space: nowrap;
}
table.fxa-table th {
  background: var(--fxa-surface-2);
  position: sticky;
  top: 0;
  color: var(--fxa-text-muted);
  font-weight: 500;
  text-align: right;
}
table.fxa-table th:first-child,
table.fxa-table td:first-child {
  text-align: left;
}
table.fxa-table tbody tr {
  cursor: pointer;
}
table.fxa-table tbody tr:hover {
  background: var(--fxa-surface-hover);
}
table.fxa-table tbody tr.active {
  background: var(--fxa-surface-row);
}

/* Status colors */
.pos,
.positive {
  color: var(--fxa-success);
}
.neg,
.negative {
  color: var(--fxa-danger);
}

/* ----- Modal overlay ----- */
.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  z-index: 1000;
  justify-content: center;
  align-items: center;
}
.modal-overlay.active {
  display: flex;
}
.modal {
  background: var(--fxa-surface);
  border: 1px solid var(--fxa-border);
  border-radius: var(--fxa-radius-lg);
  padding: 24px;
  width: 90%;
  max-width: 600px;
  max-height: 90vh;
  overflow-y: auto;
}
.modal.wide {
  max-width: 1000px;
}
.modal.chart-wide {
  max-width: 95vw;
}
.modal h3 {
  color: var(--fxa-text);
  margin: 0 0 20px;
  font-size: var(--fxa-text-md);
}

.modal-form label {
  display: block;
  color: var(--fxa-text-muted);
  margin: 14px 0 5px;
  font-size: var(--fxa-text-xs);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.modal-form input,
.modal-form select,
.modal-form textarea {
  width: 100%;
  padding: 8px 10px;
}
.modal-form textarea {
  min-height: 100px;
  resize: vertical;
}
.modal-buttons {
  display: flex;
  gap: 10px;
  margin-top: 22px;
  justify-content: flex-end;
}
.modal-buttons .btn-save {
  background: var(--fxa-success-strong);
  border-color: var(--fxa-success-strong);
  color: white;
}
.modal-buttons .btn-save:hover {
  background: var(--fxa-success-strong-hover);
}
.modal-buttons .btn-cancel {
  background: var(--fxa-surface-2);
  color: var(--fxa-text);
}
.modal-buttons .btn-delete {
  background: var(--fxa-danger-strong);
  border-color: var(--fxa-danger-strong);
  color: white;
}
.modal-buttons .btn-delete:hover {
  background: var(--fxa-danger);
  border-color: var(--fxa-danger);
}

/* ----- Loading / error notices ----- */
.loading {
  text-align: center;
  padding: 40px;
  color: var(--fxa-text-muted);
}
.error {
  background: var(--fxa-danger-bg);
  color: var(--fxa-danger);
  border: 1px solid var(--fxa-danger);
  padding: 12px 16px;
  border-radius: var(--fxa-radius);
  margin-bottom: var(--fxa-gap-lg);
}

/* ----- ag-Grid theme overrides (alpine-dark) ----- */
.ag-theme-alpine-dark {
  --ag-background-color: var(--fxa-surface);
  --ag-header-background-color: var(--fxa-surface-2);
  --ag-odd-row-background-color: var(--fxa-bg);
  --ag-row-hover-color: var(--fxa-surface-hover);
  --ag-header-foreground-color: var(--fxa-text-muted);
  --ag-foreground-color: var(--fxa-text);
  --ag-border-color: var(--fxa-border-subtle);
  --ag-secondary-border-color: var(--fxa-border-subtle);
}
.ag-theme-alpine-dark .ag-root-wrapper {
  border-radius: var(--fxa-radius-lg);
  border: 1px solid var(--fxa-border);
}
.ag-theme-alpine-dark .ag-cell {
  user-select: text !important;
  -webkit-user-select: text !important;
  cursor: text;
}

/* Generic icon button */
.btn-icon {
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: var(--fxa-radius-sm);
  font-size: 1em;
  color: var(--fxa-text-muted);
}
.btn-icon:hover {
  background: var(--fxa-surface-active);
  color: var(--fxa-text);
}
.btn-edit {
  color: var(--fxa-accent);
}
.btn-delete {
  color: var(--fxa-danger);
}
