/* Custom overrides for GoTracker Web UI */

/* Avatar card styling */
.avatar-card {
  transition: box-shadow 0.3s ease;
}

.avatar-card:hover {
  box-shadow: 0 8px 16px rgba(10, 10, 10, 0.1);
}

/* Status indicators */
.status-online {
  color: #48c774;
}

.status-offline {
  color: #f14668;
}

.status-never-seen {
  color: #b5b5b5;
}

/* Sortable column headers */
.sortable-header {
  color: inherit;
  text-decoration: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.sortable-header:hover {
  color: #3273dc;
}

.sortable-header.active {
  color: #3273dc;
  font-weight: 600;
}

/* Status count badges */
#status-counts {
  margin-left: 25px;
}

#status-counts .tag {
  margin-right: 0.5rem;
  cursor: help;
}

#status-counts .tag .icon {
  margin-right: 0.25rem;
}

/* Add tooltips for compact status counts */
#status-counts .tag[title] {
  position: relative;
}

/* HTMX loading indicators */
.htmx-indicator {
  opacity: 0;
  transition: opacity 500ms ease-in;
}

.htmx-request .htmx-indicator {
  opacity: 1;
}

.htmx-request.htmx-indicator {
  opacity: 1;
}

/* Auto-refresh status indicator */
#auto-refresh-status {
  font-size: 0.75rem;
  color: #666;
  margin-left: 0.5rem;
  transition: color 0.3s ease;
}

#auto-refresh-status.active {
  color: #48c774;
}

#auto-refresh-status.active::before {
  content: "●";
  margin-right: 0.25rem;
}

/* Specific indicator for avatar list auto-refresh */
#avatar-loading-indicator {
  margin: 1rem 0;
}

/* Flash message styling */
#flash-messages .notification {
  margin-bottom: 0.5rem;
}

/* Mobile navbar burger functionality */
.navbar-burger {
  cursor: pointer;
}

.navbar-burger.is-active span:nth-child(1) {
  transform: translateY(5px) rotate(45deg);
}

.navbar-burger.is-active span:nth-child(2) {
  opacity: 0;
}

.navbar-burger.is-active span:nth-child(3) {
  transform: translateY(-5px) rotate(-45deg);
}

/* Form styling improvements */
.field.is-grouped .control:not(:last-child) {
  margin-right: 0.5rem;
}

/* Loading spinner for HTMX requests */
.htmx-request .button {
  position: relative;
}

