/* ==========================
   Scotty Desk Phase 1 Theme
   ========================== */

/* --------- Theme Variables --------- */
:root {
  /* Primary brand color old primary #3b82f6, old hover #2563eb */
  --primary-color: #546ec3;

  /* Bootstrap variables */
  --bs-primary: #546ec3;
  --bs-primary-rgb: 84, 110, 195;

  /* Links */
  --bs-link-color: #546ec3;
  --bs-link-hover-color: #3f5bb5;

  /* Secondary / body / card */
  --secondary-color: #6c757d;
  --body-bg: #f8f9fa;
  --card-bg: #ffffff;
  --card-shadow: 0 .125rem .25rem rgba(0,0,0,.075);

  /* Badges 
  --badge-urgent: #dc3545;
  --badge-normal: #364881;
  --badge-low: #6c757d;
  */

   /* Badges */
  --badge-urgent: #dc3545;
  --badge-urgent-border: #9d2531;
  --badge-normal: #546ec3;
  --badge-normal-border: #3a4c88;
  --badge-low: #6c757d;
  --badge-low-border: #4e545a;

  /* Text */
  --text-color: #292122;
  --text-muted: #6c757d;
  --border-color: #e5e7eb;
}

/* --------- Dark Mode Overrides --------- */
[data-bs-theme="dark"] {
  --body-bg: #1a1d21;
  --card-bg: #212529;
  --card-shadow: 0 .125rem .25rem rgba(0,0,0,.3);
  --text-color: #e0e0e0;
  --text-muted: #9ca3af;
  --border-color: #373b3f;
}

/* --------- Body --------- */
body {
  background-color: var(--body-bg);
  color: var(--text-color);
  font-family: "Inter", "Helvetica", sans-serif;
}

/* Page fade effect */
.page-container {
  opacity: 0;
  transition: opacity 0.5s ease;
}
.page-container.active {
  opacity: 1;
}

/* --------- Navbar --------- */
.navbar {
  background-color: var(--card-bg);
  box-shadow: var(--card-shadow);
}

.navbar .nav-link {
  color: var(--text-color);
  font-weight: 500;
  padding: 0.5rem 0.75rem;
  border-radius: 0.375rem;
  text-decoration: none;
  transition:
    color 0.15s ease,
    background-color 0.15s ease,
    transform 0.15s ease;
}

.navbar .nav-link:hover {
  color: var(--bs-primary);
  background-color: rgba(var(--bs-primary-rgb), 0.10);
  transform: translateY(-1px);
}

.navbar .nav-link.active {
  color: var(--bs-primary);
}


/* --------- Dashboard typography --------- */
.dashboard-container {
  font-size: 0.9rem;
}

/* --------- Cards --------- */
.card {
  background-color: var(--card-bg);
  box-shadow: var(--card-shadow);
  border-radius: 0.375rem;
  padding: 1rem;
  margin-bottom: 1rem;
}

/* --------- Buttons / Links / Toggles (Full Brand Blue) --------- */
.btn-primary,
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-outline-primary,
.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active,
a.btn,
a.btn-primary,
a.btn-outline-primary {
  background-color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
  color: #fff !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-outline-primary:hover,
.btn-outline-primary:focus,
a.btn-primary:hover,
a.btn-outline-primary:hover {
  background-color: var(--bs-link-hover-color) !important; /* slightly darker for hover/focus */
  border-color: var(--bs-link-hover-color)!important;
  color: #fff !important;
}

/* Secondary outline buttons */
.btn-outline-secondary {
  color: var(--secondary-color);
  border-color: var(--secondary-color);
  transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.btn-outline-secondary:hover {
  background-color: var(--secondary-color);
  color: #fff;
  border-color: var(--secondary-color);
}

/* Full-width buttons for forms */
.btn.w-100 {
  width: 100%;
}

/* --------- Page Titles --------- */
.page-title {
  font-size: 1.5rem;              /* Slightly larger than body */
  font-weight: 600;
  color: var(--text-color);
  margin-bottom: 1rem;
  letter-spacing: 0.01em;
  
  border-bottom: 1px solid var(--border-color);
  padding-bottom: 0.5rem;
}

/* Small buttons */
.btn-sm {
  padding: 0.25rem 0.5rem;
  font-size: 0.875rem;
}

.btn-group .btn i {
  font-size: 1.1rem;
}

.btn-group .btn {
  padding: 0.2rem 0.5rem;
}

/* --------- Badges --------- */
.badge {
  font-size: 0.65rem;
}

.badge-urgent {
  background-color: var(--badge-urgent);
  color: #fff;
  border: 1px solid var(--badge-urgent-border);
  border-radius: 0.375rem; 
}

.badge-normal {
  background-color: var(--badge-normal);
  color: #fff;
  border: 1px solid var(--badge-normal-border);
  border-radius: 0.375rem; 
}

.badge-low {
  background-color: var(--badge-low);
  color: #fff;
  border: 1px solid var(--badge-low-border);
  border-radius: 0.375rem; 
}

/* --------- Created On Column --------- */
.created-on {
  color: var(--text-muted);
  font-size: 0.75rem;
  white-space: nowrap;
}

/* --------- Forms --------- */
.form-label {
  font-weight: 500;
}

.form-check-label {
  font-weight: 400;
}

input.form-control,
textarea.form-control,
select.form-control {
  border-radius: 0.375rem;
  border: 1px solid var(--border-color);
  box-shadow: none;
}

input.form-control:focus,
textarea.form-control:focus,
select.form-control:focus {
  border-color: var(--bs-primary);
  box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25);
}

/* --------- Tables --------- */
.table {
  margin-bottom: 1rem;
}

.table th {
  font-weight: 600;
}

.table-hover tbody tr:hover {
  background-color: rgba(var(--bs-primary-rgb), 0.05);
}

/* --------- Fade in sections --------- */
.fade-section {
  opacity: 0;
  transition: opacity 0.3s ease;
}

.fade-section.fade-in {
  opacity: 1;
}

/* --------- Page Specific --------- */
#signin-page {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
}

