/* LedgerBot Custom Styles - Dark Theme */

/* Custom variables */
:root {
  --ledgerbot-primary: #5865F2; /* Discord blurple */
  --ledgerbot-danger: #ed4245;
  --ledgerbot-success: #57f287;
  --ledgerbot-warning: #fee75c;
  --ledgerbot-bg: #1a1a2e;
  --ledgerbot-bg-secondary: #16213e;
  --ledgerbot-bg-card: #0f3460;
  --ledgerbot-text: #e4e4e7;
  --ledgerbot-text-muted: #a1a1aa;
  --ledgerbot-border: #2d3748;
}

body {
  background-color: var(--ledgerbot-bg) !important;
}

/* Resource status colors - slightly muted for dark theme */
.resource-depleted { background-color: #ed4245; color: white; }
.resource-critical { background-color: #d4a017; color: white; }
.resource-scarce { background-color: #c9a227; color: #1a1a2e; }
.resource-adequate { background-color: #5865F2; color: white; }
.resource-abundant { background-color: #3ba55d; color: white; }

/* Progress bar styling for resources */
.resource-progress {
  height: 1.5rem;
  border-radius: 0.375rem;
  background-color: var(--ledgerbot-bg-secondary);
}

.resource-progress .progress-bar {
  transition: width 0.3s ease-in-out;
  font-weight: 600;
}

/* Card styling */
.card {
  border-radius: 0.5rem;
  background-color: var(--ledgerbot-bg-card) !important;
  border-color: var(--ledgerbot-border) !important;
  box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.3);
}

.card.resource-card {
  transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}

.card.resource-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 0.5rem 1rem rgba(88, 101, 242, 0.2);
}

/* Navbar styling */
.navbar {
  background-color: var(--ledgerbot-bg-secondary) !important;
  border-bottom: 1px solid var(--ledgerbot-border);
}

.navbar-brand {
  font-weight: 700;
  color: #5865F2 !important;
}

/* Discord-style buttons */
.btn-discord {
  background-color: #5865F2;
  border-color: #5865F2;
  color: white;
}

.btn-discord:hover {
  background-color: #4752c4;
  border-color: #4752c4;
  color: white;
}

.btn-primary {
  background-color: #5865F2;
  border-color: #5865F2;
}

.btn-primary:hover {
  background-color: #4752c4;
  border-color: #4752c4;
}

/* Sidebar navigation */
.sidebar {
  min-height: calc(100vh - 56px);
  background-color: var(--ledgerbot-bg-secondary);
  border-right: 1px solid var(--ledgerbot-border);
}

.sidebar .nav-link {
  color: var(--ledgerbot-text-muted);
  padding: 0.75rem 1rem;
  border-radius: 0.375rem;
  margin: 0.125rem 0.5rem;
}

.sidebar .nav-link:hover {
  background-color: rgba(88, 101, 242, 0.2);
  color: var(--ledgerbot-text);
}

.sidebar .nav-link.active {
  background-color: #5865F2;
  color: white;
}

/* Flash messages */
.alert-flash {
  border-radius: 0.375rem;
  border-left: 4px solid;
}

.alert-flash.alert-success { border-left-color: #57f287; }
.alert-flash.alert-danger { border-left-color: #ed4245; }
.alert-flash.alert-warning { border-left-color: #fee75c; }

/* Table styling */
.table-ledger thead th {
  background-color: var(--ledgerbot-bg-secondary);
  border-bottom: 2px solid #5865F2;
  font-weight: 600;
}

.table-ledger tbody tr:hover {
  background-color: rgba(88, 101, 242, 0.1);
}

/* Form styling */
.form-control,
.form-select {
  background-color: var(--ledgerbot-bg-secondary);
  border-color: var(--ledgerbot-border);
  color: var(--ledgerbot-text);
}

.form-control:focus,
.form-select:focus {
  background-color: var(--ledgerbot-bg-secondary);
  border-color: #5865F2;
  box-shadow: 0 0 0 0.25rem rgba(88, 101, 242, 0.25);
  color: var(--ledgerbot-text);
}

/* Badge styling for severity */
.badge-severity-low { background-color: #17a2b8; }
.badge-severity-medium { background-color: #ffc107; color: #212529; }
.badge-severity-high { background-color: #dc3545; }

/* Morale tags */
.morale-high {
  color: #57f287;
  font-weight: 600;
}

.morale-low {
  color: #ed4245;
  font-weight: 600;
}

/* Stress indicator */
.stress-indicator {
  padding: 1rem;
  border-radius: 0.5rem;
  text-align: center;
}

.stress-indicator.stress-peaceful { background-color: rgba(87, 242, 135, 0.25); }
.stress-indicator.stress-manageable { background-color: rgba(88, 101, 242, 0.25); }
.stress-indicator.stress-strained { background-color: rgba(254, 231, 92, 0.25); }
.stress-indicator.stress-crisis { background-color: rgba(237, 66, 69, 0.25); }

/* Prompt display */
.prompt-display {
  background-color: var(--ledgerbot-bg-secondary);
  border-left: 4px solid #5865F2;
  padding: 1.5rem;
  border-radius: 0.375rem;
  font-style: italic;
}

.prompt-display.prompt-need { border-left-color: #17a2b8; }
.prompt-display.prompt-event { border-left-color: #ffc107; }
.prompt-display.prompt-dilemma { border-left-color: #dc3545; }
.prompt-display.prompt-twist { border-left-color: #6f42c1; }

/* Empty state */
.empty-state {
  text-align: center;
  padding: 3rem;
  color: var(--ledgerbot-text-muted);
}

.empty-state i {
  font-size: 3rem;
  margin-bottom: 1rem;
}

/* Footer */
footer {
  background-color: var(--ledgerbot-bg-secondary) !important;
  border-top: 1px solid var(--ledgerbot-border);
}

/* Subtle version stamp in the footer corner */
.app-version {
  position: absolute;
  right: 0.75rem;
  bottom: 0;
  font-size: 0.7rem;
  opacity: 0.35;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
  pointer-events: none;
  user-select: none;
}

@media (max-width: 576px) {
  .app-version {
    position: static;
    display: block;
    margin-top: 0.25rem;
  }
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .sidebar {
    min-height: auto;
    border-right: none;
    border-bottom: 1px solid #dee2e6;
  }
}
