/* ─────────────────────────────────────────────────────────────
   ValuationOS — Global Styles
   ───────────────────────────────────────────────────────────── */

/* Reset */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* Scrollbar */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: #0a0c14; }
::-webkit-scrollbar-thumb { background: #1e2130; border-radius: 2px; }

/* Base */
body {
  background: #07090f;
  color: #eef0f8;
  font-family: 'DM Sans', sans-serif;
  min-height: 100vh;
}

/* ── Interactive elements ── */
.tbtn {
  cursor: pointer;
  transition: all 0.15s;
}
.tbtn:hover { background: #111520 !important; }

.rbtn { transition: background 0.1s; }
.rbtn:hover { background: #0d0f18 !important; cursor: pointer; }

/* Delete button — visible only on row hover */
.delbtn {
  opacity: 0;
  transition: opacity 0.15s;
  cursor: pointer;
}
tr:hover .delbtn { opacity: 1; }

/* Drop zone */
.dropz {
  transition: all 0.2s;
  cursor: pointer;
}
.dropz:hover {
  border-color: #c9a84c !important;
  background: #c9a84c07 !important;
}

/* File / action buttons */
.fbtn {
  cursor: pointer;
  transition: all 0.15s;
}
.fbtn:hover {
  background: #c9a84c14 !important;
  border-color: #c9a84c77 !important;
}

/* Metric / toggle buttons */
.mbtn {
  cursor: pointer;
  transition: all 0.15s;
  border: none;
}
.mbtn:hover { opacity: 0.8; }

/* Asset cards */
.acard {
  transition: all 0.18s;
  cursor: pointer;
  border: 1px solid #141720 !important;
}
.acard:hover {
  border-color: #c9a84c44 !important;
  transform: translateY(-1px);
}

/* ── Animations ── */
@keyframes spin {
  to { transform: rotate(360deg); }
}

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

.fi { animation: fadeIn 0.25s ease both; }

.spinner {
  width: 18px;
  height: 18px;
  border: 2px solid #c9a84c33;
  border-top-color: #c9a84c;
  border-radius: 50%;
  animation: spin 1s linear infinite;
  flex-shrink: 0;
}