/* --------- Dashboard Card Hover --------- */
.dashboard-card {
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.dashboard-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 0.5rem 1rem rgba(0,0,0,0.15);
}

.dashboard-card p {
  margin: 0.25rem 0;
}

.dashboard-card small {
  color: var(--text-muted);
}

/* Detail & Settings card padding */
.detail-card,
.settings-card {
  padding: 1rem;
}

/* --------- Links --------- */
a {
  color: var(--bs-link-color);
  text-decoration: none;
}

a:hover {
  color: var(--bs-link-hover-color);
  text-decoration: underline;
}

/* --------- Dashboard Toggle Button Active State --------- */
#table-view-btn,
#card-view-btn,
#tab-active,
#tab-completed {
  background-color: var(--card-bg) !important;
  border-color: var(--bs-primary) !important;
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.1);
  color: rgba(var(--bs-primary-rgb), 0.85) !important;
}
#table-view-btn.active,
#card-view-btn.active,
#tab-active.active,
#tab-completed.active {
  background-color: var(--bs-primary) !important; 
  border-color: var(--bs-primary) !important;
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.1);
  color: #fff!important;
}

#table-view-btn:not(.active):hover,
#card-view-btn:not(.active):hover,
#tab-active:not(.active):hover,
#tab-completed:not(.active):hover {
  background-color: rgba(var(--bs-primary-rgb), 0.10) !important;
  color: rgba(var(--bs-primary-rgb), 0.85) !important;
}

/* --------- Action Icons --------- */
.action-icons {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

/* Ensure the flex container fills the table cell height so icons vertically match wrapped rows */
.action-icons {
  height: 100%;
}

.action-icon {
  background: none;
  border: none;
  color: var(--text-muted);
  padding: 0.25rem;
  cursor: pointer;
  transition: color 0.15s ease, transform 0.1s ease;
}

.action-icon:hover {
  color: var(--primary-color);
  transform: scale(1.1);
}

.action-icon.mark-complete:hover {
  color: #28a745;
  transform: scale(1.1);
}

.action-icon.text-danger {
  color: #dc3545;
}

.action-icon.text-danger:hover {
  color: #b02a37;
  transform: scale(1.1);
}

/* --------- Dark Mode Extras --------- */
[data-bs-theme="dark"] .table-light {
  --bs-table-bg: #2b3035;
  --bs-table-color: var(--text-color);
}

[data-bs-theme="dark"] .navbar {
  border-bottom: 1px solid var(--border-color);
}

[data-bs-theme="dark"] .bg-light {
  background-color: var(--body-bg) !important;
}

[data-bs-theme="dark"] .shadow-sm {
  box-shadow: 0 .125rem .25rem rgba(0,0,0,.3) !important;
}

/* Theme toggle button */
.theme-toggle {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 1.2rem;
  padding: 0.4rem;
  cursor: pointer;
  transition: color 0.15s ease, transform 0.15s ease;
  display: flex;
  align-items: center;
}

.theme-toggle:hover {
  color: var(--bs-primary);
  transform: scale(1.1);
}