.htmx-request .button::after {
  content: "";
  position: absolute;
  width: 16px;
  height: 16px;
  margin: auto;
  border: 2px solid transparent;
  border-top-color: #ffffff;
  border-radius: 50%;
  animation: button-loading-spinner 1s ease infinite;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

@keyframes button-loading-spinner {
  from {
    transform: rotate(0turn);
  }
  to {
    transform: rotate(1turn);
  }
}

/* Dark mode styles */
[data-theme="dark"] {
  background-color: #0a0a0a;
  color: #f5f5f5;
}

[data-theme="dark"] .box {
  background-color: #1a1a1a;
  color: #f5f5f5;
}

[data-theme="dark"] .title,
[data-theme="dark"] .subtitle {
  color: #f5f5f5;
}

[data-theme="dark"] .navbar {
  background-color: #1a1a1a !important;
}

[data-theme="dark"] .navbar-item,
[data-theme="dark"] .navbar-link {
  color: #f5f5f5 !important;
  opacity: 1 !important;
}

[data-theme="dark"] .navbar-item:hover,
[data-theme="dark"] .navbar-link:hover {
  background-color: #2a2a2a !important;
  color: #f5f5f5 !important;
}

[data-theme="dark"] .navbar-item.is-active,
[data-theme="dark"] .navbar-link.is-active {
  background-color: #2a2a2a !important;
  color: #f5f5f5 !important;
}

[data-theme="dark"] .navbar-item.has-dropdown.is-active .navbar-link,
[data-theme="dark"] .navbar-item.has-dropdown:hover .navbar-link,
[data-theme="dark"] .navbar-item.has-dropdown.is-hoverable:hover .navbar-link {
  background-color: #2a2a2a !important;
  color: #f5f5f5 !important;
}

[data-theme="dark"] .navbar-dropdown .navbar-item:hover {
  background-color: #2a2a2a !important;
  color: #f5f5f5 !important;
}

[data-theme="dark"] .navbar-dropdown {
  background-color: #1a1a1a !important;
  border-top-color: #2a2a2a;
}

[data-theme="dark"] .navbar-dropdown .navbar-item {
  color: #f5f5f5 !important;
}

[data-theme="dark"] .navbar-burger span {
  background-color: #f5f5f5 !important;
}

[data-theme="dark"] .button {
  background-color: #2a2a2a;
  border-color: #3a3a3a;
  color: #f5f5f5;
}

[data-theme="dark"] .button:hover {
  background-color: #3a3a3a;
}

[data-theme="dark"] .button.is-primary {
  background-color: #00d1b2;
  color: #fff;
}

[data-theme="dark"] .button.is-primary:hover {
  background-color: #00b89c;
}

[data-theme="dark"] .input,
[data-theme="dark"] .textarea,
[data-theme="dark"] .select select {
  background-color: #2a2a2a;
  border-color: #3a3a3a;
  color: #f5f5f5;
}

[data-theme="dark"] .label {
  color: #f5f5f5;
}

[data-theme="dark"] .table {
  background-color: #1a1a1a;
  color: #f5f5f5;
}

[data-theme="dark"] .table td,
[data-theme="dark"] .table th {
  border-color: #3a3a3a;
  color: #f5f5f5;
}

[data-theme="dark"] .table.is-striped tbody tr:not(.is-selected):nth-child(even) {
  background-color: #0f0f0f;
}

[data-theme="dark"] .notification {
  background-color: #2a2a2a;
  color: #f5f5f5;
}

[data-theme="dark"] .notification.is-success {
  background-color: #48c774;
  color: #fff;
}

[data-theme="dark"] .notification.is-danger {
  background-color: #f14668;
  color: #fff;
}

[data-theme="dark"] .modal-card-head,
[data-theme="dark"] .modal-card-foot {
  background-color: #1a1a1a;
  border-color: #3a3a3a;
}

[data-theme="dark"] .modal-card-body {
  background-color: #0a0a0a;
  color: #f5f5f5;
}

[data-theme="dark"] .modal-card-title {
  color: #f5f5f5;
}

[data-theme="dark"] .breadcrumb a {
  color: #00d1b2;
}

[data-theme="dark"] .breadcrumb li.is-active a {
  color: #f5f5f5;
}

[data-theme="dark"] .table.is-hoverable tbody tr:hover {
  background-color: #2a2a2a !important;
}

[data-theme="dark"] .table.is-hoverable tbody tr:hover td,
[data-theme="dark"] .table.is-hoverable tbody tr:hover th {
  color: #f5f5f5 !important;
}

[data-theme="dark"] .table.is-hoverable tbody tr:hover .title,
[data-theme="dark"] .table.is-hoverable tbody tr:hover .subtitle {
  color: #f5f5f5 !important;
}

[data-theme="dark"] .table.is-hoverable tbody tr:hover .tag {
  background-color: #3a3a3a;
  color: #f5f5f5;
}

[data-theme="dark"] .table.is-hoverable tbody tr:hover .tag.is-success {
  background-color: #48c774;
  color: #fff;
}

[data-theme="dark"] .table.is-hoverable tbody tr:hover .tag.is-info {
  background-color: #3e8ed0;
  color: #fff;
}

[data-theme="dark"] .table.is-hoverable tbody tr:hover .tag.is-warning {
  background-color: #ffe08a;
  color: rgba(0, 0, 0, 0.7);
}
